/*
Theme Name : ohtaka
*/

* {
    font-family: "Zen Old Mincho", "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif !important;
}

.en {
    font-family: "Inter", sans-serif !important;
}

.section_title {
    font-family: "Zen Old Mincho", "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif !important;
}

.section_title_en {
    font-family: "Lora", serif !important;
}

html {
    height: 100%;
}

img {
    width: 100%;
}

h2,
h3,
h4 {
    margin: 0;
}

a {
    text-decoration: none;
}

.contents_wrapper {
    position: relative;
    -webkit-transition: -webkit-transform 0.6s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: -webkit-transform 0.6s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: transform 0.6s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: transform 0.6s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 0.6s cubic-bezier(0.215, 0.61, 0.355, 1);
}

label {
    cursor: pointer;
}

.content_block {
    position: relative;
    width: 100%;
    padding: 120px 0;
}

.content_inner {
    position: relative;
    max-width: 1920px;
    padding: 0 5vw;
    margin: 0 auto;
    z-index: 2;
}

.content_inner .inner_section_block {
    margin-top: 90px;
}

.content_inner .inner_section_block2 {
    margin-top: 120px;
}

.content_inner h2 {
    color: #333333;
    font-size: 33px;
    line-height: 1.5;
    margin-bottom: 0;
}

.content_inner h2 .jp_ruby {
    color: #333333;
    font-size: 1.25rem;
    font-weight: 500;
}

.content_inner.-privacy h2 {
    font-size: 1.999rem;
    line-height: 1.75;
    margin: 1rem 0;
    border-bottom: 1px solid #333333;
}

.content_inner.-privacy h3 {
    font-size: 1.414rem;
    font-weight: 700;
    margin: 0.5rem 0;
}

*,
::after,
::before {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

::after,
::before {
    text-decoration: inherit;
    vertical-align: inherit;
}

html {
    cursor: default;
    line-height: 1.5;
    -moz-tab-size: 4;
    -o-tab-size: 4;
    tab-size: 4;
    -webkit-tap-highlight-color: transparent;
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
    word-break: break-word;
}

body {
    margin: 0;
}

h1 {
    font-size: 2em;
    margin: 0.67em 0;
}

dl dl,
dl ol,
dl ul,
ol dl,
ul dl {
    margin: 0;
}

ol ol,
ol ul,
ul ol,
ul ul {
    margin: 0;
}

hr {
    height: 0;
    overflow: visible;
}

main {
    display: block;
}

nav ol,
nav ul {
    list-style: none;
    padding: 0;
}

pre {
    font-family: monospace, monospace;
    font-size: 1em;
}

a {
    background-color: transparent;
}

abbr[title] {
    text-decoration: underline;
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
}

b,
strong {
    font-weight: bolder;
}

code,
kbd,
samp {
    font-family: monospace, monospace;
    font-size: 1em;
}

small {
    font-size: 80%;
}

audio,
canvas,
iframe,
img,
svg,
video {
    vertical-align: middle;
}

audio,
video {
    display: inline-block;
}

audio:not([controls]) {
    display: none;
    height: 0;
}

iframe {
    border-style: none;
}

img {
    border-style: none;
}

svg:not([fill]) {
    fill: currentColor;
}

svg:not(:root) {
    overflow: hidden;
}

table {
    border-collapse: collapse;
}

button,
input,
select {
    margin: 0;
}

button {
    overflow: visible;
    text-transform: none;
}

[type=button],
[type=reset],
[type=submit],
button {
    -webkit-appearance: button;
}

fieldset {
    border: 1px solid #a0a0a0;
    padding: 0.35em 0.75em 0.625em;
}

input {
    overflow: visible;
}

legend {
    color: inherit;
    display: table;
    max-width: 100%;
    white-space: normal;
}

progress {
    display: inline-block;
    vertical-align: baseline;
}

select {
    text-transform: none;
}

textarea {
    margin: 0;
    overflow: auto;
    resize: vertical;
}

[type=checkbox],
[type=radio] {
    padding: 0;
}

[type=search] {
    -webkit-appearance: textfield;
    outline-offset: -2px;
}

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
    height: auto;
}

::-webkit-input-placeholder {
    color: inherit;
    opacity: 0.54;
}

::-webkit-search-decoration {
    -webkit-appearance: none;
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit;
}

::-moz-focus-inner {
    border-style: none;
    padding: 0;
}

:-moz-focusring {
    outline: 1px dotted ButtonText;
}

:-moz-ui-invalid {
    box-shadow: none;
}

details {
    display: block;
}

dialog {
    background-color: #fff;
    border: solid;
    color: #000;
    display: block;
    height: -moz-fit-content;
    height: -webkit-fit-content;
    height: fit-content;
    left: 0;
    margin: auto;
    padding: 1em;
    position: absolute;
    right: 0;
    width: -moz-fit-content;
    width: -webkit-fit-content;
    width: fit-content;
}

dialog:not([open]) {
    display: none;
}

summary {
    display: list-item;
}

canvas {
    display: inline-block;
}

template {
    display: none;
}

[tabindex],
a,
area,
button,
input,
label,
select,
summary,
textarea {
    -ms-touch-action: manipulation;
    touch-action: manipulation;
}

[hidden] {
    display: none;
}

[aria-busy=true] {
    cursor: progress;
}

[aria-controls] {
    cursor: pointer;
}

[aria-disabled=true],
[disabled] {
    cursor: not-allowed;
}

[aria-hidden=false][hidden] {
    display: initial;
}

[aria-hidden=false][hidden]:not(:focus) {
    clip: rect(0, 0, 0, 0);
    position: absolute;
}

header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 10;
}

header .header_pc {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    height: 120px;
}

header .header_pc .header_logo {
    width: 210px;
    margin-left: 40px;
}

header .header_pc .header_item .header_contact {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

header .header_pc .header_item .header_contact ul.header_company_info {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 0;
    margin: 0 30px 0 0;
    list-style: none;
}

header .header_pc .header_item .header_contact ul.header_company_info li {
    margin-right: 30px;
    position: relative;
}

header .header_pc .header_item .header_contact ul.header_company_info li:last-of-type {
    margin-right: 0;
}

header .header_pc .header_item .header_contact ul.header_company_info li a {
    position: relative;
    display: inline-block;
    color: #ffffff;
    font-size: 14px;
}

header .header_pc .header_item .header_contact ul.header_company_info li a::before {
    position: absolute;
    bottom: -2px;
    left: 0;
    content: "";
    width: 100%;
    height: 1px;
    background: #ffffff;
    -webkit-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: left top;
    transform-origin: left top;
    -webkit-transition: -webkit-transform 0.3s;
    transition: -webkit-transform 0.3s;
    transition: transform 0.3s;
    transition: transform 0.3s, -webkit-transform 0.3s;
}

header .header_pc .header_item .header_contact ul.header_company_info li a:hover::before {
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
}

header .header_pc .header_item .header_contact ul.header_company_info li ul.child_menu {
    width: 120px;
    padding: 10px;
    opacity: 0;
    visibility: hidden;
    position: absolute;
    top: calc(100% + 8px);
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    z-index: -10;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    background: #495364;
    list-style: none;
}

header .header_pc .header_item .header_contact ul.header_company_info li ul.child_menu li {
    width: 100%;
    height: 100%;
    position: relative;
}

header .header_pc .header_item .header_contact ul.header_company_info li ul.child_menu li a {
    width: 100%;
    height: 100%;
    color: #ffffff;
    font-size: 14px;
    font-weight: normal;
    padding: 10px;
}

header .header_pc .header_item .header_contact ul.header_company_info li ul.child_menu li a:hover {
    background: rgba(255, 255, 255, 0.2);
}

header .header_pc .header_item .header_contact ul.header_company_info li:hover {
    -webkit-transform: none;
    transform: none;
}

header .header_pc .header_item .header_contact ul.header_company_info li:hover .child_menu {
    opacity: 1;
    visibility: visible;
    z-index: 999;
}

header .header_pc .header_item .header_contact ul.header_company_info .has_child {
    color: #ffffff;
    font-weight: 500;
    display: inline-block;
    position: relative;
}

header .header_pc .header_item .header_contact .header_shop {
    margin: 0 20px 0 0;
}

header .header_pc .header_item .header_contact .header_shop a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    height: 33px;
    width: 151px;
    background: #ffffff;
    border: 1px solid #ffffff;
    color: #495364;
    font-size: 14px;
    font-weight: 500;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

header .header_pc .header_item .header_contact .header_shop a:hover {
    background: #495364;
    color: #ffffff;
}

header .header_pc .header_item .header_contact .header_online {
    margin: 0 40px 0 0;
}

header .header_pc .header_item .header_contact .header_online a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    height: 33px;
    width: 151px;
    background: #495364;
    border: 1px solid #ffffff;
    color: #ffffff;
    font-size: 14px;
    font-weight: 500;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

header .header_pc .header_item .header_contact .header_online a:hover {
    background: #ffffff;
    color: #495364;
}

header .header_pc .header_item .header_nav {}

header .header_pc .header_item .header_nav .parent_menu {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 0;
    margin: 0 40px 0 0;
    list-style: none;
    justify-content: space-between;
}

header .header_pc .header_item .header_nav .parent_menu li {
    /* margin-right: 70px; */
    position: relative;
}

header .header_pc .header_item .header_nav .parent_menu li:last-of-type {
    margin-right: 0;
}

header .header_pc .header_item .header_nav .parent_menu>li:last-of-type {
    border: 1px solid #FFFFFF;
    background: rgba(73, 83, 100, .6);
    width: 150px;
    text-align: center;
    line-height: 33px;
}

header .header_pc .header_item .header_nav .parent_menu .has_child span {
    display: inline-block;
    vertical-align: text-bottom;
}

header .header_pc .header_item .header_nav .parent_menu li a {
    position: relative;
    display: inline-block;
    color: #ffffff;
    font-weight: 500;
}

header .header_pc .header_item .header_nav .parent_menu li a::before {
    position: absolute;
    bottom: 0px;
    left: 0;
    content: "";
    width: 100%;
    height: 1px;
    background: #ffffff;
    -webkit-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: left top;
    transform-origin: left top;
    -webkit-transition: -webkit-transform 0.3s;
    transition: -webkit-transform 0.3s;
    transition: transform 0.3s;
    transition: transform 0.3s, -webkit-transform 0.3s;
}

header .header_pc .header_item .header_nav .parent_menu li a:hover::before {
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
}

header .header_pc .header_item .header_nav .parent_menu li .child_menu {
    width: 200px;
    padding: 10px;
    opacity: 0;
    visibility: hidden;
    position: absolute;
    top: calc(100% + 4px);
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    z-index: -10;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    background: #495364;
}

header .header_pc .header_item .header_nav .parent_menu li .child_menu li {
    width: 100%;
    height: 100%;
    position: relative;
}

header .header_pc .header_item .header_nav .parent_menu li .child_menu li a {
    width: 100%;
    height: 100%;
    color: #ffffff;
    font-size: 14px;
    font-weight: normal;
    padding: 10px;
}

header .header_pc .header_item .header_nav .parent_menu li .child_menu li a:hover {
    background: rgba(255, 255, 255, 0.2);
}

header .header_pc .header_item .header_nav .parent_menu li:hover {
    -webkit-transform: none;
    transform: none;
}

header .header_pc .header_item .header_nav .parent_menu li:hover .child_menu {
    opacity: 1;
    visibility: visible;
    z-index: 999;
}

header .header_pc .header_item .header_nav .parent_menu .has_child {
    color: #ffffff;
    font-weight: 500;
    display: inline-block;
    position: relative;
}

.header_bg.change-color {
    background: rgba(73, 83, 100, .9);
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

#drawer {
    position: absolute;
    top: 0px;
    right: 0px;
    z-index: 11;
    /* :::::: toggle button :::::: */
    /* :::::: drawer menu :::::: */
}

#drawer label {
    cursor: pointer;
    position: absolute;
    top: 0;
    right: 0;
}

#drawer #navTgl:checked~.contents_wrapper {
    -webkit-transform: translateX(-250px);
    transform: translateX(-250px);
}

#drawer #navTgl {
    display: none;
}

#drawer .open {
    z-index: 12;
    position: inherit;
    width: 100px;
    height: 100px;
}

#drawer .open span {
    position: absolute;
    top: calc(50% - 8px);
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: 40px;
    height: 3px;
    background: #ffffff;
    display: inline-block;
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
}

#drawer .open span:nth-of-type(1) {
    -webkit-transform: translate(-50%, calc(-50% - 14px));
    transform: translate(-50%, calc(-50% - 14px));
}

#drawer .open span:nth-of-type(3) {
    -webkit-transform: translate(-50%, calc(-50% + 14px));
    transform: translate(-50%, calc(-50% + 14px));
}

#drawer .open span:nth-of-type(3)::after {
    content: "MENU";
    position: absolute;
    top: calc(50% + 16px);
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    color: #ffffff;
    font-size: 16px;
    white-space: nowrap;
}

#drawer #navTgl:checked+.open span:nth-of-type(1) {
    -webkit-transform: translate(-50%, -50%) rotate(-45deg);
    transform: translate(-50%, -50%) rotate(-45deg);
}

#drawer #navTgl:checked+.open span:nth-of-type(2) {
    opacity: 0;
}

#drawer #navTgl:checked+.open span:nth-of-type(3) {
    -webkit-transform: translate(-50%, -50%) rotate(45deg);
    transform: translate(-50%, -50%) rotate(45deg);
}

#drawer #navTgl:checked+.open span:nth-of-type(3)::after {
    content: "CLOSE";
    -webkit-transform: translate(calc(-50% + 20px), calc(-50% + 4px)) rotate(-45deg);
    transform: translate(calc(-50% + 20px), calc(-50% + 4px)) rotate(-45deg);
}

#drawer .close {
    width: 100%;
    height: 100vh;
    -webkit-transition: background 0.6s cubic-bezier(0.4, 0, 0.2, 1);
    transition: background 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

#drawer #navTgl:checked~.close {
    position: fixed;
    background: rgba(30, 30, 30, 0.5);
    pointer-events: auto;
    z-index: 11;
}

#drawer .menu {
    z-index: 11;
    position: fixed;
    overflow: auto;
    top: 0;
    right: 0;
    width: 50%;
    max-width: 1000px;
    height: 100%;
    margin: 0;
    padding: 50px 100px 50px 50px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    background: #495364;
    -webkit-transform: translateX(200%);
    transform: translateX(200%);
    -webkit-transition: -webkit-transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
    transition: -webkit-transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
    transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
    transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1), -webkit-transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

#drawer .menu h2,
#drawer .menu a {
    color: #ffffff;
    font-size: 18px;
}

#drawer .menu h2 {
    text-align: center;
}

#drawer .menu ul {
    margin: 0;
    padding: 0;
}

#drawer .menu li {
    line-height: 1.25;
}

#drawer #navTgl:checked~.menu {
    -webkit-transform: none;
    transform: none;
}

.sp_menu .header_nav_block ul {
    list-style: none;
    padding: 0;
}

.sp_menu .header_nav_block ul li {
    margin-bottom: 0.75rem;
}

.sp_menu .header_nav_block ul li:last-of-type {
    margin-bottom: 0;
}

.sp_menu .header_nav_block ul li a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.sp_menu .header_nav_block ul li a .nav_ruby {
    font-size: 14px;
    font-weight: normal;
    color: #ffffff;
    padding-left: 14px;
}

.sp_menu .header_nav_block ul li a:hover {
    background: rgba(255, 255, 255, 0.2);
}

.sp_menu .header_nav_block ul li .parent_menu_ttl {
    margin-bottom: 0.75rem;
    padding: 5px 20px;
    border-bottom: 1px solid #ffffff;
}

.sp_menu .header_nav_block ul li ul li .child_menu_ttl {
    padding: 5px 20px;
}

.sp_menu .header_nav_block ul li ul li .child_menu_ttl::before {
    font-family: "fontello";
    content: "\f105";
    margin-right: 10px;
}

.sp_menu .header_nav_block ul li ul li .child_menu_ttl .mega_ruby {
    font-size: 14px;
    font-weight: normal;
    color: #ffffff;
    padding-left: 14px;
}

.sp_menu .header_nav_sns .header_nav_sns_icon:not(:last-of-type) {
    margin-right: 80px;
}

.sp_menu .header_nav_sns .header_nav_sns_icon img.-instagram {
    width: 22px;
    height: auto;
}

.sp_menu .header_nav_sns .header_nav_sns_icon img.-youtube {
    width: 22px;
    height: auto;
}

.sp_menu .header_nav_sns .header_nav_sns_icon img.-tiktok {
    width: 20px;
    height: auto;
}

.sp_menu .header_nav_btn .header_nav_shop a {
    padding: 14px 10px;
    display: inline-block;
    width: 100%;
    background: #ffffff;
    border: 2px solid #ffffff;
    color: #495364 !important;
    font-size: 1rem;
    font-weight: 500;
    text-align: center;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.sp_menu .header_nav_btn .header_nav_shop a:hover {
    background: #495364;
    color: #ffffff !important;
}

.sp_menu .header_nav_btn .header_nav_online a {
    padding: 14px 10px;
    display: inline-block;
    width: 100%;
    background: #495364;
    border: 2px solid #ffffff;
    color: #ffffff !important;
    font-size: 1rem;
    font-weight: 500;
    text-align: center;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.sp_menu .header_nav_btn .header_nav_online a:hover {
    background: #ffffff;
    color: #495364 !important;
}

footer {
    width: 100%;
    padding: 60px 0;
    position: relative;
    background: rgba(73, 83, 100, .9);
	text-align: left;
}

@media (max-width: 768px) { /* 适用于小屏幕（如手机） */
    footer {
        text-align: center;
    }
}



footer .footer_inner {
    max-width: 1920px;
    padding: 0 5vw;
    margin: 0 auto;
    position: relative;
}

footer .footer_inner .footer_logo {
    margin-bottom: 60px;
}

footer .footer_inner .footer_logo img {
    width: 220px;
    height: 100%;
}

footer .footer_inner .footer_shopinfo p {
    color: #ffffff;
    font-size: 16px;
    font-weight: 500;
	text-align:left;
}


@media (max-width: 768px) {
    footer .footer_inner .footer_shopinfo p {
        text-align: center;
    }
}


footer .footer_inner .footer_shopinfo .office {
    display: inline-block;
    background: #ffffff;
    padding: 0 10px;
    color: #495364;
    font-size: 12px;
    font-weight: 500;
}

footer .footer_inner .footer_shopinfo .contact {
    color: #ffffff;
    font-size: 16px;
    font-weight: 900;
}

footer .footer_inner .footer_shopinfo .contact .contact_tel {
    color: #ffffff;
    font-size: 12px;
    font-weight: 500;
}

footer .footer_inner .footer_shopinfo .contact a {
    color: #ffffff;
    font-size: 16px;
    font-weight: 900;
}

footer .footer_inner .footer_shopinfo .contact .contact_fax {
    color: #ffffff;
    font-size: 12px;
    font-weight: 500;
}

footer .footer_inner .footer_shopinfo .footer_sns .footer_sns_icon {
    margin-right: 30px;
}

footer .footer_inner .footer_shopinfo .footer_sns .footer_sns_icon:last-of-type {
    margin-right: 0;
}

footer .footer_inner .footer_shopinfo .footer_sns .footer_sns_icon img {
    width: 30px;
}

footer .footer_nav ul {
    margin: 0;
    padding-left: 16.75rem;
}

footer .footer_nav ul li a {
    position: relative;
    color: #ffffff;
    font-size: 18px;
    font-weight: 500;
    line-height: 2.126;
}

footer .footer_nav ul li a::before {
    position: absolute;
    bottom: -2px;
    left: 0;
    content: "";
    width: 100%;
    height: 1px;
    background: #ffffff;
    -webkit-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: left top;
    transform-origin: left top;
    -webkit-transition: -webkit-transform 0.3s;
    transition: -webkit-transform 0.3s;
    transition: transform 0.3s;
    transition: transform 0.3s, -webkit-transform 0.3s;
}

footer .footer_nav ul li a:hover::before {
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
}

footer .copy {
    margin-top: 50px;
    text-align: end;
}

footer .copy small {
    color: #ffffff;
}

.pagetop_block {
    position: fixed;
    bottom: 1%;
    right: 1%;
    z-index: 9;
}

.pagetop_block .contact_sp {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    width: 35%;
}

.pagetop_block .contact_sp a {
    background: #495364;
    padding: 2px;
    height: 60px;
    width: 100%;
    text-decoration: none;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    font-size: 14px;
    color: #ffffff;
    border: 1px solid #495364;
    border-right: 1px solid #ffffff;
}

.pagetop_block .contact_sp2 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    width: 45%;
}

.pagetop_block .contact_sp2 a {
    background: #495364;
    padding: 2px;
    height: 60px;
    width: 100%;
    text-decoration: none;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    font-size: 14px;
    color: #ffffff;
    border: 1px solid #495364;
    border-right: 1px solid #ffffff;
}

.pagetop_block #pagetop {
    width: 60px;
    height: 60px;
    margin-left: auto;
}

.pagetop_block #pagetop a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    width: 100%;
    height: 100%;
    text-decoration: none;
    background: #ffffff;
    border: 1px solid #495364;
    color: #495364;
    font-weight: 500;
    border-radius: 50rem;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.pagetop_block #pagetop a::before {
    font-family: "fontello";
    content: "\e804";
    font-size: 16px;
    line-height: 0.75;
}

.pagetop_block #pagetop a:hover {
    background: #495364;
    color: #ffffff;
}

.breadcrumb_block {
    max-width: 1920px;
    margin: 0 auto;
    padding: 1rem 0;
}

.breadcrumb_block ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.breadcrumb_block ul li,
.breadcrumb_block ul a,
.breadcrumb_block ul li,
.breadcrumb_block ul span {
    color: #333333;
    font-size: 13px;
}

.breadcrumb_block ul li {
    padding-right: 30px;
    position: relative;
}

.breadcrumb_block ul li::before {
    font-family: "fontello";
    content: "\f105";
    position: absolute;
    right: 10px;
}

.breadcrumb_block ul li:last-of-type::before {
    content: "";
}

#mw_wp_form_mw-wp-form-12 p.form_item.input {
    font-size: 16px;
}

#mw_wp_form_mw-wp-form-12 p.form_item.input:last-of-type {
    margin-bottom: 0;
}

.mw_wp_form_preview form p.form_item.input {
    border-bottom: 1px dotted #333333;
    padding-bottom: 10px;
}

.form_item input {
    width: 100%;
    padding: 5px;
    font-size: 16px;
    font-weight: normal;
    margin-bottom: 10px;
}

.form_item textarea {
    width: 100%;
    padding: 5px;
    font-size: 16px;
    font-weight: normal;
    margin-bottom: 10px;
}

.form_item .red_text {
    font-size: 14px;
}

.form_item_button {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin-top: 32px;
}

.form_item_button input {
    border: none;
    background: #495364;
    color: #ffffff;
    font-size: 16px;
    font-weight: bold;
    width: 250px;
    height: 48px;
    line-height: 1;
    cursor: pointer;
}

.form_item_button input:hover {
    opacity: 0.8;
}

.form_item_button input:nth-of-type(2) {
    margin-left: 20px;
}

.home_button {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.home_button a {
    display: block;
    border: none;
    text-decoration: none;
    background: #333333;
    color: #ffffff;
    font-size: 16px;
    text-align: center;
    padding: 10px;
    width: 160px;
    line-height: 1;
    cursor: pointer;
}

.home_button a:hover {
    opacity: 0.8;
}

.products_item_list {
    margin-bottom: 3rem;
}

.products_item_list figure {
    overflow: hidden;
    width: 100%;
    aspect-ratio: 1/1;
}

.products_item_list figure img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center;
    object-position: center;
    font-family: "object-fit: cover; object-position: center;";
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
}

.products_item_list:hover img {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
}

.products_item_list h2 {
    font-size: 1.414rem;
    line-height: 1.25;
}

.products_item_list h3 {
    font-size: 14px;
    font-weight: 400;
}

.products_item_list h4 {
    font-size: 1rem;
    font-weight: 600;
    color: #495364;
}

.products_item_list p {
    font-size: 1.414rem;
    font-weight: 500;
    text-align: end;
    line-height: 0.75;
}

.products_item_list p span {
    display: inline-block;
    font-size: 0.75rem;
    font-weight: 400;
}

.recipes_item_list {
    margin-bottom: 3rem;
}

.recipes_item_list figure {
    overflow: hidden;
    width: 100%;
    aspect-ratio: 1/1;
}

.recipes_item_list figure img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center;
    object-position: center;
    font-family: "object-fit: cover; object-position: center;";
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
}

.recipes_item_list:hover img {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
}

.recipes_item_list h2 {
    font-size: 1.414rem;
    line-height: 1.25;
}

.recipes_item_list h3 {
    font-size: 14px;
    font-weight: 400;
}

.recipes_item_list h4 {
    font-size: 1rem;
    font-weight: 600;
    color: #495364;
}

.recipes_item_list p {
    font-size: 1.414rem;
    font-weight: 500;
    text-align: end;
    line-height: 0.75;
}

.recipes_item_list p span {
    display: inline-block;
    font-size: 12px;
    font-weight: 400;
}

.card_item figure {
    margin: 0;
}

.card_item figure img {
    border-radius: 0.25rem 0.25rem 0 0;
    width: 100%;
    height: 180px;
    -o-object-fit: cover;
    object-fit: cover;
}

.card-body {
    position: absolute;
    bottom: 0;
    left: 50%;
    -webkit-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
}

.card_text {
    margin: 1rem 0;
    min-height: 70px;
}

.blog_post_date {
    font-size: 13px;
    display: block;
}

.btn_main-color {
    color: #ffffff !important;
    background-color: #495364 !important;
    border-color: #495364 !important;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.btn_main-color:hover {
    opacity: 0.8 !important;
}

.btn_main-color .icons {
    color: #ffffff;
}

.btn_main-color .icons::before {
    font-weight: bold;
}

.btn_sub-color {
    color: #495364 !important;
    background-color: #F0F7FF !important;
    border-color: #F0F7FF !important;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.btn_sub-color:hover {
    opacity: 0.8 !important;
}

.btn_sub-color .icons {
    color: #495364;
}

.btn_sub-color .icons::before {
    font-weight: bold;
}

.bg_gray-light {
    background: #eeeeee !important;
}

.bg_gray-lighter {
    background: #f5f5f5 !important;
}

.bg_main-color {
    background: #495364 !important;
}

.bg_sub-color {
    background: #F0F7FF !important;
}

.bg_bg-color {
    background: #f7f6f2 !important;
}

.bg_bg-color2 {
    background: #f1f0eb !important;
}

.bg_gradient-color {
    background: -webkit-radial-gradient(center, circle, #F0F7FF 0%, #ffffff 100%) !important;
    background: radial-gradient(circle at center, #F0F7FF 0%, #ffffff 100%) !important;
}

.bg_gradient-color2 {
    background: -webkit-gradient(linear, left bottom, left top, from(#F0F7FF), to(#ffffff)) !important;
    background: -webkit-linear-gradient(bottom, #F0F7FF 0%, #ffffff 100%) !important;
    background: linear-gradient(to top, #F0F7FF 0%, #ffffff 100%) !important;
}

.bg_orange {
    background: #f5a669 !important;
}

.bg_green {
    background: #5d9944 !important;
}

.bg_blue-light {
    background: #2fb4d6 !important;
}

.bg_text-color {
    background: #333333 !important;
}

.bg_initial {
    background: initial !important;
}

.main-color {
    color: #495364 !important;
}

.text-color {
    color: #333333 !important;
}

.sub-color {
    color: #F0F7FF !important;
}

.orange {
    color: #f5a669 !important;
}

.green {
    color: #5d9944 !important;
}

.blue {
    color: #6e51f5 !important;
}

.red {
    color: #f5735d !important;
}

.border-main-color {
    border-color: #495364 !important;
}

.border-sub-color {
    border-color: #F0F7FF !important;
}

.border-orange {
    border-color: #f5a669 !important;
}

.border-green {
    border-color: #5d9944 !important;
}

.d_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.justify_center {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.justify_between {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.justify_around {
    -ms-flex-pack: distribute;
    justify-content: space-around;
}

.align_items_center {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.align_items_end {
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
}

.align_items_start {
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
}

.marker-normal {
    background: -webkit-gradient(linear, left top, left bottom, color-stop(75%, transparent), color-stop(0%, #F0F7FF));
    background: -webkit-linear-gradient(transparent 75%, #F0F7FF 0%);
    background: linear-gradient(transparent 75%, #F0F7FF 0%);
}

.marker-bold {
    background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(0%, #F0F7FF));
    background: -webkit-linear-gradient(transparent 60%, #F0F7FF 0%);
    background: linear-gradient(transparent 60%, #F0F7FF 0%);
}

.marker-all {
    background: -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(0%, #F0F7FF));
    background: -webkit-linear-gradient(transparent 0%, #F0F7FF 0%);
    background: linear-gradient(transparent 0%, #F0F7FF 0%);
}

.btn01 a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    color: #333333;
    font-size: 16px;
    font-weight: bold;
}

.btn01 a::after {
    font-family: "fontello";
    content: "\e80f";
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    color: #495364;
    margin-left: 20px;
    width: 80px;
    height: 80px;
    border: 2px solid #495364;
    border-radius: 50%;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.btn01 a:hover::after {
    color: #ffffff;
    background: #495364;
}

.btn02 a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    color: #333333;
    font-size: 16px;
    font-weight: bold;
}

.btn02 a::after {
    font-family: "fontello";
    content: "\e80f";
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    color: #495364;
    margin-left: 20px;
    width: 80px;
    height: 80px;
    border: 2px solid #495364;
    border-radius: 50%;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.btn02 a:hover::after {
    color: #ffffff;
    background: #495364;
}

.btn03 .more_btn {
    width: 100%;
    padding: 1vw 0.5vw;
    background: #495364;
    border: 2px solid #495364;
    color: #ffffff;
    font-size: 1rem;
    text-align: center;
    font-weight: 500;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.btn03 .more_btn::after {
    font-family: "fontello";
    content: "\f107";
    color: #ffffff;
    margin-left: 10px;
}

.btn03 .more_btn:hover {
    background: #ffffff;
    color: #495364;
}

.pagination {
    margin-top: 40px;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.pagination a {
    color: #333333;
    width: 32px;
    line-height: 32px;
    text-align: center;
    border: 1px solid #A3A3A3;
    color: #A3A3A3;
    margin: 0 10px;
}

.pagination a.prev,
.pagination a.next {
    width: 24px;
    height: 24px;
    border: none;
}

.pagination a.page-num-current {
    border: 1px solid #000000;
    color: #333333;
}

.pagination .page-numbers {
    margin: 0 10px;
}

.pagination .current {
    border-bottom: 1px solid #333333;
}

.loading {
    background: #f7f6f2;
    position: fixed;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    z-index: 9000;
}

.loading div {
    position: fixed;
    left: 50%;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    display: none;
    z-index: 9999;
    width: 380px;
}

#elevator_nav {
    position: fixed;
    right: 0;
    top: 45%;
    padding: 30px 10px 30px 0;
    z-index: 1;
}

#elevator_nav ul {
    padding: 0;
    list-style: none;
    margin: 0;
    position: relative;
}

#elevator_nav ul::after {
    content: "";
    position: absolute;
    border-left: 1px solid #dddddd;
    height: 96px;
    top: 10px;
    left: 11px;
    z-index: 0;
}

#elevator_nav ul li {
    margin-bottom: 25px;
}

#elevator_nav ul li:last-of-type {
    margin-bottom: 0;
    font-size: 13px;
}

#elevator_nav ul li a {
    text-decoration: none;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    color: #333333;
}

#elevator_nav ul li a::before {
    font-size: 13px;
    font-family: "fontello";
    content: "\e807";
    color: #dddddd;
    width: 23px;
    height: 20px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    z-index: 1;
}

#elevator_nav ul li a span {
    font-size: 13px;
}

.current::before {
    color: #6e51f5 !important;
    font-size: 16px !important;
}

.map_wrap {
    width: 100%;
}

.ggmap {
    height: 0;
    overflow: hidden;
    padding-bottom: 100%;
    position: relative;
    width: 100%;
}

.ggmap iframe {
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    width: 100%;
}

.accordion_area {
    list-style: none;
    padding: 0;
    margin-top: 120px;
}

.accordion_area li {
    margin: 0;
}

.accordion_area li section .accordion {
    position: relative;
    padding: 2.21rem;
    border-bottom: 1px solid #333333;
}

.accordion_area li section .accordion::before {
    position: absolute;
    bottom: -1px;
    left: 0;
    content: "";
    width: 100%;
    height: 2px;
    background: #333333;
    -webkit-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: left top;
    transform-origin: left top;
    -webkit-transition: -webkit-transform 0.6s;
    transition: -webkit-transform 0.6s;
    transition: transform 0.6s;
    transition: transform 0.6s, -webkit-transform 0.6s;
}

.accordion_area li section .accordion:hover::before {
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
}

.accordion_area li section .accordion h3 {
    position: relative;
    margin-bottom: 0;
    padding-right: 1.999rem;
    font-size: 1.414rem;
    font-weight: 700;
    cursor: pointer;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.accordion_area li section .accordion h3::before,
.accordion_area li section .accordion h3::after {
    position: absolute;
    content: "";
    width: 23px;
    height: 3px;
    background-color: #333333;
}

.accordion_area li section .accordion h3::before {
    top: 50%;
    right: 0;
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
}

.accordion_area li section .accordion h3::after {
    top: 50%;
    right: 0;
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
}

.accordion_area li section .accordion h3 .q-mark {
    font-size: 2.25rem;
    font-weight: 700;
}

.accordion_area li section .accordion h3.close::before {
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

.accordion_area li section .accordion h3.close::after {
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

.accordion_area li section .accordion .box {
    display: none;
    padding: 2.25rem;
}

.accordion_area li section .accordion.type1 {
    border-top: 1px solid #333333;
}

.accordion_area_product {
    list-style: none;
    padding: 0;
}

.accordion_area_product li {
    margin: 0;
}

.accordion_area_product li section .accordion {
    position: relative;
    padding: 1rem;
    border-bottom: 1px solid #333333;
}

.accordion_area_product li section .accordion::before {
    position: absolute;
    bottom: -1px;
    left: 0;
    content: "";
    width: 100%;
    height: 2px;
    background: #333333;
    -webkit-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: left top;
    transform-origin: left top;
    -webkit-transition: -webkit-transform 0.6s;
    transition: -webkit-transform 0.6s;
    transition: transform 0.6s;
    transition: transform 0.6s, -webkit-transform 0.6s;
}

.accordion_area_product li section .accordion:hover::before {
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
}

.accordion_area_product li section .accordion h3 {
    position: relative;
    margin-bottom: 0;
    font-size: 1rem;
    font-weight: 700;
    cursor: pointer;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.accordion_area_product li section .accordion h3::before,
.accordion_area_product li section .accordion h3::after {
    position: absolute;
    content: "";
    width: 15px;
    height: 3px;
    background-color: #333333;
}

.accordion_area_product li section .accordion h3::before {
    top: 50%;
    right: 0;
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
}

.accordion_area_product li section .accordion h3::after {
    top: 50%;
    right: 0;
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
}

.accordion_area_product li section .accordion h3.close::before {
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

.accordion_area_product li section .accordion h3.close::after {
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

.accordion_area_product li section .accordion .box {
    display: none;
    padding: 1.25rem;
}

.accordion_area_product li section .accordion .box p {
    font-size: 14px;
}

.accordion_area_product li section .accordion .box p a {
    font-size: 14px;
    color: #6e51f5;
}

.accordion_area_product li section .accordion .box p a::after {
    font-family: "fontello";
    content: "\f08e";
}

.accordion_area_product li section .accordion.type1 {
    border-top: 1px solid #333333;
}

.purchase_block {
    margin-top: 120px;
}

.purchase_block h3 {
    font-size: 3.375rem;
    font-weight: 900;
    color: #495364;
}

.purchase_block .purchase_btn .purchase_shop a {
    position: relative;
    top: 0;
    padding: 2.05vw 1.75vw;
    display: inline-block;
    width: 100%;
    background: #ffffff;
    border: 2px solid #495364;
    color: #495364;
    font-size: 2.25rem;
    font-weight: 500;
    text-align: center;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.purchase_block .purchase_btn .purchase_shop a:hover {
    top: -1rem;
    -webkit-box-shadow: 0 12px 23px rgba(175, 187, 183, 0.75);
    box-shadow: 0 12px 23px rgba(175, 187, 183, 0.75);
    background: #495364;
    color: #ffffff;
}

.purchase_block .purchase_btn .purchase_online a {
    position: relative;
    top: 0;
    padding: 2.75vw 1.75vw;
    display: inline-block;
    width: 100%;
    background: #495364;
    border: 2px solid #495364;
    color: #ffffff;
    font-size: 2.25rem;
    text-align: center;
    font-weight: 500;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    min-height: 142px;
}

.purchase_block .purchase_btn .purchase_online a:hover {
    top: -1rem;
    -webkit-box-shadow: 0 12px 23px rgba(175, 187, 183, 0.75);
    box-shadow: 0 12px 23px rgba(175, 187, 183, 0.75);
    background: #ffffff;
    color: #495364;
}

.loop_wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    overflow: hidden;
    margin-top: 120px;
}

.loop_wrap .loop_wrap_text {
    color: #5b6473;
    font-size: 21.875rem;
    font-weight: 600;
    line-height: 1;
    white-space: nowrap;
    padding: 0 60px;
}

.loop_wrap .loop_wrap_text:nth-child(odd) {
    -webkit-animation: loop 60s -30s linear infinite;
    animation: loop 60s -30s linear infinite;
}

.loop_wrap .loop_wrap_text:nth-child(even) {
    -webkit-animation: loop2 60s linear infinite;
    animation: loop2 60s linear infinite;
}

@-webkit-keyframes loop {
    0% {
        -webkit-transform: translateX(100%);
        transform: translateX(100%);
    }

    to {
        -webkit-transform: translateX(-100%);
        transform: translateX(-100%);
    }
}

@keyframes loop {
    0% {
        -webkit-transform: translateX(100%);
        transform: translateX(100%);
    }

    to {
        -webkit-transform: translateX(-100%);
        transform: translateX(-100%);
    }
}

@-webkit-keyframes loop2 {
    0% {
        -webkit-transform: translateX(0);
        transform: translateX(0);
    }

    to {
        -webkit-transform: translateX(-200%);
        transform: translateX(-200%);
    }
}

@keyframes loop2 {
    0% {
        -webkit-transform: translateX(0);
        transform: translateX(0);
    }

    to {
        -webkit-transform: translateX(-200%);
        transform: translateX(-200%);
    }
}

.block-revealer__element {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #495364;
    pointer-events: none;
    opacity: 0;
}

.content_block_404 {
    position: relative;
    width: 100%;
    height: 100vh;
    padding: 240px 0 120px;
}

.content_block_404 .content_inner_404 {
    position: relative;
    max-width: 1920px;
    padding: 0 5vw;
    margin: 0 auto;
    height: 100%;
}

.content_block_404 .content_inner_404::after {
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "";
    aspect-ratio: 1/1;
    background: url(../image/circle-gradient.svg);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    width: min(100%, 800px);
    z-index: -1;
}

.content_block_404 .content_inner_404 .text_404 {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    white-space: nowrap;
}

.content_block_404 .content_inner_404 .text_404 h2 {
    font-size: 7.594rem;
    font-weight: 900;
    text-align: center;
    line-height: 0.315;
}

.content_block_404 .content_inner_404 .text_404 h2 .jp_ruby {
    color: #333333;
    font-size: 1.25rem;
    font-weight: 500;
}

.content_block_404 .content_inner_404 .text_404 h3 {
    font-size: 1.414rem;
    text-align: center;
    font-weight: 700;
}

.content_block_404 .content_inner_404 .text_404 p {
    text-align: center;
}

.mb0 {
    margin-bottom: 0 !important;
}

.mb10 {
    margin-bottom: 10px;
}

.mb15 {
    margin-bottom: 15px;
}

.mb20 {
    margin-bottom: 20px;
}

.mb25 {
    margin-bottom: 25px;
}

.mb30 {
    margin-bottom: 30px;
}

.mb35 {
    margin-bottom: 35px;
}

.mb40 {
    margin-bottom: 40px;
}

.mb45 {
    margin-bottom: 45px;
}

.mb50 {
    margin-bottom: 50px;
}

.mb55 {
    margin-bottom: 55px;
}

.mb60 {
    margin-bottom: 60px;
}

.mt20 {
    margin-top: 20px;
}

.mt30 {
    margin-top: 30px;
}

.mt40 {
    margin-top: 40px;
}

.pt10 {
    padding-top: 10px;
}

.md_pt10 {
    padding-top: 10px;
}

.pt15 {
    padding-top: 15px;
}

.pt20 {
    padding-top: 20px;
}

.pt25 {
    padding-top: 25px;
}

.pt30 {
    padding-top: 30px;
}

.pt35 {
    padding-top: 35px;
}

.pt40 {
    padding-top: 40px;
}

.pt45 {
    padding-top: 45px;
}

.pt50 {
    padding-top: 50px;
}

.pt55 {
    padding-top: 55px;
}

.pt60 {
    padding-top: 60px;
}

* {
    color: #333333;
    font-weight: 400;
}

p,
a,
li,
table {
    font-size: 16px;
}

p {
    text-align: justify;
    text-justify: inter-ideograph;
    line-height: 2;
    margin: 0;
}

h2 {
    font-size: 32px;
    margin: 0 0 40px;
    color: #333333;
    font-weight: bold;
}

h3 {
    margin: 0 0 20px;
    font-size: 23px;
    font-weight: bold;
}

h4 {
    font-size: 21px;
    font-weight: bold;
    margin-bottom: 10px;
}

.text_link {
    font-weight: bold;
    color: #6e51f5;
}

.fw {
    font-weight: bold;
}

.red_text {
    color: #f5735d;
}

.yellow_text {
    color: #f5c969;
}

.pink_text {
    color: #ef75c4;
}

.under_line {
    font-weight: bold;
    border-bottom: 1px dashed #333333;
}

.note,
.quote {
    margin-top: 10px;
    font-size: 13px;
}

.note a,
.quote a {
    font-size: 13px;
}

.note {
    position: relative;
}

.note::before {
    content: "※";
    left: 0;
    top: 0;
}

.note2,
.quote2 {
    margin-top: 10px;
    font-size: 20px;
}

.note2 a,
.quote2 a {
    font-size: 20px;
}

span.eng {
    font-size: 14px;
}

span.marker-bold {
    background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(0%, #F0F7FF));
    background: -webkit-linear-gradient(transparent 60%, #F0F7FF 0%);
    background: linear-gradient(transparent 60%, #F0F7FF 0%);
}

.align_c {
    text-align: center;
}

.align_l {
    text-align: left;
}

/* Slider */

.slick-slider {
    position: relative;
    display: block;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -ms-touch-action: pan-y;
    touch-action: pan-y;
    -webkit-tap-highlight-color: transparent;
}

.slick-list {
    position: relative;
    overflow: hidden;
    display: block;
    margin: 0;
    padding: 0;
}

.slick-list:focus {
    outline: none;
}

.slick-list.dragging {
    cursor: pointer;
    cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
}

.slick-track {
    position: relative;
    left: 0;
    top: 0;
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.slick-track:before,
.slick-track:after {
    content: "";
    display: table;
}

.slick-track:after {
    clear: both;
}

.slick-loading .slick-track {
    visibility: hidden;
}

.slick-slide {
    float: left;
    height: 100%;
    min-height: 1px;
    display: none;
}

[dir=rtl] .slick-slide {
    float: right;
}

.slick-slide img {
    display: block;
}

.slick-slide.slick-loading img {
    display: none;
}

.slick-slide.dragging img {
    pointer-events: none;
}

.slick-initialized .slick-slide {
    display: block;
}

.slick-loading .slick-slide {
    visibility: hidden;
}

.slick-vertical .slick-slide {
    display: block;
    height: auto;
    border: 1px solid transparent;
}

.slick-arrow.slick-hidden {
    display: none;
}

/* Slider */

.slick-loading .slick-list {
    background: #fff url("../image/ajax-loader.gif") center center no-repeat;
}

/* Icons */

@font-face {
    font-family: "slick";
    src: url("../font/slick.eot");
    src: url("../font/slick.eot") format("embedded-opentype"), url("../font/slick.woff") format("woff"), url("../font/slick.ttf") format("truetype"), url("../font/slick.svg") format("svg");
    font-weight: normal;
    font-style: normal;
}

/* Arrows */

.slick-prev,
.slick-next {
    position: absolute;
    display: block;
    height: 20px;
    width: 20px;
    line-height: 0px;
    font-size: 0px;
    cursor: pointer;
    background: transparent;
    color: transparent;
    top: 50%;
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    padding: 0;
    border: none;
    outline: none;
}

.slick-prev:hover,
.slick-prev:focus,
.slick-next:hover,
.slick-next:focus {
    outline: none;
    background: transparent;
    color: transparent;
}

.slick-prev:hover:before,
.slick-prev:focus:before,
.slick-next:hover:before,
.slick-next:focus:before {
    opacity: 1;
}

.slick-prev.slick-disabled:before,
.slick-next.slick-disabled:before {
    opacity: 0.25;
}

.slick-prev:before,
.slick-next:before {
    font-family: "slick";
    font-size: 20px;
    line-height: 1;
    color: white;
    opacity: 0.75;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.slick-prev {
    left: -25px;
}

[dir=rtl] .slick-prev {
    left: auto;
    right: -25px;
}

.slick-prev:before {
    content: "←";
}

[dir=rtl] .slick-prev:before {
    content: "→";
}

.slick-next {
    right: -25px;
}

[dir=rtl] .slick-next {
    left: -25px;
    right: auto;
}

.slick-next:before {
    content: "→";
}

[dir=rtl] .slick-next:before {
    content: "←";
}

/* Dots */

.slick-dotted.slick-slider {
    margin-bottom: 30px;
}

.slick-dots {
    position: absolute;
    bottom: -25px;
    list-style: none;
    display: block;
    text-align: center;
    padding: 0;
    margin: 0;
    width: 100%;
}

.slick-dots li {
    position: relative;
    display: inline-block;
    height: 20px;
    width: 20px;
    margin: 0 5px;
    padding: 0;
    cursor: pointer;
}

.slick-dots li button {
    border: 0;
    background: transparent;
    display: block;
    height: 20px;
    width: 20px;
    outline: none;
    line-height: 0px;
    font-size: 0px;
    color: transparent;
    padding: 5px;
    cursor: pointer;
}

.slick-dots li button:hover,
.slick-dots li button:focus {
    outline: none;
}

.slick-dots li button:hover:before,
.slick-dots li button:focus:before {
    opacity: 1;
}

.slick-dots li button:before {
    position: absolute;
    top: 0;
    left: 0;
    content: "•";
    width: 20px;
    height: 20px;
    font-family: "slick";
    font-size: 6px;
    line-height: 20px;
    text-align: center;
    color: black;
    opacity: 0.25;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.slick-dots li.slick-active button:before {
    color: black;
    opacity: 0.75;
}

.main_visual {
    position: relative;
    width: 100%;
    /* min-height: 100vh; */
    /* Fallback */
    /* min-height: calc(var(--vh, 1vh) * 100); */
}

.main_visual img {
    width: 100%;
}

.main_visual video {
    position: fixed;
    width: 100vw;
    height: 100vh;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center;
    object-position: center;
    font-family: "object-fit: cover; object-position: center;";
    z-index: -1;
}

.main_visual .main_visual_inner {
    width: 100%;
    height: 100%;
}

.main_visual .main_visual_inner .catch_copy_bg {
    position: absolute;
    bottom: calc(3.9vw + 80px);
    left: calc(0.9vw + 80px);
}

.main_visual .main_visual_inner .catch_copy {
    font-size: 5.653rem;
    letter-spacing: 0.25rem;
    color: #ffffff;
    margin: 0;
}

.main_visual .main_visual_inner .catch_copy_read {
    font-size: 1.414rem;
    font-weight: 700;
    color: #ffffff;
}

.main_visual .main_visual_inner .catch_copy_read span {
    font-size: 1.414rem;
    font-weight: 700;
    color: #ffffff;
}

.main_visual .main_visual_inner .catch_copy_btn a {
    display: block;
    position: relative;
    font-size: 1.414rem;
    color: #ffffff;
    border: 2px solid #FFFFFF;
    border-radius: 999px;
    width: 265px;
    text-align: center;
}

.main_visual .main_visual_inner .catch_copy_btn a::after {
    display: inline-block;
    content: '';
    background: url('../image/barrow.png');
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    color: #ffffff;
    margin-left: 20px;
    width: 12px;
    height: 11px;
    vertical-align: middle;
    margin-top: -5px;
}

.main_visual .main_visual_inner .catch_copy_btn a::before {
    position: absolute;
    bottom: 0px;
    left: 0;
    content: "";
    width: 100%;
    height: 1px;
    background: #ffffff;
    -webkit-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: left top;
    transform-origin: left top;
    -webkit-transition: -webkit-transform 0.3s;
    transition: -webkit-transform 0.3s;
    transition: transform 0.3s;
    transition: transform 0.3s, -webkit-transform 0.3s;
}

.main_visual .main_visual_inner .catch_copy_btn a:hover::before {
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
}

.concept_bg {
    position: relative;
}

.concept_bg::after {
    position: absolute;
    top: 60%;
    left: 80px;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "";
    aspect-ratio: 1/1;
    background: url(../image/circle-gradient.svg);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    width: min(100%, 800px);
    z-index: -1;
}

.concept_bg .concept_area {
    max-width: 1080px;
    padding: 0;
    margin: 0 auto;
}

.concept_bg .concept_area h2.concept span,
.concept_bg .concept_area h2.concept ruby {
    font-family: "Zen Old Mincho", "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif !important;
    font-size: 5.653rem;
    font-weight: 700;
    line-height: 1.5;
}

.concept_bg .concept_area h2.concept span rt,
.concept_bg .concept_area h2.concept ruby rt {
    display: none;
}

.concept_bg .concept_area h2.concept ruby[data-ruby] {
    position: relative;
}

.concept_bg .concept_area h2.concept ruby[data-ruby]::before {
    content: attr(data-ruby);
    position: absolute;
    top: -0.75rem;
    left: 0;
    right: -1rem;
    text-align: center;
    font-family: "Zen Old Mincho", "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif !important;
    font-size: 1.414rem;
    font-weight: 500;
    letter-spacing: 1rem;
}

.concept_bg .concept_area p.concept_read {
    margin-top: 100px;
    font-size: 1.5rem;
}

.top_info_block {
    margin-top: 120px;
}

.top_info_block .top_info_inner {
    width: 58.875vw;
    margin-left: auto;
}

.top_info_block .top_info_inner dl {
    position: relative;
    padding: 2.21rem 70px 2.21rem 0;
    border-bottom: 1px solid #495364;
    margin: 0;
}

.top_info_block .top_info_inner dl::before {
    position: absolute;
    bottom: -1px;
    left: 0;
    content: "";
    width: 100%;
    height: 2px;
    background: #495364;
    -webkit-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: left top;
    transform-origin: left top;
    -webkit-transition: -webkit-transform 0.6s;
    transition: -webkit-transform 0.6s;
    transition: transform 0.6s;
    transition: transform 0.6s, -webkit-transform 0.6s;
}

.top_info_block .top_info_inner dl::after {
    position: absolute;
    top: 50%;
    right: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    font-family: "fontello";
    content: "\e811";
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    color: #ffffff;
    width: 60px;
    height: 60px;
    background: #495364;
    border-radius: 50%;
    -webkit-box-shadow: 0 0 0 0 #495364;
    box-shadow: 0 0 0 0 #495364;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.top_info_block .top_info_inner dl:hover::before {
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
}

.top_info_block .top_info_inner dl:hover::after {
    -webkit-box-shadow: 0 0 0 5px #495364;
    box-shadow: 0 0 0 5px #495364;
}

.top_info_block .top_info_inner dl dt {
    margin-bottom: 1.125rem;
}

.top_info_block .top_info_inner dl dt span {
    display: inline-block;
    color: #495364;
    border: 1px solid #495364;
    font-size: 12px;
    font-weight: 500;
    padding: 2px 10px;
}

.top_info_block .top_info_inner dl dt time {
    font-size: 1rem;
    font-weight: 400;
    margin-left: 1.25rem;
}

.top_info_block .top_info_inner dl dd {
    font-weight: 400;
}

.carousel_slider .slick-slider {
    cursor: pointer;
}

.carousel_slider .slick-slider .slick-track {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.carousel_slider .slick-slider .slick-slide {
    margin-right: 10px;
}

.carousel_slider .slick-slider .slick-list {
    margin-right: -10px;
}

.carousel_slider .slick-slider .slick-prev {
    left: 25px;
    top: 47%;
    z-index: 9;
}

.carousel_slider .slick-slider .slick-prev::before {
    font-size: 40px;
    font-family: "fontello";
    content: "\e805";
    color: #ffffff;
    -webkit-filter: drop-shadow(2px 4px 6px rgba(115, 109, 78, 0.4));
    filter: drop-shadow(2px 4px 6px rgba(115, 109, 78, 0.4));
}

.carousel_slider .slick-slider .slick-next {
    right: 25px;
    top: 47%;
    z-index: 9;
}

.carousel_slider .slick-slider .slick-next::before {
    font-size: 40px;
    font-family: "fontello";
    content: "\e806";
    color: #ffffff;
    -webkit-filter: drop-shadow(2px 4px 6px rgba(115, 109, 78, 0.4));
    filter: drop-shadow(2px 4px 6px rgba(115, 109, 78, 0.4));
}

.galleryList {
    width: 100%;
}

.modal_item {
    cursor: pointer;
}

.modal_item img {
    border-radius: 1rem;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.modal_item img:hover {
    opacity: 0.8;
}

.modalBg {
    background-color: rgba(0, 0, 0, 0.8);
    display: none;
    height: 100%;
    left: 0;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 100;
}

.modalContent {
    display: none;
    height: 100%;
    left: 0;
    position: fixed;
    top: 0;
    bottom: 0;
    width: 100%;
    z-index: 101;
    cursor: pointer;
}

.modalImg {
    position: relative;
    max-width: 500px;
}

.modalImg img {
    border-radius: 1rem;
}

.modalImg .closeBtn {
    position: absolute;
    right: 0;
    top: 0;
    z-index: 103;
    border: 0;
    background: #F0F7FF;
    border-radius: 0 1rem 0 1rem;
    padding: 10px;
    cursor: pointer;
    outline: none;
}

.modalImg .closeBtn i {
    color: #495364;
    font-size: 20px;
    line-height: 1;
}

.promise_block {
    position: relative;
    padding-bottom: 120px;
}

.promise_block .promise_img {
    width: 37.5vw;
}

.promise_block .promise_img img {
    -webkit-box-shadow: 22px 24px 46px rgba(175, 187, 183, 0.75);
    box-shadow: 22px 24px 46px rgba(175, 187, 183, 0.75);
}

.promise_block .num_block {
    position: absolute;
    top: 0vw;
    right: 5vw;
    width: 12.5vw;
}

.promise_block .promise_title h3 {
    text-align: right;
}

.promise_block .promise_title .decoration .block-revealer__content {
    display: inline;
    font-size: 5.653rem;
    font-weight: 900;
    line-height: 1.75;
    color: #ffffff;
    background: #495364;
    padding: 0 30px;
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
    font-family: "Zen Old Mincho", "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif !important;
}

.promise_block .promise_title .decoration.top-1 {
    position: absolute;
    top: 12vw;
    right: 5vw;
    white-space: nowrap;
}

.promise_block .promise_title .decoration.top-2 {
    position: absolute;
    top: 12vw;
    right: 5vw;
    white-space: nowrap;
}

.promise_block .promise_title .decoration.top-3 {
    position: absolute;
    top: 12vw;
    right: 5vw;
    white-space: nowrap;
}

.promise_block .promise_title .decoration.top-4 {
    position: absolute;
    top: 12vw;
    right: 5vw;
    white-space: nowrap;
}

.promise_block .promise_title .decoration.top-5 {
    position: absolute;
    top: 12vw;
    right: 5vw;
    white-space: nowrap;
}

.promise_block .promise_title .decoration.top-6 {
    position: absolute;
    top: 12vw;
    right: 5vw;
    white-space: nowrap;
}

.promise_block .promise_title .decoration.bottom {
    position: absolute;
    top: calc(12vw + 10.126rem);
    right: 5vw;
    white-space: nowrap;
}

.promise_block .promise_text {
    position: absolute;
    top: calc(12vw + 10.126rem + 10.126rem);
    right: 5vw;
    max-width: 700px;
    width: 100%;
	
}



@media (max-width: 768px) { 
    .promise_block .promise_text {
        width: 60%; 
    }
}



.pick-up_block {
    margin-top: 120px;
}

.pick-up_block .pick-up_img img {
    -webkit-box-shadow: 22px 24px 46px rgba(175, 187, 183, 0.75);
    box-shadow: 22px 24px 46px rgba(175, 187, 183, 0.75);
}

.pick-up_block .pick-up_text h3 {
    font-size: 3.375rem;
    font-weight: 900;
    margin-bottom: 5%;
}

.pick-up_block .pick-up_text h3 span {
    font-size: 24px;
    font-weight: 900;
}

.pick-up_block .pick-up_text h4 {
    font-size: 1.414rem;
    font-weight: 700;
    color: #495364;
}

.enzyme_block {
    position: relative;
    padding-bottom: 120px;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.enzyme_block .enzyme_text {
    padding-left: 5vw;
    width: 52.25vw;
}

.enzyme_block .enzyme_text h3 {
    font-size: 3.375rem;
    font-weight: 900;
    color: #495364;
}

.enzyme_block .enzyme_img {
    margin-left: auto;
    width: 40.25vw;
}

.enzyme_block .enzyme_img img {
    -webkit-box-shadow: -22px 24px 46px rgba(175, 187, 183, 0.75);
    box-shadow: -22px 24px 46px rgba(175, 187, 183, 0.75);
}

.enzyme_trivia_bg {
    position: relative;
}

/*.enzyme_trivia_bg::after {
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "";
    aspect-ratio: 1/1;
    background: url(../image/circle-gradient.svg);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    width: min(100%, 800px);
    z-index: -1;
}*/

.visual_enzyme {
    height: 28.125vw;
    background-image: url('../Downloads/%27%27');
    background-attachment: fixed;
    background-size: cover;
    background-position: center;
}

.page_name h1 {
    color: #333333;
    font-size: 5.653rem;
    line-height: 0.5;
}

.page_name h1 .jp_ruby {
    color: #333333;
    font-size: 1.25rem;
    font-weight: 500;
}

.page_name_product h1 {
    color: #333333;
    font-size: 2.827rem;
    line-height: 1.25;
}

.page_name_product h1 .jp_ruby {
    color: #333333;
    font-size: 1.25rem;
    font-weight: 500;
}

.page_name_recipe h1 {
    color: #333333;
    font-size: 2.827rem;
    line-height: 1.25;
}

.page_name_recipe h1 .jp_ruby {
    color: #333333;
    font-size: 1.25rem;
    font-weight: 500;
}

.form_block {
    margin: 0 auto;
    width: 100%;
}

.form_block .form_row {
    padding-bottom: 1rem;
}

.form_block .form_row span {
    font-size: 0.833rem;
    line-height: 2;
}

.form_block .form_row:last-child {
    margin-bottom: 0;
}

.form_block .form_btn_wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: distribute;
    justify-content: space-around;
}

.form_block .form_btn {
    display: block;
    width: 300px;
    color: #ffffff;
    padding: 10px 0;
    border: none;
    border-radius: 50px;
    text-align: center;
    background: #333333;
    margin: 50px auto 0;
    text-decoration: none;
    cursor: pointer;
}

.form_block .form_btn:focus,
.form_block .form_btn:hover {
    opacity: 0.8;
}

.form_block .form_btn[value=back] {
    background-color: #ffffff;
    border: 1px solid #495364;
    color: #495364;
}

.form_block p {
    margin-bottom: 2rem;
    position: static;
}

.form_block p.form_item {
    font-weight: 500;
}

.form_block p.form_item.input {
    margin-bottom: 1rem;
}

.form_block input[type=text],
.form_block input[type=email],
.form_block select,
.form_block textarea {
    border: 1px solid #dddddd;
    border-radius: 3px;
    padding: 10px;
    width: 400px;
}

.form_block select {
    padding-right: 50px;
}

.form_block .mwform-radio-field {
    line-height: 1;
}

.form_block .mwform-radio-field label {
    display: block;
}

.form_block .mwform-radio-field label span {
    font-size: 1rem;
}

.form_block .required {
    background-color: #f5735d;
    color: #ffffff;
    font-size: 0.833rem;
    margin-left: 1rem;
    padding: 5px 10px;
    word-break: keep-all;
}

.form_block .any {
    background-color: #757575;
    color: #ffffff;
    font-size: 0.833rem;
    margin-left: 1rem;
    padding: 5px 10px;
    word-break: keep-all;
}

.form_block .input_long {
    width: 100%;
}

.mw_wp_form_input .input_none {
    display: none;
    speak: none;
}

.mw_wp_form_preview .preview_none {
    display: none;
    speak: none;
}

.mw_wp_form_preview .input_none {
    display: block;
    speak: normal;
}

.mwform-tel-field input[type=text] {
    display: inline-block;
}

.content_inner_btn a {
    background: #495364;
    color: #ffffff;
    font-size: 16px;
    font-weight: bold;
    width: 250px;
    height: 48px;
    margin: 0 auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    text-decoration: none;
}

.philosophy_area {
    max-width: 1080px;
    padding: 0;
    margin: 0 auto;
}

.philosophy_area h2.philosophy {
    font-size: 2.627rem;
    font-weight: 600;
    line-height: 1.5;
}

.philosophy_area p.concept_read {
    margin-top: 120px;
    font-size: 1.5rem;
}

.message_block {
    position: relative;
    padding-bottom: 120px;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.message_block .message_text {
    margin-left: auto;
    padding-right: 5vw;
    width: 52.25vw;
}

.message_block .message_text h3 {
    font-size: 2.827rem;
    font-weight: 600;
    color: #495364;
}

.message_block .message_text .signature img {
    width: min(75%, 441px);
    float: right;
}

.message_block .message_img {
    width: 40.25vw;
}

.message_block .message_img img {
    -webkit-box-shadow: 22px 24px 46px rgba(175, 187, 183, 0.75);
    box-shadow: 22px 24px 46px rgba(175, 187, 183, 0.75);
}

.content_inner_company {
    margin-top: 120px;
}

.content_inner_company table tr {
    padding-bottom: 1rem;
    border-bottom: 1px solid #495364;
    margin-bottom: 3%;
}

.content_inner_company .companyCon table tr {
    padding-bottom: 1rem;
    border-bottom: 1px solid #495364;
    display: block;
    margin-bottom: 3%;
}

.content_inner_company table tr td:nth-child(1) {
    font-weight: 700;
}

.content_inner_company .companyCon table tr td:nth-child(1) {
    font-weight: 700;
    display: block;
}

.content_inner_company table tr td:nth-child(2) {
    font-weight: 400;
    margin-bottom: 0;
}

.content_inner_company .companyCon table tr td:nth-child(2) {
    font-weight: 400;
    margin-bottom: 0;
    display: block;
}

.content_inner_company table tr td:nth-child(2) a {
    font-weight: 400;
    font-size: 16px;
}

.content_inner_company .companyCon table tr td:nth-child(2) a {
    font-weight: 400;
    font-size: 16px;
}

.content_inner_company .companyCon table {
    width: calc(100% / 2 - 1%);
    margin-right: 1%;
}

.content_inner_company .companyCon table:nth-child(2n+2) {
    margin-right: 0;
}

.l_contents_with_nav {
    margin-top: 120px;
}

.l_contents_with_nav .l_side_nav {
    position: sticky;
    top: 240px;
    left: 0;
}

.l_contents_with_nav .l_side_nav .category_group .category_name {
    font-size: 12px;
}

.l_contents_with_nav .l_side_nav .category_group .category_list {
    list-style: none;
}

.l_contents_with_nav .l_side_nav .category_group .category_list .category a {
    position: relative;
    padding-left: 1rem;
    font-size: 16px;
    font-weight: 700;
    color: #333333;
}

.l_contents_with_nav .l_side_nav .category_group .category_list .category a::before {
    position: absolute;
    bottom: -1px;
    left: 0;
    content: "";
    width: 100%;
    height: 1px;
    background: #495364;
    -webkit-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: left top;
    transform-origin: left top;
    -webkit-transition: -webkit-transform 0.3s;
    transition: -webkit-transform 0.3s;
    transition: transform 0.3s;
    transition: transform 0.3s, -webkit-transform 0.3s;
}

.l_contents_with_nav .l_side_nav .category_group .category_list .category a::after {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    width: 0.5rem;
    height: 1px;
    background: #495364;
}

.l_contents_with_nav .l_side_nav .category_group .category_list .category a:hover::before {
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
}

.l_contents_with_nav .l_side_nav .category_group .category_list .category a span {
    display: inline-block;
    font-size: 16px;
    font-weight: 700;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner {
    margin-bottom: 10vw;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner:last-of-type {
    margin-bottom: 0;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner .l_main_contents_name {
    font-size: 2.827rem;
    line-height: 1.5;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner .prefecture_name {
    font-size: 18px;
    font-weight: 700;
    text-align: center;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner .shop_name {
    font-size: 1rem;
    font-weight: 500;
    color: #ffffff;
    background: #495364;
    border: 2px solid #495364;
    padding: 0.5vw 1vw;
    text-align: center;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner .shop_name a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    font-size: 1rem;
    font-weight: 500;
    color: #ffffff;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner .shop_name a::after {
    font-family: "fontello";
    content: "\f08e";
    margin-left: 10px;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner .shop_name.-link:hover {
    background: #ffffff;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner .shop_name.-link:hover a {
    color: #495364;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner dl {
    padding-bottom: 1rem;
    border-bottom: 1px solid #495364;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner dl dt {
    font-weight: 700;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner dl dd {
    font-weight: 400;
    margin-bottom: 0;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner dl dd a {
    font-weight: 400;
    font-size: 16px;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner dl .data_map {
    display: block;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner dl .data_map a {
    color: #6e51f5;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner dl .data_map a::after {
    font-family: "fontello";
    content: "\f08e";
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner .l_main_contents_box {
    position: relative;
    top: 0;
    width: 100%;
    padding: 3vw 1vw;
    border: 2px solid #495364;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner .l_main_contents_box:hover {
    top: -1rem;
    -webkit-box-shadow: 0 12px 23px rgba(175, 187, 183, 0.75);
    box-shadow: 0 12px 23px rgba(175, 187, 183, 0.75);
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner .l_main_contents_box:hover h3 {
    color: #ffffff;
    border-color: #ffffff;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner .l_main_contents_box:hover p {
    color: #ffffff;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner .l_main_contents_box h3 {
    color: #ffffff;
    font-size: 1.414rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid #ffffff;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner .l_main_contents_box p {
    color: #ffffff;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner .l_main_contents_box.-superohtaka {
    background: url(../image/product_tmb1.webp);
    background-position: center;
    background-size: cover;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner .l_main_contents_box.-helaluno {
    background: url(../image/product_tmb2.webp);
    background-position: center;
    background-size: cover;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner .l_main_contents_box.-gel {
    background: url(../image/product_tmb3.webp);
    background-position: center;
    background-size: cover;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner .l_main_contents_box.-food-beverage {
    background: url(../image/product_tmb4.webp);
    background-position: center;
    background-size: cover;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner .l_main_contents_box.-cosmetics {
    background: url(../image/product_tmb5.webp);
    background-position: center;
    background-size: cover;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner .l_main_contents_box.-hair-care {
    background: url(../image/product_tmb6.webp);
    background-position: center;
    background-size: cover;
}

.l_contents_with_nav .l_main_contents .l_main_contents_inner .l_main_contents_box.-other {
    background: url(../image/product_tmb7.webp);
    background-position: center;
    background-size: cover;
}

.cosmetics_banner {
    width: 60%;
    margin: 0 auto;
}

.about_product_area {
    max-width: 1080px;
    padding: 0;
    margin: 0 auto;
}

.about_product_area h2.about_product {
    font-size: 2.827rem;
    font-weight: 600;
    line-height: 1.5;
}

.about_product_area .about_product_img {
    width: 60%;
    margin: 90px auto 0;
}

.about_product_area h3 {
    font-size: 1.414rem;
    font-weight: 600;
    color: #495364;
}

.feature_block {
    margin-top: 120px;
}

.feature_block .feature_img img {
    -webkit-box-shadow: 22px 24px 46px rgba(175, 187, 183, 0.75);
    box-shadow: 22px 24px 46px rgba(175, 187, 183, 0.75);
}

.feature_block .feature_text h3 {
    font-size: 2.827rem;
    font-weight: 900;
    color: #495364;
}

.how-to-use_block {
    margin-top: 120px;
}

.how-to-use_block h3 {
    font-size: 1.999rem;
    font-weight: 900;
    color: #495364;
}

.how-to-use_block h3 span {
    font-size: 1rem;
    font-weight: 900;
    color: #495364;
}

.how-to-use_block h4 {
    font-size: 1.25rem;
    font-weight: 900;
    text-align: center;
}

.how-to-use_block img {
    margin-top: 1.5rem;
}

.product_faq_bg {
    position: relative;
}

.product_faq_bg::after {
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "";
    aspect-ratio: 1/1;
    background: url(../image/circle-gradient.svg);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    width: min(100%, 800px);
    z-index: -1;
}

.clickable_map a {
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.clickable_map a:hover {
    opacity: 0.8;
}

.fasting_block {
    position: relative;
    padding-bottom: 120px;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.fasting_block .fasting_text {
    margin-left: auto;
    padding-right: 5vw;
    width: 52.25vw;
}

.fasting_block .fasting_text .fasting_check li {
    font-size: 1.414rem;
    font-weight: 500;
}

.fasting_block .fasting_text .fasting_check li:before {
    content: "";
    background: url(../image/icon_check.svg);
    background-position: center;
    background-repeat: no-repeat;
    display: inline-block;
    width: 26px;
    height: 26px;
    margin-right: 10px;
    vertical-align: sub;
}

.fasting_block .fasting_img {
    width: 40.25vw;
}

.fasting_block .fasting_img img {
    -webkit-box-shadow: 22px 24px 46px rgba(175, 187, 183, 0.75);
    box-shadow: 22px 24px 46px rgba(175, 187, 183, 0.75);
}

.method .methodBox {
    margin-bottom: 90px;
}

.method .methodBox .calculation .calInner .ttlArea {
    background: #495364;
    padding: 3vw;
}

.method .methodBox .calculation .calInner .ttlArea h3 {
    color: #ffffff;
    font-size: 1.999rem;
    font-weight: 700;
    text-align: center;
}

.method .methodBox .calculation .calInner .ttlArea h3 small {
    color: #ffffff;
    font-weight: 700;
}

.method .methodBox .calculation .calInner .ttlArea p {
    color: #ffffff;
    text-align: center;
}

.method .methodBox .calculation .calInner .practiceArea {
    background: #F0F7FF;
    text-align: center;
    padding: 3vw 6vw;
}

.method .methodBox .calculation .calInner .practiceArea .item,
.method .methodBox .calculation .calInner .practiceArea .resultArea {
    padding: 3vw 2.5vw;
    background: #ffffff;
    margin-bottom: 3vw;
}

.method .methodBox .calculation .calInner .practiceArea .item dl,
.method .methodBox .calculation .calInner .practiceArea .resultArea dl {
    text-align: left;
    margin-bottom: 0;
}

.method .methodBox .calculation .calInner .practiceArea .item dl dt,
.method .methodBox .calculation .calInner .practiceArea .resultArea dl dt {
    font-size: 1.414rem;
    color: #495364;
    text-align: left;
}

.method .methodBox .calculation .calInner .practiceArea .item dl dd,
.method .methodBox .calculation .calInner .practiceArea .resultArea dl dd {
    margin-bottom: 0;
}

.method .methodBox .calculation .calInner .practiceArea .item dl dd span,
.method .methodBox .calculation .calInner .practiceArea .resultArea dl dd span {
    font-size: 1.414rem;
    font-weight: 500;
}

.method .methodBox .calculation .calInner .practiceArea .item p,
.method .methodBox .calculation .calInner .practiceArea .resultArea p {
    font-size: 1.414rem;
    font-weight: 500;
    text-align: center;
}

.method .methodBox .calculation .calInner .practiceArea .item .resultDetail,
.method .methodBox .calculation .calInner .practiceArea .resultArea .resultDetail {
    display: table;
    margin: 0 auto;
}

.method .methodBox .calculation .calInner .practiceArea .item .resultDetail p,
.method .methodBox .calculation .calInner .practiceArea .resultArea .resultDetail p {
    display: table-cell;
    padding: 0 1vw;
}

.method .methodBox .calculation .calInner .practiceArea .item .resultDetail div,
.method .methodBox .calculation .calInner .practiceArea .resultArea .resultDetail div {
    font-size: 2.827rem;
    font-weight: 700;
    background: #F0F7FF;
    border: 1px solid #495364;
    min-width: 10rem;
}

.method .methodBox .calculation .calInner .practiceArea .item .choice,
.method .methodBox .calculation .calInner .practiceArea .resultArea .choice {
    display: inline-block;
    width: inherit;
    padding-right: 2.5rem;
}

.method .methodBox .calculation .calInner .practiceArea .item .choice input[type=radio],
.method .methodBox .calculation .calInner .practiceArea .item .choice input[type=checkbox],
.method .methodBox .calculation .calInner .practiceArea .resultArea .choice input[type=radio],
.method .methodBox .calculation .calInner .practiceArea .resultArea .choice input[type=checkbox] {
    display: none;
}

.method .methodBox .calculation .calInner .practiceArea .item .choice .radio,
.method .methodBox .calculation .calInner .practiceArea .item .choice .checkbox,
.method .methodBox .calculation .calInner .practiceArea .resultArea .choice .radio,
.method .methodBox .calculation .calInner .practiceArea .resultArea .choice .checkbox {
    position: relative;
    display: inline-block;
    font-size: 1.414rem;
    font-weight: 500;
    margin: 0;
    padding-left: 2.5rem;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    vertical-align: middle;
    cursor: pointer;
}

.method .methodBox .calculation .calInner .practiceArea .item .choice .radio:before,
.method .methodBox .calculation .calInner .practiceArea .resultArea .choice .radio:before {
    position: absolute;
    top: 50%;
    left: 5px;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "";
    display: block;
    background-color: #495364;
    border-radius: 50%;
    width: 18px;
    height: 18px;
    transition: opacity 0.2s linear;
    -webkit-transition: opacity 0.2s linear;
    opacity: 0;
}

.method .methodBox .calculation .calInner .practiceArea .item .choice .radio:after,
.method .methodBox .calculation .calInner .practiceArea .resultArea .choice .radio:after {
    position: absolute;
    top: 50%;
    left: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "";
    display: block;
    border: 1px solid #333333;
    border-radius: 50%;
    width: 28px;
    height: 28px;
    transition: border-color 0.2s linear;
    -webkit-transition: border-color 0.2s linear;
}

.method .methodBox .calculation .calInner .practiceArea .item .choice input[type=radio]:checked+.radio::before,
.method .methodBox .calculation .calInner .practiceArea .resultArea .choice input[type=radio]:checked+.radio::before {
    opacity: 1;
}

.method .methodBox .calculation .calInner .practiceArea .item .error,
.method .methodBox .calculation .calInner .practiceArea .resultArea .error {
    display: block;
    font-size: 14px;
    text-align: left;
    color: #f5735d;
    padding: 0.5rem 0;
}

.method .methodBox .calculation .calInner .practiceArea .item.spec dl dd input[type=text] {
    font-size: 1.414rem;
    font-weight: 500;
    text-align: center;
    border: 1px solid #333333;
    margin-right: 0.5rem;
}

.method .methodBox .calculation .calInner .practiceArea .btnArea input[type=button] {
    padding: 2vw 1.5vw;
    display: inline-block;
    width: 100%;
    background: #ffffff;
    border: 2px solid #495364;
    color: #495364;
    font-size: 1.999rem;
    font-weight: 700;
    text-align: center;
    margin-bottom: 3vw;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.method .methodBox .calculation .calInner .practiceArea .btnArea input[type=button]:hover {
    background: #495364;
    color: #ffffff;
}

.method .methodBox .daily h3 {
    font-size: 1.999rem;
}

.method .methodBox .daily h3 span {
    font-size: 1.999rem;
    font-weight: 700;
}

.method .methodBox .daily p {
    font-size: 18px;
    font-weight: 500;
}

.method .methodBox .daily p span {
    font-size: 1.414rem;
    font-weight: 700;
}

.method .methodBox .point h3 {
    font-size: 1.999rem;
    text-align: center;
}

.method .methodBox .point h4 {
    font-size: 1.999rem;
    text-align: center;
    color: #495364;
}

.method .methodBox .point:nth-child(2) {
    background: #F0F7FF;
    padding: 3vw 6vw;
}

.method .methodBox .point:nth-child(2) li::marker {
    font-size: 1.999rem;
    font-weight: 700;
    color: #495364;
}

.method .methodBox .after_fasting h3 {
    font-size: 1.999rem;
    text-align: center;
}

.method .methodBox .after_fasting h4 {
    text-align: center;
}

.method .methodBox .after_fasting h4 span {
    font-size: 1.414rem;
    font-weight: 700;
}

.method .methodBox .after_fasting .fasting_img {
    width: 75%;
    margin: 0 auto;
}

.method .methodBox .after_fasting .btn_fasting {
    width: 75%;
    margin: 0 auto;
}

.method .methodBox .after_fasting .btn_fasting a {
    padding: 2vw 1.5vw;
    display: inline-block;
    width: 100%;
    background: #ffffff;
    border: 2px solid #495364;
    color: #495364;
    font-size: 1.414rem;
    font-weight: 700;
    text-align: center;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.method .methodBox .after_fasting .btn_fasting a::after {
    font-family: "fontello";
    content: "\f08e";
    margin-left: 10px;
}

.method .methodBox .after_fasting .btn_fasting a:hover {
    background: #495364;
    color: #ffffff;
}

.fasting_arrow {
    position: relative;
    font-size: 24px;
    color: #495364;
    text-align: center;
    background: #ffffff;
    border-bottom: 2px solid #495364;
    margin-top: 90px;
}

.fasting_arrow::before {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -43px;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    border: 22px solid transparent;
    border-top: 22px solid #ffffff;
    z-index: 2;
}

.fasting_arrow::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -24px;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    border: 24px solid transparent;
    border-top-color: #495364;
    border-bottom-width: 0;
    z-index: 1;
}

.posts_content_block {
    position: relative;
    width: 100%;
    padding: 120px 0;
}

.posts_content_block .posts_content_inner {
    position: relative;
    max-width: 1920px;
    padding: 0 5vw;
    margin: 0 auto;
}

.posts_content_block .posts_content_inner h1 {
    color: #333333;
    font-size: 5.653rem;
    line-height: 0.5;
}

.posts_content_block .posts_content_inner h1 .jp_ruby {
    color: #333333;
    font-size: 1.25rem;
    font-weight: 500;
}

.posts_breadcrumb_block {
    max-width: 1920px;
    margin: 0 auto;
    padding: 1rem 0;
}

.posts_breadcrumb_block ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.posts_breadcrumb_block ul li,
.posts_breadcrumb_block ul a,
.posts_breadcrumb_block ul li,
.posts_breadcrumb_block ul span {
    color: #333333;
    font-size: 13px;
}

.posts_breadcrumb_block ul li {
    padding-right: 30px;
    position: relative;
}

.posts_breadcrumb_block ul li::before {
    font-family: "fontello";
    content: "\f105";
    position: absolute;
    right: 10px;
}

.posts_breadcrumb_block ul li:last-of-type::before {
    content: "";
}

.pg_wrapper {
    max-width: 1000px;
    margin: 0 auto;
}

.pg_title {
    font-size: 30px;
    margin: 0 0 50px;
    color: #495364;
    text-align: center;
}

.pg_contents {
    background-color: #ffffff;
    padding: 50px;
    max-width: 1000px;
    margin: 0 auto;
}

.posts_item_list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.posts_item_list .posts_item a {
    display: block;
}

.posts_item {
    margin-bottom: 2rem;
    padding-bottom: 2rem;
    border-bottom: 1px solid #495364;
}

.posts_item:last-of-type {
    margin-bottom: 0;
}

.posts_tmb {
    margin: 0;
}

.posts_tmb img {
    -webkit-box-shadow: 1px 1px 3px #dddddd;
    box-shadow: 1px 1px 3px #dddddd;
    border-radius: 0.25rem;
    height: 180px;
    max-width: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center;
    object-position: center;
    font-family: "object-fit: cover; object-position: center;";
    width: 320px;
}

.posts_date {
    color: #495364;
    display: inline-block;
    margin-bottom: 5px;
    font-size: 13px;
}

.posts_title {
    font-size: 16px;
    line-height: 2;
    margin: 0 0 10px;
}

.posts_cat span {
    border: 1px solid;
    color: #495364;
    font-size: 12px;
    margin-right: 5px;
    padding: 2px 5px;
}

.posts_item {
    margin-bottom: 2rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid #495364;
}

.posts_item figure.blog_tmb {
    overflow: hidden;
    width: 100%;
    height: 232px;
}

.posts_item figure.blog_tmb img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center;
    object-position: center;
    font-family: "object-fit: cover; object-position: center;";
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
}

.posts_item:hover img {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
}

.wp-block-image {
    margin: 0 0 2em 0;
}

.wp-block-image img {
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center;
    object-position: center;
    font-family: "object-fit: cover; object-position: center;";
}

.wp-block-buttons {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.wp-block-button__link {
    display: block;
    width: 300px;
    font-size: 14px !important;
    padding: 10px 0;
    border-radius: 50px;
    text-align: center;
    margin: 20px auto;
    text-decoration: none;
}

.post_content_block {
    width: 100%;
    padding: 120px 0;
}

.post_content_block .post_content_inner {
    position: relative;
    max-width: 58.875vw;
    margin: 0 auto;
}

.post_content_block .post_content_inner dl dt {
    margin-bottom: 1.125rem;
}

.post_content_block .post_content_inner dl dt span {
    display: inline-block;
    color: #495364;
    border: 1px solid #495364;
    font-size: 12px;
    font-weight: 500;
    padding: 2px 10px;
}

.post_content_block .post_content_inner dl dt time {
    font-size: 1rem;
    font-weight: 400;
    margin-left: 1.25rem;
}

.post_content_block .post_content_inner dl dd {
    font-size: 1.999rem;
    font-weight: 700;
}

.post_content_block .post_content_inner .posts_content figure:not(.wp-block-table) {
    overflow: hidden;
    max-width: 58.875vw;
    aspect-ratio: 16/9;
    margin: 3rem auto;
}

.post_content_block .post_content_inner .posts_content figure:not(.wp-block-table) img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center;
    object-position: center;
    font-family: "object-fit: cover; object-position: center;";
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
}

.post_content_block .post_content_inner .posts_content figure.wp-block-table {
    white-space: nowrap;
}

.post_content_block .post_content_inner .posts_content p {
    margin-top: 1rem;
}

.post_breadcrumb_block {
    max-width: 1920px;
    margin: 0 auto;
    padding: 1rem 0;
}

.post_breadcrumb_block ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.post_breadcrumb_block ul li,
.post_breadcrumb_block ul a,
.post_breadcrumb_block ul li,
.post_breadcrumb_block ul span {
    color: #333333;
    font-size: 13px;
}

.post_breadcrumb_block ul li {
    padding-right: 30px;
    position: relative;
}

.post_breadcrumb_block ul li::before {
    font-family: "fontello";
    content: "\f105";
    position: absolute;
    right: 10px;
}

.post_breadcrumb_block ul li:last-of-type::before {
    content: "";
}

.tabs .tab_item {
    display: block;
    width: 20%;
    height: 50px;
    font-size: 1rem;
    font-weight: 500;
    color: #495364;
    text-align: center;
    line-height: 50px;
    border: 1px solid #495364;
    border-width: 2px 1px 2px 1px;
    float: left;
}

.tabs .tab_item.-left {
    border-left-width: 2px;
}

.tabs .tab_item.-right {
    border-right-width: 2px;
}

.tabs input[name=tab_item] {
    display: none;
}

.tabs .tab_content {
    display: none;
    clear: both;
}

.tabs #topics:checked~#topics_content,
.tabs #news:checked~#news_content,
.tabs #event:checked~#event_content,
.tabs #media:checked~#media_content,
.tabs #column:checked~#column_content,
.tabs #pick-up:checked~#pick-up_content,
.tabs #food-beverage:checked~#food-beverage_content,
.tabs #cosmetics:checked~#cosmetics_content,
.tabs #hair-care:checked~#hair-care_content,
.tabs #other:checked~#other_content {
    display: block;
}

.tabs input:checked+.tab_item {
    background: #495364;
    color: #ffffff;
}

.tabs.posts_categories {
    margin-top: 80px;
}

.tabs.posts_categories .tab_item {
    width: 20%;
}

.tabs.posts_categories .tab_content dl {
    position: relative;
    padding: 2.21rem 70px 2.21rem 0;
    border-bottom: 1px solid #495364;
    margin: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.tabs.posts_categories .tab_content dl::before {
    position: absolute;
    bottom: -1px;
    left: 0;
    content: "";
    width: 100%;
    height: 2px;
    background: #495364;
    -webkit-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: left top;
    transform-origin: left top;
    -webkit-transition: -webkit-transform 0.6s;
    transition: -webkit-transform 0.6s;
    transition: transform 0.6s;
    transition: transform 0.6s, -webkit-transform 0.6s;
}

.tabs.posts_categories .tab_content dl::after {
    position: absolute;
    top: 50%;
    right: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    font-family: "fontello";
    content: "\e811";
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    color: #ffffff;
    width: 60px;
    height: 60px;
    background: #495364;
    border-radius: 50%;
    -webkit-box-shadow: 0 0 0 0 #495364;
    box-shadow: 0 0 0 0 #495364;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.tabs.posts_categories .tab_content dl:hover::before {
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
}

.tabs.posts_categories .tab_content dl:hover::after {
    -webkit-box-shadow: 0 0 0 5px #495364;
    box-shadow: 0 0 0 5px #495364;
}

.tabs.posts_categories .tab_content dl dt span {
    display: inline-block;
    color: #495364;
    border: 1px solid #495364;
    font-size: 12px;
    font-weight: 500;
    padding: 2px 10px;
}

.tabs.posts_categories .tab_content dl dt time {
    font-size: 1rem;
    font-weight: 400;
    margin-left: 1.25rem;
}

.tabs.posts_categories .tab_content dl dd {
    margin-bottom: 0;
    margin-left: 1.25rem;
}

.product_block .content_inner .product_img_block {
    position: sticky;
    top: calc(120px + 3rem);
    left: 0;
}

.product_block .content_inner .product_img_block .product_img img {
    -webkit-box-shadow: 22px 24px 46px rgba(175, 187, 183, 0.75);
    box-shadow: 22px 24px 46px rgba(175, 187, 183, 0.75);
}

.product_block .content_inner h2.product_title {
    font-size: 1.999rem;
    color: #495364;
    line-height: 1.4;
}

.product_block .content_inner .product_price p {
    font-size: 1.999rem;
    font-weight: 700;
    text-align: end;
}

.product_block .content_inner .product_price p span {
    font-size: 1rem;
    font-weight: 500;
}

.recipe_block .content_inner .recipe_img_block {
    position: sticky;
    top: calc(120px + 3rem);
    left: 0;
}

.recipe_block .content_inner .recipe_img_block .recipe_img img {
    -webkit-box-shadow: 22px 24px 46px rgba(175, 187, 183, 0.75);
    box-shadow: 22px 24px 46px rgba(175, 187, 183, 0.75);
}

.recipe_block .content_inner h2 {
    font-size: 2.827rem;
    color: #495364;
    line-height: 1.4;
}

.recipe_block .content_inner h2 span {
    font-size: 1rem;
    color: #495364;
    font-weight: 500;
}

.petBox {
    margin-top: 90px;
}

.petBox .pet_banner h3 {
    font-size: 2.827rem;
    text-align: center;
}

.petBox .pet_banner .pet_img {
    width: 75%;
    margin: 0 auto;
}

.petBox .pet_desc h3 {
    font-size: 1.999rem;
    color: #495364;
    text-align: center;
}

.petBox .pet_desc p {
    font-size: 1.414rem;
    font-weight: 500;
    text-align: center;
}

.petBox .pet_desc .pet_img {
    width: 75%;
    margin: 0 auto;
}

.petBox .pet_oem {
    background: #F0F7FF;
    padding: 3vw 6vw;
}

.petBox .pet_oem h3 {
    font-size: 1.414rem;
    color: #495364;
    text-align: center;
}

.petBox .pet_oem p {
    text-align: center;
}

.petBox .pet_oem .btn_pet {
    width: 75%;
    margin: 0 auto;
}

.petBox .pet_oem .btn_pet a {
    padding: 2vw 1.5vw;
    display: inline-block;
    width: 100%;
    background: #ffffff;
    border: 2px solid #495364;
    color: #495364;
    font-size: 1.414rem;
    font-weight: 700;
    text-align: center;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.petBox .pet_oem .btn_pet a::after {
    font-family: "fontello";
    content: "\f08e";
    margin-left: 10px;
}

.petBox .pet_oem .btn_pet a:hover {
    background: #495364;
    color: #ffffff;
}

.petBox .pet_oem .btn_pet02 .pet_mail a {
    padding: 2vw 1.5vw;
    display: inline-block;
    width: 100%;
    background: #ffffff;
    border: 2px solid #495364;
    color: #495364;
    font-size: 2.25rem;
    font-weight: 700;
    text-align: center;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.petBox .pet_oem .btn_pet02 .pet_mail a::before {
    font-family: "fontello";
    content: "\e801";
    margin-right: 10px;
}

.petBox .pet_oem .btn_pet02 .pet_mail a:hover {
    background: #495364;
    color: #ffffff;
}

.petBox .pet_oem .btn_pet02 .pet_tel a {
    padding: 2vw 1.5vw;
    display: inline-block;
    width: 100%;
    background: #495364;
    border: 2px solid #495364;
    color: #ffffff;
    font-size: 2.25rem;
    font-weight: 700;
    text-align: center;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.petBox .pet_oem .btn_pet02 .pet_tel a::before {
    font-family: "fontello";
    content: "\e800";
    margin-right: 10px;
}

.petBox .pet_oem .btn_pet02 .pet_tel a:hover {
    background: #ffffff;
    color: #495364;
}

.petBox .pet_oem .btn_pet02 .pet_tel a span {
    display: block;
}

.petBox .pet_oem .pet_maker {
    border: 2px solid #495364;
    padding: 2vw 1.5vw;
}

.petBox .pet_oem .pet_maker h3 {
    font-size: 1.414rem;
    text-align: center;
}

.petBox .pet_oem .pet_maker p {
    text-align: center;
}

.petBox .pet_feature .feature_img img {
    -webkit-box-shadow: 22px 24px 46px rgba(175, 187, 183, 0.75);
    box-shadow: 22px 24px 46px rgba(175, 187, 183, 0.75);
}

.petBox .pet_feature .feature_text h3 {
    font-size: 2.827rem;
    font-weight: 900;
    color: #495364;
}

.petBox .pet_feature .feature_text p span a {
    font-size: 1rem;
}

.petBox .pet_feature .feature_text p span a::after {
    font-family: "fontello";
    content: "\f08e";
    margin-left: 5px;
}

@media screen and (min-width: 1200px) {
    #drawer {
        display: none;
    }

    #drawer .menu {
        display: none;
    }

    .pagetop_block .contact_sp {
        display: none !important;
    }

    .pagetop_block .contact_sp2 {
        display: none !important;
    }

    a[href*="tel:"] {
        pointer-events: none;
        cursor: default;
        text-decoration: none;
        color: #333333;
    }

    .lg_none {
        display: none;
    }
}

@media screen and (min-width: 1440px) {
    .content_inner {
        padding: 0 10vw;
    }

    footer .footer_inner {
        padding: 0 10vw;
    }

    .content_block_404 .content_inner_404 {
        padding: 0 10vw;
    }

    .promise_block .num_block {
        right: 10vw;
    }

    .promise_block .promise_title .decoration.top-1 {
        right: 10vw;
    }

    .promise_block .promise_title .decoration.top-2 {
        right: 10vw;
    }

    .promise_block .promise_title .decoration.top-3 {
        right: 10vw;
    }

    .promise_block .promise_title .decoration.top-4 {
        right: 10vw;
    }

    .promise_block .promise_title .decoration.top-5 {
        right: 10vw;
    }

    .promise_block .promise_title .decoration.top-6 {
        right: 10vw;
    }

    .promise_block .promise_title .decoration.bottom {
        right: 10vw;
    }

    .enzyme_block .enzyme_text {
        padding-left: 10vw;
    }

    .message_block .message_text {
        padding-right: 10vw;
    }

    .fasting_block .fasting_text {
        padding-right: 10vw;
    }

    .posts_content_block .posts_content_inner {
        padding: 0 10vw;
    }
}

@media screen and (max-width: 767px) {
    html {
        -webkit-overflow-scrolling: touch;
    }

    .contents_wrapper {
        overflow: hidden;
    }

    .content_block {
        width: 100%;
        padding: 60px 0;
    }

    .content_inner {
        width: 90%;
        margin: 0 auto;
        padding: 0;
    }

    .content_inner .inner_section_block {
        margin-top: 30px;
    }

    .content_inner .inner_section_block2 {
        margin-top: 60px;
    }

    .content_inner h2 {
        font-size: 2.4rem;
        line-height: 1;
		
    }

    .content_inner h2 .jp_ruby {
        font-size: 14px;
    }

    .content_inner.-privacy h2 {
        font-size: 1.414rem;
    }

    .content_inner.-privacy h3 {
        font-size: 1rem !important;
    }

    header .header_pc {
        height: 60px;
    }

    header .header_pc .header_logo {
        width: 120px;
        margin: 0 auto;
    }

    header .header_pc .header_item {
        display: none;
    }

    .header_bg.change-color {
        background: #495364;
        -webkit-box-shadow: 0 2px 11.5px rgba(175, 187, 183, 0.75);
        box-shadow: 0 2px 11.5px rgba(175, 187, 183, 0.75);
    }

    #drawer .open {
        width: 60px;
        height: 60px;
    }

    #drawer .open span {
        width: 28px;
        height: 2px;
    }

    #drawer .open span:nth-of-type(1) {
        -webkit-transform: translate(-50%, calc(-50% - 8px));
        transform: translate(-50%, calc(-50% - 8px));
    }

    #drawer .open span:nth-of-type(3) {
        -webkit-transform: translate(-50%, calc(-50% + 8px));
        transform: translate(-50%, calc(-50% + 8px));
    }

    #drawer .open span:nth-of-type(3)::after {
        top: calc(50% + 12px);
        font-size: 11px;
    }

    #drawer #navTgl:checked+.open span:nth-of-type(3)::after {
        -webkit-transform: translate(calc(-50% + 14px), calc(-50% + 2px)) rotate(-45deg);
        transform: translate(calc(-50% + 14px), calc(-50% + 2px)) rotate(-45deg);
    }

    #drawer .menu {
        width: 90%;
        padding: 60px 20px;
    }

    #drawer .menu h2,
    #drawer .menu a {
        font-size: 16px;
    }

    .sp_menu .header_nav_block ul li a .nav_ruby {
        font-size: 12px;
        padding-left: 12px;
    }

    .sp_menu .header_nav_block ul li a:hover {
        background: none;
    }

    .sp_menu .header_nav_block ul li .parent_menu_ttl {
        padding: 5px 10px;
    }

    .sp_menu .header_nav_block ul li ul li .child_menu_ttl {
        padding: 5px 10px;
    }

    .sp_menu .header_nav_block ul li ul li .child_menu_ttl .mega_ruby {
        font-size: 12px;
        padding-left: 12px;
    }

    footer .footer_inner {
        width: 90%;
        margin: 0 auto;
        padding: 0;
    }

    footer .footer_inner .footer_logo {
        margin-bottom: 30px;
    }

    footer .footer_inner .footer_logo img {
        width: 180px;
    }

    footer .footer_nav ul {
        margin-top: 1.5rem;
        padding-left: 0;
    }

    footer .copy {
        margin-top: 30px;
        margin-bottom: 30px;
        text-align: center;
    }

    .pagetop_block {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        bottom: 0;
        right: 0;
        left: 0;
    }

    .pagetop_block .contact_sp a {
        opacity: 1 !important;
    }

    .pagetop_block .contact_sp2 a {
        opacity: 1 !important;
    }

    .pagetop_block #pagetop {
        width: 20%;
        height: 60px;
    }

    .pagetop_block #pagetop a {
        opacity: 1 !important;
        border-radius: 0% !important;
        border-left: none;
    }

    .breadcrumb_block {
        width: 100%;
    }

    .breadcrumb_block ul {
        -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
        overflow-x: scroll;
    }

    .breadcrumb_block ul li {
        white-space: nowrap;
    }

    .form_item_button {
        margin-top: 24px;
    }

    .form_item_button input {
        width: 80%;
    }

    .products_item_list figure {
        margin: 0 auto;
    }

    .products_item_list h2 {
        font-size: 1.25rem;
        line-height: 1.25;
    }

    .products_item_list h4 {
        font-size: 14px;
    }

    .recipes_item_list figure {
        margin: 0 auto;
    }

    .recipes_item_list h2 {
        font-size: 1.414rem;
        line-height: 1.25;
    }

    .card_item {
        margin-bottom: 40px;
    }

    .card_item:last-of-type {
        margin-bottom: 0;
    }

    .card_title {
        min-height: initial;
    }

    .card_text {
        margin: 0.5rem 0 1rem;
        min-height: initial;
    }

    .sm_order1 {
        -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
        order: 1;
    }

    .sm_order2 {
        -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
        order: 2;
        margin-top: 1.5rem;
    }

    .btn01 a::after {
        margin-left: 10px;
        width: 40px;
        height: 40px;
    }

    .btn02 a::after {
        margin-left: 10px;
        width: 40px;
        height: 40px;
    }

    .loading div {
        width: 280px;
    }

    #elevator_nav {
        display: none;
    }

    .map_wrap {
        max-width: 100%;
    }

    .ggmap {
        padding-bottom: 56.25%;
    }

    .accordion_area {
        margin-top: 60px;
    }

    .accordion_area li section .accordion {
        padding: 1.333rem;
    }

    .accordion_area li section .accordion h3 {
        font-size: 1rem;
    }

    .accordion_area li section .accordion h3::before,
    .accordion_area li section .accordion h3::after {
        width: 20px;
    }

    .accordion_area li section .accordion h3 .q-mark {
        font-size: 1.333rem;
    }

    .accordion_area li section .accordion .box {
        padding: 1.333rem 0;
    }

    .accordion_area_product li section .accordion {
        padding: 0.75rem;
    }

    .accordion_area_product li section .accordion h3 {
        font-size: 1rem;
        padding-right: 0.75rem;
    }

    .accordion_area_product li section .accordion h3::before,
    .accordion_area_product li section .accordion h3::after {
        width: 12px;
        height: 2px;
    }

    .accordion_area_product li section .accordion .box {
        padding: 1rem 0;
    }

    .purchase_block {
        margin-top: 60px;
    }

    .purchase_block h3 {
        font-size: 1.999rem;
    }

    .purchase_block .purchase_btn .purchase_shop a {
        font-size: 1.5rem;
        padding: 17px 15px;
    }

    .purchase_block .purchase_btn .purchase_online a {
        font-size: 1.5rem;
        padding: 17px 15px;
    }

    .loop_wrap {
        margin-top: 90px;
    }

    .loop_wrap .loop_wrap_text {
        font-size: 11.089rem;
    }

    .content_block_404 {
        width: 100%;
        padding: 90px 0 60px;
    }

    .content_block_404 .content_inner_404 {
        width: 90%;
        margin: 0 auto;
        padding: 0;
    }

    .content_block_404 .content_inner_404 .text_404 h3 {
        font-size: 1rem;
    }

    .md_pt10 {
        padding-top: 0;
    }

    p,
    a,
    li,
    table {
        font-size: 16px;
    }

    p {
        line-height: 1.5;
    }

    h2 {
        font-size: 28px;
    }

    h3 {
        font-size: 20px;
    }

    h4 {
        font-size: 18px;
    }

    .note2,
    .quote2 {
        font-size: 15px;
    }

    .note2 a,
    .quote2 a {
        font-size: 15px;
    }

    .sm_none {
        display: none;
    }

    .main_visual .main_visual_inner .catch_copy_bg {
        bottom: 20vw;
        left: 5vw;
    }

    .main_visual .main_visual_inner .catch_copy {
        font-size: 3.236rem;
    }

    .main_visual .main_visual_inner .catch_copy_read {
        font-size: 1rem;
        margin-top: 5%;
    }

    .main_visual .main_visual_inner .catch_copy_read span {
        font-size: 1rem;
    }

    .main_visual .main_visual_inner .catch_copy_btn a {
        font-size: 1.25rem;
    }

    .concept_bg::after {
        left: 50%;
        -webkit-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%);
    }

    .concept_bg .concept_area {
        width: 100%;
    }

    .concept_bg .concept_area h2.concept span,
    .concept_bg .concept_area h2.concept ruby {
        font-size: clamp(1.75rem, 7.46vw, 2.827rem);
    }

    .concept_bg .concept_area h2.concept span rt,
    .concept_bg .concept_area h2.concept ruby rt {
        font-size: 12px;
    }

    .concept_bg .concept_area h2.concept ruby[data-ruby]::before {
        top: -0.5rem;
        left: -1rem;
        right: -1.5rem;
        font-size: 12px;
        letter-spacing: 0.25rem;
    }

    .concept_bg .concept_area p.concept_read {
        margin-top: 60px;
        font-size: 13px;
    }

    .top_info_block {
        margin-top: 60px;
    }

    .top_info_block .top_info_inner {
        width: 75vw;
    }

    .top_info_block .top_info_inner dl {
        padding: 1.333rem 40px 1.333rem 0;
    }

    .top_info_block .top_info_inner dl::after {
        width: 30px;
        height: 30px;
    }

    .carousel_slider .slick-slider .slick-prev::before {
        font-size: 30px;
    }

    .carousel_slider .slick-slider .slick-prev {
        left: 10px;
    }

    .carousel_slider .slick-slider .slick-next::before {
        font-size: 30px;
    }

    .carousel_slider .slick-slider .slick-next {
        right: 10px;
    }

    .modalImg {
        width: 90%;
    }

    .modalImg .closeBtn {
        padding: 5px;
    }

    .promise_block .num_block {
        top: -5vw;
        right: 5vw;
        width: 20vw;
    }

    .promise_block .promise_title .decoration .block-revealer__content {
        font-size: 1.414rem;
        padding: 0 5px;
    }

    .promise_block .promise_title .decoration.top-1 {
        top: 10vw;
        right: 5vw;
    }

    .promise_block .promise_title .decoration.top-2 {
        top: 10vw;
        right: 5vw;
    }

    .promise_block .promise_title .decoration.top-3 {
        top: 10vw;
        right: 5vw;
    }

    .promise_block .promise_title .decoration.top-4 {
        top: 10vw;
        right: 5vw;
    }

    .promise_block .promise_title .decoration.top-5 {
        top: 10vw;
        right: 5vw;
    }
    .promise_block .promise_title .decoration.top-6 {
        top: 10vw;
        right: 5vw;
    }

    .promise_block .promise_title .decoration.bottom {
        top: calc(10vw + 2.828rem);
        right: 5vw;
    }

    .promise_block .promise_text {
        top: calc(10vw + 2.828rem + 2.828rem);
        left: 41.25vw;
    }

    .promise_block .promise_text p {
        padding-right: 5%;
    }

    .pick-up_block {
        margin-top: 60px;
    }

    .pick-up_block .pick-up_img {
        width: 75%;
        margin: 0 auto;
    }

    .pick-up_block .pick-up_text h3 {
        font-size: 1.999rem;
    }

    .enzyme_block {
        padding-bottom: 60px;
    }

    .enzyme_block .enzyme_text {
        width: 90%;
        padding: 0;
        margin: 3rem auto 0;
    }

    .enzyme_block .enzyme_text h3 {
        font-size: 1.999rem;
    }

    .enzyme_block .enzyme_img {
        width: 75%;
        margin: 0 auto;
    }

    .visual_enzyme {
        height: 75vw;
        background-size: 175%;
        background-attachment: scroll;
    }

    .page_name h1 {
        font-size: 2.827rem;
        line-height: 1.25;
    }

    .page_name h1 .jp_ruby {
        font-size: 14px;
    }

    .page_name_product h1 {
        font-size: 1.25rem;
        line-height: 1.25;
    }

    .page_name_product h1 .jp_ruby {
        font-size: 14px;
    }

    .page_name_recipe h1 {
        font-size: 1.25rem;
        line-height: 1.25;
    }

    .page_name_recipe h1 .jp_ruby {
        font-size: 14px;
    }

    .form_block {
        padding: 0 1rem;
    }

    .form_block .form_row span {
        font-size: 1rem;
    }

    .form_block .form_btn_wrap .form_btn+.form_btn {
        margin-left: 1rem;
    }

    .form_block .form_btn {
        font-size: 16px;
        width: 250px;
        margin: 30px auto 0;
    }

    .form_block input[type=text],
    .form_block input[type=email],
    .form_block select,
    .form_block textarea {
        width: 100%;
        font-size: 16px;
    }

    .mwform-tel-field input[type=text] {
        width: 29.8% !important;
    }

    .philosophy_area {
        width: 100%;
    }

    .philosophy_area h2.philosophy {
        font-size: clamp(1.25rem, 5.33vw, 1.414rem);
    }

    .philosophy_area p.concept_read {
        margin-top: 60px;
        font-size: 1.25rem;
    }

    .message_block {
        padding-bottom: 60px;
    }

    .message_block .message_text {
        width: 90%;
        padding: 0;
        margin: 3rem auto 0;
    }

    .message_block .message_text h3 {
        font-size: 1.414rem;
    }

    .message_block .message_text .signature {
        padding-bottom: 60px;
    }

    .message_block .message_img {
        width: 75%;
        margin: 0 auto;
    }

    .content_inner_company {
        margin-top: 60px;
    }

    .l_contents_with_nav {
        margin-top: 60px;
    }

    .l_contents_with_nav .l_main_contents .l_main_contents_inner {
        margin-bottom: 20vw;
    }

    .l_contents_with_nav .l_main_contents .l_main_contents_inner .l_main_contents_name {
        font-size: 1.999rem;
    }

    .l_contents_with_nav .l_main_contents .l_main_contents_inner .prefecture_name {
        font-size: 1rem;
    }

    .l_contents_with_nav .l_main_contents .l_main_contents_inner .l_main_contents_box {
        padding: 8vw 1vw;
    }

    .l_contents_with_nav .l_main_contents .l_main_contents_inner .l_main_contents_box h3 {
        font-size: 1.414rem;
    }

    .cosmetics_banner {
        width: 100%;
    }

    .about_product_area {
        width: 100%;
    }

    .about_product_area h2.about_product {
        font-size: 1.414rem;
    }

    .feature_block {
        margin-top: 60px;
    }

    .feature_block .feature_img {
        width: 75%;
        margin: 0 auto;
    }

    .feature_block .feature_text h3 {
        font-size: 1.414rem;
    }

    .how-to-use_block {
        margin-top: 60px;
    }

    .bath_img {
        width: 75%;
        margin: 0 auto;
    }

    .fasting_block {
        padding-bottom: 60px;
    }

    .fasting_block .fasting_text {
        width: 90%;
        padding: 0;
        margin: 3rem auto 0;
    }

    .fasting_block .fasting_text .fasting_check li {
        font-size: 1rem;
    }

    .fasting_block .fasting_text .fasting_check li:before {
        width: 20px;
        height: 20px;
    }

    .fasting_block .fasting_img {
        width: 75%;
        margin: 0 auto;
    }

    .method .methodBox .calculation .calInner .ttlArea h3 {
        font-size: 1.414rem;
    }

    .method .methodBox .calculation .calInner .ttlArea p {
        font-size: 14px;
    }

    .method .methodBox .calculation .calInner .practiceArea .item dl dt,
    .method .methodBox .calculation .calInner .practiceArea .resultArea dl dt {
        font-size: 18px;
    }

    .method .methodBox .calculation .calInner .practiceArea .item dl dd span,
    .method .methodBox .calculation .calInner .practiceArea .resultArea dl dd span {
        font-size: 18px;
    }

    .method .methodBox .calculation .calInner .practiceArea .item p,
    .method .methodBox .calculation .calInner .practiceArea .resultArea p {
        font-size: 18px;
    }

    .method .methodBox .calculation .calInner .practiceArea .item .choice,
    .method .methodBox .calculation .calInner .practiceArea .resultArea .choice {
        width: 100%;
    }

    .method .methodBox .calculation .calInner .practiceArea .item .choice .radio,
    .method .methodBox .calculation .calInner .practiceArea .item .choice .checkbox,
    .method .methodBox .calculation .calInner .practiceArea .resultArea .choice .radio,
    .method .methodBox .calculation .calInner .practiceArea .resultArea .choice .checkbox {
        font-size: 18px;
        padding-left: 2rem;
    }

    .method .methodBox .calculation .calInner .practiceArea .item .choice .radio:before,
    .method .methodBox .calculation .calInner .practiceArea .resultArea .choice .radio:before {
        width: 14px;
        height: 14px;
    }

    .method .methodBox .calculation .calInner .practiceArea .item .choice .radio:after,
    .method .methodBox .calculation .calInner .practiceArea .resultArea .choice .radio:after {
        width: 24px;
        height: 24px;
    }

    .method .methodBox .calculation .calInner .practiceArea .item .error,
    .method .methodBox .calculation .calInner .practiceArea .resultArea .error {
        font-size: 12px;
    }

    .method .methodBox .calculation .calInner .practiceArea .item.spec dl dd input[type=text] {
        width: 50%;
        font-size: 18px;
    }

    .method .methodBox .calculation .calInner .practiceArea .btnArea input[type=button] {
        font-size: 1.414rem;
        padding: 17px 15px;
    }

    .method .methodBox .calculation .calInner .practiceArea .resultNote p {
        font-size: 14px;
    }

    .method .methodBox .daily h3 {
        text-align: center;
    }

    .method .methodBox .daily h3 span {
        -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;
    }

    .method .methodBox .after_fasting .fasting_img {
        width: 100%;
    }

    .method .methodBox .after_fasting .btn_fasting {
        width: 100%;
    }

    .method .methodBox .after_fasting .btn_fasting a {
        font-size: 14px;
        padding: 10px 8px;
    }

    .posts_content_block {
        padding: 60px 0;
    }

    .posts_content_block .posts_content_inner {
        width: 90%;
        margin: 0 auto;
        padding: 0;
    }

    .posts_content_block .posts_content_inner h1 {
        font-size: 2.827rem;
        line-height: 0.75;
    }

    .posts_content_block .posts_content_inner h1 .jp_ruby {
        font-size: 14px;
    }

    .posts_breadcrumb_block {
        width: 100%;
    }

    .posts_breadcrumb_block ul {
        -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
        overflow-x: scroll;
    }

    .posts_breadcrumb_block ul li {
        white-space: nowrap;
    }

    .pg_wrapper {
        padding: 0 5%;
    }

    .pg_title {
        font-size: 24px;
    }

    .pg_contents {
        padding: 50px 20px;
    }

    .posts_item_list .posts_item {
        margin-bottom: 40px;
    }

    .posts_tmb img {
        /* height: calc(((100vw - 40px) / 160) * 90); */
        width: 100%;
        border-radius: 10px;
    }

    .wp-block-button__link {
        width: 250px;
        font-size: 16px !important;
    }

    .post_content_block {
        width: 100%;
        padding: 60px 0;
    }

    .post_content_block .post_content_inner {
        max-width: 90vw;
        margin: 0 auto;
        padding: 0;
    }

    .post_content_block .post_content_inner dl dd {
        font-size: 1.414rem;
    }

    .post_content_block .post_content_inner .posts_content figure:not(.wp-block-table) {
        max-width: 75vw;
        margin: 1.5rem auto;
    }

    .post_breadcrumb_block {
        width: 100%;
    }

    .post_breadcrumb_block ul {
        -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
        overflow-x: scroll;
    }

    .post_breadcrumb_block ul li {
        white-space: nowrap;
    }

    .tabs .tab_item {
        font-size: 14px;
        border-width: 1px;
    }

    .tabs .tab_item:nth-of-type(odd) {
        border-left-width: 2px;
    }

    .tabs .tab_item:nth-of-type(even) {
        border-right-width: 2px;
    }

    .tabs .tab_item:nth-of-type(1),
    .tabs .tab_item:nth-of-type(2) {
        border-top-width: 2px;
    }

    .tabs .tab_item:nth-of-type(4),
    .tabs .tab_item:nth-of-type(5) {
        border-bottom-width: 2px;
    }

    .tabs.posts_categories {
        margin-top: 60px;
    }

    .tabs.posts_categories .tab_item {
        width: 50%;
    }

    .tabs.posts_categories .tab_content dl {
        padding: 1.333rem 40px 1.333rem 0;
        display: block;
    }

    .tabs.posts_categories .tab_content dl::after {
        width: 30px;
        height: 30px;
    }

    .tabs.posts_categories .tab_content dl dd {
        margin-left: 0;
        margin-top: 1rem;
    }

    .product_block .content_inner .product_img_block {
        position: static;
    }

    .product_block .content_inner .product_img_block .product_img {
        width: 75%;
        margin: 0 auto;
    }

    .product_block .content_inner h2.product_title {
        font-size: 18px;
    }

    .product_block .content_inner .product_price p {
        font-size: 1.25rem;
    }

    .product_block .content_inner .product_price p span {
        font-size: 14px;
    }

    .recipe_block .content_inner .recipe_img_block {
        position: static;
    }

    .recipe_block .content_inner .recipe_img_block .recipe_img {
        width: 75%;
        margin: 0 auto;
    }

    .recipe_block .content_inner h2 {
        font-size: 1.999rem;
    }

    .recipe_block .content_inner h2 span {
        font-size: 14px;
    }

    .petBox {
        margin-top: 60px;
    }

    .petBox .pet_banner h3 {
        font-size: 1.414rem;
    }

    .petBox .pet_banner .pet_img {
        width: 100%;
    }

    .petBox .pet_desc h3 {
        font-size: 1.25rem;
    }

    .petBox .pet_desc p {
        font-size: 1rem;
    }

    .petBox .pet_desc .pet_img {
        width: 100%;
    }

    .petBox .pet_oem h3 {
        font-size: 1rem;
    }

    .petBox .pet_oem .btn_pet {
        width: 100%;
    }

    .petBox .pet_oem .btn_pet a {
        font-size: 14px;
        padding: 10px 8px;
    }

    .petBox .pet_oem .btn_pet02 .pet_mail a {
        font-size: 1.25rem;
        padding: 10px 8px;
    }

    .petBox .pet_oem .btn_pet02 .pet_tel a {
        font-size: 1.25rem;
        padding: 10px 8px;
    }

    .petBox .pet_oem .pet_maker {
        padding: 10px 8px;
    }

    .petBox .pet_oem .pet_maker h3 {
        font-size: 1rem;
    }

    .petBox .pet_oem .pet_maker p {
        font-size: 14px;
    }

    .petBox .pet_feature .feature_img {
        width: 75%;
        margin: 0 auto;
    }

    .petBox .pet_feature .feature_text h3 {
        font-size: 1.414rem;
    }

    .petBox .pet_feature .feature_text p span a {
        font-size: 14px;
    }
}

@media screen and (max-width: 750px) {
    body {
        min-width: initial;
    }
}

@media screen and (min-width: 768px) and (max-width: 1199px) {
    .content_block {
        width: 100%;
        padding: 90px 0;
    }

    .content_inner {
        width: 100%;
        padding: 0 2.5vw;
        margin: 0 auto;
    }

    .content_inner .inner_section_block {
        margin-top: 60px;
    }

    .content_inner .inner_section_block2 {
        margin-top: 90px;
    }

    header .header_pc {
        height: 100px;
    }

    header .header_pc .header_logo {
        width: 240px;
        margin: 0 auto;
    }

    header .header_pc .header_item {
        display: none;
    }

    .header_bg.change-color {
        background: #495364;
        -webkit-box-shadow: 0 2px 11.5px rgba(175, 187, 183, 0.75);
        box-shadow: 0 2px 11.5px rgba(175, 187, 183, 0.75);
    }

    #drawer .open span:nth-of-type(3)::after {
        font-size: 14px;
    }

    #drawer .menu {
        width: 80%;
        padding: 50px 100px 50px 50px;
    }

    footer .footer_inner {
        width: 100%;
        padding: 0 40px;
        margin: 0 auto;
    }

    .pagetop_block .contact_sp {
        display: none !important;
    }

    .pagetop_block .contact_sp2 {
        display: none !important;
    }

    .breadcrumb_block {
        width: 100%;
    }

    a[href*="tel:"] {
        pointer-events: none;
        cursor: default;
        text-decoration: none;
        color: #333333;
    }

    .products_item_list h2 {
        font-size: 1.414rem;
        line-height: 1.25;
    }

    .recipes_item_list h2 {
        font-size: 1.414rem;
        line-height: 1.25;
    }

    .card_title {
        display: table;
        width: 100%;
        min-height: 30px;
    }

    .card_title h3 {
        display: table-cell;
        vertical-align: middle;
    }

    .card_text {
        margin: 0.5rem 0 1rem;
        min-height: 130px;
    }

    #elevator_nav {
        background: none;
        right: 1%;
    }

    .accordion_area {
        margin-top: 90px;
    }

    .purchase_block {
        margin-top: 90px;
    }

    .loop_wrap .loop_wrap_text {
        font-size: 11.089rem;
    }

    .content_block_404 {
        width: 100%;
        padding: 120px 0 90px;
    }

    .content_block_404 .content_inner_404 {
        width: 100%;
        padding: 0 2.5vw;
        margin: 0 auto;
    }

    .content_block_404 .content_inner_404::after {
        left: 50%;
        -webkit-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%);
    }

    .md_none {
        display: none;
    }

    .main_visual .main_visual_inner .catch_copy_bg {
        bottom: 80px;
        left: 40px;
    }

    .concept_bg::after {
        left: 50%;
        -webkit-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%);
    }

    .concept_bg .concept_area {
        width: 100%;
    }

    .concept_bg .concept_area h2.concept span,
    .concept_bg .concept_area h2.concept ruby {
        font-size: 3.998rem;
    }

    .concept_bg .concept_area h2.concept span rt,
    .concept_bg .concept_area h2.concept ruby rt {
        font-size: 1rem;
    }

    .concept_bg .concept_area h2.concept ruby[data-ruby]::before {
        font-size: 1rem;
    }

    .concept_bg .concept_area p.concept_read {
        margin-top: 90px;
        font-size: 1.25rem;
    }

    .top_info_block {
        margin-top: 90px;
    }

    .promise_block .num_block {
        right: 2.5vw;
    }

    .promise_block .promise_title .decoration .block-revealer__content {
        font-size: 2.827rem;
        padding: 0 15px;
    }

    .promise_block .promise_title .decoration.top-1 {
        top: 10vw;
        right: 2.5vw;
    }

    .promise_block .promise_title .decoration.top-2 {
        top: 10vw;
        right: 2.5vw;
    }

    .promise_block .promise_title .decoration.top-3 {
        top: 10vw;
        right: 2.5vw;
    }

    .promise_block .promise_title .decoration.top-4 {
        top: 10vw;
        right: 2.5vw;
    }

    .promise_block .promise_title .decoration.top-5 {
        top: 10vw;
        right: 2.5vw;
    }

    .promise_block .promise_title .decoration.top-6 {
        top: 10vw;
        right: 2.5vw;
    }

    .promise_block .promise_title .decoration.bottom {
        top: calc(10vw + 5.654rem);
        right: 2.5vw;
    }

    .promise_block .promise_text {
        top: calc(10vw + 5.654rem + 5.654rem);
        left: 41.25vw;
    }

    .promise_block .promise_text p {
        padding-right: 40px;
    }

    .pick-up_block {
        margin-top: 90px;
    }

    .pick-up_block .pick-up_text h3 {
        font-size: 2.827rem;
    }

    .enzyme_block {
        padding-bottom: 90px;
    }

    .enzyme_block .enzyme_text {
        width: 100%;
        padding: 0 5vw;
        margin-top: 3rem;
        -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
        order: 2;
    }

    .enzyme_block .enzyme_text h3 {
        font-size: 2.827rem;
    }

    .enzyme_block .enzyme_img {
        width: 75%;
        margin: 0 auto;
        -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
        order: 1;
    }

    /*.enzyme_trivia_bg::after {
        left: 50%;
        -webkit-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%);
    }*/

    .visual_enzyme {
        height: 56.25vw;
        background-size: 150%;
        background-attachment: scroll;
    }

    .page_name h1 {
        font-size: 3.998rem;
        line-height: 1;
    }

    .page_name_product h1 {
        font-size: 1.999rem;
        line-height: 1.25;
    }

    .page_name_recipe h1 {
        font-size: 1.999rem;
        line-height: 1.25;
    }

    .philosophy_area {
        width: 100%;
    }

    .philosophy_area h2.philosophy {
        font-size: 1.999rem;
    }

    .philosophy_area p.concept_read {
        margin-top: 90px;
    }

    .message_block {
        padding-bottom: 90px;
    }

    .message_block .message_text {
        width: 100%;
        padding: 0 5vw;
        margin-top: 3rem;
        -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
        order: 2;
    }

    .message_block .message_text h3 {
        font-size: 2.827rem;
    }

    .message_block .message_text .signature {
        padding-bottom: 90px;
    }

    .message_block .message_img {
        width: 75%;
        margin: 0 auto;
        -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
        order: 1;
    }

    .content_inner_company {
        margin-top: 90px;
    }

    .l_contents_with_nav {
        margin-top: 90px;
    }

    .l_contents_with_nav .l_main_contents .l_main_contents_inner .prefecture_name {
        font-size: 18px;
    }

    .cosmetics_banner {
        width: 80%;
    }

    .about_product_area {
        width: 100%;
    }

    .about_product_area h2.about_product {
        font-size: 1.999rem;
    }

    .feature_block {
        margin-top: 90px;
    }

    .feature_block .feature_text h3 {
        font-size: 1.999rem;
    }

    .how-to-use_block {
        margin-top: 90px;
    }

    .product_faq_bg::after {
        left: 50%;
        -webkit-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%);
    }

    .bath_img {
        width: 75%;
        margin: 0 auto;
    }

    .fasting_block {
        padding-bottom: 90px;
    }

    .fasting_block .fasting_text {
        width: 100%;
        padding: 0 5vw;
        margin-top: 3rem;
        -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
        order: 2;
    }

    .fasting_block .fasting_img {
        width: 75%;
        margin: 0 auto;
        -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
        order: 1;
    }

    .method .methodBox .after_fasting .fasting_img {
        width: 100%;
    }

    .method .methodBox .after_fasting .btn_fasting {
        width: 100%;
    }

    .posts_content_block {
        padding: 100px 0 90px;
    }

    .posts_content_block .posts_content_inner {
        width: 100%;
        padding: 0 40px;
        margin: 0 auto;
    }

    .posts_content_block .posts_content_inner h1 {
        font-size: 5.063rem;
    }

    .posts_breadcrumb_block {
        width: 100%;
    }

    .post_content_block {
        width: 100%;
        padding: 100px 0 90px;
    }

    .post_content_block .post_content_inner {
        max-width: 100vw;
        padding: 0 40px;
        margin: 0 auto;
    }

    .post_breadcrumb_block {
        width: 100%;
    }

    .tabs.posts_categories {
        margin-top: 90px;
    }

    .tabs.posts_categories .tab_content dl {
        display: block;
    }

    .tabs.posts_categories .tab_content dl dd {
        margin-left: 0;
        margin-top: 1rem;
    }

    .product_block .content_inner .product_img_block {
        position: static;
    }

    .product_block .content_inner .product_img_block .product_img {
        width: 75%;
        margin: 0 auto;
    }

    .product_block .content_inner h2.product_title {
        font-size: 1.414rem;
    }

    .product_block .content_inner .product_price p {
        font-size: 1.414rem;
    }

    .product_block .content_inner .product_price p span {
        font-size: 14px;
    }

    .recipe_block .content_inner .recipe_img_block {
        position: static;
    }

    .recipe_block .content_inner .recipe_img_block .recipe_img {
        width: 75%;
        margin: 0 auto;
    }

    .recipe_block .content_inner h2 {
        font-size: 1.999rem;
    }

    .recipe_block .content_inner h2 span {
        font-size: 14px;
    }

    .petBox .pet_banner .pet_img {
        width: 100%;
    }

    .petBox .pet_desc .pet_img {
        width: 100%;
    }

    .petBox .pet_oem .btn_pet {
        width: 100%;
    }

    .petBox .pet_feature .feature_text h3 {
        font-size: 1.999rem;
    }
}

@media all and (-ms-high-contrast: none) {
    .card_item {
        padding: 0 12px;
    }
}

.top_banner {
    max-width: 1200px;
    margin: 0 auto;
    display: block;
}

header .header_pc .header_item {
    width: calc(100% - 330px);
    max-width: 1200px;
}

.purchase_block .purchase_btn .purchase_shop a {
    min-height: 142px;
}

.purchase_block .purchase_btn .purchase_shop a span {
    font-size: 12px;
    font-weight: 400;
    color: #495364;
    display: block;
}

footer .footer_nav ul>div:first-of-type {
    margin-right: 50px;
}


@media (max-width: 768px) {
    footer .footer_nav ul > div:first-of-type {
        margin-right: 0px;
    }
}


.content_inner.-company .concept_bg::after {
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -moz-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    -o-transform: translateX(-50%);
    top: -100%;
}

.recipes_item_list p {
    font-weight: 400;
    font-size: 16px;
    line-height: 22.4px;
    vertical-align: middle;
    color: #333333;
    text-align: left;
    margin-top: 5%;
}

.content_block.recipe_block .btn01 a {
    justify-content: flex-start;
    -webkit-justify-content: flex-start;
    -moz-justify-content: flex-start;
    -ms-justify-content: flex-start;
    -o-justify-content: flex-start;
    margin-top: 8%;
}

.content_block.recipe_block .btn01 a::after {
    display: none;
}

.content_block.recipe_block .btn01 a::before {
    font-size: 60px;
    font-family: "fontello";
    content: "\e80f";
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    color: #495364;
    margin-left: 20px;
    width: 80px;
    height: 80px;
    border: 2px solid #495364;
    border-radius: 50%;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    transform: rotate(180deg);
    margin-right: 20px;
}

.tabs.posts_categories .tab_content.newsCon dl {
    display: block;
}

.tabs.posts_categories .tab_content.newsCon dl dt {
    display: block;
}

.tabs.posts_categories .tab_content.newsCon dl dd {
    display: block;
    margin-left: 0;
    margin-top: 2%;
}

.newPage .btn02 a::after {
    font-size: 60px;
}

.mwform-tel-field input[type="text"],
.mwform-zip-field input[type="text"] {
    display: inline-block;
    width: auto;
}

.mw_wp_form .error {
    font-size: 93%;
    color: #B70000;
    display: none;
}

.recruitPage {
    overflow: hidden;
}

.recruitPage .concept_bg::after {
    max-width: 374px;
    left: 70%;
}

.recruitPage .requirements {
    position: relative;
}

.recruitPage .requirements::after {
    position: absolute;
    top: 50%;
    left: -10%;
    -webkit-transform: none;
    transform: none;
    content: "";
    aspect-ratio: 1/1;
    background: url(../image/circle-gradient.svg);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    width: min(100%, 800px);
    z-index: 0;
    max-width: 732px;
}

.promise_block .promise_text .btn02 a {
    justify-content: end;
    -webkit-justify-content: end;
    -moz-justify-content: end;
    -ms-justify-content: end;
}



@media screen and (max-width: 768px) {
    .index_service .promise_block:nth-child(2) {
        padding-bottom: 220px;
    }
    .purchase_block .purchase_btn .purchase_shop a,
    .purchase_block .purchase_btn .purchase_online a {
        min-height: auto;
    }

    .content_inner_company .companyCon table {
        width: 100%;
        margin-right: 0;
    }

    .newPage .btn02 a::after{
        font-size: 30px;
    }

    .promise_block .promise_text .btn02 a {
        margin-right: 20px;
    }

}