@charset "UTF-8";

/* =========================================================
   2026-01 - Love Season inspired palette (Peach mist + gold)
   NOTE: Layout/structure/spacing untouched; colors & gradients only.
   ========================================================= */
:root{
  /* =========================================================
     2026-01 - Love Season inspired palette (Peach mist + champagne gold)
     NOTE: Layout/structure/spacing untouched; colors & gradients only.
     ========================================================= */

  /* Base */
  --lr-bg:  #fffaf4;                /* ivory mist */
  --lr-bg2: #ffe7cf;                /* peach veil */
  --lr-ink: #ffffff;                /* on-accent text */
  --lr-text:#5a3b2a;                /* warm brown ink */
  --lr-text-soft: rgba(90,59,42,.72);

  /* Accent (Peach) */
  --lr-violet:  #f0b37e;            /* main accent */
  --lr-violet-2:#ffe1c6;            /* soft peach */
  --lr-violet-3:#e79a5a;            /* strong peach */

  /* Gold (sub-accent) */
  --lr-gold:  #d4b06a;
  --lr-gold-2:#f3e1b6;

  /* Panels */
  --lr-panel:        rgba(240,179,126,.22);
  --lr-panel-strong: rgba(252,195,120,.78);
  --lr-panel-soft:   rgba(240,179,126,.16);

  /* Surfaces / lines */
  --lr-white:#ffffff;
  --lr-line:  rgba(255,255,255,.55);
  --lr-line-2:rgba(252,195,120,.22);

  /* Shadow */
  --lr-shadow: 0 10px 34px rgba(120,70,40,.14);
}

body {
    font-family: "Noto Serif JP", 游明朝, YuMincho, Hiragino Mincho ProN W3, ヒラギノ明朝 ProN W3, Hiragino Mincho ProN, HG明朝E, ＭＳ Ｐ明朝, ＭＳ 明朝, serif;
    margin: 0;
	line-height: 1.5;
    color: var(--lr-text);
    text-align: left;
    background-color: var(--lr-bg);
    background-image: radial-gradient(1200px 700px at 15% 10%, rgba(255,255,255,.88), rgba(255,255,255,0) 55%),
                      radial-gradient(900px 600px at 85% 25%, rgba(255,225,198,.62), rgba(255,225,198,0) 60%),
                      linear-gradient(180deg, var(--lr-bg2), var(--lr-bg));
    /*background-attachment: fixed;*/
}


a {
    color: var(--lr-text);
    text-decoration: none;
    background-color: transparent;
}

a:hover {
    color: var(--lr-violet-3);
    text-decoration:none;
}

a:not([href]):not([class]),a:not([href]):not([class]):hover {
    color: inherit;
    text-decoration:none;
}


.d-md-none {
    display: none !important;
}


img {
    max-width: 100%;
    height: auto;
}


#header {
    position: fixed;
	background: rgba(252,195,120,.92);
    top: 0;
    height: auto;
    /*margin: 40px 0 0;*/
    box-shadow: none;
    z-index: 100!important
}


.page-index .header {
    padding-top: 0
}


#header.is_work {
    background: rgba(252,195,120,.94);
    margin: 0;
}

#header, #header.is_work {
    display: block;
    width: 100%;
    padding: 0;
    transition: all .6s;
    z-index: 1000 !important;
}

.mastHead {
    text-align: center
}

.mastHead .sitenavi-list .sitenavi-item {
    flex: none
}

.header {
    position: relative
}

.header .figure {
    margin: 0
}

figure {
    margin: 0 0 1rem
}



.header .photo-event {
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%)
}

.headerbox {
    padding: 0 20px;
    display: flex;
    justify-content: space-between;
    align-items: center
}

.headerbox .photo-logo img {
    width: 190px!important
}

.headerbox .figure {
    margin-bottom: 0
}

.figure img {
    margin: 0;
    -o-object-fit: cover;
    object-fit: cover;
    height: inherit!important;
    width: 100%!important
}


.headerbox .topbox {
    display: flex;
    justify-content: flex-start;
    align-items: center
}

.headerbox .topbox .topnavi .sitenavi-item {
    padding: 2px 15px;
}

.headerbox .topbox .topnavi .sitenavi-item .sitenavi-link-text {
    color: var(--lr-ink);
    font-size: 1.2rem
}

.headerbox .topbox .topnavi .sitenavi-item .sitenavi-link-slug {
    /*display: none*/
}

.headerbox .topbox .topnavi .sitenavi-item:last-of-type {

}

.headerbox .topbox .topnavi .sitenavi-item:hover {
    background: rgba(255,255,255,.18)
}



/* headerbox */
.headerbox .info-box {
    color: var(--lr-ink);
    text-align: right
}

.headerbox .info-box .time {
    font-size: 1rem
}

.headerbox .info-box .tel {
    display: inline-block;
    text-align: right;
    padding-left: 25px;
    font-size: 1.25rem;
    position: relative;
    line-height: 1.2
}

.headerbox .info-box .fas {
	margin-right:5px;
    
	}

.headerbox .info-box .tel a {
    color: #fff
}

.headerbox .info-box .notice {
    font-size: .75rem;
    line-height: 1.2
}

.headerbox .info-box .head-address {
    font-size: .875rem;
    line-height: 1.2
}

/*sitenavi*/
.mastFoot .sitenavi,.mastHead .sitenavi {
    width: 100%
}

.d-flex {
    display: flex !important;
}



.mastFoot .sitenavi-list,.mastHead .sitenavi-list {
    display: flex;
    align-items: stretch;
    justify-content: space-between;
    width: 100%
}

.mastFoot .sitenavi-list .sitenavi-item,.mastHead .sitenavi-list .sitenavi-item {
    flex-shrink: 1;
    height: inherit
}

.mastFoot .sitenavi-list .sitenavi-item .sitenavi-link,.mastHead .sitenavi-list .sitenavi-item .sitenavi-link {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    width: 100%;
    height: 100%
}


.list-inline, .list-unstyled {
    padding-left: 0;
    list-style: none;
}



/* Navigation Bar */
/*
nav {
    background-color: rgba(255, 255, 255, 0.8);
    position: fixed;
    width: 100%;
    top: 0;
    z-index: 100;
    display: flex;
    justify-content: space-between;
    padding: 10px 20px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}

nav ul {
    display: flex;
    list-style: none;
    padding: 0;
    margin: 0;
}

nav li {
    margin: 0 10px;
}

nav a {
    text-decoration: none;
    color: #333;
    padding: 5px 10px;
    transition: background-color 0.3s;
}

nav a:hover {
    background-color: #ff79c6;
    color: white;
    border-radius: 5px;
}

/* Hero Section */
.hero {
    height: 80vh;
    position: relative;
    overflow: hidden;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
}

/* Hero logo overlay (top layer) */
.hero__logo-layer{
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 5;
    pointer-events: none;
}

.hero__logo-img{
    width: min(420px, 78vw);
    height: auto;
}

.hero h1 {
    font-size: 4rem;
    margin-bottom: 10px;
}



/* event Section */
.event {
    padding: 20px 0px;
}

.section-event-datas {
	width:60%;
	margin:0 auto;
    padding: 10px 0px;
	display: flex;
    flex-wrap: wrap;
    justify-content: center;
}



/* -お知らせ- */
.news {
    padding-bottom: 20px;
}

.news h2 {
    font-size: 2rem;
    margin-bottom: 20px;
}

.news  .container{
	background: var(--lr-panel);
	width:60%;
	margin:0 auto;
}
	
.news  .news-cont {
	background: var(--lr-white);
    padding: 1px;
    height: 320px;
    overflow-y: auto;
    font-size: 14px;

} 
	

.news-cont  .list-group {
    margin: 0;
}

.list-group {
    list-style: none;
	padding:2px;
}


.news-cont .list-group-item {
    border: 0;
    border-radius: 0;
    border-bottom: 1px dotted rgba(255,255,255,.35);
}


.news-cont .list-group-item .date {
    font-size: 14px;
    line-height: 1.3;
    color: var(--lr-ink);
    background: rgba(255,255,255,.92);
    border-radius: 5px;
    font-weight: 700;
    box-sizing: border-box;
    margin: 15px 0 5px;
    display: inline-block;
    padding: 1px 50px 2px;
    color: var(--lr-violet-3);
    box-shadow: 0 6px 16px rgba(120,70,40,.12);
}

.news-cont  .list-group-item .title {
    color: var(--lr-violet-3);
    font-size: 1.125rem;
    font-weight: 700;
}

.news-cont  .list-group-item .message {
    padding: 5px;
}





/* THERAPIST Section */
.therapist {
    padding: 20px 0px;
}


.therapist  .container{
	padding-top:40px;
	background: var(--lr-panel);
	width:60%;
	margin:0 auto;
}


.section-cast-datas {
	width:100%;
	margin:0 auto;

    padding: 10px 0px;
	display: flex;
    gap: 20px;
    flex-wrap: wrap;
    justify-content: center;
}



.therapist-card {
	position: relative;
    background: rgba(255,255,255,.86);
	border: 0 solid silver;
	width:250px;
	margin: 0 1px;	
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
    border-radius: 10px;
    overflow: hidden;
    transition: transform 0.3s;
}

.therapist-card:hover {
    transform: scale(1.05);
}

.therapist-card img {
    width: 100%;
}


.therapist-card .icon_new{
  position: absolute;
  top: 0;
  left: 0;
  z-index: 5;
  margin: 0;
}

.therapist-card .icon_new img{
  width: 30px;
  height: auto;
  display: block;
}


.therapist-card-body {
	text-align:center;
    padding: 1px;
}


.therapist-card-body .therapist-name {
    background: none;
    font-size: 14px;
    padding: 0;
    box-sizing: border-box;
    font-weight: 700;
    color: var(--lr-violet-3);
    margin: 0;
	overflow: hidden;
	
}

.therapist-card-body .therapist-size {
	border-radius: .25rem;
    background: linear-gradient(180deg, rgba(252,195,120,.95), rgba(252,195,120,.95));
	font-size: 14px;
    color: var(--lr-white);
    line-height: 1.3;
    padding: 4px 0;
    border-top: none;
}

/* Profile */
.profile {
    padding: 20px 0px;
}


.profile  .container{
	padding-top:40px;
	background: var(--lr-panel);
	width:60%;
	margin:0 auto;
}

.profile h2 {
    font-size: 2rem;
    margin-bottom: 40px;
}

.staff-detail {
    padding: 30px 0;
}

.staff-detail .row {
    padding: 30px 50px;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap
}

.row {
    display: flex;
    flex-wrap: wrap;
    margin-right: -15px;
    margin-left: -15px;
}

ol, ul {
    list-style: none;
}

.staff-detail .row .imgbox {
    width: 45%;
}

.staff-detail .row .imgbox .page-therapist-thumb img {
    width: 100%
}

.staff-detail .row .imgbox .list-inline {
    margin-top: 15px;
    display: flex;
    flex-wrap: wrap;
    margin-left: -5px
}

.staff-detail .row .imgbox .list-inline .list-inline-item {
    width: calc(20% - 5px);
    margin-bottom: 5px;
    margin-left: 5px;
    margin-right: 0
}

img {
    vertical-align: top;
    max-width: 100%;
}

.staff-detail .row .des {
    width: 45%;
    padding-left: 5%;
    font-size: 16px
}

.staff-detail .row .des .page-therapist-info {
    margin-bottom: 20px
}

.staff-detail .row .des .page-therapist-info dl {
    display: flex;
    padding: 10px 0;
    border-bottom: 1px solid rgba(255,255,255,.25)
}

.staff-detail .row .des .page-therapist-info dl dt {
    width: 20%
}

.staff-detail .row .des .page-therapist-info dl dd {
    width: 80%
}

.staff-detail .row .des .page-therapist-info dl dd .sizechart {
    display: block;
    text-align: left
}

.staff-detail .row .des .page-therapist-info dl dd .girl-size-separation {
    display: inline;
    background: none;
    letter-spacing: 0;
    width: auto;
    flex-basis: auto
}



/* SYSTEM */
.system {
    padding-bottom: 20px;
}

.system h2 {
    font-size: 2rem;
    margin-bottom: 20px;
}

.system  .container{
	padding-top:40px;
	background: var(--lr-panel);
	width:60%;
	margin:0 auto;
}


.system-cost {
    border: 0 solid #313030;
    background: transparent;
    padding-top: 30px;
 }


.system-cost {
    font-size: 20px;
    width: 100%;
    margin: 10px auto 0;
    text-align: center;
    box-shadow: 0 4px 3px rgba(1,1,1,.1);
    overflow: hidden; 
    box-sizing: border-box;
}

dd {
    margin-bottom: .5rem;
    margin-left: 0;
}

dd {
    margin-bottom: .5rem;
    margin-left: 0;
}

.system-cost .system-cost-data .cost-data-bundle {
    justify-content: center;
    flex-wrap: wrap;
}

.system-cost .system-cost-data .cost-data-bundle {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 0;
}

.system-cost .system-cost-data .cost-data-bundle {
    margin: 0 3px 5px;
}

.system-cost .system-cost-data .cost-data-bundle .cost-data-price {
    background: rgba(255,255,255,.72);
    line-height: 54px;
    font-size: 1.5rem;
    padding: 0;
}

.system-cost .system-cost-data .cost-data-bundle .cost-data-price .arrow .price-arrow,.system-cost .system-cost-data .cost-data-bundle .cost-data-price .price-1,.system-cost .system-cost-data .cost-data-bundle .cost-data-price .price-2 {
    color: var(--lr-violet-3);
}

.system-cost .system-cost-data .cost-data-bundle .cost-data-price .price-2 {
    flex: 0 0 50%;
    text-align: center;
    color: var(--lr-violet-3);
    font-size: 1.6rem;
    font-weight: 400;
}


.system-cost .system-cost-data .cost-data-bundle .cost-data-desc {
    flex: 0 0 95%;
    text-align: right;
    padding: 10px 30px
}

.system-cost .system-cost-data .cost-data-bundle .cost-data-label {
    background: var(--lr-violet-3);
    padding: 0 0 0 5px;
    color: var(--lr-ink);
    line-height: 54px;
    margin-right: 5px;
    width: 28%
}

.system-cost .system-cost-data .cost-data-bundle .cost-data-price {
    width: 68%;
    text-align: center;
    font-size: 1.6rem;;
    font-weight: 700;
     color: var(--lr-ink);
    display: flex
;
    justify-content: flex-end;
    margin-bottom: 0;
}


.system-base-box,.system-mission-box,.system-options-box {
    border: 0 solid #313030;
    background: rgba(255,255,255,.18);
    font-size: 20px;
    width: 100%;
    margin: 10px auto 0;
    overflow: hidden;
    box-sizing: border-box;
    padding: 30px 20px 20px
}

.system-base {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    color: var(--lr-ink);
    padding: 0 10px;
    font-weight: 400
}

.system-mission-item,.system-options-item {
    display: flex;
    justify-content: flex-start;
    margin-bottom: 10px;
    border-bottom: 1px dotted rgba(252,195,120,.35)
}

.system-mission-content,.system-options-services {
    color: var(--lr-ink)
}

.system-mission-desc,.system-options-desc {
    font-size: 14px;
    text-align: left
}

.system-mission-price,.system-options-price {
    font-weight: 400;
    flex: 0 0 18%
}

.system-base-options-con {
    font-weight: 400
}

.block-system-title {
    height: auto!important;
    font-weight: 400
}

.block-system-title .systemtitle-head {
    color: var(--lr-ink);
    font-size: 1.5rem
}

.block-system-title .systemtitle-head:before {
    display: none
}

.systemtitle-desc {
	font-size: 1.0rem;
    color: #fff
}

.system-cost-period {
    color: var(--lr-ink);
    margin-top: 15px
}

.system-fee_remark1-box,.system-fee_remark2-box,.system-fee_remark3-box {
    padding: 30px 20px 20px;
    border: 1px solid rgba(255,255,255,.28);
    margin-top: 10px
}



/* ACCESS */
.access {
    padding-bottom: 20px;
}

.access h2 {
    font-size: 2rem;
    margin-bottom: 20px;
}

.access  .container{
	padding-top:40px;
	background: var(--lr-panel);
	width:60%;
	margin:0 auto;
}

.access-info {
    color: var(--lr-text);
    background: var(--lr-panel-soft)
}

.access-info .access-item {
    display: flex;
    align-items: flex-start;
    font-size: .875rem;
    border-bottom: 1px solid rgba(255,255,255,.18);
    padding: 10px 5px
}

.access-info .access-item .access-list-item-label {
    width: 20%;
    text-align: center;
    font-weight: 400;
    line-height: 2;
    border-right: 1px solid rgba(255,255,255,.28);
    margin-right: 10px
}

.access-info .access-item .access-list-item-context {
    line-height: 2
}

.access-info .access-item+.access-item {
    margin-top: 10px
}

.access-imagemap {
	margin-top:10px;
	padding:2px;
}


/* RECRUIT */
.recruit {
    padding-bottom: 20px;
}

.recruit h2 {
    font-size: 2rem;
    margin-bottom: 20px;
}

.recruit  .container{
	padding-top:40px;
	background: var(--lr-panel);
	width:60%;
	margin:0 auto;
}


.recruit-info {
    color: var(--lr-text);
    background: var(--lr-panel-soft)
}

.recruit-info .recruit-item {
    display: flex;
    align-items: flex-start;
    font-size: .875rem;
    border-bottom: 1px solid rgba(255,255,255,.18);
    padding: 10px 5px
}

.recruit-info .recruit-item .recruit-list-item-label {
    width: 20%;
    text-align: center;
    font-weight: 400;
    line-height: 2;
    border-right: 1px solid rgba(255,255,255,.28);
    margin-right: 10px
}

.recruit-info .recruit-item .recruit-list-item-context {
    line-height: 2
}

.recruit-info .recruit-item+.recruit-item {
    margin-top: 10px
}

 /* LINE */
.link {
    padding-bottom: 20px;
}

.link h2 {
    font-size: 2rem;
    margin-bottom: 20px;
}

.link  .container{
	padding-top:40px;
	background: var(--lr-panel);
	width:60%;
	margin:0 auto;
}


.link-info {
    color: var(--lr-ink);
    background: var(--lr-panel-soft)
}

.link-info .link-item {
    display: flex;
    align-items: flex-start;
    font-size: .875rem;
    border-bottom: 1px solid rgba(255,255,255,.18);
    padding: 10px 5px
}

.link-info .link-item .link-list-item-label {
    width: 50%;
    text-align: center;
    font-weight: 400;
    line-height: 2;
    margin-right: 10px
}

.link-info .link-item .link-list-item-context {
    line-height: 2
}

.link-info .link-item+.link-item {
    margin-top: 10px
}


/* h2 */
.subject01 {
    text-align: center;
    margin-bottom: 25px;
    letter-spacing: 0.08em;
}


.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6, p, dt, th {
    font-size: inherit;
    font-weight: normal;
    padding: 0;
    margin: 0;
}

.subject01 .subject01-en, .subject01 .subject01-jp {
    color: var(--lr-text);
}

.subject01 .subject01-en {
    color: var(--lr-violet-3);
    font-size: 26px;
    margin-bottom: 8px;
	  /* white shadow under text */
  text-shadow: 0 2px 6px rgba(255,255,255,.95);
}

.subject01 .subject01-jp {
    font-size: 14px;
    color: var(--lr-text-soft);
}



/* Footer */
footer {
    background: linear-gradient(180deg, rgba(252,195,120,.92), rgba(252,195,120,.92));
    color: white;
    padding: 20px;
    text-align: center;
	font-size:12px;
	margin-bottom:0px;
}

/* Floating Menu */
.floating-menu {
    position: fixed;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 100;
    display: flex;
    gap: 10px;
}



.btn-circle {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: linear-gradient(180deg, rgba(242,224,171,.95), rgba(252,195,120,.95));
    color: var(--lr-ink);
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    transition: background-color 0.3s, transform 0.3s;
}

.floating-menu a:hover {
    transform: scale(1.1);
}
 

.back-to-top {
	z-index: 9999;
    display: none;
    position: fixed;
    bottom: 70px;
    right: 20px;
    background: linear-gradient(180deg, rgba(252,195,120,.98), rgba(252,195,120,.98));
	color: var(--lr-ink);
    border: none;
    border-radius: 50%;
    width: 50px;
    height: 50px;
    justify-content: center;
    align-items: center;
    cursor: pointer;
}

.back-to-top {
	box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    transition: background-color 0.3s, transform 0.3s; /* 0.3秒内缓慢变化 */
}

.back-to-top:hover {
   transform: scale(1.1);
}


.back-to-top.show {
    display: flex;
}


.Background {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    margin: 0 auto;
    z-index: -1;
    opacity: 1;
}

/* bg_common */
.bg_common {
    background: rgba(255,225,198,.45);
    padding: 50px 0;
}


/* tappage-info */
.container-inner{
	text-align:center;
}

.tappage-info {
	margin:0 auto;
	width:50%;
    padding-top: 40px
}

.tappage-info .notepad-title {
    text-align: center;
    font-size: 1.125rem;
    order: 2;
    font-family: fan;
    color: var(--lr-ink);
    letter-spacing: -1px;
    display: block;
    letter-spacing: 5px;
    position: relative
}

.tappage-info .notepad-title:after {
    position: absolute;
    bottom: -10px;
    left: 10%;
    width: 80%;
    height: 3px;
    background-color: var(--lr-violet-3);
    content: ""
}

.tappage-info .notepad-content {
	margin-top: 50px;
    background: var(--lr-panel);
    padding: 40px 40px 50px;
    color: var(--lr-ink);
    font-size: 18px;
    line-height: 1.7;
}	
	
.tappage-recruit {
    padding-top: 30px
}


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


div#footer_logo {
    width: 320px;
    margin: 20px auto;
}



div#footer_nav {
	width:60%;
	margin:0 auto;
    text-align: center;
}

.footer_nav_bt {
    font-size: 10px;
    -moz-transition: all 0.8s;
    -o-transition: all 0.8s;
    -webkit-transition: all 0.8s;
    transition: all 0.8s;
    display: inline-block;
    margin: 5px 0px 0;
    background: rgba(252,195,120,.85);
    padding: 5px 7px;
    color: #fff;
    width: 23%;
	border-radius: 7px;
}

.footer_nav_bt:hover {
	background: rgba(252,195,120,.92);

}

.footer_nav_bt li {
    font-size: 11px;
	list-style:none;
}




@media (max-width: 768px) {
	
.d-block {
    display: block !important;
}

.d-none {
    display: none !important;
}


.header-position {
    position: relative;
}

.img-fluid,.img-thumbnail {
    max-width: 100%;
    height: auto
}

.img-thumbnail {
    padding: .25rem;
    background-color: var(--lr-bg);
    background-image: radial-gradient(1200px 700px at 15% 10%, rgba(255,255,255,.88), rgba(255,255,255,0) 55%),
                      radial-gradient(900px 600px at 85% 25%, rgba(255,225,198,.62), rgba(255,225,198,0) 60%),
                      linear-gradient(180deg, var(--lr-bg2), var(--lr-bg));
    background-attachment: fixed;
    border: 1px solid rgba(252,195,120,.22);
    border-radius: .25rem;
    box-shadow: 0 1px 2px rgba(0,0,0,.075)
}

.figure {
    display: inline-block
}

.figure-img {
    margin-bottom: .5rem;
    line-height: 1
}

.figure-caption {
    font-size: 90%;
    color: #6c757d
}

 
.headerbox {
    padding: 0 5px;
    display: flex;
    justify-content: space-between;
    align-items: center
}
 
.headerbox .photo-logo img {
    width: 120px!important;
}

.headerbox .figure {
    margin-bottom: 0
}

.headerbox .topbox {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
}

.headerbox .topbox .topnavi {
    width: 100%;
    padding-left: 10px
}

.headerbox .topbox .topnavi .sitenavi-list {
    width: 100%
}

.headerbox .topbox .topnavi .sitenavi-item {
    flex: 1;
    border-left: 1px solid rgba(255,255,255,.55)
}

.headerbox .topbox .topnavi .sitenavi-item {
    padding: 0px !important;
}


.headerbox .topbox .topnavi .sitenavi-item .sitenavi-link-text {
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    transform: rotate(0deg);
    color: var(--lr-ink);
    font-size: .75rem
}

.headerbox .topbox .topnavi .sitenavi-link-slug {
    display: none
}

.headerbox .topbox .topnavi .sitenavi-item:last-of-type {
    border-right: 1px solid rgba(255,255,255,.55)
}

.headerbox .topbox .topnavi .sitenavi-item:hover {
    background: rgba(255,255,255,.18)
}


/* Hero Section */
.hero {
	height: 52vh;
    min-height: 550px;
	margin:0;
    position: relative;
    overflow: hidden;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
}

/* Hero logo size (SP) */
.hero__logo-img{
    width: min(280px, 72vw);
}



/*info-box*/
.info-box {
    background: rgba(252,195,120,.72);
	width:100%;
    text-align: center;
    padding: 7px 0;
    position: relative
}

.info-box:before {
    top: -3px
}

.info-box:after,.info-box:before {
    position: absolute;
    left: 0;
    width: 100%;
    height: 3px;
    background: rgba(252,195,120,.92);
    content: ""
}

.info-box:after {
    bottom: -3px
}

.info-box .time {
    font-size: .875rem
}

.info-box .tel {

    padding-left: 35px;
    font-size: 1.5rem;
    position: relative;
    line-height: 1.2;
    display: inline-block
}

.info-box .tel:before {
    position: absolute;
    content: "";
    top: 5px;
    left: 0;
    background: url(../../images/iphone.png);
    background-size: 100%;
    width: 24px;
    height: 21px
}

.info-box .tel a {
    color: #fff
}

.info-box .snippet-notice {
    font-size: .875rem
}


/* event Section */
 
.section-event-datas {
	width:98%; 
}


/*therapist*/
.therapist-card, .gallery-grid img {
   width: 45%;
}


.section-cast-datas {
	width:100% !important;

}


/* -お知らせ- */
 

.news  .container{
	width:98%;
}


/*tappage-info*/
.tappage-info {	
	width:95%;
}

.tappage-info .notepad-content {
    margin-top: 25px;
    background: 0,0,0,.7;
    padding: 10px;
    color: var(--lr-ink);
    line-height: 1.7;
    font-size: .875rem
}



.system  .container{
	width:100%;
}


.access  .container{
	width:100%;
}

.recruit  .container{
	width:100%;
}

.link  .container{
	width:100%;
}

.therapist  .container{
	width:100%;
}



/* footer_info */
div#footer_nav {
	width:100%;

}

/*Profile*/
.profile  .container{
	width:100%;
}

.staff-detail {
    padding: 20px 0;
}

.staff-detail .row {
    padding: 30px 10px;
    margin: 0;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap
}

.staff-detail .row .imgbox,
.staff-detail .row .imgbox .page-therapist-thumb img {
    width: 100%
}

.staff-detail .row .imgbox .list-inline {
    margin-top: 10px;
    display: flex;
    justify-content: left;
    flex-wrap: wrap;
    margin-bottom: -.5rem;
    margin-right: -.5rem
}

.staff-detail .row .imgbox .list-inline .list-inline-item {
    width: 20%;
    margin-bottom: .5rem;
    margin-right: .5rem
}

.staff-detail .row .des {
    width: 100%;
    font-size: 16px
}

.staff-detail .row .des .page-therapist-info {
    margin-bottom: 20px
}

.staff-detail .row .des .page-therapist-info dl {
    display: flex;
    padding: 10px 0;
    border-bottom: 1px solid rgba(255,255,255,.25)
}

.staff-detail .row .des .page-therapist-info dl dt {
    width: 20%
}

.staff-detail .row .des .page-therapist-info dl dd {
    width: 80%
}

.staff-detail .row .des .page-therapist-info dl dd .sizechart {
    display: block;
    text-align: left
}

.staff-detail .row .des .page-therapist-info dl dd .girl-size-separation {
    display: inline;
    background: none;
    letter-spacing: 0;
    width: auto;
    flex-basis: auto
}



}

/* =========================================================
   PICKUP (Swiper) - Love Season / Peach mist unified
   ========================================================= */
.pickup{
  padding: 20px 0;
}

.pickup .container{
  padding-top: 40px;
  background: var(--lr-panel);
  width: 60%;
  margin: 0 auto;
}

.rc-sec-title{
  text-align: center;
  margin-bottom: 18px;
  letter-spacing: .08em;
}
.rc-sec-title__en{
  color: var(--lr-violet-3);
  font-size: 26px;
  margin-bottom: 6px;
  font-weight: 700;
  /* white shadow under text */
  text-shadow: 0 2px 6px rgba(255,255,255,.75);
}
.rc-sec-title__jp{
  font-size: 14px;
  color: var(--lr-text-soft);
}

.rc-card{
  background: rgba(255,255,255,.68);
  border: 1px solid rgba(255,255,255,.35);
  border-radius: 14px;
  box-shadow: var(--lr-shadow);
  padding: 14px 14px 18px;
}

.pickup-slider{
  position: relative;
}

/* Swiper spacing */
.pickup-swiper{
  padding: 6px 6px 34px;
}

/* Card */
.pickup-card{
  background: rgba(255,255,255,.86);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 10px 24px rgba(120,70,40,.12);
  transform: translateZ(0);
}

.pickup-card__thumb{
  margin: 0;
  position: relative;
  overflow: hidden;
  background: rgba(255,255,255,.55);
}
.pickup-card__thumb a{
  display: block;
}
.pickup-card__thumb img{
  width: 100%;
  height: 260px;
  object-fit: cover;
  display: block;
  transition: transform .35s ease;
}
.pickup-card:hover .pickup-card__thumb img{
  transform: scale(1.05);
}

.pickup-card__body{
  padding: 10px 10px 12px;
  text-align: center;
}
.pickup-card__name{
  font-size: 14px;
  font-weight: 700;
  color: var(--lr-violet-3);
  line-height: 1.3;
}
.pickup-card__age{
  font-weight: 700;
  color: var(--lr-violet-3);
  margin-left: 6px;
}
.pickup-card__size{
  margin-top: 8px;
  font-size: 13px;
  color: var(--lr-white);
  background: linear-gradient(180deg, rgba(252,195,120,.95), rgba(252,195,120,.95));
  border-radius: 8px;
  padding: 6px 8px;
  line-height: 1.2;
}

/* Pagination */
.pickup .swiper-pagination-bullets{
  bottom: 6px !important;
}
.pickup .swiper-pagination-bullet{
  width: 8px;
  height: 8px;
  opacity: .45;
}
.pickup .swiper-pagination-bullet-active{
  opacity: 1;
}

/* Nav buttons */
.pickup-prev,
.pickup-next{
  width: 20px !important;
  height: 20px !important;
  border-radius: 999px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(255,225,198,.35);
  box-shadow: 0 10px 24px rgba(120,70,40,.12);
  color: var(--lr-violet-3) !important;
  font-size: 14px;
  font-weight: 700;
}
.pickup-prev:after,
.pickup-next:after{
  font-size: 14px;
  font-weight: 700;
  color: var(--lr-violet-3);
}
.pickup-prev:hover,
.pickup-next:hover{
  background: rgba(255,255,255,.88);
}

/* Pagination bullets */
.pickup-pagination .swiper-pagination-bullet{
  background: rgba(252,195,120,.32);
  opacity: .35;
}
.pickup-pagination .swiper-pagination-bullet-active{
  background: rgba(252,195,120,.86) !important;
  opacity: 1;
}

/* Responsive */
@media (max-width: 768px){
  .pickup .container{
    width: 98%;
  }
  .pickup-card__thumb img{
    height: 220px;
  }
}


/* =========================================================
   SP Bottom Nav (Love Season-like)
   ========================================================= */
.sp-bottom-nav { display: none; }

@media (max-width: 768px){

  /* 让页面内容不被底部栏遮住 */
  body{
    padding-bottom: calc(78px + env(safe-area-inset-bottom));
  }

  /* 旧的 floating-menu（如果别的页面还在用）在手机端隐藏 */
  .floating-menu{ display:none !important; }

  /* Back to top 往上抬，避免被底部栏挡住 */
  .back-to-top{
    bottom: calc(92px + env(safe-area-inset-bottom));
    right: 16px;
  }

  /* 底部固定栏本体 */
  .sp-bottom-nav{
    display:block;
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 9998;

    background: rgba(255,255,255,.92);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);

    border-top: 1px solid rgba(242,224,171,.55);
    box-shadow: 0 -10px 24px rgba(242,224,171, .18);
  }

  /* 中间淡淡的品牌字（参考图的感觉） */
  .sp-bottom-nav__brand{
    position:absolute;
    left: 50%;
    top: 6px;
    transform: translateX(-50%);
    font-family: 'Lobster', cursive;
    font-size: 22px;
    letter-spacing: .02em;
    color: rgba(252,195,120, .18);
    pointer-events:none;
    user-select:none;
    white-space:nowrap;
  }

  .sp-bottom-nav__list{
    margin: 0;
    padding: 10px 10px calc(10px + env(safe-area-inset-bottom));
    list-style: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 6px;
  }

  .sp-bottom-nav__item{
    flex: 1 1 25%;
    min-width: 0;
  }

  .sp-bottom-nav__link{
    display:flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;

    text-decoration: none;
    font-size: 11px;
    line-height: 1.1;
    color: rgba(55,70,35, .70);

    border-radius: 14px;
    padding: 8px 0;
    transition: transform .18s ease, background .18s ease, color .18s ease;
  }

  .sp-bottom-nav__icon{
    font-size: 18px;
    line-height: 1;
  }

  /* 参考图：每个图标不同颜色 */
  .sp-bottom-nav__link[data-nav="top"] .sp-bottom-nav__icon{ color: rgba(252,195,120, .95); }
  .sp-bottom-nav__link[data-nav="therapist"] .sp-bottom-nav__icon{ color: rgba(232,140,150,.95); }
  .sp-bottom-nav__link[data-nav="system"] .sp-bottom-nav__icon{ color: rgba(210,170,90,.95); }
  .sp-bottom-nav__link[data-nav="tel"] .sp-bottom-nav__icon{ color: rgba(252,195,120, .95); }

  /* 当前页高亮 */
  .sp-bottom-nav__link.is-active{
    color: rgba(252,195,120, .95);
    background: rgba(242,224,171, .14);
    transform: translateY(-1px);
  }
  .sp-bottom-nav__link.is-active .sp-bottom-nav__icon{
    filter: drop-shadow(0 6px 10px rgba(252,195,120, .18));
    transform: translateY(-1px) scale(1.05);
  }

  /* footer 原本有 margin-bottom:50px，这里再加一点冗余更稳 */
  footer{
    margin-bottom: calc(2px + env(safe-area-inset-bottom));
  }
}



.soda {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    perspective: 50vw;
    transform: translateZ(-99999px);
    transform-style: preserve-3d;
    z-index: 1001;
    pointer-events: none
}


.bubble {
    position: absolute;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background-image: url(../images/heart.png);
    background-size: 100%;
    transform: translateX(-50%);
    will-change: top,left
}
