@charset "utf-8";
/*
Theme Name: urapa
Description: urapa
Version: 1.0
*/

/*Common 
===============================================================*/
*{
	min-width: 0;
	min-height: 0;
}
body{
  font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", sans-serif;text-rendering: optimizeLegibility; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; -moz-font-feature-settings: 'liga', 'kern'; -webkit-text-size-adjust: 100%; -ms-text-size-adjust: 100%; font-size: 18px; font-weight: 500; line-height: 1.8; color: #333; font-display: swap;
}
img{
  display: block;
  max-width: 100%;
  width: 100%;
  height: auto;
  margin: 0 auto;
}
.inner{
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 20px;
}
.flex{
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
}
.noto{
  font-family: 'NotoSans',sans-serif;
}
.robo{
  font-family: 'Roboto',sans-serif;
}
.cave{
  font-family: /*'Caveat',*/ cursive;
}
.mcho{font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;}
.red{
	color: #ce4646;
	font-weight: bold;
}
.float_banner{
  display: none;
}
.spView{
  display: none;
}
strong{
	font-weight: bold;
}
#container{
	background: rgba(233,234,245,.35);
}
.main_column h2{
	text-align: center;
    color: #fff;
    font-weight: 900;
    font-size: var(--fnt-30);

}

.small {
    font-size: 18px;
    line-height: 1.4;
}


:root {
    --gra-pur: linear-gradient(to right, #7b8de3, #c78ce3);
	--clr-pur:#512c9a;
	--clr-pur2:#772c9a;
	--clr-pur3:#955ec0;
	--clr-pur4:#69318e;
	--fnt-42: clamp(24px, 4vw, 42px);
--fnt-36: clamp(22px, 3.5vw, 36px);
--fnt-30: clamp(20px, 3vw, 30px);
--fnt-26: clamp(18px, 2.5vw, 26px);
--fnt-20: clamp(16px, 2vw, 20px);
--fnt-16: clamp(14px, 1.6vw, 16px);
--fnt-14: clamp(13px, 1.4vw, 14px);
}
/*header/nav  
===============================================================*/

/*Humbtn
========================*/
/*humhum*/
  #sp-menu{
  display: block;
  width: 50px;
  height: 50px;
  position: fixed;
  top: 0;
  right: 0;
  z-index: 100;
}
#sp-menu-btn{
  display: block;
  background: #000;
  width: 32px;
  height: 2px;
  padding: 0;
  margin: 0;
  border: none;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  box-sizing: border-box;
}
.screen-reader-text {
  clip: rect(1px,1px,1px,1px);
  position: absolute!important;
  height: 1px;
  width: 1px;
  overflow: hidden;
}

#sp-menu-btn::before
,#sp-menu-btn::after{
  content: "";
  position: absolute;
  left: 0;
  display: block;
  width: 32px;
  height: 2px;
  background: #000;
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s;
}
#sp-menu-btn::before{
  top: -10px;
}
#sp-menu-btn::after{
  top: 10px;
}
#sp-menu.open #sp-menu-btn{
  height: 0;
}
#sp-menu.open #sp-menu-btn::before{
  top: 0;
  transform: rotate(45deg);
}
#sp-menu.open #sp-menu-btn::after {
    top: 0;
  transform: rotate(-45deg);
}

  /*sp slidenav*/

  #sp-menu-blc{
    display: block;
    position: fixed;
    top: 0;
    right: 0;
    width: 50vw;
    min-height: 100vh;
    z-index: 10;
    transform: translateX(100vw);
    -webkit-transition: transform .3s ease-in-out;
    -o-transition: transform .3s ease-in-out;
    transition: transform .3s ease-in-out;
    background: #f8f8f8;
  }
  #sp-menu-blc.slide{
    transform: translateX(0);

  }
  #sp-menu-blc-inner{
  }
  #sp-menu-blc-inner li{
	padding: 1em 0;
    border-bottom: 1px solid #ddd;
	}
  #overlay{
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: rgba(0,0,0,.5);
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s;
  z-index: 9;
  transform: translateX(-100vw);
  visibility: hidden;
}
#overlay.open{
  visibility: visible;
  transform: translateX(0);
}
#fix_btn{
    display: block;
    width: 96px;
    height: 96px;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 100;
  }
  #sp-menu{
  display: block;
    background: #fff;
    width: 32px;
    height: 2px;
    padding: 0;
    margin: 0;
    border: none;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    box-sizing: border-box;
	box-shadow: 0 2px 2px rgb(36 62 70);
  }
  #sp-menu::before
  ,#sp-menu::after{
    content: "";
    position: absolute;
    left: 0;
    display: block;
    width: 32px;
    height: 2px;
    background: #fff;
    -webkit-transition: all .3s;
    -o-transition: all .3s;
    transition: all .3s;
	box-shadow: 0 2px 2px rgb(36 62 70);
  }
  #sp-menu::before{
    top: -10px;
  }
  #sp-menu::after{
    top: 10px;
  }
  #sp-menu.open{
    height: 0;
	background: none;
  }
  #sp-menu.open::before{
    top: 0;
    transform: rotate(45deg);
	background: #243e46;
	box-shadow: none;
  }
  #sp-menu.open::after{
    top: 0;
    transform: rotate(-45deg);
	background: #243e46;
	box-shadow: none;
	}
  #sp-menu-block{
    width: 100vw;
    height: 100vh;
    position: fixed;
    right: -100%;
    top: 0;
    -webkit-transition: all .3s;
    -o-transition: all .3s;
    transition: all .3s;
    z-index: 15;
    background: #fff;
    padding:60px 40px 140px;
    overflow-y: scroll;
    display: none;
  }
  #sp-menu-block.slide{
    right: 0;
    -webkit-transition: all .3s;
    -o-transition: all .3s;
    transition: all .3s;
  }
  #sp-menu-block-inner > ul > li{
    border-bottom: 1px solid #243e46;
  }
  #sp-menu-block-inner > ul > li > a
  ,#sp-menu-block-inner > ul > li > p{
    font-weight: 600;
    font-size: 1.125em;
    padding: 1em 1em 1em 0;
    display: block;
  }
  #sp-menu-block-inner > ul > li > p{
    padding-bottom: .5em;
  }
  #sp-menu-block-inner > ul > li > a::after{
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    right: .25em;
    width: 5px;
    height: 5px;
    border: 2px solid;
    border-color: #243e46 #243e46 transparent transparent;
    border-radius: 2px;
    transform: translateY(-50%) rotate(45deg);
  }
  
  #sp-menu-block-inner > ul > li.drop > a{
    pointer-events: none;
  }#sp-menu-block-inner > ul > li.drop > a::after{
    content: none;
  }
  

  
  ul.type{
    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;
    margin-bottom: .5em;
  }
  ul.type li{
    width: 50%;
  }
  ul.type.c3 li{
    width: 33.3%;
  }
  ul.type li a{
    display: block;
    padding:.65em .25em .5em 1em;
    font-weight: 600;
    font-size: .92em;
  }
  ul.type li a::before{
    content: "";
    display: block;
    width: 5px;
    height: 5px;
    border: 1px solid;
    border-color: #243e46 #243e46 transparent transparent;
    border-radius: 2px;
    transform: translateY(-50%) rotate(45deg);
    position: absolute;
    top: 50%;
    left: 0;
  }
  
  .sp_nav_bg{
    position: fixed;
    left: -100%;
    width: 100%;
    height: 100%;
    background: #243e46;
    -webkit-transition: all .3s;
    -o-transition:  all .3s;
    transition:  all .3s;
    z-index: 10;
  }
  .sp_nav_bg.openbk{
    left: 0;
  }

/*header
====================*/
header{
  width: 100%;
  padding: 20px 0 10px;
  background: #fff;
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s;
  border-bottom: 2px solid #4b2991;
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s;
}
header .inner{
  justify-content: space-between;
  -ms-align-items: flex-end;
  align-items: flex-end;
}
.header-inner{
	max-width: 960px;
    margin: 0 auto;
}
.head_logo{
  width: 400px;
}
.head_logo a{
   -ms-align-items: center;
  align-items: center;
}
.head_logo .logo {
    width: 180px;
    max-width: 50%;
    margin-right: 15px;
}
.head_logo .txt{
  padding-left: 1em;
  line-height: 1.2;
  font-size: .8em;
  font-weight: 600;
  color: #fff;
}
.head_logo .txt span.noto{
  color: #f0cbcb;
  font-weight: 800;
  display: block;
  font-size: 2.24em;
  line-height: 1.2;
}
.head_logo .txt span.noto > span.intxt{
font-size: .55em;
}


.menu-container {
  display: flex;
  justify-content: space-between;
  background-color: var(--clr-pur3); /* 紫背景 */
}

.menu-item {
    flex: 1;
    text-align: center;
    color: #fff;
    font-size: 16px;
    padding: 5px;
    border-right: 2px dotted #fff;
    position: relative;
	width:25%;
}

.menu-item::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: linear-gradient(
    -30deg,
    rgba(100, 40, 130, 0.4) 50%,
    rgba(100, 40, 130, 0) 50%
  );
    pointer-events: none;
    z-index: 2;
}


.menu-item:last-child {
  border-right: none;
}
.menu-item a{
	z-index:3;
}

.menu-item img {
    width: 50px;
    aspect-ratio: 1/1;
    margin-bottom: 5px;
}

.menu-item:nth-child(2) img {
    width: 38px;
    margin-bottom: 5px;
    height: 50px;
}




/*------------------------------
main_column
*/
.main_column{
	width: 100%;
    max-width: 640px;
    box-sizing: border-box;
	background:#fff;
}

.main_bk {
    justify-content: center;
}

/*------------------------------
トップページ共通　main_column
*/


.urapa-btn {
    text-align: center;
    margin: 2em 0;
}

.urapa-btn a {
    display: inline-block;
    background: #2f9981;
    color: #fff;
    font-size: 20px;
    font-weight: bold;
    text-decoration: none;
    padding: 1em 2em;
    border-radius: 40px;
    transition: 0.3s;
}

.urapa-btn a:hover {
    background: #24806b;
}


h2.gra, h2.pur {
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--clr-pur4);
    color: #fff;
    font-weight: bold;
    padding: 10px;
    gap: 10px;
    margin: 0;
    line-height: 1.3;
}

h2.pur{
	background: var(--clr-pur);
}

h2 > span{
    width: min(7%, 100px);
}



h3.deco-frame{
	text-align: center;
    font-size: 1.4em;
    font-weight: 900;
    position: relative;
    padding: 1em 0;
	color: #512c9a;
}
h3.deco-frame::before{
	content: "";
	background: url("image/common/line-top.svg") no-repeat center;
	width: 100%;
	height: 22px;
    position: absolute;
    top: 5px;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);	
}
h3.deco-frame::after{
	content: "";
	background: url("image/common/line-bottom.svg") no-repeat center;
	width: 100%;
	height: 15px;
    position: absolute;
    bottom: 4px;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);	
}
h4.deco-underline{
	font-size: 1.4em;
    border-bottom: 1px solid #ce4646;
    font-weight: 900;
    margin-bottom: 0.85em;
}
.home .triangle_box{
	margin: 1.5em 0 0;
}







.site-ranking {
    padding: 5%;
	background-image: url(https://www.urapa.jp/wp-content/themes/urapa/image/common/bg_gry.jpg);
}


.teller-list .teller-card {
    position: relative;
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    background: #fff;
    border: 1px solid var(--clr-pur3);
    border-radius: 12px;
    padding: 1em 2em 1em 1em;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05);
    margin: 0 auto 20px;
    overflow: hidden;
}

.teller-list .teller-card > a,.category-item > a,.category-card > a {
    display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    z-index: 1;
}

.teller-card::before {
    content: "";
    position: absolute;
    top: -20%;
    left: -10%;
    width: 250px;
    height: 250px;
    background-size: contain;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    font-weight: bold;
    color: #fff;
    z-index: 0;
}

.teller-list .rank01::before {
	background: url('https://www.urapa.jp/wp-content/themes/urapa/image/common/crown1.svg') no-repeat center center;
}

.teller-list .rank02::before {
	background: url('https://www.urapa.jp/wp-content/themes/urapa/image/common/crown2.svg') no-repeat center center;
}

.teller-list .rank03::before {
	background: url('https://www.urapa.jp/wp-content/themes/urapa/image/common/crown3.svg') no-repeat center center;
}

.teller-list .rank00::before {
	background: url('https://www.urapa.jp/wp-content/themes/urapa/image/common/crown_common.svg') no-repeat center center;
}









.teller-list .featurebox {
    background: #9c4167;
    color: white;
    padding: 1em;
    border-radius: 5px;
    font-weight: bold;
    margin: 5px 0;
}

.teller-list .teller-content {
  flex: 1;
	position:relative;
}

.teller-list .teller-header {
    padding-bottom: 10px;
}

.teller-list .teller-header .inbox {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.teller-list .teller-header h2 .rank-number {
    color: #fff;
    font-size: 1.1em;
	font-family: "Jost", sans-serif;
}

.teller-list .teller-header h2 {
    font-size: var(--fnt-36);
    margin: 0;
    color: #000;
    text-shadow: none;
	line-height:1;
}

.teller-list .label-feel {
    color: var(--clr-pur4);
    padding: 5px 14px;
    border-radius: 5px;
    margin-left: 10px;
    white-space: nowrap;
    border: 2px solid var(--clr-pur4);
	font-size:var(--fnt-16);
	font-weight:bold;
}

.teller-list .teller-meta {
    margin: 1em 0;
    display: flex;
    gap: 10px;
    font-size: .9em;
}

.teller-list .badge {
    background-color: #ebdafd;
    color: var(--clr-pur4);
    padding: 5px 20px;
    border-radius: 30px;
    line-height: 1.4;
    flex: 1;
    display: flex;
    justify-content: center;
}

.teller-list .teller-info {
    color: #333;
    line-height: 1.5;
    width: min(65%,360px);
}

.teller-list .teller-card::after {
	content: '';
    width: 10px;
    height: 10px;
    border: 0px;
    border-top: solid 2px var(--clr-pur3);
    border-right: solid 2px var(--clr-pur3);
    -ms-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    position: absolute;
    top: 50%;
    right: 5px;
}

.teller-list .teller-info p {
  margin: 6px 0;
}

figure.icon_div{
	width:1.5em;
	
}
.teller-info .txtdata {
    gap: .5em;
    align-items: center;
}

.teller-info .txtdata:nth-of-type(3) {
  padding-bottom: .5em;
}


.site-info .info-table {
  border: 1px solid #ccc;
  border-collapse: collapse;
  width: 100%;
	font-size:var(--fnt-16);
}

.site-info .info-row {
  display: flex;
  border-top: 1px solid #ccc;
}

.site-info .info-row:first-child {
  border-top: none;
}

.site-info .info-cell {
  padding: 10px;
  border-left: 1px solid #ccc;
}

.site-info .info-cell:first-child {
    border-left: none;
    background: #f9f9f9;
    font-weight: bold;
    width: 30%;
}






.cate-uranaishi .section-title {
  text-align: center;
  position: relative;
}

.cate-uranaishi .section-title h3 {
  font-size: var(--fnt-30);
  font-weight: bold;
  color: var(--clr-pur4); /* 紫系 */
  display: inline-block;
  margin: 0 20px;
  position: relative;
  z-index: 1;
	    line-height: 1;
}

.cate-uranaishi .section-title .decoration {
  width: 60px;
  height: auto;
  vertical-align: middle;
  display: inline-block;
}
.cate-uranaishi .section-title .decoration:last-of-type {
  transform: scale(-1, 1);
}


.cate-uranaishi .section-title .en {
  font-size: 16px;
  color: #a1865e; /* ゴールド系ブラウン */
  font-weight: 500;
	    line-height: 1;
}




.teller-list .dot {
  color: #502e8e;
  margin-right: 4px;
}


.teller-content .box{
	justify-content:space-between;
	align-items: flex-start; 
}

.teller-content .teller-image {
  width: min(30%,200px); /* ← 幅があればOK */
  aspect-ratio: 1 / 1;
  height: auto; /* 明示しなくてもOKだけど保険で */
  overflow: hidden;
  border: 2px solid white; /* 内側白ボーダー */
  box-shadow: 0 0 0 2px #e0d080; /* 外側茶色ボーダー */
	border-radius:10px;
}


.teller-content .site-image {
  width: 100% /* ← 幅があればOK */
  height: auto; /* 明示しなくてもOKだけど保険で */
  overflow: hidden;
  border: 2px solid white; /* 内側白ボーダー */
  box-shadow: 0 0 0 2px #e0d080; /* 外側茶色ボーダー */
	border-radius:10px;
}

.teller-list .teller-image img,.teller-box .teller-thum img,.teller-box .bg img,.teller-review .review-user img {
  width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}

.teller-main .teller-thum {
    aspect-ratio: 1 / 1;
    height: auto;
    overflow: hidden;
    border-radius: 50%;
    margin: min(-20px,-15%) auto 0;
    border: 3px solid #fff;
	width:min(50%,200px);
}

.teller-main .teller-header .medal {
    width: 3em;
    position: absolute;
    top: 0;
    left: 5%;
}

.teller-header .siteimg {
    position: absolute;
    top: calc(min(130px, 17vh) + 0.5em);
    right: 5%;
    color: #000;
    text-align: right;
    gap: .5em;
    display: flex;
    align-items: center;
    line-height: 1.2;
}

.teller-header .siteimg figure {
    width: 50px;
    aspect-ratio: 1 / 1;
    border: 1px solid #d1d1d1;
    border-radius: 8px;
}

.teller-box .bg {
    height: min(130px,17vh);
}


.teller-review .review-user figure,ul.uranaishi_carousel li figure{
	aspect-ratio: 1 / 1;
    height: auto;
    overflow: hidden;
    border-radius: 50%;
    border: 3px solid #fff;
}
.teller-review .review-user {
    width: 20%;
    text-align: center;
}

.teller-review .review-comment{
	flex:1;
}

section.teller-review .inbox{
	padding:2em 0;
}

.cate-uranaishi{
  background: url(https://urapa.jp/wp-content/themes/urapa/image/common/bg_pur.jpg) center/contain;
}

.uranaishi-toplist > p{
	font-size:var(--fnt-16);
}



/*タグ
=========================*/
p.tag span {
    padding: .5em 1em .35em;
    font-size: .78em;
    line-height: 1;
    border-radius: 3px;
    overflow: hidden;
    display: block;
    position: relative;
    font-weight: 600;
}
.rank-entry-head p.tag.pic_04 span,
.rank-entry-head p.tag.pic_07 span,
.rank-entry-head p.tag.pic_10 span{
	background: #65afa4;
    color: #fff;
}
.rank-entry-head p.tag.pic_01 span,
.rank-entry-head p.tag.pic_02 span,
.rank-entry-head p.tag.pic_05 span,
.rank-entry-head p.tag.pic_08 span,
.rank-entry-head p.tag.pic_11 span{
	background: #AE0000;
    color: #F3D443;
}
.rank-entry-head p.tag.pic_03 span,
.rank-entry-head p.tag.pic_06 span,
.rank-entry-head p.tag.pic_09 span,
.rank-entry-head p.tag.pic_12 span{
	background: #F3D443;
    color: #C8181B;
}
.rank-entry-head p.tag.pr span{
	background: linear-gradient(to bottom, #cfa034,#fff2ab,#cfa034);
    color: #512e00;
    z-index: 1;
}

p.tag span::before {
    animation: shine 3s ease-in-out infinite;
    background-color: #fff;
    content: "";
    height: 100%;
    left: 0;
    opacity: 0;
    position: absolute;
    top: -50px;
    transform: rotate(45deg);
    width: 5px;
}




/*------------------------------
カテゴリー別紹介部
*/

.uranaishi-toplist{
	padding:1em;
}
.div-sec h3,.nayami-sec h3{
	font-size:var(--fnt-26);
	color:var(--clr-pur4);
	font-weight:bold;
	text-align:center;
}

.div-sec,.nayami-sec{
	padding:1.5em 0;
}

.cate-uranaishi .category-flex {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 20px;
    max-width: 600px;
    margin: 0 auto;
    padding: 1em 0 3em;
    border-bottom: 1px solid #958abf;
}

.cate-uranaishi .category-item {
  flex: 0 1 170px; /* 幅固定、縮小可能 */
  border: 2px solid #e0d080;
  border-radius: 10px;
  text-align: center;
  padding: 10px;
  position: relative;
  overflow: hidden;
	background: white; /* 基本背景を白に */
	    aspect-ratio: 1 / 1;
	display: flex;
  flex-direction: column;
  justify-content: center; /* 上下中央寄せ */
  align-items: center;     /* 左右中央寄せ */
}

.cate-uranaishi .category-item::before {
  content: "";
  position: absolute;
  top: 0; right: 0; bottom: 0; left: 0;
  background: linear-gradient(
    -45deg,
    rgba(200,200,200,0.1) 50%,
    rgba(255,255,255,0) 50%
  );
  pointer-events: none;
  z-index: 2;
}




.cate-uranaishi .category-item img{
	mix-blend-mode: multiply;
	max-width: 80%;
  max-height: 80%;
  height: auto;
  width: auto;
}




.div-inbox .category-card {
  display: flex;
  align-items: center;
  border: 2px solid #e0d080;
  border-radius: 10px;
  padding: 20px;
  background: white;
  max-width: 600px;
  margin: 20px auto;
  position: relative;
	gap:1em;
}

.div-inbox .category-card img {
  width: 30%; /* 好みに応じて調整 */
  flex-shrink: 0;
}

.div-inbox .category-card .card-text {
  flex: 1;
	padding-right: 2em;
}

.div-inbox .category-card h3 {
  margin: 0 0 5px;
  font-size:var(--fnt-26);
	    line-height: 1.5;
  display: flex;
  align-items: center;
  color: #7b4db7; /* 紫系 */
  font-weight: bold;
}

.div-inbox .category-card h3 .icon {
  display: inline-block;
  width: 24px;
  height: 24px;
  background: url('https://urapa.jp/wp-content/themes/urapa/image/cate/icon_div.png') no-repeat center center / contain;
  margin-right: 5px;
}

.div-inbox .category-card p {
    margin: 0;
    font-size:var(--fnt-16);
    line-height: 1.5;
}



.site_pickup {
    background: var(--clr-pur4);
    padding: 1.5em 0;
}


.site_pickup .mySwiper {
  width: 100%;
  max-width: 800px;
  margin: 0 auto;
}

.site_pickup .mySwiper .swiper-wrapper {
  display: flex; /* 念のため明示 */
}

.site_pickup .mySwiper .swiper-slide {
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
}

.site_pickup .mySwiper .swiper-slide img {
  display: block;
  width: 100%;
  max-width: 400px;
}



	
/*------------------------------
占い師ページ
*/
.teller-box {
    margin: auto;
    background: #fff;
    overflow: hidden;
    text-align: center;
    padding-bottom: min(50px,10%);
}

.teller-box .teller-header {
  position: relative;
}

.teller-box .teller-rank {
  position: absolute;
  top: 10px;
  left: 10px;
  background: gold;
  border-radius: 50%;
  width: 30px;
  height: 30px;
  line-height: 30px;
  font-weight: bold;
}



.site-main .teller-box .teller-thum img {
    width: 100%;
    border-radius: 0;
    border: none;
    object-fit: cover;
    margin-top: 0;
}


.teller-box .teller-info .teller-name {
    font-size: var(--fnt-42);
    margin: 0;
    color: #000;
    line-height: 1.5;
}

.teller-box .teller-info .teller-copy {
    font-size: var(--fnt-26);
    margin: 0;
    font-weight: bold;
    color: var(--clr-pur);
}

.site-main .teller-box .teller-info .teller-copy {
    color: var(--clr-pur2);
    padding-top: 1em;
}
/* .teller-box .teller-data {
    display: flex;
    justify-content: space-around;
    background: #ede7f5;
    padding: 15px 0;
    border-radius: 5px;
    border-top: 1px solid #eee;
    border-bottom: 1px solid #eee;
    width: 90%;
    margin: 1em auto;
} */

/* .teller-box .teller-data {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  background: #ede7f5;
  padding: 15px 0;
  border-radius: 5px;
  border-top: 1px solid #eee;
  border-bottom: 1px solid #eee;
  width: 90%;
  margin: 1em auto;
  text-align: center;
}
.teller-box .teller-data div {
    font-size: 20px;
    font-weight: bold;
	color: var(--clr-pur);
	position: relative;
}

.teller-box .teller-data > div:not(:last-child)::after {
  content: "";
  position: absolute;
  top: 0;
  right: -22px;
  width: 1px;
  height: 100%;
  background-color: #512c9a;
} */

.teller-box .teller-data {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  background: #f3eaff;
  border-radius: 6px;
  padding: 1em 0;
  width: 90%;
  margin: 1em auto;
  text-align: center;
  position: relative;
  font-family: sans-serif;
}

.teller-box .teller-data > div {
  display: grid;
  grid-template-rows: auto 1fr;
  align-items: start;
  padding: 0 1em;
  position: relative;
}

.teller-box .teller-data > div:not(:last-child)::after {
  content: "";
  position: absolute;
  top: 10%;
  right: 0;
  height: 80%;
  width: 1px;
  background-color: #9e79d3;
}

.teller-box .teller-data span {
  font-size: var(--fnt-20);
  color: #512c9a;
  font-weight: bold;
  margin-bottom: 4px;
  height: 1.5em;
}

.teller-box .teller-data .data-value {
  font-size: 28px;
  font-weight: bold;
  color: #000;
  line-height: 1.4;
}



.teller-box .teller-data .data-value {
    display: block;
    font-size: 28px;
    color: #333;
    display: flex;
    align-items: center;
	justify-content: center;
    padding-top: 10px;
}

.teller-box .teller-data div:nth-child(3) .data-value {
    line-height: 1.2;
	font-size:18px;
}

.teller-box .teller-tags {
  margin: 10px 0;
}

.teller-box .teller-tags span {
    display: inline-block;
    margin: 0 5px;
    padding: 3px 25px;
    background: var(--gra-pur);
    border-radius: 20px;
    font-size: var(--fnt-20);
    color: #fff;
    font-weight: bold;
}

.teller-box .teller-banner {
  padding: 15px;
}

.teller-box .teller-banner h3 {
  font-size: 1.4em;
  margin: 10px 0;
  color: #a0005c;
}

.teller-box .teller-banner span {
  color: #c00078;
  font-size: 1.5em;
}

.profile-section .profile-text img{
	padding:1em 0;
}



.profile-section,.teller-review {
  padding: 0 5% 5%;
  margin: auto;
  background-image: url("https://www.urapa.jp/wp-content/themes/urapa/image/teller/bg1.jpg");
  background-size: cover;         /* 画面いっぱいに広げる */
  background-position: center;    /* 中央寄せ */
  background-repeat: no-repeat;   /* 繰り返さない */
  background-color: #f8f6fc;      /* 画像が読み込めないときの保険 */
}


.profile-section > .page_txtbox,
.profile-section > .page_tablebox,
.profile-section > .page_tellerbox {
  padding: 1em 0;
}


.profile-section .skill-box {
    background: white;
    border-radius: 10px;
    margin-bottom:2em;
    overflow: hidden;
    border: 1px solid #560080;
}

.profile-section .skill-box .inbox{
	padding:5%;
}

.profile-section .profile-heading {
    font-size: var(--fnt-20);
    color: #5b41c6;
    margin-bottom: 10px;
    text-align: center;
    font-weight: bold;
    background: #ede7f5;
    padding: 2%;
}

.site-main .profile-box .profile-heading {
	color:#6e0a8b;
}

.profile-box .profile-heading {
    background: none;
    padding: 0%;
	    font-size: var(--fnt-30);
}

ul.uranaishi_carousel{
display:flex;
    padding-top: 1em;
    overflow-x: scroll;
    justify-content: normal;
    flex-wrap: nowrap;
    -webkit-overflow-scrolling: touch;

}

ul.uranaishi_carousel li {
    display: block;
    width: 33%;
    padding-right: 1em;
    line-height: 1.4em;
    text-align: center;
    font-size: .9em;
}


.profile-section .profile-box{
	padding:2em 0 1em;
}

.profile-section .btnbox{
	text-align:center;
}
.profile-section .profile-button {
  margin: 15px auto; /* ← これで中央揃え */
  padding: 8px 45px;
  background: linear-gradient(to right, #ffa4c8, #f78dac);
  color: white;
  border: none;
  border-radius: 70px;
  cursor: pointer;
  box-shadow: 0 3px 5px rgba(0, 0, 0, 0.1);
	font-size:var(--fnt-20);
}







.teller-review .review-title .icon {
  margin-right: 8px;
}

.teller-review .review-card {
    display: flex;
    align-items: flex-start;
    padding: 15px 0px;
    gap: 15px;
}





.teller-review .user-info {
  font-size: 0.9em;
  color: #555;
  margin-top: 5px;
}


.teller-review .review-comment .bubble {
    position: relative;
    display: inline-block;
    margin: 0 0 0 15px;
    padding: 5%;
    min-width: 120px;
    max-width: 100%;
    color: #555;
    background: #FFF;
    border: solid 2px #b19edb;
    box-sizing: border-box;
    border-radius: 10px;
}

.teller-review .review-comment .bubble::before {
  content: "";
  position: absolute;
  top: 2em;
left: -18px;
  margin-top: -9px;
  border: 9px solid transparent;
  border-right: 9px solid #FFF;
  z-index: 2;
}

.teller-review .review-comment .bubble::after {
  content: "";
  position: absolute;
  top: 2em;
 left: -21px;
  margin-top: -10px;
  border: 10px solid transparent;
  border-right: 10px solid #b19edb; /* ← 枠線と同じ色 */
  z-index: 1;
}

.teller-button-wrapper {
  text-align: center; /* ←これで内包ボタンを中央揃え */
}

.teller-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: min(500px, 90%);
    padding: 30px 30px;
    background: linear-gradient(to bottom, #00c49a 0%, #00c49a 50%, #05c093 50%, #05c093 100%);
    color: white;
    font-weight: bold;
    font-size: var(--fnt-30);
    text-decoration: none;
    gap: 10px;
    border-radius: 100px;
    box-shadow: 0 4px 0 #007f61;
    transition: 0.2s ease;
}

.teller-button .teller-icon {
	width:50px;	
}


.site-main .info-table {
    width: 100%;
    border-collapse: collapse;
    font-family: sans-serif;
    background: #fff;
}

.site-main .info-table th,
.site-main .info-table td {
  border: 1px solid var(--clr-pur2); /* 枠線の色を統一 */
  padding: 10px;
  vertical-align: top;
}

.site-main .info-table th.section-title {
  background-color: #ede7f5; /* タイトルの背景色 */
  color: #3d0aa9;               /* タイトル文字の色（落ち着いた黒系） */
  font-weight: bold;
  text-align: left;
  font-size: 18px;
}

.site-main .info-table tbody td:first-child {
  width: 25%;
  font-weight: bold;
  background-color: #fff;
}

.site-main .info-table tbody td:last-child {
  width: 75%;
}


.affiliation .carousel-container {
  overflow-x: auto;
  padding: 20px 0;
  white-space: nowrap;
  scroll-snap-type: x mandatory;
}

.affiliation .carousel {
  display: flex;
  gap: 20px;
  padding-left: 20px;
}

.affiliation .card {
  flex: 0 0 auto;
  width: 140px;
  scroll-snap-align: start;
  text-align: center;
  text-decoration: none;     /* リンクの下線消す */
  color: inherit;            /* テキストカラーを継承 */
  transition: transform 0.2s;
}

.affiliation .card:hover {
  transform: scale(1.03);    /* ホバーでちょっと拡大 */
}

.affiliation .card img {
  width: 140px;
  height: 140px;
  border-radius: 50%;
  object-fit: cover;
  display: block;
  margin: 0 auto 8px;
}

.affiliation .card p {
  font-size: 16px;
}


/*------------------------------
フローティングボタン
*/
.float_banner {
    width: 100%;
    position: fixed;
    background: 0 0;
    justify-content: center;
    bottom: 20px;
    padding: 0 10px;
    z-index: 5;
}
.float_banner a {
    width: 95%;
    margin: 0 auto 5px;
    display: block;
	background: #fa7d0c;
    border-radius: 40px;
    overflow: hidden;
	box-shadow: 0 4px #6c3016;
}
.float_banner a:before {
    content: "";
    animation: shine 3s ease-in-out infinite;
    background-color: rgba(255,255,255,.5);
    height: 100%;
    left: 0;
    opacity: 0;
    position: absolute;
    top: -50px;
    transform: rotate(45deg);
    width: 15px;
}
.float_banner a p::before{
    content: "";
    position: absolute;
    right: 10px;
    top: 50%;
    width: 8px;
    height: 8px;
    transform: translateY(-50%) rotate(-45deg);
    border-right: 1px solid #fff;
    border-bottom: 1px solid #fff;
  }

.float_banner a p span.cam {
    display: block;
    font-size: .8em;
    margin-bottom: 2px;
    letter-spacing: .05em;
    color: #ff0;
}
.float_banner a p span.br {
    display: inline-block;
}
.float_banner a p {
    text-align: center;
    font-weight: 600;
    color: #fff;
    font-size: 1.18em;
    padding: 10px;
    line-height: 1.2;
	}
/*------------------------------
ピックアップサイト
*/
.pickup-list {
    color: #000;
    padding: 5%;
    width: 100%;
    margin: auto;
    text-align: center;
}

.site_pickup .pickup-list > li {
    background: #fff;
    border-radius: 10px;
    padding-bottom: 15px;
    overflow: hidden;
	margin-bottom: 1rem;
}

.site_pickup .pickup-list-header {
    background-color: #eee6fb;
    padding: .3em;
    font-size: min(25px, 4vw);
    display: flex;
    justify-content: center;
    align-items: center;
	gap:10px;
}
.site_pickup .pickup-list-header.pickup-list-header_pink {
    background-color: #ffccd3;
}
.site_pickup .pickup-list-header.pickup-list-header_blue {
    background-color: #cce2ff;
}
.site_pickup .pickup-list-header.pickup-list-header_yellow {
    background-color: #fff0cc;
}
.site_pickup .pickup-list-header .pickup{
	width:23%;
}


.site_pickup .pickup-list-header .highlight {
    background-color: #fff;
    color: #e60039;
    padding: 5px 15px;
    line-height: 1.5;
    font-weight: bold;
}

.site_pickup .pickup-list-header .title {
  color: #4b2991;
  font-weight: bold;
}

.site_pickup .pickup-list-subtitle p {
    font-size: var(--fnt-26);
    margin: 16px 0 5px;
    line-height: 1.3;
    font-weight: bold;
}

.site_pickup .pickup-list-sites {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  max-width: 800px;
  margin: 0 auto; /* 中央寄せ */
  padding: 0 5%; /* 画面端に寄りすぎないように */
  box-sizing: border-box;
}

.site_pickup .pickup-list-sites .site {
  background-color: #fff;
  padding: 12px;
  border-radius: 10px;
}

.site_pickup .pickup-list-sites .site img {
    width: 100%;
    border-radius: 10px;
    border: 1px solid #eee;
}

.site_pickup .pickup-list-sites .site p {
  margin-top: 8px;
  font-size: 0.9em;
  color: #000;
  line-height: 1.3;
}




h2.termttl {
    color: var(--clr-pur4);
}

/* ページネーション全体 */
.nav-links {
    padding: 2em;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}

/* 数字ボタン・現在ページ */
.nav-links a,
.nav-links span {
    width: 50px;
    height: 50px;
    margin: 2px;
    line-height: 50px;
    text-align: center;
    font-size: 16px;
    font-weight: bold;
    text-decoration: none;
    background: #fff;
    color: #222;
    border-radius: 100%;
    display: inline-block;
    transition: 0.3s;
}

/* 現在のページ */
.nav-links .current {
    background: #cfa1e5; /* お好みで色調整（ピンク系） */
    color: #fff;
}

/* 数字ボタンホバー */
.nav-links a:hover {
    background: #5b2b90;
    color: #fff;
}

/* 次へ・前へボタン（ » ）はテキストリンク風 */
.nav-links .next,
.nav-links .prev {
    width: auto;
    height: auto;
    line-height: normal;
    padding: 10px 14px;
    border-radius: 8px;
    background: transparent;
    color: #5b2b90;
    font-weight: bold;
}

.nav-links .next:hover,
.nav-links .prev:hover {
    background: transparent;
    color: #a788dd;
    text-decoration: underline;
}






/*------------------------------
トップ占い師総合ランキング
*/
.sensei_ranking-list > li:not(:last-child){
    border-bottom: 1px #ddd solid;
    padding: 0 0 40px;
}
.sensei_ranking-list .bs-name{
	padding-top: 2px;
    background-size: 35px 80%;
    background-repeat: no-repeat;
    font-weight: 900;
    font-size: 1.4em;
}
.sensei_ranking-list li + lI{
	margin-top: 1.5em;
}
/*
.sensei_ranking-list .bs-name.rank01,
.sensei_ranking01 .bs-name{
  background-image: url( "image/rank-icon/rank1.svg");
}
.sensei_ranking-list .bs-name.rank02,
.sensei_ranking02 .bs-name{
  background-image: url( "image/rank-icon/rank2.svg");
}
.sensei_ranking-list .bs-name.rank03,
.sensei_ranking03 .bs-name{
  background-image: url( "image/rank-icon/rank3.svg");
}
.sensei_ranking-list .bs-name.rank04{
  background-image: url( "image/rank-icon/rank4.svg");
}
.sensei_ranking-list .bs-name.rank05{
  background-image: url( "image/rank-icon/rank5.svg");
}
.sensei_ranking-list .bs-name.rank06{
  background-image: url( "image/rank-icon/rank6.svg");
}
.sensei_ranking-list .bs-name.rank07{
  background-image: url( "image/rank-icon/rank7.svg");
}
.sensei_ranking-list .bs-name.rank08{
  background-image: url( "image/rank-icon/rank8.svg");
}
.sensei_ranking-list .bs-name.rank09{
  background-image: url( "image/rank-icon/rank9.svg");
}
.sensei_ranking-list .bs-name.rank10{
  background-image: url( "image/rank-icon/rank10.svg");
}
.sensei_ranking-list .bs-name.rank11{
  background-image: url( "image/rank-icon/rank11.svg");
}
.sensei_ranking-list .bs-name.rank12{
  background-image: url( "image/rank-icon/rank12.svg");
}
.sensei_ranking-list .bs-name.rank13{
  background-image: url( "image/rank-icon/rank13.svg");
}
.sensei_ranking-list .bs-name.rank14{
  background-image: url( "image/rank-icon/rank14.svg");
}
.sensei_ranking-list .bs-name.rank15{
  background-image: url( "image/rank-icon/rank15.svg");
}
.sensei_ranking-list .bs-name.rank16{
  background-image: url( "image/rank-icon/rank16.svg");
}
.sensei_ranking-list .bs-name.rank17{
  background-image: url( "image/rank-icon/rank17.svg");
}
.sensei_ranking-list .bs-name.rank18{
  background-image: url( "image/rank-icon/rank18.svg");
}
.sensei_ranking-list .bs-name.rank19{
  background-image: url( "image/rank-icon/rank19.svg");
}
.sensei_ranking-list .bs-name.rank20{
  background-image: url( "image/rank-icon/rank20.svg");
}
*/
.sensei_ranking-list .rank-thum{
	width: 22%;
}
.sensei-rank-entry-body{
	justify-content: space-between;
	margin: .65em 0;
    align-items: center;
}
.sensei-rank-entry-body .rank-thum img{
	overflow: hidden;
	border-radius: 10px;
}
.sensei-rank-deta{
	width: calc(78% - 10px);
}
.sensei-rank-deta .instar{
	align-items: center;
    justify-content: flex-start;
    color: #ce4646;
    font-weight: 900;
}
.sensei-rank-deta .instar > p:nth-child(1){
	width: 32%;
}
.sensei-rank-deta .scr{
	font-size: 2em;
	margin-left: .5em;
}
.sensei-star{
	width: 70%;
    max-width: 130px;
}
.sensei-rank-deta > * + *{
	margin-top: .25em;
}
.sensei-rank-deta__inner span{
	font-weight: 900;
    width: 32%;
}
.continue-btn{
	display: block;
    text-align: center;
}
.continue-btn::before {
  content: "続きを読む"
}
.continue-item {
  position: relative;
  overflow: hidden;
  height: 80px; /*隠した状態の高さ*/
}
.continue-item::before {
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 30px;
  background: -webkit-linear-gradient(top, rgba(255,255,255,0) 0%, rgba(255,255,255,0.9) 50%, rgba(255,255,255,0.9) 50%, #fff 100%);
  background: linear-gradient(top, rgba(255,255,255,0) 0%, rgba(255,255,255,0.9) 50%, rgba(255,255,255,0.9) 50%, #fff 100%);
  content: "";
}
.continue-trigger {
  display: none; /*チェックボックスは常に非表示*/
}
.continue-trigger:checked ~ .continue-btn::before {
  content: "" /*チェックされていたら、文言を変更する*/
}
.continue-trigger:checked ~ .continue-item {
  height: auto; /*チェックされていたら、高さを戻す*/
}
.continue-trigger:checked ~ .continue-item::before {
  display: none; /*チェックされていたら、continue-itemのbeforeを非表示にする*/
}

/*------------------------------
下層MV 共通パーツ
*/
#breadcrumbs{
	color: #fff;
	margin-bottom: 1em;
}
#title_page {
  width: 100%;
background: #596a6f;
	color: #fff;
}
#title_page h1 {
  font-size: 40px;
  font-weight: 600;
  text-align:center;
  padding: 100px;
}
.main_column .under-page_block{
	background: #fff;
	border-radius: 10px;
	padding: 20px;
}
.under-page_block div + div{
	margin-top: 20px;
}
.main_column .under-page_block h2{
	border-left: 4px solid #243e46;
    font-size: 1.15em;
    font-weight: 600;
    padding: 5px 10px;
    line-height: 1.2;
    margin: 0 0 20px;
	color: inherit;
    text-shadow: none;
    text-align: left;
}
/*------------------------------
相談内容別占い師ランキングテンプレート
*/
.sub-main-mv{
	color: #fff;
}
.sensei_list li + li{
	margin-top: 2em;
}


/*------------------------------
お問い合わせフォーム
*/
#mw_wp_form_mw-wp-form-20{
	background: #fff;
	border-radius: 10px;
	padding: 20px;
}
input[type="submit"],
input[type="button"] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}
input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
  display: none;
}
input[type="submit"]::focus,
input[type="button"]::focus {
  outline-offset: -2px;
}
.mw_wp_form dt {
	border-left: 4px solid #243e46;
    padding-left: 6px;
    font-size: 1.15em;
    font-weight: 600;
    padding: 5px 10px;
    line-height: 1.2;
    margin: 0 0 20px;
}
.mw_wp_form dd {
  margin-bottom: 20px;
}
.mw_wp_form select,
.mw_wp_form input {
display: block;
padding: 5px 0;
font-size: 18px;
}
.mw_wp_form select{
	-webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
	width: 80%;
    padding: 10px;
	color: #333;
	background: #fff;
	border: 1px solid #333;
}
.mw_wp_form input,
.mw_wp_form textarea {
  width: 96%;
	font-size: 18px;
	border: 1px solid #7f7f7f;
}

input[type="submit"]  {
  width: 14em;
    padding: 1em;
    margin: 20px auto;
  border-radius: 0;
	background: #243e46;
	color: #fff;
}
/*------------------------------
調査概要
*/

.survey{
  margin-bottom: 40px;
}
.survey dl dt{
  width: 100%;
  background: #fafafa;
  color: #243e46;
  font-weight: 600;
  padding: .5em;
}

.survey dl dd{
  width: 100%;
  padding: .5em;
  margin-bottom: .5em;
}

.survey ul li{
  padding: .5em;
}

.survey ul li:nth-child(2n+1){
  background: #fafafa;
}

.survey-result table{
  width: 100%;
}
.survey-result td, .survey-result th{
  line-height: 1.2;
  padding: .5em;
  vertical-align: middle;
  text-align: center;
}
.survey-result .name{
  background: #bfd0cd;
  font-size: .8em;
}
.survey-result .name.head{
  width: 30%;
  padding: 0 6vw;
}
.survey-result .name.other{
  width: 10%;
  padding: 0.5em 1.2em;
}
.survey-result tr:nth-child(2n+1){
  background: #fafafa;
}
.survey-result td.total{
  font-weight: 600;
  color: #243e46;
}
.scroll-table table {
  display: block;
  overflow-x: scroll;
  white-space: nowrap;
  -webkit-overflow-scrolling: touch;
}
.survey-link{
	padding-top: 20px;
	color: #65afa4;
    text-decoration: underline;
}
/*------------------------------
フッター設定
*/
footer {
    width: 100%;
    background: #4b2991;
}
footer p {
  color: #fff;
  text-align: center;
  font-size: 14px;
    padding: 20px;
}

.footer_txt .content.flex {
  justify-content: center;
}

.footer_txt .content.flex a {
  position: relative;
  padding: 0 0 0 1em;
}
.footer_txt .content.flex a::before {
  content: "";
    width: 10px;
    height: 10px;
    position: absolute;
    top: 3px;
    left: 2px;
    margin: auto;
    box-sizing: border-box;
    border: 5px solid transparent;
    border-left: 6px solid #545454;   /* 好みで色を変えてください */
}
.footer_txt {
  font-size: 14px;
    padding: 20px;
    background: #fff;
}
.footer_txt .content a + a {
  margin-left: 3em;
}

/* ------------------------
 メディアクエリ
 */
@media screen and (max-width: 480px) {
/* header */
.menu-item {
	font-size: 14px;
}
.menu-container {
	display: none;
}

/* ピックアップ */

.teller-card::before {
	width: 200px;
    height: 200px;
}
.teller-list .teller-header h2 {
    font-size: var(--fnt-26);
}
.teller-list .rank-header h2{
	font-size: 21px;	
}

.teller-list .teller-info {
	font-size: var(--fnt-16);
}
.teller-list .teller-catch {
	font-size: var(--fnt-16);
}

.urapa-btn {
	width: 280px;
}
	
/* 悩み占い師特集 */
.soudan-list {
	margin: 0 1em;
}
/* サイト一覧 */
.site_pickup .pickup-list-subtitle p {
    font-size: var(--fnt-16);
}
.site_pickup .pickup-list-sites {
	grid-template-columns: repeat(4, 1fr);
}
.site_pickup .pickup-list-sites .site {
	padding: 0;
}
	
/* ----------------------------------------
占い師紹介部 */
	

.teller-box .teller-info .teller-name {
    font-size: var(--fnt-30);
}
.teller-box .teller-info .teller-copy {
    font-size: var(--fnt-16);
}
.teller-box .teller-data div {
	font-size: 16px;
}
.teller-box .teller-data span {
    font-size: var(--fnt-16);
}
.teller-box .teller-data .data-value {
	font-size: var(--fnt-16);
}
.teller-box .teller-data div:nth-child(3) .data-value {
    font-size: var(--fnt-14);
}
.teller-box .teller-tags {
	display: flex;
	justify-content: center;
}
.teller-box .teller-tags span {
	padding: 1px 12px;
	font-size: var(--fnt-16);
}
.teller-button {
	font-size: 1.2em;
	padding: 20px 30px;
}
.teller-button .teller-icon {
    width: 30px;
}
.profile-section .profile-heading {
	margin-bottom: 0;
}
.profile-box .profile-heading {
	font-size: var(--fnt-20);
	margin-top: 5%;
}
.profile-section .profile-text {
    padding: 2%;
}
.profile-section, .teller-review {
    padding: 2% 2% 10% 2%;
}
}