@charset "UTF-8";
/* CSS Document */ :root {
  --pink: #E60180;
  --red: #FF0000;
  --wblue: #46B0E1;
  --green: #01A13C;
  --wall-pink: #FFEDF7;
  --wall-gry: #EDEDED;
  --wall-beg: #F2E5E5;
  --wall-d-gry: #565656;
  --bdr-gry: #727272;
  --bdr-pale-gry: #D9D9D9;
  --wall-op-blue: rgba(83, 201, 255, .2);
  --wall-blue: #1C83B3;
  --wall-wblue: #ECF7FC;
  --wall-ylw: rgba(255, 254, 213, 1);
  --wall-op-ylw: rgba(255, 243, 0, .3);
}
/*Common 
===============================================================*/
body {
  font-family: 'Noto Sans JP', "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", Arial, Osaka, Sans-Serif;
  font-size: min(15px, 3.4vw);
  font-weight: 400;
  background: #FFF8F8;
  width: 100%;
}
.inner {
  padding-left: min(25px, 1.5vw);
  padding-right: min(25px, 1.5vw);
}
.fl {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
}
#pagetop {
  position: fixed;
  bottom: 20px;
  right: 20px;
  cursor: pointer;
  z-index: 5;
  display: none;
}
#pagetop.is-fit {
  position: absolute;
  bottom: auto;
  top: 0;
  transform: translateY(-100%);
}
/*Container 
===============================================================*/
#container {
  width: min(770px, 100%);
  margin-left: auto;
  margin-right: auto;
  overflow-x: hidden;
  min-height: 100dvh;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  background: #fff;
  -ms-overflow-style: none;
  scrollbar-width: none;
  box-shadow: 0 10px 10px rgba(0, 0, 0, .16);
}
#container::-webkit-scrollbar {
  display: none;
}
.in-text {
  line-height: calc(16/10);
  text-align: justify;
}
.fw-w {
  font-weight: 800;
}
.fc-red {
  color: var(--red);
}
.fc-pink {
  color: var(--pink);
}
.clr-wblue {
  color: var(--wblue);
}
.line-ylw {
  background: linear-gradient(rgba(255, 255, 0, 0) 60%, rgba(255, 255, 0, 1) 60%)
}
.line-op-ylw {
  background: linear-gradient(rgba(255, 255, 204, 0) 60%, rgba(255, 255, 204, 1) 60%)
}
.bkg-ylw {
  background: linear-gradient(rgba(255, 255, 0, 0) 12%, rgba(255, 255, 0, 1) 12%, rgba(255, 255, 0, 1) 90%, rgba(255, 255, 0, 0) 90%)
}
.bkg-op-ylw {
  background: linear-gradient(rgba(255, 255, 204, 0) 12%, rgba(255, 255, 204, 1) 12%, rgba(255, 255, 204, 1) 90%, rgba(255, 255, 204, 0) 90%)
}
.dot-line {
  border-bottom: dashed 2px currentColor;
  padding-bottom: 4px;
}
a.cvr {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 1;
}
a.udl {
  text-decoration: underline;
}
.min-att {
  text-align: right;
  font-size: min(10px, 2.6vw);
  line-height: calc(8/6);
}
/*header
===============================================================*/
header h1 {
  background: var(--pink);
  color: #fff;
  font-size: min(24px, calc(100vw/23.5));
  font-weight: 800;
  padding: min(20px, 3vw) min(10px, 1.5vw);
  text-align: center;
}
/*main +++++++++++++++++++++++++++++++++++++++++*/
main {
  flex: 1;
}
.mt_5 {
  margin-top: min(5px, 1.25vw);
}
.mt_10 {
  margin-top: min(10px, 2vw);
}
.mt_14 {
  margin-top: min(14px, 3vw);
}
.mt_20 {
  margin-top: min(20px, 5vw);
}
.mt_25 {
  margin-top: min(25px, 7vw);
}
.gray-box {
  background: var(--wall-gry);
}
.gray-box > ul {
  padding: min(13px, 3vw);
}
/*Content
=====================================*/
#content {
  margin-top: min(20px, 5vw);
  padding-bottom: min(50px, 10vw);
}
.contents-box, section + section {
  margin-top: min(25px, 5vw);
}
.sec-title {
  background: var(--pink);
  color: #fff;
  font-size: min(24px, calc(100vw/18));
  font-weight: 800;
  text-align: center;
  line-height: calc(30/20);
  padding: 10px min(15px, 3vw)
}
.line-title {
  background: #FFF8F8;
  font-size: min(20px, calc(100vw/21));
  font-weight: 600;
  padding: 10px 10px 10px 15px;
  border-left: 6px solid var(--pink);
  line-height: 1.3em;
}
.fkds-box {
  display: grid;
  grid-template-columns: min(80px, 22.5vw) auto;
  gap: min(16px, 5vw);
}
.fkds-box figcaption {
  font-size: min(9px, 2.5vw);
  margin-top: 5px;
}
.fkds-box .comment p {
  background: var(--wall-pink);
  padding: min(10px, 3vw) min(15px, 5vw);
  border-radius: 20px;
}
.fkds-box .comment p::before {
  content: "";
  width: min(15px, 4vw);
  aspect-ratio: 1;
  background: var(--wall-pink);
  position: absolute;
  left: 2px;
  top: 2em;
  clip-path: polygon(100% 0, 0 50%, 100% 100%);
  translate: -100% 0;
}
.graph figcaption {
  font-size: min(12px, 2.5vw);
  text-align: right;
  display: flex;
  justify-content: flex-end;
}
.thumb_clm {
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.check-list > li {
  line-height: calc(16/10);
  padding-left: 1.5em;
  font-size: 1.07em;
}
.check-list > li:nth-child(n+2) {
  margin-top: min(10px, 2vw);
}
.check-list > li::before {
  content: "";
  width: 1em;
  aspect-ratio: 1;
  background: url("../imgs/check.png") no-repeat center/cover;
  position: absolute;
  left: 0;
  top: .25em;
}
.check-list.pink > li::before {
  width: 1.25em;
  aspect-ratio: 1;
  background-image: url("../imgs/check_pink.svg");
}
/*intro ++++++++++++++++++++*/
.sec-intro-blc {
  padding-left: min(25px, 3vw);
  padding-right: min(25px, 3vw);
}
/*point ++++++++++++++++++++*/
.sec-point-blc {
  background: var(--wall-beg);
  padding-bottom: min(50px, 6vw);
}
.sec-point-blc .contents-box {
  margin-top: 10px;
}
.point-list {
  background: #fff;
  padding: min(20px, 3vw) min(20px, 3vw);
  border-radius: 15px;
  box-shadow: 0 0 min(10px, 2vw) rgba(0, 0, 0, .25)
}
.point-list li:nth-child(n+2) {
  margin-top: min(30px, 8vw);
}
.point-list .in-title {
  font-size: min(24px, 4.5vw);
  font-weight: 700;
  display: grid;
  grid-template-columns: 2.25em auto;
  -ms-align-items: center;
  align-items: center;
  justify-content: flex-start;
  gap: .5em;
}
.point-list .in-title .num {
  display: grid;
  place-content: center;
  aspect-ratio: 1;
  border-radius: 100vmax;
  background: var(--pink);
  color: #fff;
}
.point-list .in-title .num::before {
  content: "";
  width: calc(100% - 6px);
  aspect-ratio: 1;
  border: 2px solid #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  border-radius: 100vmax;
}
.point-list .in-title .num span {
  font-size: min(25px, 5.5vw);
  color: #fff;
  font-family: Arial, Helvetica, "sans-serif"
}
.point-list .in-title .dot-line {
  color: var(--pink);
}
.sec-point-blc > .in-text {
  padding-left: min(25px, 3vw);
  padding-right: min(25px, 3vw);
}
.define-table {
  display: grid;
  grid-template-columns: min(500px, 80vw);
  justify-content: center;
  font-size: 1.15em;
}
.define-title {
  background: var(--wall-d-gry);
  color: #fff;
  text-align: center;
  padding: min(13px, 3vw);
  font-weight: 700;
  font-size: 1.125em;
}
.define-table dl {
  border: 1px solid var(--bdr-gry);
}
.define-table dl > div {
  display: grid;
  grid-template-columns: 3.5em auto;
}
.define-table dl > div:nth-child(n + 2) {
  border-top: 1px solid var(--bdr-gry);
}
.define-table dl dt {
  display: grid;
  place-content: center;
  background: var(--wall-gry);
  font-weight: 700;
}
.define-table dl dd {
  line-height: calc(16/12);
  padding: 7px 10px;
  border-left: 1px solid var(--bdr-gry);
}
.type-list {
  display: grid;
  grid-template-columns: 35% 1fr 1fr;
  border: 1px solid var(--bdr-pale-gry);
}
.type-item {
  display: grid;
  grid-template-rows: subgrid;
  grid-area: span 3;
}
.type-item:nth-child(n+2) {
  border-left: 1px solid var(--bdr-pale-gry);
}
.type-item.hybrid {
  background: var(--wall-pink);
}
.type-item .thumb {
  display: grid;
  place-content: space-around;
  place-items: center;
  gap: min(20px, 5vw);
  padding: min(15px, 4vw) min(20px, 2vw);
}
.type-item .thumb .type-title {
  background: var(--wall-blue);
  color: #fff;
  font-weight: 600;
  font-size: min(20px, 3vw);
  padding: 5px 1em;
  border-radius: 100vmax;
}
.type-item .thumb figure img {
  object-fit: contain;
  height: 100%;
  object-position: center;
}
.type-item .thumb figure {
  width: min(200px, 100%);
  aspect-ratio: 1/0.7846;
}
.type-item.hybrid .thumb figure {
  width: min(250px, 100%);
  aspect-ratio: 1/0.7784;
}
.type-item .star {
  border-top: 1px solid var(--bdr-pale-gry);
  padding: 10px;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -ms-align-items: center;
  align-items: center;
  justify-content: center;
}
.type-item .star figure {
  height: min(20px, 8vw);
}
.type-item.hybrid .star figure {
  height: min(30px, 10vw);
}
.type-item .star figure img {
  object-fit: contain;
  object-position: center;
  height: 100%;
}
.type-item .comment {
  border-top: 1px solid var(--bdr-pale-gry);
  padding: min(15px, 2vw);
}
/*hikaku*/
.sec-hikaku-blc {
  margin-top: 0;
  padding-bottom: min(25px, 5vw);
}
.sec-hikaku-blc .guide {
  width: min(550px, 100%);
  margin-left: auto;
  margin-right: auto;
}
.table-wrap {
  width: 100%;
  padding-bottom: 10px;
  padding-top: min(40px, 8vw);
}
.hikaku-table {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}
.hikaku-table td {
  border: 1px solid #000;
  vertical-align: middle;
  text-align: center;
  line-height: calc(14/12);
  padding: min(15px, 3vw) 0;
  font-weight: 600;
}
.hikaku-table td img {
  width: 80%;
  margin-left: auto;
  margin-right: auto;
}
.hikaku-table td .crown::after {
  content: "";
  background: url("../imgs/crown.png") no-repeat center/cover;
  width: min(50px, 40%);
  aspect-ratio: 1/0.908;
  position: absolute;
  right: 0;
  top: 0;
  translate: 15% -100%;
}
.hikaku-table tr td:nth-child(1) {
  width: 6em;
  background: var(--wall-wblue);
  font-weight: 600;
}
.hikaku-table tr td:nth-child(2) {
  background: var(--wall-op-ylw);
  /*  width: 30%;*/
}
.hikaku-table tr.total td:nth-child(n+2) {
  font-size: min(20px, 6vw);
  font-weight: 800;
}
.hikaku-table tr.total td:nth-child(2) {
  font-size: min(24px, 8vw);
  color: #E6015D;
}
.hikaku-table tr.fs-min td p.mark {
  font-size: min(11px, .75em);
  min-height: 4em;
}
.hikaku-table tr.csp td p.mark {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -ms-align-items: center;
  align-items: center;
  gap: 2px;
  font-size: min(11px, .88em);
  min-height: 4em;
}
.hikaku-table td > div {
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -ms-align-items: center;
  align-items: center;
  gap: 5px;
}
.hikaku-table td .score {
  background: #000;
  color: #fff;
  padding: 3px 1em 4px;
  border-radius: 100vmax;
  font-size: min(13px, 3vw);
  line-height: 1;
}
.hikaku-table td .mark {
  min-height: 3em;
  display: grid;
  place-content: center;
}
.hikaku-table td .mark::before {
  content: "";
  width: min(50px, 12vw);
  aspect-ratio: 1;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
}
.hikaku-table td .mark.max::before {
  background-image: url("../imgs/icon_max.svg");
}
.hikaku-table td .mark.mid::before {
  background-image: url("../imgs/icon_mid.svg");
}
.hikaku-table td .mark.min::before {
  background-image: url("../imgs/icon_min.svg");
}
.hikaku-table {
  width: 100%;
  min-width: 640px;
  counter-reset: number 0;
}
.hikaku-table .att {
  padding-right: 1.5em;
}
.hikaku-table .att::after {
  counter-increment: number 1;
  content: "※"counter(number);
  position: absolute;
  top: 0;
  right: 0;
  font-size: min(10px, 3vw);
  font-weight: 400;
}
.hikaku-table td a {
  display: grid;
  height: 3em;
  width: 88%;
  border-radius: 100vmax;
  place-content: center;
  background: var(--green);
  margin-left: auto;
  margin-right: auto;
  color: #fff;
  font-size: .88em;
  animation: dokidoki 1s ease-in-out infinite;
}
.hikaku-table td a span {
  padding-right: 1.8em;
}
.hikaku-table td a span::after {
  content: "";
  width: 1.35em;
  aspect-ratio: 1;
  background: url("../imgs/arrow.svg") no-repeat center/contain;
  position: absolute;
  right: 0;
  top: 50%;
  translate: 0 -50%;
}
.att-num-list {
  counter-reset: number 0;
}
.att-num-list > li {
  padding-left: 2em;
}
.att-num-list > li::before {
  counter-increment: number 1;
  content: "※"counter(number);
  top: 0;
  left: 0;
  position: absolute;
}
.sec-hikaku-blc .att-num-list {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: flex-end;
  font-size: min(11px, 2.5vw);
  gap: 5px 1em;
  margin-top: 5px;
}
/*ranking +++++++++++++++++++++++++++++++++*/
.sec-ranking-blc {
  background: var(--wall-beg);
  margin-top: 0;
  padding-top: min(30px, 8vw);
  padding-bottom: min(30px, 8vw);
}
.sec-ranking-box {
  margin-top: 0;
}
.ranking-title {
  filter: drop-shadow(0 8px 3px rgba(0, 0, 0, .3));
}
.ranking-item {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  gap: min(20px, 4vw);
}
.ranking-item:nth-child(n+2) {
  margin-top: min(50px, 12vw);
}
.ranking-detail {
  background: #fff;
  border-radius: min(15px, 5vw);
  padding: min(15px, 4vw) min(15px, 2vw) min(50px, 8vw);
  filter: drop-shadow(0 5px 10px rgba(0, 0, 0, .25));
}
.ranking__head .in-title {
  display: grid;
  grid-template-columns: 1fr 1fr;
  -ms-align-items: flex-end;
  align-items: flex-end;
  font-weight: 700;
}
.ranking__head .in-title .site-name {
  font-size: min(30px, calc(100vw/18));
  display: grid;
  grid-template-columns: min(10vw, 50px) auto;
  -ms-align-items: flex-end;
  align-items: flex-end;
  gap: 3px;
}
.ranking__head .in-title .site-name.min {
  font-size: min(30px, calc(100vw/20));
}
.ranking__head .in-title .star-area {
  display: grid;
  grid-template-columns: 5.5em auto;
  -ms-align-items: center;
  align-items: center;
  justify-content: flex-end;
}
.ranking__head .in-title .star-area .star {
  height: min(25px, 5vw);
}
.ranking__head .in-title .star-area .star img {
  object-fit: contain;
  height: 100%;
  object-position: right center;
}
.ranking__score {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5px;
  -ms-align-items: center;
  align-items: center;
}
.ranking__point, .ranking__target {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -ms-align-items: flex-start;
  align-items: flex-start;
  box-shadow: 3px 4px 4px rgba(0, 0, 0, .25);
}
.ranking__point ul, .ranking__target ul {
  padding: min(15px, 3vw) min(40px, 4vw);
  font-weight: 600;
  font-size: min(18px, 3.4vw);
}
.ranking__point {
  background: var(--wall-ylw);
  --ttl-clr: var(--pink);
}
.ranking__target {
  background: var(--wall-op-blue);
  --ttl-clr: var(--wall-blue);
}
.dig-title {
  clip-path: polygon(0 0, 100% 0%, calc(100% - min(3vw, 20px)) 100%, 0% 100%);
  background: var(--ttl-clr);
  color: #fff;
  padding: min(10px, 2vw) 1.5em min(10px, 2vw) min(10px, 3vw);
  font-weight: 600;
  font-size: min(20px, 4vw);
}
/*review*/
.review-item:nth-child(n+2) {
  margin-top: min(15px, 5vw);
}
.review-item dt {
  display: grid;
  grid-template-columns: min(100px, 15vw) auto;
  gap: 10px;
  -ms-align-items: center;
  align-items: center;
}
.review-item dt .title {
  font-weight: 600;
  line-height: calc(20/14);
}
.review-item dt .title h4 {
  font-size: min(20px, 3.6vw);
}
.review-item dt .title .data {
  padding-left: 1em;
  font-size: min(16px, 3.4vw);
}
.review-item dd {
  padding-top: min(25px, 5vw);
}
.review-item dd .fkds {
  border: 2px solid #EACFCF;
  border-radius: 10px;
  padding: min(15px, 3vw) min(15px, 3vw);
  background: #fff;
  z-index: 1;
}
.review-item dd .fkds::before, .review-item dd .fkds::after {
  content: "";
  position: absolute;
  width: min(20px, 5vw);
  aspect-ratio: 1/.85;
  translate: 0 -100%;
  clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
  z-index: -1;
}
.review-item dd .fkds::before {
  background: #EACFCF;
  left: min(40px, 5vw);
  top: 0;
}
.review-item dd .fkds::after {
  background: #fff;
  width: calc(min(20px, 5vw) - 4px);
  left: calc(min(40px, 5vw) + 2px);
  top: 1px;
}
.review-item dd .min-att {
  margin-top: 5px;
}
/*price*/
.price-list {
  border: 2px solid #000;
}
.price-list dt {
  background: #000;
  color: #fff;
  -ms-align-items: flex-end;
  align-items: flex-end;
  font-size: min(18px, 4vw);
  font-weight: 800;
  gap: 1em;
  padding: min(5px, 1.25vw) .5em min(8px, 1.8vw);
}
.price-list dd {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 10px;
  padding: min(10px, 3vw) min(10px, 1.5vw) min(15px, 4vw);
  background: #F5F5F5;
}
.price-list dd > div {
  font-size: min(18px, 3.4vw);
  border-radius: min(20px, 4vw);
  box-shadow: 0 4px 4px rgba(0, 0, 0, .25);
  padding: min(12px, 3vw) min(10px, 2vw) min(15px, 4vw);
  display: grid;
  place-items: center;
  background: #fff;
  gap: 8px;
  font-weight: 600;
}
.price-list dd > div .title {
  border-bottom: 1.5px dashed;
  padding-bottom: 4px;
}
.price-list dd > div .price span {
  font-size: 1.45em;
  font-weight: 800;
}
/*
.campaign-list {
  border: 2px solid var(--pink);
}
*/

.campaign-list + .min-att {
  margin-top: 5px;
}
.campaign-list dt {
  background: var(--pink);
  color: #fff;
  font-size: min(18px, 4vw);
  font-weight: 800;
  padding: min(5px, 1.25vw) .5em min(8px, 1.8vw);
}
.campaign-list dd {
  padding: min(15px, 3vw) min(10px, 1vw) min(10px, 2vw);
  background: #FFFED5;
}

/*add 20250603 */
.campaign-list {
  border: none;
}

.campaign-list table {
  border: 1px solid #ff7e7e;
  text-align: center;
  border-collapse: collapse;
  margin-right: auto;
  margin-left: auto;
}

.campaign-list table.camp_zwei {
  width: 51%;
}

.campaign-list table.camp_fiore {
  width: 32%;
}

.campaign-list table.camp_sun, .camp_pa, .camp_ibj{
  width: 41%;
}

.campaign-list table th{
  border: none;
  color: #fff;
  background: #ff7e7e;
  font-size: min(18px, 4vw);
  font-weight: 800;
  padding: min(8px, 1.8vw) .5em min(10px, 2vw);
}

.campaign-list table td.cost-list{
  padding: min(13px, 1.8vw) 0;
  border: 1px solid #C0C0C0;
}

.campaign-list table td .title {
  white-space: nowrap;
  display: table-cell;
  vertical-align: middle;
  font-size: 1em;
  font-weight: 400;
  width: 19vw;
  line-height: 1.4em;
  padding-left: .3em;
}

.campaign-list 
table.camp_pa td .title,
table.camp_ibj td .title,
table.camp_sun td .title {
  width: 10vw;
}


.campaign-list table td .title span {
  font-size: .8em;
  color: #fff;
  background-color: #ff7e7e;
  padding: 1px .5em 2px;
  border-radius: 20px;
  font-weight: 600;
}

.campaign-list table td .title span.att{
  font-size: .7em;
  color: #000;
  background-color: #fff;
  padding: 0;
  font-weight: 400;
}

.campaign-list table td .price {
  display: table-cell;
  vertical-align: middle;
  text-align: center;
}


.campaign-list table td .default {
  font-size: 1.2em;
  font-weight: 400;
  text-align: right;
  padding-right: .5em;
  width: 27vw;
}

.campaign-list table td .default span{
  text-decoration: line-through;
  font-size: 1.1em;
  margin-right:1px;
}

.campaign-list table td .after {
  font-weight: 600;
  color: #ff0000;
  font-size: 1.4em;
  text-align: right;
  padding-right: .5em;
  width: 26vw;
}

.campaign-list table td .after span{
  font-size: 1.5em;
  color: #ff0000;
  margin-right: 1px;
}

.campaign-list table td .after span.att{
  font-size: .5em;
  color: #ff0000;
  margin-right: 1px;
}

.sp_br {
  display: none;
}

@media screen and (max-width: 768px) {
  .sp_br {
    display: block;
  }

  .campaign-list table.camp_zwei {
    width: 75%;
  }

  .campaign-list table.camp_fiore {
    width: 50%;
  }

  .campaign-list table.camp_pa,
  .campaign-list table.camp_sun,
  .campaign-list table.camp_ibj {
    width: 60%;
  }

  .campaign-list table td.cost-list{
    text-align: center;
  }

  .campaign-list table td .title {
    width: 19vw;
  }

  .campaign-list table td .title span {
    font-size: .7em;
  }

  .campaign-list table td .default {
    font-size: 1.2em;
    width: 33vw;
    padding-right: .5em;
  }

  .campaign-list table td .after {
    width: 32vw;
    font-size: 1.1em;
    padding-right: .5em;
  }

  .campaign-list table.camp_pa td .after, 
  .campaign-list table.camp_sun td .after,
  .campaign-list table.camp_ibj td .after
{
    width: 42vw;
  }

}


/*cta*/
.cta-button {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -ms-align-items: center;
  align-items: center;
}
.cta-button .fkds-text {
  width: min(84%, 24em);
  text-align: center;
  background: #fff;
  border: 2px solid #43D765;
  border-radius: 100vmax;
  color: #07A92B;
  font-weight: 600;
  font-size: min(20px, 3.6vw);
  height: 2.5em;
  display: grid;
  place-content: center;
  z-index: 1;
  padding-bottom: 3px
}
.cta-button .fkds-text::before, .cta-button .fkds-text::after {
  content: "";
  width: min(15px, 8vw);
  aspect-ratio: 1/.65;
  clip-path: polygon(0 0, 44% 100%, 100% 0);
  position: absolute;
  left: 50%;
  translate: -50% 100%;
}
.cta-button .fkds-text::before {
  background: #43D765;
  bottom: 0;
}
.cta-button .fkds-text::after {
  background: #fff;
  bottom: 4px;
}
.cta-button .button {
  width: 95%;
  aspect-ratio: 1/.22;
  border-radius: 100vmax;
  background: linear-gradient(#00952D, #07CB00);
  display: grid;
  place-content: center;
  place-items: center;
  font-size: min(25px, calc(100vw/24));
  line-height: calc(21/14);
  padding-top: .5em;
  margin-top: -.5em;
  animation: dokidoki 1s ease-in-out infinite;
}
.cta-button .button .ylw {
  color: #FCFF00;
  font-size: min(18px, 3.2vw);
  letter-spacing: .05em;
  font-weight: 600;
}
.cta-button .button .main {
  font-size: min(40px, calc(100vw/20));
  color: #fff;
  letter-spacing: .025em;
  font-weight: 700;
}
.cta-button .button::before {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  translate: -40% -50%;
  width: 1.25em;
  aspect-ratio: 1;
  background: url("../imgs/line-arrow.svg") no-repeat center/contain;
}
/*thanks*/
.page-thanks-blc {
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -ms-align-items: center;
  align-items: center;
}
.round-button {
  width: min(250px, 100%);
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  margin-top: min(60px, 10vw);
  height: 50px;
  border-radius: 100vmax;
  background: var(--green);
}
.round-button a {
  width: 100%;
  height: 100%;
  display: grid;
  place-content: center;
  color: #fff;
  font-weight: 600;
  font-size: min(18px, 3.6vw);
}
@keyframes dokidoki {
  0% {
    filter: brightness(1);
    transform: scale(1)
  }
  50% {
    filter: brightness(1);
    transform: scale(1.025)
  }
  51% {
    filter: brightness(1.3);
    transform: scale(1.05)
  }
  75% {
    filter: brightness(1.1);
    transform: scale(1.025)
  }
  100% {
    filter: brightness(1);
    transform: scale(1)
  }
}
.box-fiore .campaign-list dd, .box-ibj .campaign-list dd {
  display: grid;
  grid-template-columns: min(520px, 78%);
  place-content: center;
}
/*診断*/
.sec-diag-blc {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -ms-align-items: center;
  align-items: center;
}
.sec-diag-blc .top-text {
  font-weight: 700;
  font-size: min(24px, calc(100vw/22));
}
.sec-diag-box {
  width: min(600px, calc(100% - 8px));
  border-radius: 15px;
  background: var(--pink);
  border: 2px solid var(--pink);
}
.sec-diag-box::before {
  content: "";
  width: calc(100% + 8px);
  height: calc(100% + 8px);
  border-radius: 20px;
  border: 2px solid var(--pink);
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
}
.que-title {
  display: grid;
  grid-template-columns: min(500px, 75%);
  place-content: center;
  padding: min(20px, 4vw) 0;
}
.sec-diag__head .comment {
  background: #fff;
  text-align: center;
  font-weight: 600;
  font-size: min(20px, calc(100vw/20));
  padding: min(25px, 3vw) min(10px, 2vw);
  line-height: calc(26/20);
}
.sec-diag__head .comment::after {
  content: "";
  width: min(35px, 10vw);
  aspect-ratio: 1/.4;
  background: #fff;
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  position: absolute;
  left: 50%;
  bottom: 1px;
  translate: -50% 100%;
}
.sec-diag__body {
  padding: min(30px, 5vw) min(20px, 2vw);
}
.que-item {
  background: #fff;
  padding: min(20px, 4vw) min(20px, 2vw) min(40px, 8vw);
  border-radius: 18px;
  overflow: hidden;
  display: none;
}
.que-item_head {
  display: grid;
  grid-template-columns: 2.5em auto;
  font-size: min(20px, calc(100vw/24));
  color: var(--pink);
  font-weight: 700;
  -ms-align-items: center;
  align-items: center;
  gap: 5px;
}
.que-item_head .num {
  aspect-ratio: 1;
  display: grid;
  place-content: center;
  border: 2px solid currentcolor;
  border-radius: 100vmax;
  overflow: hidden;
}
.que-item_head .num span {
  translate: 0 -2%;
}
.que-item .thumb {
  margin-top: min(20px, 2vw);
}
.ans-button-wrap {
  margin-top: min(25px, 5vw);
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center;
  gap: min(30px, 8vw);
}
.ans-button {
  font-weight: 700;
  width: 5em;
  aspect-ratio: 1/0.4575;
  max-height: 50px;
  background: var(--btn-clr);
  box-shadow: 0 4px 4px var(--sdw);
  border: 1.5px solid #fff;
  border-radius: 10px;
  font-size: min(5vw, 24px);
  color: #fff;
  padding-bottom: 3px;
  white-space: nowrap;
}
.ans-button.yes {
  --sdw: rgba(230, 1, 128, .2);
  --btn-clr: var(--pink);
}
.ans-button.no {
  --sdw: rgba(70, 176, 225, .2);
  --btn-clr: var(--wall-blue);
}
.answer_title {
  display: flex;
  justify-content: center;
  font-size: min(25px, 6vw);
  font-weight: 700;
}
.answer_title span {
  padding-bottom: 4px;
  border-bottom: 2px dashed currentColor;
}
#answer-box .cta-button .button {
  width: 100%;
}
#answer-box .thumb p {
  text-align: center;
  font-size: min(20px, calc(100vw/20));
  font-weight: 600;
  color: var(--pink);
  line-height: calc(28/20);
}
#answer-box .thumb p span {
  font-weight: 700;
  font-size: 1.35em;
  background: linear-gradient(rgba(255, 246, 0, 0) 60%, rgba(255, 246, 0, 1) 60%);
}
#answer-box .thumb figure {
  box-shadow: 1px 1px 4px rgba(0, 0, 0, .25);
  border: 4px solid #fff;
}
#answer-box .cta-button .button .main {
  font-size: min(30px, calc(100vw / 21));
}
/*footer ++++++++++++++++++++++ */
footer {
  background: #575757;
  padding-top: min(30px, 6vw);
  padding-bottom: min(30px, 6vw);
}
.footer-nav {
  color: #fff;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center;
  gap: 1.5em;
}
.footer-nav a {
  font-size: min(14px, 3.2vw);
  padding-left: 1em;
}
.footer-nav a::before {
  content: "";
  width: .5em;
  aspect-ratio: 1/1.25;
  background: #fff;
  clip-path: polygon(0% 0%, 0% 100%, 100% 50%);
  position: absolute;
  left: 0;
  top: 50%;
  translate: 0 -50%;
}
/*under contents ++++++++++++++++++++++++++++++++++++++++++++++*/
#content.under-contents {
  margin-top: min(50px, 10vw);
}
#hero.under {
  background: var(--wall-beg);
  height: min(150px, 25vw);
  display: grid;
  place-content: center;
}
.under-title {
  font-size: min(24px, calc(100vw / 18));
  font-weight: 800;
  letter-spacing: .05em;
}
.under-contents .line-title {
  font-size: min(20px, calc(100vw / 25));
  padding-left: 10px;
}
/*overview +++++++++++++++++++*/
.overview-item > dd {
  padding: min(20px, 3vw);
}
.overview-item:last-child > dd {
  padding-bottom: 0;
}
.overview-detail-list dt {
  padding-left: 1em;
  font-weight: 600;
}
.overview-detail-list dt::before {
  content: "";
  width: .85em;
  aspect-ratio: 1/.65;
  background: var(--pink);
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  position: absolute;
  left: 0;
  top: 0;
  translate: 0 50%;
}
.overview-detail-list dd {
  padding: 10px 10px 10px 1em;
  line-height: calc(20/14);
}
.survey-list li {
  padding-bottom: 10px;
}
.survey-list li:nth-child(n+2) {
  padding-top: 10px;
  border-top: 1px solid var(--bdr-pale-gry);
}
.survey-result-table {
  width: 100%;
  text-align: center;
}
.survey-result-table th, .survey-result-table td {
  padding: 8px 5px;
}
.survey-result-table thead th {
  background: #f8f8f8;
}
.survey-result-table tbody td {
  font-weight: 600;
  border-bottom: 1px solid #f8f8f8;
}
.link-area {
  margin-top: min(30px, 10vw);
}
/*operation*/
.operation-item .comment {
  margin-top: min(20px, 4vw);
  padding-left: 1em;
  padding-right: 1em;
}
.operation-item:not(:last-child) {
  padding-bottom: min(50px, 6vw);
}
.operation-detail-list {
  border: 1px solid #ddd;
}
.operation-detail-list > div {
  display: grid;
  grid-template-columns: 10em auto;
}
.operation-detail-list dt {
  background: #f8f8f8;
  padding: min(15px, 4vw) min(10px, 2vw);
}
.operation-detail-list dd {
  padding: min(15px, 4vw) min(10px, 3vw) min(15px, 4vw) min(20px, 4vw);
}
.operation-detail-list > div:nth-child(n+2) {
  border-top: 1px solid #ddd;
}
/*contact*/
#conf-form {
  display: none;
}
.form-wrap {
  width: min(600px, 100%);
  margin-left: auto;
  margin-right: auto;
}
.form-list > div:nth-child(n+2) {
  margin-top: min(15px, 3vw);
}
.form-list dd {
  margin-top: min(10px, 2vw);
}
.form-list input, .form-list textarea {
  border: 1px solid var(--bdr-gry);
  width: 100%;
  padding: 8px 10px;
  font-size: 16px;
}
.form-list textarea {
  height: min(200px, 25vw);
}
.form-list input {
  height: 40px;
}
::placeholder {
  font-size: min(14px, 3.4vw);
  color: #CFCFCF;
}
.form-button-wrap {
  margin-top: min(50px, 8vw);
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -ms-align-items: center;
  align-items: center;
  gap: min(10vw, 20px);
}
#conf-button, #send-button {
  width: min(100%, 380px);
  height: min(60px, 12vw);
  background: var(--green);
  font-size: min(18px, 4vw);
  font-weight: 600;
  color: #fff;
}
@media (min-width:768px) {
  body {
    padding-top: 30px;
    padding-bottom: 30px;
  }
  #container {
    border-radius: 30px;
  }
  .type-list {
    grid-template-columns: 40% 1fr 1fr;
  }
  .type-item {
    display: grid;
    grid-template-rows: 250px 60px auto; /* 行を3つ明示 */
  }
  .type-item .thumb {
    gap: 10px;
  }
  .type-item.hybrid .thumb figure {
    width: min(200px, 100%);
  }
  .type-item .thumb figure, .type-item.hybrid .thumb figure {
    aspect-ratio: 1;
  }
  .type-item.hybrid .star figure {
    height: min(20px, 8vw);
  }
  .type-item.hybrid {
    grid-area: 1 / 1 / 2 / 2;
  }
  .type-item:nth-child(2) {
    grid-area: 1 / 2 / 2 / 3;
    border-left: 1px solid var(--bdr-pale-gry);
    border-top: none;
  }
  .type-item:nth-child(3) {
    grid-area: 1 / 3 / 2 / 4;
    border-top: none;
  }
}
/*20250514 edit ++++*/
.price-hikaku-wrap .table-wrap {
  padding-top: 0;
}
.hikaku-table.price tr.base td p {
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -ms-align-items: center;
  align-items: center;
  font-size: min(11px, .88em);
  min-height: 5em;
  gap: 2px;
}
.price-hikaku-wrap .att-num-list {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: flex-end;
  font-size: min(12px, 2.5vw);
  gap: 5px 1em;
  margin-top: 5px;
}

/*エリア　20250519 edit +++++++++*/
.tbl-list {
  width: 100%;
  color: #008A00;
}
@media (max-width: 619px) {
  .tbl-list {
    font-size: 80%;
  }
}
.tbl-list th, .tbl-list td {
  vertical-align: top;
  font-weight: normal;
  text-align: left;
  border-width: 1px;
  border-style: solid;
}
.tbl-list th {
  /* 見出しセルの背景色 */
  background-color: #008A00;
  text-align: center;
  vertical-align: middle;
  font-size: 110%;
  /* 見出しセルの文字色 */
  color: #fff;
  padding: 0.5em;
  border-color: #008A00 #008A00 #fff #008A00;
  width: 30%;
}
.tbl-list td {
  border-color: #ccc;
}
.list-link {
  list-style-type: none;
  margin: 0;
  padding: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
.list-link > li {
  -ms-flex-preferred-size: calc(100%/3);
  flex-basis: calc(100%/3);
  padding: 0.5em;
}
.list-link > li a {
  color: #1a73e8;
  text-decoration: underline;
  line-height: 1.4;
}
.rankig-area .min-att {
  text-align: center;
  font-size: min(12px, 2.6vw);
}
/*point 20250611edit*/
.sec-point-blc.wall-wht{
  background-color: #fff;
}
.sec-point-blc.wall-wht .contents-box{
  margin-top: min(14px,3vw);
}
.sec-point-blc.wall-wht .point-list{
  padding: 0;
  border-radius: 0;
  box-shadow: none;
}
.sec-point-blc.wall-wht .point-list li:nth-child(n+2) {
  margin-top: min(20px, 4vw);
}
.sec-point-blc.wall-wht .point-list .in-title{
  justify-content: center;
  translate:-.5em 0;
}
.sec-point-blc.wall-wht .point-list .in-title .dot-line{
  font-size: 1.1em;
}