@charset "UTF-8";

.mcafeecolor {
color: #C01818;
}
.mcafeecolor a {
color: #C01818;
}
.bg_whitedesign {
--accent: #C01818;
--decor-h: 70px;
position: relative;
background: #fff;
padding-block: calc(var(--decor-h) + 1.5rem);
z-index: 0;
}
.bg_whitedesign::before {
content: "";
position: absolute;
top: 0;
left: 0;
width: 100%;
height: var(--decor-h);
background: var(--accent);
clip-path: polygon(0 0, 0 100%, 100% 0);
z-index: -1;
}
.bg_whitedesign::after {
content: "";
position: absolute;
bottom: 0;
left: 0;
width: 100%;
height: var(--decor-h);
background: var(--accent);
clip-path: polygon(0 100%, 100% 0, 100% 100%);
z-index: -1;
}
.bg_reddesign {
position: relative;
background: #fdf8f5;
}
.bg_reddesign .menu {
display: flex;
justify-content: space-between;
align-items: center;
}
.bg_reddesign .menu_link {
position: relative;
display: inline-block;
text-align: center;
text-decoration: none;
transition: transform 0.2s ease, color 0.2s ease;
}
.bg_reddesign .menu_en {
font-size: 28px;
font-weight: 700;
color: rgba(0, 0, 0, 0.1);
display: block;
letter-spacing: 1px;
}
.bg_reddesign .menu_jp {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
white-space: nowrap;
}
.bg_reddesign .menu_button {
flex: 1;
text-align: center;
}
.bg_reddesign .menu_button a {
display: block;
width: 100%;
height: 100%;
text-decoration: none;
color: inherit;
}
.bg_reddesign .menu_button:not(:last-child) {
border-right: 1px solid #ccc;
}
.bg_reddesign .menu_link:hover {
transform: translateY(-3px);
}
.plan_contents {
position: relative;
background: #fff;
border-radius: 8px;
padding: 20px;
transition: transform 0.2s ease, box-shadow 0.2s ease;
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
}
.plan_contents.standard {
position: relative;
border: 8px solid #C01818;
border-radius: 8px;
padding: 15px;
}
.plan_contents.standard .plan_label {
position: absolute;
top: 0;
left: 50%;
transform: translate(-50%, -50%);
background: #C01818;
color: #fff;
padding: 4px 12px;
border-radius: 4px;
font-weight: bold;
white-space: nowrap;
z-index: 2;
}
.plan_contents .small {
font-size: 16px;
}
.toggle_design {
position: relative;
border-radius: 8px;
color: #333;
background: #fff;
z-index: 1;
transition: transform 0.2s ease, box-shadow 0.2s ease;
display: flex;
padding: 10px 20px;
cursor: pointer;
align-items: center;
}
.toggle_text {
color: #333;
}
.toggle_design::before {
content: "";
position: absolute;
inset: 0;
border-radius: 8px;
padding: 3px;
background: linear-gradient(to right,
    #C01818,
    #e05252,
    #f3b2b2);
-webkit-mask:
linear-gradient(#fff 0 0) content-box,
linear-gradient(#fff 0 0);
-webkit-mask-composite: xor;
mask-composite: exclude;
z-index: -1;
}
.toggle_design:hover {
transform: translateY(-3px);
}
.arrow_container {
display: flex;
align-items: stretch;
gap: 0;
background: #fff;
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
}
.col.left,
.col.right {
display: flex;
flex-direction: column;
justify-content: center;
}
.content_1 {
background: #ffebeb;
color: #c01818;
padding: 20px;
width: 320px;
display: flex;
align-items: center;
justify-content: center;
height: 100%;
}
.arrow_shape {
flex-shrink: 0;
width: 30px;
background: #ffebeb;
clip-path: polygon(0 0, 100% 50%, 0 100%);
}
.feature_contents {
position: relative;
background: #fff;
border-radius: 8px;
padding: 20px;
transition: transform 0.2s ease, box-shadow 0.2s ease;
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
}
.feature_img {
min-height: 160px;
margin: 10px auto;
display: flex;
align-items: center;
justify-content: center;
}
.topic_contents {
position: relative;
background: #fff;
border-radius: 8px;
padding: 20px;
transition: transform 0.2s ease, box-shadow 0.2s ease;
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
margin: 2rem auto;
display: table;
width: calc((100% / 12) * 8);
}
/* --- SP表示 --- */
@media (max-width: 768px) {
.bg_whitedesign {
padding-block: calc(var(--decor-h) + 0em);
}
.bg_whitedesign {
--accent: #C01818;
--decor-h: 50px;
}
.bg_reddesign .menu_en {
font-size: 18px;
letter-spacing: 0px;
}
.arrow_container {
flex-direction: column;
align-items: center;
}
.arrow_shape {
width: 20%;
height: 20px;
clip-path: polygon(0 0, 50% 100%, 100% 0);
margin-top: -3px;
}
.col.left,
.col.right {
width: 100%;
}
.content_1,
.content_2,
.content_3 {
width: 100%;
}
.feature_img {
min-height: 60px;
}
.topic_contents {
width: 100%
}
}

