@charset "utf-8";

:root {
    --black: #333333;
    --gray: #595757;
    --white: #ffffff;
    --red: #e14222;
    --orange: #f15a24;
    --yellow: #fbb03b;
    --yellow-light: #ffefb9;
    --point-img-w: 96px;
    --point-num-img-w: 64px;
}

html {
    font-size: 16px;
}

body {
    color: var(--black);
    line-height: 1.8;
}

h2, h3 {
    font-weight: bold;
}

#hozonsui7 {
    padding: 24px 15px;
}

/* 既存のスタイルを初期化 */
#hozonsui7 p {
    color: var(--black);
    font-size: 1rem;
    margin-bottom: 0;
}

#hozonsui7 h3 {
    font-size: initial;
    padding: 0;
    background-image: none;
    background-repeat: initial;
    background-position: initial;
    border: none;
    margin-bottom: initial;
}

.header_area #hozonsui7 img {
    display: block;
    height: auto;
    margin-bottom: 0;
}

.header_area #hozonsui7 img:not(.full-image) {
    max-width: 100%;
}

/* 横全体に画像を表示 */
.full-image {
    width: calc(100% + 60px);
    margin-left: -30px;
}

/* 各ブロックの余白 */
.block-margin {
    margin-top: 1.5rem;
    margin-bottom: 1.5rem;
}

/* 袋文字 */
#hozonsui7 .outline-text {
    position: relative;
}

#hozonsui7 .outline-text h1,
#hozonsui7 .outline-text h3 {
    position: relative;
    color: var(--white);
    font-weight: bold;
    line-height: 1;
    letter-spacing: 0.1em;
    z-index: 20;
}

#hozonsui7 .outline-text::before {
    position: absolute;
    width: 100%;
    color: var(--red);
    font-weight: bold;
    line-height: 1;
    letter-spacing: 0.1em;
    top: 50%;
    left: 50%;
    translate: -50% -50%;
    z-index: 10;
    filter: blur(1px);
}

/* キービジュアル */
.hozonsui7__top__copy {
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: center;
    z-index: 20;
}

/* キービジュアル（キャッチコピー） */
.hozonsui7__top__copy__text {
    margin-right: 8px;
    font-size: 2rem;
    font-weight: bold;
}

#hozonsui7__top .hozonsui7__top__copy__text p {
    color: var(--red);
    font-size: 1.75rem;
    margin-bottom: 0.5em;
}

/* キービジュアル（袋文字） */
.hozonsui7__top__copy__text__heading {
    position: relative;
}

#hozonsui7 .hozonsui7__top__copy__text__heading h1,
#hozonsui7 .hozonsui7__top__copy__text__heading::before {
    font-size: 2em;
    letter-spacing: 0;
}

#hozonsui7 .hozonsui7__top__copy__text__heading::before {
    content: "大安心保存水";
    -webkit-text-stroke: 8px var(--red);
}

/* キービジュアル（商品画像） */
.hozonsui7__top__copy__image {
    width: 250px;
}

/* キービジュアル（イメージ画像） */
.hozonsui7__top__kv {
    position: relative;
    margin-top: -48px;
    z-index: 10;
}

/* H2 */
.hozonsui7-heading {
    font-size: 1rem;
    margin-top: 4.5em;
    margin-bottom: 3em;
}

.hozonsui7-heading h2 {
    display: flex;
    flex-direction: column;
    align-items: center;
}

/* H2（英語） */
#hozonsui7 .hozonsui7-heading__en {
    margin-bottom: 0;
    font-size: 1.85em;
    line-height: 1;
    letter-spacing: 0.15em;
}

/* H2（日本語） */
#hozonsui7 .hozonsui7-heading__ja {
    position: relative;
    padding-bottom: 1em;
    margin-top: calc(1em - 8px);
    letter-spacing: 0.15em;
}

/* H2（横線） */
.hozonsui7-heading__ja::after {
    content: "";
    position: absolute;
    width: 6.5em;
    height: 7px;
    background-color: var(--yellow);
    border-radius: 8px;
    bottom: 0;
    left: 50%;
    translate: -50% 0;
}

/* H2直下の画像 */
.hozonsui7-heading + img {
    margin-top: 2rem;
    margin-bottom: 2rem;
}

/* Concept */
#hozonsui7__concept {
    width: 100%;
    padding: 0 30px 90px 30px;
    margin-left: -30px;
    overflow: hidden;
}

#hozonsui7__concept img:not(.back-circle) {
    position: relative;
    z-index: 20;
}

/* Concept（2カラム） */
.hozonsui7__concept__vision {
    padding-top: 2rem;
    padding-bottom: 4rem;
}

/* Concept（2カラム / ロゴ） */
.hozonsui7__concept__vision__copy__logo {
    width: 95%;
}

/* Concept（2カラム / キャッチコピー） */
.hozonsui7__concept__vision__copy {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 1.25fr;
}

.hozonsui7__concept__vision__copy > *,
.hozonsui7__concept__vision__column > * {
    position: relative;
    z-index: 20;
}

.hozonsui7__concept__vision__copy > div {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

#hozonsui7__concept .hozonsui7__concept__vision__copy h3 {
    margin-bottom: 1em;
}

#hozonsui7__concept .hozonsui7__concept__vision__copy h3 p {
    color: var(--red);
    font-size: 2rem;
    margin-bottom: 0;
}

#hozonsui7__concept .hozonsui7__concept__vision__copy h3 p:first-child {
    text-indent: -0.5em;
}

#hozonsui7__concept .hozonsui7__concept__vision__copy p {
    font-size: 1.5rem;
}

/* Concept（2カラム / 解説） */
.hozonsui7__concept__vision__column {
    position: relative;
    display: grid;
    gap: 24px;
    grid-template-columns: 1fr 1fr;
    align-items: center;
    margin-bottom: 40px;
}

.hozonsui7__concept__vision__column:last-child {
    margin-bottom: 0;
}

.hozonsui7__concept__vision__column img:not(.back-circle) {
    border-radius: 32px;
}

#hozonsui7__concept .hozonsui7__concept__vision__column .message {
    color: var(--red);
    font-size: 1.5rem;
    font-weight: bold;
    line-height: 1.5;
    text-align: center;
    margin-top: 1.5em;
    margin-bottom: 0;
}

/* Concept（2カラム / 背景の丸） */
.back-circle {
    position: absolute;
    z-index: 10;
}

.back-circle1 {
    min-width: 660px;
    top: -10%;
    right: -30%;
}

.back-circle2 {
    width: 42%;
    top: 22%;
    left: -12%;
}

.back-circle3 {
    width: 85%;
    bottom: -90%;
    left: 0;
}

/* About water */
#hozonsui7__about {
    position: relative;
    margin-top: -100px;
    z-index: 20;
}

/* About water（概要文） */
.hozonsui7__about__overview {
    margin-bottom: 4rem;
}

#hozonsui7__about .hozonsui7__about__overview h3 {
    color: var(--red);
    font-size: 1.5rem;
    margin-top: 1.5em;
    margin-bottom: 0.5em;
}

/* About water（製品情報） */
.hozonsui7__about__product li {
    display: grid;
    gap: 16px 32px;
    grid-template-columns: minmax(256px, 1fr) 2fr;
    margin-bottom: 32px;
}

.hozonsui7__about__product__overview {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.hozonsui7__about__product__overview h3 {
    font-size: 1.25rem;
}

.hozonsui7__about__product__overview h3 span {
    display: inline-block;
    background-color: var(--red);
    color: var(--white);
    font-size: 1.5rem;
    line-height: 1;
    padding: 0.5em 1em;
    border-radius: 12px;
}

#hozonsui7__about .hozonsui7__about__product__overview h3 p {
    color: var(--red);
    font-size: 1.5rem;
    line-height: 1.5;
    margin-top: 0.75em;
    margin-bottom: 0.75em;
}

/* About water（体に嬉しいポイント） */
.hozonsui7__about__merit {
    width: 100%;
    background-color: var(--yellow-light);
    margin-left: -30px;
    padding: 30px;
}

/* About water（体に嬉しいポイント / 袋文字） */
.hozonsui7__about__merit__heading {
    margin: 2em 0 2em;
}

#hozonsui7__about .hozonsui7__about__merit__heading h3,
#hozonsui7__about .hozonsui7__about__merit__heading::before {
    font-size: 1.75rem;
}

#hozonsui7__about .hozonsui7__about__merit__heading::before {
    content: "体に嬉しいポイント";
    -webkit-text-stroke: 4px var(--red);
}

/* About water（体に嬉しいポイント / リスト） */
.hozonsui7__about__merit__ol li {
    display: grid;
    grid-template-columns: var(--point-img-w) 1fr;
    background-color: var(--white);
    padding: 1.25rem 1.75rem;
    margin-bottom: 1.75rem;
    border-radius: 24px;
}

.hozonsui7__about__merit__ol li:last-child {
    margin-bottom: 0;
}

/* About water（体に嬉しいポイント / Point） */
#hozonsui7__about .hozonsui7__about__merit__ol .image-point {
    width: var(--point-img-w);
    margin-bottom: 8px;
}

.image-point-num {
    width: var(--point-num-img-w);
}

/* About water（体に嬉しいポイント / 見出し） */
.hozonsui7__about__merit__ol__heading {
    display: flex;
    align-items: flex-end;
}

.hozonsui7__about__merit__ol__heading h4 {
    color: var(--red);
    font-size: 1.5rem;
    font-weight: normal;
    line-height: 1.5;
    margin-left: calc(var(--point-img-w) / 5 * -1);
    margin-bottom: calc(var(--point-num-img-w) / 2 - 2em);
    translate: 0 -75%;
}

/* About water（体に嬉しいポイント / 段落） */
.hozonsui7__about__merit__ol__text {
    grid-column: 1 / 3;
    font-size: 1rem !important;
    margin-top: 1em;
}

/* About water（製造の流れ） */
.hozonsui7__about__flow__heading {
    margin: 5em 0 2em;
}

/* About water（製造の流れ/ 袋文字） */
#hozonsui7__about__flow .hozonsui7__about__flow__heading h3,
.hozonsui7__about__flow__heading::before {
    font-size: 1.75rem;
}

.hozonsui7__about__flow__heading::before {
    content: "製造の流れ";
    -webkit-text-stroke: 4px var(--red);
}

/* About water（製造の流れ / 画像） */
#hozonsui7__about__flow img {
    width: min(100%, 480px);
    margin: 0 auto;
}

/* About water（製品情報 / 袋文字） */
.hozonsui7__about__information__heading {
    margin: 5em 0 2em;
}

#hozonsui7__about__information .hozonsui7__about__information__heading h3,
.hozonsui7__about__information__heading::before {
    font-size: 1.75rem;
}

.hozonsui7__about__information__heading::before {
    content: "製品情報";
    -webkit-text-stroke: 4px var(--red);
}

/* About water（製品情報 / 表） */
#hozonsui7__about__information table {
    border-collapse: collapse;
}

#hozonsui7__about__information table th,
#hozonsui7__about__information table td {
    border: solid 1px var(--black);
    font-size: 1rem;
}

#hozonsui7__about__information table th {
    width: 8rem;
    background-color: var(--yellow-light);
    padding: 0.25em 0.5em;
    font-weight: normal;
}

#hozonsui7__about__information table td {
    padding: 0.25em 1em;
}

/* About water（製品情報 / 注釈） */
#hozonsui7__about__information .annotation {
    position: relative;
    margin-top: 0.75em;
    padding-left: 1em;
}

#hozonsui7__about__information .annotation::before {
    content: "※";
    position: absolute;
    left: 0;
}

/* Scene（説明文） */
#hozonsui7__scene .hozonsui7__scene__text p {
    margin-bottom: 2em;
}

/* Scene（セット） */
.hozonsui7__scene__set {
    display: grid;
    gap: 40px;
    grid-template-columns: repeat(3, 1fr);
}

#hozonsui7__scene .hozonsui7__scene__set h3 {
    background-color: var(--yellow);
    border-radius: 8px;
    padding: 0.75em 1em;
    margin: 8px 0;
    text-align: center;
}

/* how to buy（説明文） */
#hozonsui7__buy .hozonsui7__buy__text {
    margin-top: 2em;
    margin-bottom: 2em;
}

/* how to buy（お問合せ） */
.hozonsui7__buy__contact {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: min(100%, 360px);
    margin: 0 auto;
    border: solid 8px var(--yellow);
    border-radius: 40px;
    padding: 1.25rem;
}

#hozonsui7__buy .hozonsui7__buy__contact p {
    color: var(--red);
    font-weight: bold;
    line-height: 1.5;
    text-align: center;
    margin-bottom: 1em;
}

.hozonsui7__buy__contact a {
    display: inline-block;
}

.hozonsui7__buy__contact a img {
    width: 260px;
    transition: all 0.3s;
}

/* ホバー時 */
@media (hover: hover) {
    .hozonsui7__buy__contact a:hover img {
        opacity: 0.6;
    }
}

/* 768px以下 */
@media screen and (max-width: 768px) {

    #hozonsui7 {
        padding: 24px 0;
    }

    .header_area #hozonsui7 img:not(.full-image) {
        max-width: 100%;
    }

    .header_area #hozonsui7 .full-image {
        max-width: initial;
    }

    /* 横全体に画像を表示 */
    .full-image {
        width: calc(100% + 30px);
        margin-left: -15px;
    }

    /* H2 */
    .hozonsui7-heading {
        margin-top: 3em;
        margin-bottom: 2em;
    }

    /* キービジュアル */
    .hozonsui7__top__copy {
        flex-direction: column;
    }

    /* キービジュアル（キャッチコピー） */
    .hozonsui7__top__copy__text {
        margin-right: 0;
    }

    #hozonsui7__top .hozonsui7__top__copy__text p {
        font-size: clamp(18px, 5vw, 40px);
        text-align: center;
    }

    /* キービジュアル（袋文字） */
    #hozonsui7__top .hozonsui7__top__copy__text__heading h1 {
        margin-bottom: 0.5em;
    }

    #hozonsui7 .hozonsui7__top__copy__text__heading h1, #hozonsui7 .hozonsui7__top__copy__text__heading::before {
        font-size: clamp(40px, 12vw, 88px);
        text-align: center;
    }

    /* キービジュアル（商品画像） */
    .hozonsui7__top__copy__image {
        width: min(50%, 320px);
        margin: 0 auto;
    }

    /* キービジュアル（イメージ画像） */
    .hozonsui7__top__kv {
        margin-top: -15%;
    }

    /* Concept */
    #hozonsui7__concept {
        width: calc(100% + 30px);
        padding: 0 15px 90px 15px;
        margin-left: -15px;
    }

    /* Concept（2カラム / キャッチコピー） */
    .hozonsui7__concept__vision__copy {
        grid-template-columns: 1fr;
        justify-content: center;
        padding-bottom: 4rem;
    }

    .hozonsui7__concept__vision__copy__logo {
        width: min(100%, 280px);
        margin: 0 auto;
    }

    .hozonsui7__concept__vision__copy > div {
        align-items: center;
    }

    #hozonsui7__concept .hozonsui7__concept__vision__copy h3 p,
    #hozonsui7__concept .hozonsui7__concept__vision__copy p {
        line-height: 1.5;
    }

    .hozonsui7__concept__vision__column {
        grid-template-columns: 1fr;
    }

    .hozonsui7__concept__vision__column img:not(.back-circle) {
        order: 1;
    }

    .hozonsui7__concept__vision__column p {
        order: 2;
    }

    /* Concept（2カラム / 背景の丸） */
    .back-circle1 {
        min-width: 150%;
        right: initial;
        top: 100%;
        left: 50%;
        translate: -50% -80%;
    }

    .back-circle2 {
        width: 80%;
        top: 30%;
        left: initial;
        right: 0;
    }

    .back-circle3 {
        width: 100%;
        bottom: initial;
        top: 75%;
        left: 40%;
        translate: -50% -50%;
    }

    /* About water（商品情報） */
    .hozonsui7__about__product li {
        grid-template-columns: 1fr;
    }

    .hozonsui7__about__product img {
        width: min(100%, 280px);
        margin-right: auto;
    }

    /* About water（体に嬉しいポイント） */
    .hozonsui7__about__merit {
        width: calc(100% + 30px);
        margin-left: -15px;
        padding: 30px 15px;
    }

    /* About water（体に嬉しいポイント / リスト） */
    .hozonsui7__about__merit__ol li {
        display: flex;
        flex-direction: column;
        padding: 1.5rem;
    }

    /* About water（体に嬉しいポイント / Point） */
    .hozonsui7__about__merit__ol_image {
        display: flex;
        align-items: center;
        margin-bottom: 8px;
    }

    #hozonsui7__about .hozonsui7__about__merit__ol .image-point {
        width: 72px;
        margin-right: 4px;
    }

    .image-point-num {
        width: 48px;
    }

    /* About water（体に嬉しいポイント / 見出し） */
    .hozonsui7__about__merit__ol__heading h4 {
        margin-left: 0;
        margin-bottom: 0;
        translate: 0 0;
    }

    /* About water（製造の流れ / 画像） */
    #hozonsui7__about__flow img {
        width: 100%;
    }

    /* About water（製品情報） */
    #hozonsui7__about .hozonsui7__about__product__overview h3 p {
        margin-top: 0.5em;
    }

    /* About water（製品情報 / 表） */
    .hozonsui7__about__information__table {
        overflow-x: scroll;
    }

    #hozonsui7__about__information table {
        min-width: 640px;
    }

    /* Scene（説明文） */
    #hozonsui7__scene .hozonsui7__scene__text p {
        margin-bottom: 1.5em;
    }

    /* Scene（セット） */
    .hozonsui7__scene__set {
        grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    }

    /* how to buy（お問合せ） */
    .hozonsui7__buy__contact a img {
        width: max(100%, 320px);
    }
}