@charset "utf-8";

#contents {
width:auto !important;
}


#header,#footer_Wrap,.pageTop,footer,header,#footer
{display: none !important;}

.top_block {
    width: 100vw;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
    margin-bottom: 40px;
    background-color: #CC0033;
    height: 116px; /* ダミーで高さを指定 */
} 
.bottom_block {
    width: 100vw;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
    margin-top: 130px;
    background-color: #CC0033;
    height: 290px; /* ダミーで高さを指定 */
}
[id^="router"] {
  scroll-margin-top: 80px;
}
.content_wrap {
    max-width: 890px;
    width: 90%;
    margin: 0 auto;
    text-align: left;
}
.inner_box_01 {
    padding: 0 20px;
}

/* ページタイトル */
.cont_tit {
    font-size: 4rem;
    font-weight: 700;
    line-height: 1.5;
    margin-bottom: 25px;
}
.img_wrap {
    margin-bottom: 30px;
}
.content_wrap p {
    font-size: 1.5rem;
    line-height: 1.7;
    font-weight: 400;
    margin-bottom: 30px;
}
.img_fl01 {
    float: right;
    margin: 0 0 0 30px;
    max-width: 269px;
    width: 45.5%;
}
.img_fl01_sp {
    display: none;
}
.img_center {
    text-align: center;
}
.marker {
    background: linear-gradient(transparent 60%, #FF890080 60%);
    font-weight: 700;
}
.text_bold {
    font-weight: 700;
}
.text_mg_block {
    display: block;
    margin-left: 1em;
}
ul.pcmt_list li {
    font-size: 1.5rem;
    line-height: 1.7;
    font-weight: 700;
    background: url(../images/icon_check.svg) no-repeat 0 5px;
    background-size: 15px auto;
    padding-left: 18px;
}

/* ボタン */
.btn_wrap {
    text-align: center;
    margin-bottom: 43px;
}
.foot_btn_wrap {
    text-align: center;
    margin: 70px 0 50px;
}
.rt_btn {
    position: relative;
    background-color: #FF8900;
    color: #fff !important;
    font-weight: 700;
    display :flex;
    flex-direction: column;
    justify-content: center;
    border-radius: 9999px;
}
.rt_btn::after {
    content: "";
    display: inline-block;
    width: 15px;
    height: 32px;
    background: url(../images/arrow.png) no-repeat center / contain;
    position: absolute;
    right: 30px;
    top: 50%;
    transform: translateY(-50%);
}
.rt_btn .upper_text {
    display: block;
    font-size: 1.5rem;
    margin-bottom: 10px;
}
.rt_btn .lower_text {
    display: block;
    font-size: 2rem;
    margin-top: 10px;
}
.btn-01 {
    margin: 0 auto;
    font-size: 2.6rem;
    text-align: center;
    max-width: 462px;
    height: 90px;
}
.btn-03 {
    margin: 0 auto;
    font-size: 2.4rem;
    text-align: center;
    max-width: 432px;
    height: 90px;
    text-align: center;
    margin-bottom: 30px;
    font-feature-settings: "palt";
}
.btn-04 {
    background-color: #CC0033;
    font-size: 2rem;
    text-align: center;
    width: 100%;
    height: 55px;
    text-align: center;
}

/* 目次 */
dl.t_content {
    background: #F3F3F3;
    padding: 35px 20px;
}
dl.t_content dt {
    font-size: 2.4rem;
    font-weight: 700;
    margin-bottom: 1em;
}
dl.t_content dd {
    margin-bottom: 0.8em;
    line-height: 1.5;
}
dl.t_content dd:last-child {
    margin-bottom: 0;
}
dl.t_content dd a {
    color: #0047FF;
    font-size: 1.5rem;
    text-decoration: underline;
}
dl.t_content dd a:hover {
    text-decoration: none;
}

/* コンテンツタイトル */
.pcmt_title {
    font-size: 3.6rem;
    font-weight: 700;
    line-height: 1.5;
    text-align: left;
    border-left: 9px solid #CC0033;
    border-bottom: 1px solid #717171;
    margin: 90px 0 47px;
    padding: 5px 0 5px 10px;
    display: flex;
    align-items: flex-start;
    gap: 5px;
}
.kerning {
    font-feature-settings: "palt";
}
/* コンテンツサブタイトル */
.pcmt_subtitle {
    font-size: 2.4rem;
    font-weight: 700;
    line-height: 1.5;
    color: #fff;
    background: #555555;
    /* display: flex; */
    align-items: flex-start;
    padding: 10px 18px;
    /* gap: 8px; */
    margin: 40px 0 30px;
}

/* 小見出し */
.pcmt_subject {
   font-size: 2rem;
   font-weight: 700;
   line-height: 1.5;
   margin-bottom: 20px; 
}
/* 小見出し（アイコン付き） */
.pcmt_subject.iconized {
   display: flex;
   align-items: center;
   gap: 3px;
}
.pcmt_icon02 {
    position: relative;
    top: -3px;
}
.point_wrap {
    display: flex;
    align-items: flex-start;
    gap: 3px;
}
.point_wrap img {
    position: relative;
    top: 3px;
}
ul.maker_list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
	gap: 30px;
}

/* Q＆A */
.pcmt_faq_item {
    border: 1px solid #555;
    padding: 20px 20px 20px;
    text-align: left;
    margin-bottom: 40px;
}
.pcmt_text_box {
    display: flex;
    align-items: flex-start;
    margin-bottom: 20px;
    gap: 5px;
}
.pcmt_q_icon,
.pcmt_q_text {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.5;
}
.pcmt_a_text {
    font-size: 1.5rem;
    font-weight: 500;
    line-height: 1.7;
}
.pmbt_q_icon {
    flex-shrink: 0;
    width: 25px;
    text-align: right;
}
.pcmt_q_text {
    flex: 1;
}
ul.pc_item_list {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 43px;
}
/* === PCのスタイル (769px以上) === */
@media (min-width: 769px) {
    /* 画像がある場合のみGridを適用 */
    .pcmt_faq_item.has-image {
        display: grid;
        grid-template-columns: 1fr 296px;
        grid-template-rows: auto 1fr;
        gap: 8px 30px;
    }
    .has-image .q_text {
        grid-column: 1;
        grid-row: 1;
    }
    .has-image .pcmt_faq_img {
        grid-column: 2;
        grid-row: 1 / 3;
        width: 100%;
        height: auto;
        margin: 0;
    }
    .has-image .pcmt_a_text {
        grid-column: 1;
        grid-row: 2;
    }
}

/* === スマホのスタイル (768px以下) === */
@media (max-width: 768px) {
    .q_text {
        margin-bottom: 1em;
    }
    .pcmt_faq_img {
        float: right;
        margin: 0 0 10px 10px;
        min-width: 150px;
        width: 45.5%;
    }
    .pcmt_faq_item.has-image::after {
        content: "";
        display: table;
        clear: both;
    }
}

/* 商品紹介 */
.product_text {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.7;
    padding: 0 20px;
    margin-bottom: 40px;
}
.product_wrap {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(420px, 1fr));
	gap: 30px 45px;
    align-items: stretch;
}
.product_pic {
    margin-bottom: 60px;
    flex-grow: 1;
}
.product_box {
    border: 1px solid #555;
    padding: 20px 20px 30px;
    display: flex;
    flex-direction: column;
}
.product_header {
    display: flex;
    flex-direction: column;
}
.slider {
    width: 100%;
    box-sizing: border-box;
    display: flex;
    justify-content: center;
    align-items: center;
    max-width: 316px;
    max-height: 316px;
    margin: 0 auto;
}
.slider img {
    max-width: 100%;
    max-height: 100%;
    height: auto;
    width: auto;
    display: block;
    margin: 0 auto;
}
@media (max-width: 430px) { 
    .slider {
        max-width: 100%;
        max-height: none;
    }
}
.product_maker {
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 15px;
}
.product_info {
  display: flex;
  flex-direction: column;
}
.product_name {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.5;
    margin-bottom: 10px;
    word-break: break-word;
    overflow-wrap: break-word;
}
.product_number {
    font-size: 1.3rem;
    font-weight: 400;
    margin-bottom: 30px;
}

.slick-dots {
    bottom: -30px;
}
.slick-dots li {
    width: 15px;
    height: 15px;
    margin: 0 10px;
}
.slick-dots li button::before {
    content: "";
    width: 15px;
    height: 15px;
    background: #D9D9D9;
    border-radius: 15px;
    opacity: 1;
}
.slick-dots li.slick-active button:before {
    background: #000;
}

/* テーブル全体 */
.table_wrapper {
    overflow: auto;
    width: 100%;
}
.pcmt_compare_table {
  width: 100%;
  font-size: 1.5rem;
  line-height: 1.5;
  text-align: center;
  table-layout: fixed;
}

/* ヘッダー行 */
.pcmt_compare_table thead th {
  background-color: #CC0033;
  color: #fff;
  font-weight: bold;
  padding: 10px;
  vertical-align: middle;
}

/* ヘッダー行の最初のセル（「項目」）に幅を指定 */
.pcmt_compare_table thead th:first-child {
    width: 18%;
}

/* 一番左の比較項目列 */
.pcmt_compare_table tbody th {
  background-color: #F3F3F3;
  font-weight: bold;
  padding: 5px 5px 5px 10px;
  text-align: left;
  vertical-align: middle;
  width: 18%;
}
/* 各セル */
.pcmt_compare_table td {
  padding: 5px 3px;
  vertical-align: middle;
  font-feature-settings: "palt";
  word-break: break-all;
}
/* 全体のボーダー */
.pcmt_compare_table th,
.pcmt_compare_table td {
    border: 1px solid #555;
}
.cell_special th,
.cell_special td {
    padding: 16px 3px;
}

@media screen and (max-width: 900px) {
    .pcmt_compare_table {
        font-size: 1.3rem;
        table-layout: auto;
    }
    .pcmt_compare_table thead th,
    .pcmt_compare_table tbody th,
    .pcmt_compare_table td {
        padding: 8px;
        width:1%;
        white-space:nowrap;
    }
}/* Media Queries 900px END */

@media (max-width: 698px) { 
    /* ページタイトル */
    .cont_tit {
        font-size: 2.8rem;
    }
    .inner_box_01 {
        padding: 0;
    }
    /* コンテンツタイトル */
    .pcmt_title {
        font-size: 2rem;
        margin: 45px 0 23px;
        padding: 5px 0 5px 10px;
    }
    /* コンテンツサブタイトル */
    .pcmt_subtitle {
        font-size: 1.8rem;
        line-height: 1.5;
        margin: 40px 0 15px;
    }
    [id^="router"] {
        scroll-margin-top: 30px;
    }
    /* 小見出し */
    .pcmt_subject {
        font-size: 1.7rem;
    }
    .btn-03 {
        font-size: 2rem;
    }
    .rt_btn .lower_text {
        font-size: 1.6rem;
        margin-top: 10px;
    }
    .img_fl01 {
        display: none;
    }
    .img_fl01_sp {
        display: block;
        float: right;
        margin: 0 0 0 10px;
        min-width: 150px;
        width: 45.5%;
    }
}/* Media Queries 698px END */

@media (max-width: 430px) { 
    .content_wrap p {
        margin-bottom: 20px;
    }
    .rt_btn .upper_text {
        font-size: 1.3rem;
    }
    .btn-01 {
        font-size: 1.8rem;
    }
    .btn-03 {
        font-size: 1.8rem;
    }
    .rt_btn .lower_text {
        font-size: 1.4rem;
    }

    /* 商品紹介 */
    .product_text {
        font-size: 1.6rem;
        margin-bottom: 20px;
    }
    .product_wrap {
        display: block;
    }
    .product_box {
        display: block;
        margin-bottom: 20px;
        padding: 20px;
    }
    .product_name {
        font-size: 1.8rem;
    }
    .product_number {
        margin-bottom: 15px;
    }
    /* Q＆A */
    .pcmt_faq_item {
        padding: 15px;
        margin-bottom: 20px;
    }
    .pcmt_text_box {
        margin-bottom: 15px;
    }
    .pcmt_q_icon,
    .pcmt_q_text {
        font-size: 1.8rem;
    }
    .foot_btn_wrap {
        margin-top: 40px;
    }
    .btn-04 {
        font-size: 1.6rem;
    }
    .rt_btn.btn-04::after {
        width: 12px;
        height: 14px;
    }
    ul.pc_item_list {
        gap: 15px;
    }
    ul.maker_list {
        grid-template-columns: repeat(2, 1fr);
        gap: 15px;
    }
    .sp_mg {
        display: block;
        margin-bottom: 15px;
    }
}/* Media Queries 430px END */
