@charset "UTF-8";

@import url('https://fonts.googleapis.com/css2?family=Asap+Condensed&family=Oswald:wght@400;500&display=swap');

/*additional reset
---------------------------------------------------*/
*, *:before, *:after {
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
         -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
            box-sizing: border-box;
}

body.safari #content, body.safari #footer {/*サファリでリンク先から戻った時文字が拡大する対応*/
    -webkit-text-size-adjust: 100%;
}

body {
    font: 16px / 1.5 "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", メイリオ, Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  background-color: #fff;
  background-image: linear-gradient(#e7f9fc 1px, transparent 0),
                    linear-gradient(90deg, #e7f9fc 1px, transparent 0);
  background-size: 20px 20px;
margin: 0;
}
/** link **/
a:link {
    color: #1c7fbd;
	text-decoration: underline;
}

a:visited {
    color: #1c7fbd;
}

a:hover,
a:active {
	text-decoration: none;
}

/*初期設定
----------------------------------------------------*/
#wrapper{
    width: 800px;
    padding: 0 0 0 0;
    overflow: hidden;
    margin: auto;
    position: relative;
/*    background-color: #fff;*/
    filter: drop-shadow(2px 3px 6px rgba(88, 88, 88, 0.1));
}
.content{
    display: block;
    margin: 0 auto;
    width: 95%;
}
@media screen and (min-width:640px) {
    .pc{
        display: block;
    }
    .sp{
        display: none;
    }
}

@media screen and (max-width:640px) {
    .pc{
        display: none;
    }
    .sp{
        display: block;
    }
    #wrapper{
        width: 100%;
    }
}
/*layout
----------------------------------------------------*/
p {
    margin-top: 20px;
    margin-bottom: 20px;
}

img{
    width: 100%;
/*    margin: 0 0 20px;*/
    padding: 0;
}
.taC{
    text-align: center;
}
.taR{
    text-align: right;
}
.mt0{
    margin-top: 0;
}
.mb0{
    margin-bottom: 0;
}
.mb10{
    margin-bottom: 10px;
}
.mb20{
    margin-bottom: 20px;
}
.mt20{
    margin-top: 20px;
}
.mb30{
    margin-bottom: 30px;
}
.mt30{
    margin-top: 30px;
}
.mb40{
    margin-bottom: 40px;
}
.mt40{
    margin-top: 40px;
}
.red{
    color: rgb(255, 0, 0);
    font-weight:bold;
}
.gray{
    color: rgb(110, 110, 110);
}
.blue{
    color: rgb(0, 0, 255);
    font-weight:bold;
}
.marker{
    background: rgba(0, 0, 0, 0) linear-gradient(transparent 60%,#faf685 0%) repeat scroll 0 0;
}
.marker02{
    border-bottom-style: dotted;
    border-bottom-color: #dcdcdc;
    border-bottom-width: 3px;
    padding-bottom: 3px;
}
.fsLL{
    font-size: 23px;
}
.fsL{
    font-size: 20px;
}
.fsM{
    font-size: 19px;
}
.fsSM{
    font-size: 14px;
}
.fsS{
    font-size: 10px;
}
.fwB {
  font-weight:bold;
}
.note {
    text-align: right;
    font-size: 12px!important;
    color: rgb(110, 110, 110);
    margin-top: 5px;
}
.note2 {
    text-align: right;
    font-size: 10.5px!important;
    color: rgb(110, 110, 110);
    margin-top: 5px;
}
.swipe {
    text-align: center;
    color: #a3a0a0;
    font-size: 0.9rem;
    margin-bottom: 10px;
    margin-top: 0;
}
video {
  width: 100%;
}
.video_ma {
  margin-top:1.5vw;
}


/*ヘッダー*/
header {
    z-index: 999;
    box-shadow: 0 1px 8px rgba(0, 0, 0, 0.34);
}

/*ライター紹介*/
.balloon_box{
    margin: 1.5em 0;
    overflow: hidden;
    display: flex;
    background: #fff;
    padding: 10px;
    box-shadow: 0 1px 3px rgba(0,0,0,.2);
    border-radius: 10px;
    font-size: 13px;
    align-items: center;
    justify-content: center;
}

.faceicon {
    display: inline-block;
    width: 55px;
    min-width: 55px;
    height: auto;
    position: relative;
    overflow: hidden;
}

.faceicon img {
    border: solid 3px #adeafd;
    box-sizing: border-box;
    width: 55px;
    max-width: 55px;
    height: 55px !important;
    object-fit: cover;
    border-radius: 50%;
    margin: 0 !important;
}

.balloon {
    display: block;
    position: relative;
    margin: 0 0 0 10px;
}
.name {
    display: inherit;
    font-size: 10px;
    color: #808080;
    text-align: center;
}

@media screen and (max-width: 699px){
    .balloon_box{
        font-size: 10.5px;
    }
}

/* 目次 */
.contenedor {
  display: table;
  margin: 0px auto;
  position: relative;
  width: 90%;
}

ul#toc {
    list-style: none;
    padding-left: 0;
}

.expand {
  width: 100%;
  padding:8% 5% 10%;
  max-height: 80px;
  overflow: hidden;
  position: relative;
  transition: .5s;
  background-color:#f7f7f7;
  font-size: 13px;
  border-radius:8px;
  color:#666666;
  line-height: 1.8;
  margin-bottom: 10%;
}
.expand span {
  padding-left: 13px;
}
.expand li {
  border-bottom: 1px dotted #abb1ad;
}
.expand a {
  text-decoration: none;
  color:#666666;
  font-weight: normal;
}

.expand a:hover {
  text-decoration: none;
}

.expand a:visited {
  text-decoration: none;
}

.expand::before {
    content: "";
    position: absolute;
    width: 120%;
    height: 50%;
    bottom: 0;
    left: -10%;
    background-image: linear-gradient(rgba(255, 255, 255, 0), #ffffff);
    pointer-events: none;
    transition: 1s;
}

.contenedor input {
  visibility: hidden;
}

.contenedor label {
  position: absolute;
  bottom: 20%;
  display: block;
  font-size: .9em;
  padding: .20em 10px;
  right: 0;
  left: 0;
  margin: auto;
  width: fit-content;
  background: #aaa;
  box-shadow:-5px 0 white;
  color: white;
  z-index:999;
  cursor: pointer;
  text-transform: uppercase;
  border-radius: 5px;
}
input[type=checkbox]:checked ~ .expand {
 max-height: 500px;
}

input[type=checkbox]:checked ~ .expand:before {
 opacity: 0
}

@media screen and (max-width:768px){
.expand {
    padding: 17% 5% 10%;
}
.contenedor label {
    bottom: 10%;
}
}

h1 {
  font-family: 'Asap Condensed', sans-serif;
  color: #fff;
  background: #009ce4;
  border-top: none;
  font-size: clamp(20px, 2.2vw, 24px);
  z-index: 999;
  text-align: center;
  margin: 0;
  padding: 5px 0;
}
h2 {
    padding: 0.5rem 1.5rem;
    font-size: clamp(22px, 2.2vw, 24px);
    background-color: #afedff;
    margin-top: 5%;
}

h2 .fas {
    padding-right: 10px;
}

h2 span {
  font-size: clamp(14px, 2.2vw, 18px);
}

h3 {
    padding: 0.7em 1.5rem 0.5em 1.5rem;
    color: #494949;
    background: #f6f6f6;
    font-weight: bold;
    font-size: clamp(20px, 2.2vw, 22px);
    line-height: 1.6rem;
    margin-bottom: 20px;
    border-left: 3px solid #79c6dc;
    margin-top: 5%;
}

h4 {
    padding: 0.7rem 1rem;
    background: #eaf5f8;
    font-size: clamp(20px, 2.7vw, 22px);
    border-bottom: 2px solid #1dbbe1;
}

h5 {
    background-color: #23acda;
    padding: 10px;
    font-weight: bold;
    margin-bottom: 10px;
    margin-top: 0;
    text-align: center;
    font-size: clamp(18px, 2.7vw, 20px);
    box-shadow: 2px 2px 3px #23acda;
    color: #fff;
}

h5.hyou {
  background-color: #d5f2f9;
  box-shadow: 2px 2px 3px #b5c1c4;
  margin: 7% 10% 1%;
  color: #000;
}


.bg_w {
  background: #fff;
    border-radius: 10px;
    box-shadow: 0 1px 3px rgba(0,0,0,.2);
    margin: 3% 0;
    padding: 3%;
    position: relative;
    margin-bottom:5%;
}

/*表*/
.list_table,
.list_table > dt,
.list_table > dd {
  box-sizing: border-box;
}

.list_table > dt,
.list_table > dd {
  padding: 0.3em;
  margin: 0px;
}

.list_table {
  display: flex;
  flex-wrap: wrap;
  margin: 2% 10% 1%;
  font-size: 0.9rem;
  text-align: center;
  border-bottom: 1px solid #ddd;
  border-left: 1px solid #ddd;
}
.list_table > dt,
.list_table > dd {
  display: flex;
  flex-direction: column;
  justify-content: center;
  border-top: 1px solid #ddd;
  border-right: 1px solid #ddd;
}
.list_table > dt {
  width: 40%;
  background-color: #e1f6fb;
}
.list_table > dd {
  width: 60%;
  border-right: 1px solid #ddd;
}

@media screen and (max-width:768px){
  .list_table {
    margin: 3% 0% 1%;
  }
  h2 {
    margin-top: 10%;
    padding: 0.5rem 1rem;
  }
  h3 {
    padding: 0.7em 1rem 0.5em 1rem;
}
  h5 {
    padding: 5px;
  }
  h5.hyou {
    margin: 0;
  }
}

  /* 矢印 */
        .downArrow {
            display: -webkit-box;
            display: -ms-flexbox;
            display: flex;
            -webkit-box-pack: center;
            -ms-flex-pack: center;
            justify-content: center;
            -webkit-box-sizing: border-box;
            box-sizing: border-box;
                margin-top: 1vw;
            /*animation: moveDown 1s infinite;*/ /* アニメーションを追加 */
        }

        .downArrow>span {
            /* 矢印の大きさの設定 */
            width: 100px;
            height: 65px;
            padding: 0 10px;
            -webkit-box-sizing: border-box;
            box-sizing: border-box;
        }

        .downArrow>span::before {
            content: "";
            display: block;
            margin: 0 auto;
            width: 50%;
            height: 40%;
            /* 矢印の色の設定 */
            background: #e10000;
        }

        .downArrow>span::after {
            content: "";
            display: block;
            width: 100%;
            height: 50%;
            /* 矢印の色の設定 */
            background: -webkit-gradient(linear, left bottom, right top, color-stop(49%, transparent), color-stop(50%, #d096bb)) top left/50% 100% no-repeat, -webkit-gradient(linear, right bottom, left top, color-stop(49%, transparent), color-stop(50%, #d096bb)) top right/50% 100% no-repeat;
            background: linear-gradient(to top right, transparent 49%, #e10000 50%) top left/50% 100% no-repeat, linear-gradient(to top left, transparent 49%, #e10000 50%) top right/50% 100% no-repeat;
        }

        @keyframes moveDown {
            0% {
                transform: translateY(0);
            }
            100% {
                transform: translateY(50px); /* 下方向に100px移動 */
            }
        }

        @media screen and (max-width:768px){
          .downArrow {
            margin-top: 3vw;
          }
        }

/*比較表*/
.rankTable{
  margin-inline: auto;
  margin-top: 100px;
  overflow-x: auto; /* tableタグのはみ出た要素を隠す */
  white-space: nowrap; /* テキストの折り返しなし */
  width: 300px;
  vertical-align: middle;
  font-size:14px;
}
.rankTable>p{
    display: none;
}
.rankTable table{
  width: 100%;
  border-collapse: collapse;
  line-height: 1.2;
  font-size:14px;
  text-align: center;
}
.rankTable th{
  position: sticky;
  width: 70px;
    background-color: #fff;
  left: 0;
  border-bottom: 1px dotted #ddd;
  z-index: 5;
  font-size: 14px;
  color: #fff;
}
.rankTable td{
  width: auto;
  border-bottom: 1px dotted #ddd;
  border-right: 1px dotted #ddd;
  　vertical-align: middle;
  background: #fff;
  font-size:13px;
  padding: 3px 10px 5px;
}
.rankTable table th:first-child {
  color:#1c7fbd;
  padding: 0 15px;
}

.rankTable tr {
     background-color: #79c6dc;
    height: 30px;
}

.rankTable td:last-child{
    border-right: none;
}
.rankTable tr:last-child td,
.rankTable tr:last-child th{
    border-bottom: none;
}
.rankTable  tr:nth-of-type(2) td {
    background-color: #fffbe8;
}
.rankTable  tr:nth-of-type(1) td {
    background-color: #79c6dc;
color:#fff;
font-weight:bold;
vertical-align:middle;
}
.rankTable td:nth-of-type(2) a {
    background-color: #fa3e61;
color:#fff;
border-radius:10px;
padding: 10px;
margin:10px 0;
    font-weight: bold;
    display: block;
box-shadow: #bb223e 0px 0.2em;
text-decoration: none;
}
.rankTable td:nth-of-type(11) {
    font-size: 17px;
}
.rankTable {
width: 100%;
    border: 2px solid #ddd;
    margin-top: 0px;
    z-index: 99;
    vertical-align: middle;
}
.rankTable img{
    margin: 0px !important;
}

span.exe ,span.good,span.normal,span.bad {
    font-size: 150%;
}

span.exe {
    color: #ff3248;
}
span.good {
  color: #99e8f2;
}
span.normal {
  color: #ffd100;
}

    @media screen and (max-width:768px){
        .sp{
            display: block;
        }
        .rankTable table{
            width: 550px;
        }
        .rankTable{
            overflow-x: scroll;
        }
.rankTable td {
font-size:12px;
}
.rankTable th {
font-size:12px;
padding:5px;
color: #000;
}
.rankTable td:nth-of-type(3) a {
margin:2px 5px;
padding:7px 10px ;
    }
}



/*くちこみ*/
ul.slider {
    padding: 0;
}
.voice {
    background-color: #fff;
    padding: 0 3% 3%;
}
.voice_wrapper {
    background-color: #d9f0f7;
    padding: 3%;
}
.kuti {
    border: 1px solid ##23acda47;
    border-radius: 10px;
    background-color: #fff;
    padding: 2% 3%;
}
.star {
  color:#ff9900;
}

.review_header {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 4px 10px 4px;
    line-height: 1.2;
    border-bottom: 1px solid #d9d9d9;
}
.review_header {
    margin-right: 10px;
    margin-top: 3px;
}
.profile_p {
    width: 12%;
    height: auto;
    margin-right: 3%;
}

@media screen and (max-width:768px){
.profile_p {
    width: 24%;
}
.profile {
    font-size: 0.9rem;
}
.kuti > p {
    font-size: 0.9rem;
}
}

/*cta*/
.button {
   margin: 7% 0 0;
}
.yureru-j {
    animation: yureru-j 2s infinite;
}
@keyframes yureru-j {
    0% {
        transform: translate(0px, 2px);
    }
    5% {
        transform: translate(0px, -2px);
    }
    10% {
        transform: translate(0px, 2px);
    }
    15% {
        transform: translate(0px, -2px);
    }
    20% {
        transform: translate(0px, 2px);
    }
    25% {
        transform: translate(0px, -2px);
    }
    30% {
        transform: translate(0px, 0px);
    }
}

.cta02 {
  color: #fff;
  background-color: #f68316;
  border-bottom: 5px solid #b84c00;
  width: 80%;
  text-align: center;
  margin: 4% auto;
  padding: 2% 6%;
  border-radius: 10px;
}
.cta02:hover {
/*  margin-top: 3px;*/
  color: #fff;
  background: #f56500;
  border-bottom: 2px solid #b84c00;
  transform: translateY(2px); /* ホバー時の少しの移動を追加 */
}

.cta02 a {
  color: #fff;
  text-align:center;
  text-decoration: none;
}



footer{
    padding: 30px 20px;
    text-align: center;
    background: #ECECEC;
    margin-top: 50px;
    font-size: 13px;
}

