@charset "UTF-8";
/*
    Template: swell
    Theme Name: SWELL CHILD
    Theme URI: https://swell-theme.com/
    Description: SWELLの子テーマ
    Version: 1.0.0
    Author: LOOS WEB STUDIO
    Author URI: https://loos-web-studio.com/

    License: GNU General Public License
    License URI: http://www.gnu.org/licenses/gpl.html
*/

/* Header ------------------------------------------------------------------*/
.l-header__bar .c-catchphrase{
	color:var(--color_main);
}
@media(min-width:960px){
.l-header__inner.l-container,
.l-fixHeader__inner{
 display: grid;
 grid-template-columns: repeat(2, 1fr);
 grid-template-rows: repeat(2, 1fr);
 grid-column-gap: 0px;
 grid-row-gap: 0px;
}
.l-header__logo,
.l-fixHeader__logo{
  grid-area: 1 / 1 / 3 / 2;
}
.w-header.pc_ {
	grid-area: 1 / 2 / 2 / 3;
	justify-content: end;
	padding-top:5px;
	margin-bottom:8px;
}
.l-header__gnav,
.l-fixHeader__gnav{
  grid-area: 2 / 2 / 3 / 3;
}
}
/* インスタ */
.menu-item-insta{
	background:#ed7b9c;
	color:#fff;
}
.menu-item-insta span{
	display:flat;
	align-items:center;
}
/* SPメニュー */
.sp-menu-column2{
	gap:3px;
	justify-content:center;
}

/* Footer ------------------------------------------------------------------*/
#before_footer_widget .swell-block-column.footer-gmap{
	position:relative;
	margin-bottom: 1rem !important;
    margin-top: 1rem;
}
.footer-gmap iframe{
	position:relative;
	z-index:2;
}
.footer-gmap::after{
	background:url(/wp-content/uploads/2025/09/621259587.jpeg);
	position: absolute;
    left: 50%;
    top: 50%;
    content: "";
    width: calc(90% + 20px);
    height: calc(350px + 20px);
    z-index: -1;
    transform: translate(-50%, -50%);
	box-sizing: border-box;
	z-index:1;
	border-radius:30px;
}
/* SP追従メニュー */
.footer-fixmenu{
	height:100%;
	color:#fff !important;
	display: flex;
    justify-content: center;
    align-items: center;
	font-weight:600;
}
.footer-fixmenu-tel{
	background:var(--color_deep04);
}
.footer-fixmenu-mail{
	background:var(--color_main);
}
.footer-fixmenu-line{
	background:	#00B900;
}

/* ページタイトル ------------------------------------------------------------------*/
h1.c-pageTitle {
    color: var(--color_main);
}
/* 共通、ブロック------------------------------------------------------------------ */
/* 非表示 */
.display-none{
	display:none;
}
/* スマホでは中央揃え ============*/
@media(max-width:599px){
	.sp-txtCenter{
		text-align:center;
	}
}
/* タイトル ============*/
@media(min-width:960px){
.s-title-group h2{
	font-size:32px;
}
}
/* 全幅フルワイド ============*/
.fw-column{
	padding:2rem 128px 2rem 3rem;
}
@media(max-width:959px){
	.fw-column{
		padding:2rem;
	}
}
/* 背景に画像ありセクション ============*/
.s-bg-img {
  position: relative;
}
.s-bg-img::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -65px;
  width: 350px;
  height: 350px;
  background: url("/wp-content/uploads/2025/09/Blurred-Circle-1.png") no-repeat center;
  background-size: contain;
  pointer-events: none;
  z-index: 0;
}

/* STEP ============*/
.s-step .swell-block-fullWide__inner{
	padding-right:3rem;
	padding-left:3rem;
}
.s-step .swell-block-step__number.u-col-main {
    border-radius: 50% ;
    width: 60px ;
    height: 60px ;
    background:var(--color_main);
    color: #fff !important;
}
@media (min-width: 960px) {
    .s-step .swell-block-step.is-style-big {
        display: flex;
    }
}

.s-step .is-style-big > .swell-block-step__item {
    --swl-step_arrow_color: var(--color_link);    
}

@media (min-width: 960px) {
    .s-step .is-style-big > .swell-block-step__item:before {
        left: 100%;
        top: 50%;
        transform: translateY(-50%) rotate(-90deg);
    }
}

.s-step .is-style-big>.swell-block-step__item {
    border-top: 1px dashed var(--swl-step_arrow_color);
}

/* エリア ============*/
.s-area{
	border-radius:60px;
}
.s-area:before{
	border-radius:60px;
}
.s-area .wp-block-columns{
    border-radius: 30px;
}
/* FAQ ============*/
.swell-block-faq .swell-block-faq__item { /* スコープを明確化 */
  position: relative;
}

/* 質問 */
.swell-block-faq .faq_q {
  cursor: pointer;
  background-color: var(--color_main);
  color: #fff;
  border-radius: 15px;
  padding-right: 58px; /* !important削除 */
  position: relative;  /* アイコン配置用 */
  outline: none;       /* focus-visibleで見た目を制御 */
}

/* 回答（閉） */
.swell-block-faq .faq_a {
  max-height: 0;
  overflow: hidden;
  transition: max-height .25s ease, padding .25s ease, border-color .25s ease;
  padding: 0;               /* !important削除 */
  border: 1px solid transparent;
  border-top: 0;
  border-radius: 0 0 15px 15px;
}

/* 開状態の外観 */
.swell-block-faq__item.open .faq_q {
  border-radius: 15px 15px 0 0;
}

/* 回答（開） */
.swell-block-faq .faq_a.open {
  /* 十分大きめ（中身に合わせて調整） */
  max-height: 1000px;
  padding: 1em 1em 1em 3em;
  border-color: var(--color_main);
}

/* 余計な影オフ・位置調整（テーマ依存の見た目調整） */
.swell-block-faq .faq_q:before,
.swell-block-faq .faq_a:before {
  box-shadow: none;
  left: 1px;
}

/* アイテム間の余白や線などが必要ならここで調整 */
.swell-block-faq .swell-block-faq__item + .swell-block-faq__item {
  margin-top: 10px;
}

/* 開閉アイコン（フォントアイコン想定） */
.swell-block-faq__item .faq_q:after {
  content: "\e910";
  font-family: icomoon !important;
  color: #fff;
  font-weight: bold;
  position: absolute;
  right: 30px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1.4em;
}
.swell-block-faq__item.open .faq_q:after {
  content: "\e912";
}

/* キーボード操作の視認性向上 */
.swell-block-faq .faq_q:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 3px;
}

/* 動きが苦手な人への配慮 */
@media (prefers-reduced-motion: reduce) {
  .swell-block-faq .faq_a {
    transition: none;
  }
}


/* 料金表 */
/* 外枠は figure で描く（角丸との相性◎） */
figure.wp-block-table.price-table {
  --table-border: none;          /* SWELL既定の枠線は使わない */
  border: none;
  border-radius: 15px;
  overflow: hidden;              /* 角からのはみ出し防止 */
}

/* テーブル本体は separate で安定させる */
.price-table table {
  border-collapse: separate;   /* collapse は角丸と相性が悪い */
  border-spacing: 0;
  width: 100%;
}

/* セルの格子線を再定義（内部のみ） */
.price-table th,
.price-table td {
  border-right: 1px solid #eee;
  border-bottom: 1px solid #eee;
}

/* 外周セルは二重線にならないように調整 */
.price-table tr > *:first-child { border-left: 0; }
.price-table tr > *:last-child  { border-right: 0; }
.price-table tbody tr:last-child > * { border-bottom: 0; }

/* 見出し行（colspanのth）だけ下線が欲しければ */
.price-table thead tr:last-child > * { border-bottom: 1px solid #eee; }

/* WP/SWELLのセル背景スパンが角からはみ出す場合の保険 */
.price-table th,
.price-table td {
  background-clip: padding-box;
}

/* TOP ------------------------------------------------------------------*/
/* MV */
.wp-block-group.sp_only {
    position: absolute;
}
.mv-title-sp{
	text-shadow: 0px 0px 4px #d886a0, 0px 0px 1px #D886A0, 0px 0px 1px #d886a0;
	color:#fff;
}
.mv-txt-sp{
	text-shadow: 0px 0px 10px #fff, 0px 0px 10px #fff, 0px 0px 10px #fff, 0px 0px 10px #fff;
}

/* サービス */
.service-columns .swell-block-column{
	border-radius:30px !important;
	position:relative;
	border-color:var(--color_main) !important;
	transition:all 0.6s;
}
.service-columns figure.wp-block-image{
	border-radius:15px;
	overflow: hidden; 
}
.service-columns img{
	border-radius:15px;
	transition:all 0.6s;
}
.column-link{
	display: block; 
	position: absolute; 
	top: 0; 
	left: 0; 
	width: 100%; 
	height: 100%; 
	z-index: 10;
}

.service-columns .swell-block-column:hover {
    background: var(--color_pale01) !important;
}
.service-columns .swell-block-column:hover img{
	transform: scale(1.2);
}
/* TOPnews */
.s-news .p-postList.-type-simple{
	border:none;
}
.s-news .p-postList__item a{
	padding: 20px 10px 20px 50px;
	margin-bottom: 15px;
    background: #fff;
    border-radius: 40px;
    font-weight: bold;
    box-shadow: 0px 5px 0px rgb(231 214 207);
	border:none;
}
.s-news .p-postList__meta{
	margin-bottom:0 !important;
}
@media(min-width:960px){
.s-news .p-postList__body {
    display: flex;
    align-items: center;
    gap: 10px;
	overflow: hidden;
    white-space: nowrap;
}
}
/* Home Medical Care */
.s-hmc .swell-block-box-menu__link,
.s-hmc .swell-block-box-menu__item.has-link{
    border-radius: 45px;
}
@media (hover: hover) {
    .s-hmc .swell-block-box-menu .has-link:hover {
        border-radius: 45px;
    }
}
/* Serviceページ ------------------------------------------------------------------*/
.service-box .wp-block-column{
	border-radius:30px;
	background:var(--color_pale01) ;
}
.service-box .wp-block-image{
	position: relative;
    width: 100%;
    height: 100%;
    -webkit-mask: url(/wp-content/uploads/2025/09/Vector.png) center / contain no-repeat;
    mask: url(/wp-content/uploads/2025/09/Vector.png) center / contain no-repeat;
	z-index:2;
}
.wp-block-column.service-box-img {
    position: relative;
}
.service-box-img::after{
	background:url(/wp-content/uploads/2025/09/621259587.jpeg);
	-webkit-mask: url(/wp-content/uploads/2025/09/Vector.png) center / contain no-repeat;
    mask: url(/wp-content/uploads/2025/09/Vector.png) center / contain no-repeat;
	position: absolute;
    left: 50%;
    top: 50%;
    content: "";
    width: calc(100% + 25px);
    height: calc(100% + 25px);
    z-index: -1;
    transform: translate(-50%, -50%);
	box-sizing: border-box;
	z-index:1;
}
/* 私たちについて ------------------------------------------------------------------*/
.first-message .wp-block-column {
    box-shadow: 0px 0px 4px 4px #fff2f0;
    border-radius: 15px;
}
.s-dr-message::after,
.s-ns-message::after{
  content: "";
  position: absolute;
  width: 350px;
  height: 350px;
  background: url("/wp-content/uploads/2025/09/Blurred-Circle.png") no-repeat center;
  background-size: contain;
  pointer-events: none;
  z-index: 0;
}
.s-dr-message::after{
  right: 0;
  top: -5px;
}
.s-ns-message::after{
	left:0;
	bottom:0;
}
.s-dr-message img{
	border-radius:0px 30px 30px 0px;
}
.s-ns-message img{
	border-radius:30px 0px 0px 30px;
}
.s-dr-message .wp-block-image,
.s-ns-message .wp-block-image{
	position:relative;
	z-index:2;
}
.s-dr-message .wp-block-image::after,
.s-ns-message .wp-block-image::after{
	content: "";
    width: 100%;
    height: 100%;
    background: var(--color_pale01);
    position: absolute;
    z-index: -1;
    top: 10%;
    left: 5%;
    border-radius: 30px;
	visibility: visible;
}
.s-ns-message .wp-block-image::after{
	left:-10%;
}
/*SP以下*/
@media(max-width:781px){
	.s-dr-message1{
		order:2;
	}
	.s-dr-message2{
		order:1;
	}
}
/* 各種サービス ------------------------------------------------------------------*/
.catch-section p{
	font-size:20px;
}
.s-service-contents .swell-block-column.swl-has-mb--s {
    border-radius: 15px;
    background: var(--color_deep02) !important;
    color: #fff !important;
}
@media(min-width:960px){
	.s-service-target ul{
	display: grid;
	grid-template-columns: 1fr 1fr; /* 2列 */
	gap: 0.5em 1.5em; /* 行間・列間の調整 */
	}
}
@media(max-width:959px){
	.catch-section p{
	font-size:18px;
}
}
/* 自費診療 */
.s-service-price .wp-block-column {
    border-radius: 30px;
}
@media(min-width:600px){
	.self-support-title{
		font-size:20px;
	}
}


/* 採用情報 ------------------------------------------------------------------*/
.recruit-box{
	border-radius:30px;
}
.recruit-title-en{
	line-height:1.2;
}


/* Contact ------------------------------------------------------------------*/
.wp-block-snow-monkey-forms-item.contact-form-pp {
    text-align: center;
}