@charset "utf-8";
@import url("sub-styles.css");

* {
    box-sizing: border-box;
    padding:0;
    margin:0;
}

ul li {
    list-style-type: none;
}

a {
    text-decoration: none;
    color: #494949;
}


/*上の見出し*/

h2 {
    padding: 1em 1.5em;
    color: #494949;
    font-size: 30px;
    background: #f4ede3;
    border-left: solid 10px #ba213b;
    border-bottom: solid 3px #f5e5cd;
    position: relative;
    line-height: 40px;
    font-size: 20px;
    margin-bottom: 15px;
    text-align: left;
}

/*下の見出し*/

h3 {
    font-size: 18px;
    text-align: left;
}


h1 {
    font-size: 30px;
}

h6 {
    font-size: 18px;
    text-align: left;
    padding-bottom:10px;
    margin: 35px 15px;
    border-bottom:3px dotted #265085;
}

p {
   padding: 10px;
   line-height: 280%;
}

img {
   margin: 0;
}

.img-box {
    text-align: center;
}

.small {
    font-size: 10px;
}

.big {
    font-size: 40px;
    font-weight: bold;
}

body {
    max-width: 900px;
    margin:0 auto;
    font-family: 'Noto Sans JP', sans-serif;
}

iframe {
    width: 100%;
    background: #ba213b;
    height: 50px;
}


/*全体ボックス*/
.container {
    margin: 0 auto;
    max-width: 900px;
    border-top: 30px solid #265085;
    border-left: 10px solid #265085;
    border-right: 10px solid #265085;
    border-bottom: 30px solid #265085;
}

.content-01 {
    max-width: 900px;
}

.content-01 img{
    width: 100%;
}

.content-02, .content-03, .content-04, .content-05, .content-06{
    margin: 40px 30px;
}

.content-02 {
    background: linear-gradient(#ecebeb 30%, #f4ede3);
    height:600px;
    padding:0;
    margin:0;
}

.content-02 h2.midashi {
    background: transparent;
    font-size: 35px;
    color: darkred;
    border:0;
    text-align: center;
}

.content-02 .new-ctt-01 {
    position: relative;
    margin: 0;
    /* background: url('img/s02-bg.png') no-repeat center center; */
    width: 100%;
    /* background-position: center; */
    /* background-size: contain; */
    padding-bottom: 300px;
}

.content-06 .new-ctt-03 {
    margin: 0;
    background: url('img/kenkyu_woman_seikou.webp') no-repeat;
    width: 100%;
    height: 420px;
    background-position: right;
    background-size: 250px;  
    border: 4px solid darkred;
    border-radius: 20px;
    
    padding: 15px;
}

.new-ctt-03 h1.midashi {
    font-size: 26px;
    float: left;
    width: 72%;
    padding: 10px;
    
}

.new-ctt-03 .content {
    border-top: 1px solid #ccc;
    float: left;
    width: 72%;
}

.new-ctt-03 .content:after {
    clear: both;
}

.img-bg {
    position: absolute;
    top: 150px;
    left: 30%;
}

.img-bg img {
    width: 290px;
}

.balloon {
    /* border: 1px solid #999; */
    box-shadow: 0 -1px 20px rgba(0, 0, 0, 0.1);
    display: inline-block;
    position: absolute;
    background: #fff;
    margin: 0 auto 10px;
    padding:2%;
    border-radius: 10px;
    z-index: 99;
    color: #000;
    font-size: 18px;

}

.balloon:after, .balloon::before {
	border: solid transparent;
	content: " ";
	height: 0;
	width: 0;
	position: absolute;
	pointer-events: none;
}


.balloon01 {
    left: 20px;
    top: 120px;
    width: 300px;
}

.balloon02 {
   right: 40px;
   top: 110px;
   width: 310px;
}

.balloon03 {
    left: 30px;
    bottom: -10px;
    width: 300px;
    opacity: 1;
}

.balloon04 {
    font-size: 18px;
    color: darkred;
    right:-20px;
    bottom:-170px;
    border-radius: 0;
    width: 400px;
    z-index:9999;
    border: 4px solid darkred;
}

.balloon01:after {
	content: '';
    position: absolute;
    border-style: solid;
    border-width: 12px 0 12px 31px;
    border-color: transparent #FFFFFF;
    display: block;
    width: 0;
    z-index: 1;
    right: -31px;
    top: 78px;
}


.balloon02:after {
	content: '';
    position: absolute;
    border-style: solid;
    border-width: 12px 31px 12px 0;
    border-color: transparent #FFFFFF;
    display: block;
    width: 0;
    z-index: 1;
    left: -31px;
    top: 30px;
}

.balloon03:after {
	content: '';
    position: absolute;
    border-style: solid;
    border-width: 12px 0 12px 31px;
    border-color: transparent #FFFFFF;
    display: block;
    width: 0;
    z-index: 100;
    right: -31px;
    top: 28px;
}


.content-07 {
    margin: 40px 0;
}

/*list 1番目*/

.list_01_choice {
    padding: 20px;
    margin: 10px 20px;
    line-height: 280%;
    border:5px solid #f5e5cd;
}

.list_01_choice li {
    font-size:17px;
}

.list_01_choice li:before {
    font-family: FontAwesome;
    color: #ba213b;
    margin-right: 15px;
    content: '\f00c';
}

/*table*/

.rank-img td{
    border:none!important;
    background: none!important;
}

.rank-img td img{
    width: 60px;
}

.content-03 table{
    width: 100%;
    border-collapse: collapse;
    text-align: center;
}

.content-03 .item-king {
    background: #FBEFEF;
    border-left: 5px solid red;
    border-right: 5px solid red;
}


.content-03 th {
    border: 1px solid #ddd;
    padding: 10px;
}

.content-03 th:nth-of-type(2) {
    border-top: 5px solid red;
}

.btn_wrapper td:nth-of-type(2) {
    border-bottom: 5px solid red;
}

.content-03 td {
    border: 1px solid #ddd;
    padding: 5px;
    width: 25%;
}

.content-03 img {
    width: 100px;
}

.content-03 td:first-child{
     font-weight: bold;
     background: #ececec;
}





/*ボタン*/

.fluffy {
    z-index: 1;
    animation: skew 2.3s linear infinite;
}
@-webkit-keyframes skew {
    0% {transform: skew(0deg, 0deg);}
    5% {transform: skew(5deg, 4.2deg);}
    10% {transform: skew(-4deg, -3deg);}
    15% {transform: skew(3deg, 2.2deg);}
    20% {transform: skew(-2deg, -1.5deg);}
    25% {transform: skew(0.9deg, 0.9deg);}
    30% {transform: skew(-0.6deg, -0.6deg);}
    35% {transform: skew(0.3deg, 0.3deg);}
    40% {transform: skew(-0.2deg, -0.2deg);}
    45% {transform: skew(0.1deg, 0.1deg);}  
    50% {transform: skew(0deg, 0deg);}}
@keyframes skew {
    0% {transform: skew(0deg, 0deg);}
    5% {transform: skew(5deg, 4.2deg);}
    10% {transform: skew(-4deg, -3deg);}
    15% {transform: skew(3deg, 2.2deg);}
    20% {transform: skew(-2deg, -1.5deg);}
    25% {transform: skew(0.9deg, 0.9deg);}
    30% {transform: skew(-0.6deg, -0.6deg);}
    35% {transform: skew(0.3deg, 0.3deg);}
    40% {transform: skew(-0.2deg, -0.2deg);}
    45% {transform: skew(0.1deg, 0.1deg);}  
    50% {transform: skew(0deg, 0deg);}}

.content-03 .moji_back, .content-09 .moji_back {
    position: relative;
}

.moji_wrapper {
    position: absolute;
    z-index: inherit;
    top:-30px;
    left:0;
}

.moji {
    position: relative;
	display: inline-block;
 	margin: 1.5em 0;
	padding: 7px 10px;
	min-width: 120px;
 	max-width: 100%;
 	color: #fff;
	font-size: 16px;
	background: #265085;
}

.moji:before {
	content: "";
	position: absolute;
	top: 100%;
	left: 20%;
 	margin-left: -15px;
	border: 15px solid transparent;
	border-top: 15px solid #265085;
}



/*○○○○○○○○*/
.maru_01 {
    font-size: 90px;
    font-weight: bold;
    color: red;
}

.maru_02 {
    font-size: 90px;
    font-weight: bold;
    color: #e6ac57;
}

.content-04 ul{
    margin:  0;
    padding: 20px;
      
}

.content-04 ul li:before {
    content:  "";     /* 空の要素作成 */
    width: 10px;                /* 幅指定 */
    height: 10px;               /* 高さ指定 */
    display:  inline-block;     /* インラインブロックにする */
    background-color: #265085;  /* 背景色指定 */
    position:  relative;        /* 位置調整 */
    top: 1px;                   /* 位置指定 */
    border-radius:  50%;        /* 要素を丸くする */
    margin-right: 5px;       
}

.content-04 ul li{
    padding:  10px;             /* 余白指定 */
    border-bottom: 1px dotted #ddd;
    border-radius:  10px;       /* 角丸指定 */
    margin-bottom: 5px;         /* 要素と要素の間指定 */
    font-size:  17px;           /* 文字サイズ指定 */
}

.content-04 p {
    font-size: 20px;
    text-align: center;
}

.content-05 .point-wrap{
    text-align: center;
    width: 100%;
    display: flex;
    -moz-display: flex;
    -webkit-display: flex; 
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-around;
    flex:1;
}

.content-05 .point-wrap p {
    line-height: 1.7;
    text-align: left;
    font-size: 0.7em;
}

.point-wrap img {
    width: 100%;
    height: 
}

.point-wrap .point-01,.point-02,.point-03,.point-04{
    width: 33%;
    border: 1px solid #ccc;
    margin-bottom: 12px;
    position: relative;
}


.content-05 .point-wrap:nth-of-type(2){
    
    margin: 0 auto;
    text-align: center;
    width: 70%;
    display: flex;
    -moz-display: flex;
    -webkit-display: flex; 
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-around;
}

.point-wrap:nth-of-type(2) .point-04,.point-05{
    width: 33%;
    border: 1px solid #ccc;
    margin-bottom: 12px;
    position: relative;
}

.point-01 h1,.point-02 h1,.point-03 h1,.point-04 h1,.point-05 h1{
    font-size: 18px;
    background: #ececec;
    padding: 25px;
}

.point-num {
    position: absolute;
    top:0;left:0;
    z-index:40;
    border-top: 30px solid red;
    border-right: 30px solid transparent;
    border-bottom: 30px solid transparent;
    border-left: 30px solid red;
}

.point-num span{
    position: absolute;
    top:-25px;left:-20px;
    color:white;
    font-size: 20px;
    z-index:41;
    
}


/* .left-txt {
    text-align: left;
    font-size: 18px;
}

.right-txt {
    text-align: right;
    font-size: 18px;
}

.center-txt {
    text-align: center;
} */




/*ranking*/

.r-king-wrap {
    height: 170px;
    border-top:4px solid #265085;
    
}

.r-king-wrap .left{
    float: left;
    width: 49%;
}

.r-king-wrap .right{
    float: right;
    width: 49%;
    height: 170px;
    overflow: hidden;
    margin-top:10px;
    margin-right: 5px;
    position: relative;
}


.r-king-wrap .left h1{
    text-align: left!important; 
    padding: 20px 0 0 20px!important;
    font-size: 2em;
    color: rgb(209, 6, 6);
}

.r-king-wrap .left h1 img {
    width: 70px;
    vertical-align: middle;
}

.r-king-wrap .left p{
   width: 100%;
}

.r-king-wrap .left p img{
    width: 50%;
    padding-left: 10px;
}

.r-king-wrap .right div:nth-of-type(1){
    display: inline-block;
    width: 50%;
    position: absolute;
    left:20px;
    top:-20px;
}

.r-king-wrap .right div:nth-of-type(1) img {
    width: 170px;
    border:1px solid #999;
}


.r-king-wrap .right div:nth-of-type(2){
    display: inline-block;
    width: 50%;
    position: absolute;
    right:0;
    top:-20px;
    
}

.r-king-wrap .right div:nth-of-type(2) img {
    width: 200px;
    border:1px solid #999;
}

.r-king-wrap-01 {
    width: 100%;
    height: 350px;
    margin-top: 30px;
    border-bottom: 1px solid #999;

}

.r-king-wrap-01:nth-of-type(3) {

    height: 250px;
}

.r-king-wrap-01 h2{
    border:0;
    font-size: 1.5em;
    line-height: 1.4;
    padding: 10px;
    background: #E0F2F7;
}

.r-king-wrap-01 .img-left div:nth-of-type(1) {
    float: left;
    width: 30%;
}

.r-king-wrap-01 .img-left div:nth-of-type(1) img {
    border:1px solid #999;
    width: 90%;
    margin-left:20px;
}

.r-king-wrap-01 .img-left div:nth-of-type(2) {
    float: right;
    width: 70%;
}

.r-king-wrap-01 .img-left div:nth-of-type(2) p {
    line-height: 1.7;
    font-size:1.1em;
}

.r-king-wrap-01 .img-right div:nth-of-type(1) {
    float: left;
    width: 70%;
}

.r-king-wrap-01 .img-right div:nth-of-type(1) p {
    line-height: 1.7;
    font-size:1.1em;
}


.r-king-wrap-01 .img-right div:nth-of-type(2) {
    float: right;
    width: 30%;
}


.r-king-wrap-01 .img-right div:nth-of-type(2) img {
    border:1px solid #999;
    width: 95%;
}

.r-king-wrap-01::after {
    clear: both;
}

.r-king-wrap-02 h1{
    padding: 20px 0!important;
    color:#2E2E2E;
        
    background: #E0F2F7;
}

.r-king-wrap-02 img{
    width: 100%;
}

.r-king-wrap-03 .review{
    padding: 100px;
    text-align: center;
    background: #E0F2F7;
}

table.rnk2item {
    table-layout: auto;
    border: solid 1px #CCC;
    width: 100%;
    font-size: 13px;
    margin: 10px 0;
    border-collapse: collapse;
    border-spacing: 0px;
}

.rnk2item th.ttitle {
    padding: 20px;
    text-align: left;
    font-size: 22px;
    background-color: #265085;;
}


.rnk2item th.ttitle a {
    color: #fff;
}

.rnk2item td,th{
    display: table-cell;
    vertical-align: inherit;
    border: solid 1px #265085;
}

.kingtable td,th{
    display: table-cell;
    vertical-align: inherit;
    border: solid 1px #265085;
}

table.ttable {
    width: 100%;
    border: solid 1px #265085;
    margin: 0px;
    padding: 0px;
    table-layout: fixed;
    border-collapse: collapse;
}

.ttable th {
    background: #265085;
    color: #fff!important;
    font-size: 17px;
    border-right: 1px solid #fff;
}

.ttable th:nth-child(3), .ttable th:nth-child(6){
    border-right: none;
}

.ttable th, .ttable td {
    padding: 8px;
    text-align: center;
}

.ttable p {
    line-height: 120%;
}


.item_img_wrapper {
    text-align: center;
    padding:20px;
}

#ranking_wrapper {
    background: #fff;
    border-left: 5px solid #265085;
    border-right: 5px solid #265085;
}

#ranking_wrapper h1{
    text-align: center;
    margin:0;
    padding:0;
}

.item_point {
    background: #265085;
    padding:15px;

}

.item_point li{
    color:#fff;
}

.item_point li {
    margin: 20px;
    font-size:20px;
}

.item_point li:before {
    font-family: FontAwesome;
    color: yellow;
    margin-right: 15px;
    content: '\f00c';
}

.item_text {
    padding: 20px;
    font-size: 15px;
}

.link_site {
    text-align: right;
}

.link_site a{
    text-align: right;
    font-size: 24px; color: red;
    font-weight: bold;
}

.item_btn_wrapper {
    text-align: center;
    padding: 20px;
}

.content-07 {
    background: #eee;
    padding:20px;
}

.content-07 h3>img {
    width: 100%;
}

.content-08 {
    text-align: center;
}

.content-08 .last-txt {
    padding: 2em;
    margin: 2em 0;
    color: #5d627b;
    background: white;
    border-top: solid 5px #5d627b;
    box-shadow: 0 3px 5px rgba(0, 0, 0, 0.22);
    text-align: left;
}

.last-txt p {
    margin: 0; 
    padding: 0;
    font-size: 20px;
}

.content-08 .last-txt-01 {
    padding: 2em;
    margin: 2em 0;
    background: white;
    color: #da3434;
    border-top: solid 5px #da3434;
}

.last-txt-01 p {
    margin: 0; 
    padding: 0;
    font-size: 20px;
}

.content-09 th {
     border: none;
}

.banner-box {
     margin: 10px;
     box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
}

#footer {
    margin-top:70px;
    padding-top:30px;
    text-align: center;
    border-top:1px solid #ddd;

}

#footer a {
    color: #da3434;
}

