@charset "UTF-8";
/* CSS Document */ :root {
  --pink: #E60180;
  --red: #ec0319;
  --wblue: #46B0E1;
  --green: #01A13C;
  --ylw: #fcff00;
  --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);
}

.mt5 {margin-top: min(5px, 1.25vw);}
.mb5 {margin-bottom: min(5px, 1.25vw);}
.pt5 {padding-top: min(5px, 1.25vw);}
.pb5 {padding-bottom: min(5px, 1.25vw);}
.mt10 {margin-top: min(10px, 2vw);}
.mb10 {margin-bottom: min(10px, 2vw);}
.pt10 {padding-top: min(10px, 2vw);}
.pb10 {padding-bottom: min(10px, 2vw);}
.mt15 {margin-top: 15px;}
.mb15 {margin-bottom: 15px;}
.pt15 {padding-top: 15px;}
.pb15 {padding-bottom: 15px;}

.mt14 { margin-top: min(14px, 3vw); }
.mt20 { margin-top: min(20px, 5vw); }
.mt25 { margin-top: min(25px, 7vw); }

.fs-80 { font-size: 80%; }
.fs-85 { font-size: 85%; }
.fs-90 { font-size: 90%; }
.fs-110 { font-size: 110%; }

/*.ffs-p { font-feature-settings: "palt"; }*/

/*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: #fff;
  width: 100%;
 font-feature-settings: "palt";
}
.inner {
  padding-left: min(25px, 3vw);
  padding-right: min(25px, 3vw);
}
.fl {
  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;
  flex-direction: column;
  background: #fff;
  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 {
  color:#040404;
  font-weight: 800;
}
.fc-red {
  color: var(--red);
}
.fc-pink {
  color: var(--pink);
}
.fc-ylw {
  color: var(--ylw);
}
.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(251, 255, 154, 0) 60%, rgba(251, 255, 154, 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(251, 255, 154, 0) 12%, rgba(251, 255, 154, 1) 12%, rgba(251, 255, 154, 1) 90%, rgba(251, 255, 154, 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);
}
img.img-boxshadow {
  margin-bottom: 1em;
  box-shadow: 0px 3px 5px 0px rgba(0, 0, 0, 0.25);
}

/*header
===============================================================*/
/* ヘッダー */
.site-header {
  padding: 0;
}
/*
.site-header img {
  height: min(34px,11vw);
  width: auto;
}*/

/*main +++++++++++++++++++++++++++++++++++++++++*/
main {
  flex: 1;
}
/*Content
=====================================*/
#content {
  margin-top: min(20px, 5vw);
  padding-bottom: min(50px, 10vw);
}
.contents-box, section + section {
  margin-top: min(25px, 5vw);
}
.sec-hikaku-blc.under-blc .contents-box, section + section {
  margin-top: 0;
}
.contents-box .in-text {
/*  font-size: clamp(0.875rem, 0.83rem + 0.23vw, 1rem);*/
}
.sec-title {
  background: #0c2c75;
  color: #fff;
  font-size: min(24px, calc(100vw/21));
  font-weight: 800;
  text-align: center;
  line-height: calc(30/20);
  padding: 10px min(15px, 3vw)
}
.line-title {
  background: #f8f8ff;
  font-size: min(20px, calc(100vw/21));
  font-weight: 600;
  padding: 10px 10px 10px 15px;
  border-left: 6px solid #092b72;
  line-height: 1.3em;
  margin: 1em min(15px, 2vw);
}
.gray-box {
  background: #EDEDED;;
}
.gray-box > ul {
  padding: min(13px, 3vw);
}
.intro-check-list > li {
  line-height: calc(16/10);
  padding-left: 1.5em;
  font-size: 1.07em;
}
.intro-check-list > li:nth-child(n+2) {
  margin-top: min(10px, 2vw);
}
.intro-check-list > li::before {
  content: "";
  width: 1em;
  aspect-ratio: 1;
  background: url("../images/icon-chk.webp") no-repeat center/cover;
  position: absolute;
  left: 0;
  top: .25em;
}
.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: #fdf4e3;
  padding: min(10px, 3vw) min(15px, 5vw);
  border-radius: 20px;
  text-spacing-trim: space-all;
}
.fkds-box .comment p::before {
  content: "";
  width: min(15px, 4vw);
  aspect-ratio: 1;
  background: #fdf4e3;
  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;
}
/*intro ++++++++++++++++++++*/
.sec-intro-blc {
  padding-left: min(25px, 3vw);
  padding-right: min(25px, 3vw);
  padding-bottom: min(50px, 6vw);
}
/*point ++++++++++++++++++++*/
.sec-point-blc {
  background: #fefaf4;
  padding-bottom: min(50px, 6vw);
}
.sec-point-blc .contents-box {
  margin-top: 10px;
}

/* acc */
.acc-point-item {
  border: 1px solid #1a3269;
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: .8em;
  background: #fff;
}
.acc-point-header {
  display: flex;
  align-items: center;
  cursor: pointer;
  position: relative;
  min-height: 80px;
  padding-right: 48px;
}
.acc-point-thumb {
  width: 90px;
  min-width: 90px;
  height: 80px;
  overflow: hidden;
  border-radius: 9px 0 0 9px;
  flex-shrink: 0;
}
.acc-point-item.open .acc-point-thumb {
  border-radius: 9px 0 0 0;
}
.acc-point-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.acc-point-header-text {
  padding: min(10px, 2vw) min(10px, 2vw);
  flex: 1;
}
.acc-point-header-text .num {
  font-size: min(26px, 6.4vw);
  font-weight: 900;
  color: #1a3269;
  margin-right: 4px;
}
.acc-point-header-text .title {
  font-size: min(22px, 4.7vw);
  font-weight: 900;
  color: #1a3269;
  display: inline;
  background: linear-gradient(transparent 1em, #e4d5aa 0, #e4d5aa 1.4em, transparent 0);
  -webkit-text-stroke: 0.5px currentColor;
}
.acc-point-header-text .title_s {
  font-size: min(22px, 4.5vw);
  font-weight: 900;
  color: #1a3269;
  display: inline;
/*  background: linear-gradient(transparent 70%, #e4d5aa 70%);*/
  background: linear-gradient(transparent 1em, #e4d5aa 0, #e4d5aa 1.4em, transparent 0);
  -webkit-text-stroke: 0.5px currentColor;
}

.acc-point-header-text .sub {
  margin-top: .5em;
  font-size: clamp(0.75rem, 0.614rem + 0.68vw, 1.125rem);
  font-weight: 900;
  color: #1a3269;
  line-height: 1.3;
}
.acc-point-icon {
  position: absolute;
  right: 14px;
  top: 0;
  bottom: 0;
  margin: auto 0;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  font-weight: 300;
  color: #1a3269;
  line-height: 1;
  transition: transform 0.25s ease, opacity 0.15s ease;
  user-select: none;
}
.acc-point-item.open .acc-point-icon {
}
.acc-point-body {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.45s ease;
}
.acc-point-item.open .acc-point-body {
  max-height: 2000px;
}
.acc-point-body-inner {
  padding: 20px 16px 24px;
  border-top: 1px solid #e0e0e0;
}
.acc-point-body-inner .body-text {
  font-size: clamp(0.75rem, 0.659rem + 0.45vw, 1rem);
  line-height: calc(16/10);
  color: #333;
  margin-bottom: 10px;
}
.acc-point-body-inner .info-image {
  width: 100%;
  height: auto;
  display: block;
  margin-bottom: 12px;
  box-shadow: 0px 3px 5px 0px rgba(0, 0, 0, 0.25);
}
.acc-point-body-inner .info-image.border {
  border: 5px solid #fff;
}
.acc-point-body-inner .body-text-bottom {
  font-size: clamp(0.75rem, 0.659rem + 0.45vw, 1rem);
  line-height: calc(16/10);
  color: #333;
  margin-top: 12px;
}

.sec-point-blc > .in-text {
  padding-left: min(25px, 3vw);
  padding-right: min(25px, 3vw);
}

/*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-top: min(20px, 5vw);
}
.hikaku-table {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  border-right: 1px solid #000;
  border-bottom: 1px solid #000;
  border-collapse: separate;
}
.hikaku-table td {
  border-top: 1px solid #000;
  border-left: 1px solid #000;
  vertical-align: middle;
  text-align: center;
  line-height: calc(14/12);
  padding: min(10px, 2vw) 0;
  font-weight: 600;
}
.hikaku-table td.td-rank {
  padding: min(4px, 1vw) 0 min(8px, 2vw);
}
.hikaku-table .crown {
  width: clamp(37px, 10vw, 67px);
  height: auto;
  display: block;
  margin: 0 auto 2px;
}
.hikaku-table .logo-box {
  margin: 0 auto 5px;
  width: 90%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.hikaku-table .logo-box img {
  max-width: 100%;
  height: 52px;
  object-fit: contain;
  display: block;
}
.hikaku-table .name-link {
  display: block;
  text-align: center;
  font-size: clamp(0.563rem, 0.403rem + 0.8vw, 1rem);
  font-weight: bold;
  color: #1a50a0;
  text-decoration: underline;
  text-underline-offset: 3px;
  line-height: 1.3;
}
.hikaku-table .name-link:hover {
  color: #0a3070;
}
.stars {
  font-size: clamp(12px, 3.2vw, 20px);
  line-height: 1;
  white-space: nowrap;
  padding-top: .3em;
  padding-bottom: .3em;
}
.stars img {
  width: 70%;
  height: auto;
  margin: 0 auto;
}
.star-on  { color: #f5c400; }
.star-off { color: #ccc; }
.score {
  font-size: clamp(1.625rem, 1.375rem + 1.25vw, 2.313rem);
  font-weight: 900;
  color: #ed0d1e;
  line-height: 1.1;
}
.score span { font-size: 0.55em; }

.hikaku-table tr td:nth-child(1) {
/*  width: min(76px, 18vw);*/
  width: 18%;
  background: #0b2d75;
  font-weight: 600;
  position: sticky;
  left: 0;
  z-index: 1;
  border-right: 1px solid #000;
  color: #fff;
  font-size: clamp(0.719rem, 0.526rem + 0.97vw, 1.25rem);
}
.hikaku-table tr td:nth-child(1) span {
  font-size: 70%;
}
.hikaku-table tr td:nth-child(2) {
  background: #fff9bb;
  border-left: none;
/*  width: min(100px, 27vw);*/
  width: 30%;
}
.hikaku-table tr.total td:nth-child(n+2) {
  font-size: clamp(1.125rem, 0.716rem + 2.05vw, 2.25rem);
  font-weight: 800;
  width: 26%;
}
.hikaku-table tr.total td:nth-child(2) {
  font-size: clamp(1.25rem, 0.841rem + 2.05vw, 2.375rem);
  color: #E6015D;
}
.hikaku-table td > div {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  font-size: clamp(1.063rem, 0.767rem + 1.48vw, 1.875rem);
  line-height: 1.3;
}
.hikaku-table td > div.fs-mid {
  font-size: clamp(0.563rem, 0.313rem + 1.25vw, 1.25rem);
}
.hikaku-table tr.sapo td > div.fs-mid {
  font-size: clamp(0.625rem, 0.352rem + 1.36vw, 1.375rem);
}
.hikaku-table tr.quality td > div {
  font-size: clamp(0.625rem, 0.253rem + 1.86vw, 1.125rem);
}
.hikaku-table tr.cost td > div {
  font-size: clamp(0.6rem, 0.341rem + 1.3vw, 1.313rem);
}
.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 tr.sapo td .mark {
  min-height: 4.5em;
}
.hikaku-table tr.quality td .mark {
  min-height: 4.5em;
}
.hikaku-table td .mark::before {
  content: "";
  width: clamp(3.125rem, 2.67rem + 2.27vw, 4.375rem);
  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("../images/icon-hikaku_max.svg");
}
.hikaku-table td .mark.mid::before {
  background-image: url("../images/icon-hikaku_mid.svg");
}
.hikaku-table td .mark.min::before {
  background-image: url("../images/icon-hikaku_min.webp");
}
.hikaku-table {
  width: 100%;
  counter-reset: number 0;
}
.hikaku-table .att {
  padding-right: 1.2em;
}
.hikaku-table .att::after {
  counter-increment: number 1;
  content: "※"counter(number);
  position: absolute;
  top: 1px;
  right: 0;
  font-size: clamp(0.438rem, 0.256rem + 0.91vw, 0.938rem);
  font-weight: 400;
}
.hikaku-table sup {
  position: absolute;
  top: 12%;
  right: -1.7em;
  font-size: clamp(0.5rem, 0.221rem + 1.4vw, 0.875rem);
  font-weight: 400;
}

.hikaku-table tr.cost sup {
  top: 7%;
  right: -1.1em;
}

.hikaku-table tr.quality sup {
  top: 3%;
  right: -1.7em;
}

.hikaku-table tr.hikaku-cta 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: clamp(0.625rem, 0.398rem + 1.14vw, 1.25rem);
  animation: dokidoki 1s ease-in-out infinite;
}
.hikaku-table td a span {
  padding-right: min(27px, 3.5vw);
}
.hikaku-table td a span::after {
  content: "";
  width: 1em;
  aspect-ratio: 1;
  background: url("../images/icon-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: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  font-size: min(11px, 2.5vw);
  gap: 5px 1em;
  margin-top: 5px;
}


/*ranking +++++++++++++++++++++++++++++++++*/
.sec-ranking-blc {
  background: #fdfaf5;
  margin-top: 0;
  padding-top: min(20px, 4vw);
  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: flex;
  flex-direction: column;
  gap: min(10px, 1vw);
}
.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); */
  padding: min(12px, 3vw) 0 min(50px, 8vw);
  filter: drop-shadow(0 5px 10px rgba(0, 0, 0, .25));
}
.ranking__head .in-title {
  display: grid;
  grid-template-columns: 3fr 1fr;
  align-items: center;
  font-weight: 700;
  padding: 0 min(9px, 2vw);
}
.ranking__head .in-title .site-name {
  font-size: min(30px, calc(100vw/18));
  display: grid;
  grid-template-columns: min(10vw, 50px) auto;
  align-items: center;
  gap: 3px;
}
.ranking__head .in-title .site-name .icon {
  padding-bottom: 3px;
}
.ranking__head .in-title .site-name.min {
  font-size: min(30px, calc(100vw/20));
}
.ranking__head .in-title .score-area {
  display: grid;
  grid-template-columns: 5.5em auto;
  align-items: center;
  justify-content: flex-end;
}
.ranking__head .in-title .score-area p {
  font-size:clamp(1.313rem, 1.018rem + 1.48vw, 2.125rem);
  color: #ff2b40;
  text-align: right;
  padding-right: .2em;
}
.ranking__head .in-title .score-area p span {
  font-size: min(15px, calc(100vw/20));
  color: #ff2b40;
  padding-bottom: 1px;
}
.ranking__score {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5px;
  align-items: center;
}
.ranking__padding-box {
  padding: 0 min(15px, 2vw) 0;
}
.ranking__point, .ranking__target {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.ranking__point ul, .ranking__target ul {
  padding: min(10px, 1vw) min(20px, 2vw);
  font-weight: 600;
/*  font-size: clamp(0.688rem, 0.438rem + 1.25vw, 1.375rem);*/
  font-size: min(18px, 3.4vw);
}
.ranking__point {
  background: #fff;
  border: 2px solid #a47f39;
}
.ranking__target {
  background: #fff;
  border: 2px solid #c5af86;
}
.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);
  top: -1px;
}
.dig-title.p1 {
  background: #a47f39;
  color: #fff;
}
.dig-title.p2 {
  background: #c5af86;
  color: #fff;
}
.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(5px, 1vw);
}
.check-list > li::before {
  content: "";
  width: 1em;
  aspect-ratio: 1;
  position: absolute;
  left: 0;
  top: .25em;
}
.check-list.p1 > li::before {
  width: 1.25em;
  aspect-ratio: 1;
  background: url("../images/icon-point1.webp") no-repeat center/cover;
}
.check-list.p2 > li::before {
  width: 1.25em;
  aspect-ratio: 1;
  background: url("../images/icon-point2.webp") no-repeat center/cover;
}

/*review*/
.voice-heading { position: relative; width: 100%; }
.voice-heading img { width: 100%; height: auto; display: block; }
.review-bg { background: #fffbf5; }

.carousel-wrapper {
  position: relative;
  margin-top: -40px;
  padding: 0 24px 40px;
}
.carousel-track-outer { overflow: hidden; border-radius: 4px; }
.carousel-track { display: flex; transition: transform 0.4s ease; }

.slide {
  min-width: 100%;
  background: #fff;
  border: 2px solid #D5A446;
  border-radius: 4px;
  overflow: hidden;
}
.slide-photo img { width: 100%; height: auto; display: block; }
.slide-body { padding: 20px 1em 1em; }

.slide-title {
  text-align: center;
  font-size: clamp(1.125rem, 1.034rem + 0.45vw, 1.375rem);
  font-weight: 700;
  color: #333;
  margin-bottom: .3em;
}
.slide-title .heart {
  display: inline-block;
  width: clamp(1.25rem, 1.159rem + 0.45vw, 1.5rem);
  height: clamp(1.25rem, 1.159rem + 0.45vw, 1.5rem);
  vertical-align: middle;
  margin-right: 6px;
  position: relative;
  top: -2px;
}

.slide-names {
  text-align: center;
  margin-bottom: .5em;
  line-height: 1.5;
}
.name-row { font-size: clamp(0.875rem, 0.739rem + 0.68vw, 1.25rem); font-weight: 700; }
.name-row.blue { color: #2563be; }
.name-row.gold { color: #D5A446; }

.slide-text {
  font-size: clamp(0.875rem, 0.784rem + 0.45vw, 1.125rem);
  line-height: 1.5;
  color: #333;
}

.carousel-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-80%);
  width: 36px;
  height: 36px;
  background: #D5A446;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
}
.carousel-btn.prev { left: -2px; }
.carousel-btn.next { right: -2px; }
.carousel-btn svg {
  width: 16px; height: 16px;
  fill: none; stroke: #fff;
  stroke-width: 2.5;
  stroke-linecap: round; stroke-linejoin: round;
}

.carousel-dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 16px;
}
.dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #ddd;
  cursor: pointer;
  transition: background 0.3s;
}
.dot.active { background: #D5A446; }
/* /carousel */

.review-item:nth-child(n+2) {
  margin-top: min(25px, 8vw);
}
.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 #c7b180;
  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: #c7b180;
  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 dt {
/*  border-radius: min(20px, 4vw) min(20px, 4vw) 0 0;*/
  border-radius: 10px 10px 0 0;
  background: #0b2d75;
  color: #fff;
  font-size: min(18px, 4vw);
  font-weight: 800;
  gap: 1em;
  padding: clamp(0.313rem, 0.153rem + 0.8vw, 0.75rem) .5em clamp(0.313rem, 0.153rem + 0.8vw, 0.75rem);
  text-align: center;
  border: 2px solid #0b2d75;
}
.price-list dt p {
  text-align: center;
  font-size: clamp(0.625rem, 0.489rem + 0.68vw, 1rem);
}
.price-list dd {
  border: 2px solid #0b2d75;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 10px;
/*  padding: min(10px, 3vw) min(10px, 1.5vw) min(15px, 4vw);*/
  padding: clamp(0.75rem, 0.568rem + 0.91vw, 1.25rem) min(10px, 1.5vw);
  background: #f6f9ff;
/*  border-radius: 0 0 min(20px, 4vw) min(20px, 4vw);*/
  border-radius: 0 0 10px 10px;
  color: #0c2977;
}
.price-list dd > div {
  font-size: min(18px, 3.4vw);
  box-shadow: 0px 1px 3px 0px rgba(166, 182, 228, 1);
/*  padding: min(12px, 3vw) min(10px, 2vw) min(15px, 4vw); */
  padding: clamp(0.75rem, 0.568rem + 0.91vw, 1.25rem) min(10px, 2vw);
  display: grid;
  place-items: center;
  background: #fff;
  gap: 8px;
  font-weight: 600;
  border-radius: 5px;
}
.price-list dd > div .price span {
  font-size: 1.45em;
  font-weight: 800;
  margin-right: 2px;
}

.sp_br {
  display: none;
}

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


/*cta*/
.cta-button {
  display: flex;
  flex-direction: column;
  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);*/
  font-size: clamp(0.75rem, 0.523rem + 1.14vw, 1.375rem);
  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); */
  font-size: clamp(0.875rem, 0.557rem + 1.59vw, 1.75rem);
  letter-spacing: .05em;
  font-weight: 600;
}
.cta-button .button .main {
/*  font-size: min(40px, calc(100vw/20));*/
  font-size: clamp(1.188rem, 0.665rem + 2.61vw, 2.625rem);
  color: #fff;
  letter-spacing: .025em;
  font-weight: 600;
}
.cta-button .button::before {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
/*  translate: -40% -50%;*/
  translate: -90% -50%;
  width: 1.25em;
  aspect-ratio: 1;
  background: url("../images/icon-cta-arrow.svg") no-repeat center/contain;
}
/*thanks*/
.page-thanks-blc {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.round-button {
  width: min(250px, 100%);
  display: flex;
  flex-direction: column;
  margin-top: min(60px, 10vw);
  height: 50px;
  border-radius: 100vmax;
  background: linear-gradient(#07CB00, #00952D);
  border-bottom: solid 3px #143300;
  border-radius: 5px;
}
.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;
}
/*footer ++++++++++++++++++++++ */
footer {
  background: #0b2d75;
  padding-top: min(30px, 6vw);
  padding-bottom: min(30px, 6vw);
}
.footer-nav {
  color: #fff;
  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: #0b2c75;
  height: min(150px, 25vw);
  display: grid;
  place-content: center;
}
.under-title {
  font-size: min(24px, calc(100vw / 18));
  font-weight: 800;
  letter-spacing: .05em;
  color: #fff;
}
.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: #0b2c75;
  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: #f2f2f2;
}
.survey-result-table tbody td {
  font-weight: 600;
  border-bottom: 1px solid #f2f2f2;
}
.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: flex;
  flex-direction: column;
  align-items: center;
  gap: min(10vw, 20px);
  padding-bottom: 3px;
  border-radius: 5px;
}
#conf-button, #send-button {
  width: min(100%, 380px);
  height: min(60px, 12vw);
  background: linear-gradient(#07CB00, #00952D);
  font-size: min(18px, 4vw);
  font-weight: 600;
  color: #fff;
  border-bottom: solid 3px #143300;
  border-radius: 5px;
}

#conf-form .form-list dt{
  font-weight: 600;
}

#conf-form .form-list dd {
  margin-bottom: 2em;
}

@media (min-width:768px) {
  body {
    padding-bottom: 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;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}
.price-hikaku-wrap .att-num-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  font-size: min(12px, 2.5vw);
  gap: 5px 1em;
  margin-top: 5px;
}
/* price hikaku-table */
.hikaku-table tr td:nth-child(1) {
  width: 6em;
  font-size: clamp(0.719rem, 0.526rem + 0.97vw, 1.25rem);
}
.hikaku-table.price tr td:nth-child(1) span {
  font-size: 90%;
  line-height: 1.4;
}
.hikaku-table .price td > div {
  font-size: clamp(1rem, 0.75rem + 1.25vw, 1.688rem);
  line-height: 1.3;
}

/*エリア　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;
}

.sec-hikaku-blc.under-blc h2{
  color: #fffc81;
}

.sec-hikaku-blc.under-blc h2 span{
  color: #fff;
}

/* detail-hikaku */
.detail-hikaku-wrap {
  padding:5px 3px;
  box-shadow: 0px 3px 5px 0px rgba(0, 0, 0, 0.25);
}
.detail-hikaku-head {
  display: block;
  width: 90%;
  height: auto;
  margin: 0 auto;
}
.detail-hikaku-cols {
  display: flex;
  gap: 10px;
  align-items: stretch;
}
.detail-hikaku-col {
  flex: 1;
  border-radius: clamp(0.313rem, 0.08rem + 1.16vw, 0.625rem);
  overflow: hidden;
}
.detail-hikaku-col--left {
  border: 1px solid #046f95;
}
.detail-hikaku-col--right {
  border: 1px solid #f42140;
}
.col-header {
  text-align: center;
  font-size: clamp(0.563rem, 0.283rem + 1.4vw, 0.938rem);
  font-weight: 600;
  color: #fff;
  padding: 6px;
  letter-spacing: 0.02em;
}
.col-header--left  { background: #046f95; }
.col-header--right { background: #f42140; }
.col-body-img {
  display: block;
  width: 100%;
  height: auto;
  padding: .5em;
}

.detail-hikaku-col a {
  display: grid;
  height: 3em;
  width: 95%;
  border-radius: 100vmax;
  place-content: center;
  background: linear-gradient(#00952D, #07CB00);
  margin-left: auto;
  margin-right: auto;
  color: #fff;
  font-size: clamp(0.55rem, 0.029rem + 2.6vw, 1.25rem);
  animation: dokidoki 1s ease-in-out infinite;
}
.detail-hikaku-col a span.txt {
  padding-right: min(27px, 3.5vw);
}
.detail-hikaku-col a span.txt::after {
  content: "";
  width: 1em;
  aspect-ratio: 1;
  background: url("../images/icon-arrow.svg") no-repeat center/contain;
  position: absolute;
  right: 0;
  top: 50%;
  translate: 0 -50%;
}
