html, body {
	line-height: 1.5;
	font-size: 16px;	
	font-weight: 500;
	letter-spacing: .05em
}
body{
	position: relative;
	font-size: 1rem;
	font-family: yu-gothic-pr6n, "Hiragino Sans", Meiryo, sans-serif;
	color: var(--clr_base);
}

/*
 * Remove text-shadow in selection highlight:
 * https://twitter.com/miketaylr/status/12228805301
 *
 * Customize the background color to match your design.
 */

::-moz-selection {
  background: #b3d4fc;
  text-shadow: none;
}

::selection {
  background: #b3d4fc;
  text-shadow: none;
}

/*
 * A better looking default horizontal rule
 */

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
  margin: 1em 0;
  padding: 0;
}

/*
 * Remove the gap between audio, canvas, iframes,
 * images, videos and the bottom of their containers:
 * https://github.com/h5bp/html5-boilerplate/issues/440
 */

audio,
canvas,
iframe,
img,
svg,
video {
  vertical-align: middle;
}

/*
 * Remove default fieldset styles.
 */

fieldset {
  border: 0;
  margin: 0;
  padding: 0;
}

/*
 * Allow only vertical resizing of textareas.
 */

textarea {
  resize: vertical;
}

/* ==========================================================================
   Commons styles
   ========================================================================== */
a{text-decoration: none; color: inherit}
a:focus, *:focus { outline:none;}
/*a[href^="tel:"] {
	pointer-events: none;
	cursor: text;
}*/
img{border: 0px;}
dd{margin: 0}
p,h1,h2,h3,h4,h5{margin: 0;padding: 0}
figure{margin: 0;padding: 0}
ul,li,dl,ol{margin: 0;padding: 0;list-style: none}
.b{font-weight: bold}
.fw_n{font-weight: normal}
.tx_und{text-decoration: underline}
.tx_cent{text-align: center}
.tx_right{text-align: right}
.tx_left{text-align: left}
.disp_blk{display: block}
.disp_non{display: none}
.marker_tp_1 {background:rgba(0, 0, 0, 0) linear-gradient(transparent 75%, #ffff00 0%) repeat scroll 0 0; }
/*-------------------------------------
色設定
--------------------------------------*/
:root {
    --clr_wht: #FFF;
    --clr_blk: #000000;		
    --clr_base: #1a1a1a;	
    --clr_brown: #534741;
    --clr_brown_2: #f9f7f4;	
    --clr_brown_3: #f2eee9;		
    --clr_blue: #0081d9;	
    --clr_org: #f7cfbc;	
    --clr_org_2: #fcb59b;	
    --clr_pink: #ffe0e3;	
    --clr_pink_2: #ff7b89;	
	
}
/*-------------------------------------
背景色/文字色
--------------------------------------*/
.bg_clr_wht {
	background-color: #FFF
}
.bg_clr_brown_2 {
	background-color: var(--clr_brown_2)
}
.bg_clr_brown_3 {
	background-color: var(--clr_brown_3)
}
.fc_wht{color: #FFF}
.fc_pink{color: var(--clr_pink)}
.fc_pink_2{color: var(--clr_pink_2)}
.fc_org{color: var(--clr_org)}
.fc_org_2{color: var(--clr_org_2)}
.fc_brown{color: var(--clr_brown)}
.fc_blue{color: var(--clr_blue)}
.txs_12 {
	font-size: 12px;	
}
.txs_13 {
	font-size: 13px;	
}
.txs_14 {
	font-size: 14px;	
}
.txs_15 { font-size: clamp(12px, 1vw, 15px); }
.txs_16 { font-size: clamp(13px, 1.07vw, 16px); }
.txs_17 { font-size: clamp(13px, 1.13vw, 17px); }
.txs_18 { font-size: clamp(13px, 1.2vw, 18px); }
.txs_19 { font-size: clamp(13px, 1.27vw, 19px); }
.txs_20 { font-size: clamp(13px, 1.33vw, 20px); }
.txs_21 { font-size: clamp(13px, 1.4vw, 21px); }
.txs_22 { font-size: clamp(13px, 1.47vw, 22px); }
.txs_23 { font-size: clamp(17px, 1.53vw, 23px); }
.txs_24 { font-size: clamp(17px, 1.6vw, 24px); }
.txs_25 { font-size: clamp(18px, 1.67vw, 25px); }
.txs_26 { font-size: clamp(18px, 1.73vw, 26px); }
.txs_27 { font-size: clamp(18px, 1.8vw, 27px); }
.txs_28 { font-size: clamp(18px, 1.87vw, 28px); }
.txs_29 { font-size: clamp(18px, 1.93vw, 29px); }
.txs_30 { font-size: clamp(22px, 2vw, 30px); }
.txs_31 { font-size: clamp(22px, 2.07vw, 31px); }
.txs_32 { font-size: clamp(22px, 2.13vw, 32px); }
.txs_33 { font-size: clamp(22px, 2.2vw, 33px); }
.txs_34 { font-size: clamp(24px, 2.27vw, 34px); }
.txs_35 { font-size: clamp(16px, 2.33vw, 35px); }
.txs_36 { font-size: clamp(26px, 2.4vw, 36px); }
.txs_37 { font-size: clamp(36px, 2.47vw, 37px); }
.txs_38 { font-size: clamp(26px, 2.53vw, 38px); }
.txs_39 { font-size: clamp(28px, 2.6vw, 39px); }
.txs_40 { font-size: clamp(20px, 2.67vw, 40px); }
.txs_41 { font-size: clamp(36px, 2.73vw, 41px); }
.txs_42 { font-size: clamp(30px, 2.8vw, 42px); }
.txs_43 { font-size: clamp(30px, 2.87vw, 43px); }
.txs_44 { font-size: clamp(18px, 2.93vw, 44px); }
.txs_45 { font-size: clamp(20px, 3vw, 45px); }
.txs_46 { font-size: clamp(36px, 3.07vw, 46px); }
.txs_47 { font-size: clamp(36px, 3.13vw, 47px); }
.txs_48 { font-size: clamp(36px, 3.2vw, 48px); }
.txs_49 { font-size: clamp(36px, 3.27vw, 49px); }
.txs_50 { font-size: clamp(36px, 3.33vw, 50px); }
.txs_51 { font-size: clamp(36px, 3.4vw, 51px); }
.txs_52 { font-size: clamp(36px, 3.47vw, 52px); }
.txs_53 { font-size: clamp(36px, 3.53vw, 53px); }
.txs_54 { font-size: clamp(36px, 3.6vw, 54px); }
.txs_55 { font-size: clamp(36px, 3.67vw, 55px); }
.txs_56 { font-size: clamp(36px, 3.73vw, 56px); }
.txs_57 { font-size: clamp(36px, 3.8vw, 57px); }
.txs_58 { font-size: clamp(36px, 3.87vw, 58px); }
.txs_59 { font-size: clamp(36px, 3.93vw, 59px); }
.txs_60 { font-size: clamp(36px, 4vw, 60px); }
.txs_61 { font-size: clamp(36px, 4.07vw, 61px); }
.txs_62 { font-size: clamp(36px, 4.13vw, 62px); }
.txs_63 { font-size: clamp(36px, 4.2vw, 63px); }
.txs_64 { font-size: clamp(36px, 4.27vw, 64px); }
.txs_65 { font-size: clamp(36px, 4.33vw, 65px); }
.txs_66 { font-size: clamp(36px, 4.4vw, 66px); }
.txs_67 { font-size: clamp(36px, 4.47vw, 67px); }
.txs_68 { font-size: clamp(36px, 4.53vw, 68px); }
.txs_69 { font-size: clamp(36px, 4.6vw, 69px); }
.txs_70 { font-size: clamp(36px, 4.67vw, 70px); }
.txs_71 { font-size: clamp(36px, 4.73vw, 71px); }
.txs_72 { font-size: clamp(36px, 4.8vw, 72px); }
.txs_73 { font-size: clamp(36px, 4.87vw, 73px); }
.txs_74 { font-size: clamp(36px, 4.93vw, 74px); }
.txs_75 { font-size: clamp(36px, 5vw, 75px); }
.txs_76 { font-size: clamp(36px, 5.07vw, 76px); }
.txs_77 { font-size: clamp(36px, 5.13vw, 77px); }
.txs_78 { font-size: clamp(36px, 5.2vw, 78px); }
.txs_79 { font-size: clamp(36px, 5.27vw, 79px); }
.txs_80 { font-size: clamp(36px, 5.33vw, 80px); }
.txs_81 { font-size: clamp(36px, 5.4vw, 81px); }
.txs_82 { font-size: clamp(36px, 5.47vw, 82px); }
.txs_83 { font-size: clamp(36px, 5.53vw, 83px); }
.txs_84 { font-size: clamp(36px, 5.6vw, 84px); }
.txs_85 { font-size: clamp(36px, 5.67vw, 85px); }
.txs_86 { font-size: clamp(36px, 5.73vw, 86px); }
.txs_87 { font-size: clamp(36px, 5.8vw, 87px); }
.txs_88 { font-size: clamp(36px, 5.87vw, 88px); }
.txs_89 { font-size: clamp(36px, 5.93vw, 89px); }
.txs_90 { font-size: clamp(36px, 6vw, 90px); }
.txs_91 { font-size: clamp(36px, 6.07vw, 91px); }
.txs_92 { font-size: clamp(36px, 6.13vw, 92px); }
.txs_93 { font-size: clamp(36px, 6.2vw, 93px); }
.txs_94 { font-size: clamp(36px, 6.27vw, 94px); }
.txs_95 { font-size: clamp(36px, 6.33vw, 95px); }
.txs_96 { font-size: clamp(36px, 6.4vw, 96px); }
.txs_97 { font-size: clamp(36px, 6.47vw, 97px); }
.txs_98 { font-size: clamp(36px, 6.53vw, 98px); }
.txs_99 { font-size: clamp(36px, 6.6vw, 99px); }
.txs_100 { font-size: clamp(36px, 6.67vw, 100px); }
.tx_sdw_1{
    text-shadow:2px 2px 0 #ffffff,-2px 2px 0 #ffffff,2px -2px 0 #ffffff,-2px -2px 0 #ffffff;
}
span.line {
  padding-bottom: 2px;
  border-bottom: 2px solid var(--clr_base);
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}
@font-face {
	font-family: 'yug_b';
	src: url('../font/YuGothB.ttc') format('truetype')
}
.ff_yug_b {font-family: 'yug_b';} 	

.ff_min {
	font-family: zen-old-mincho, sans-serif;
}
.ff_en {
	font-family: garamond-premier-pro, serif;
}
.ff_fut {
	font-family: "futura-pt", sans-serif;
}
.ls_ng_100 {
	letter-spacing: -.1em;
}
.ls_ng_55 {
	letter-spacing: -.055em;
}
.ls_ng_25 {
	letter-spacing: -.055em;
}
.ls_ng_15 {
	letter-spacing: -.015em
}
.ls_0 {
	letter-spacing: 0
}
.ls_25 {
	letter-spacing: .025em
}
.ls_35 {
	letter-spacing: .035em
}
.ls_5 {

	letter-spacing: .05em
}
.ls_75 {
	letter-spacing: .075em;
}
.ls_80 {
	letter-spacing: .08em
}
.ls_100 {
	letter-spacing: .1em
}
.ls_200 {
	letter-spacing: .2em
}
.fw_400 {
	font-weight: 400
}
.fw_500 {
	font-weight: 500
}
.fw_550 {
	font-weight: 550
}
.fw_600 {
	font-weight: 600
}
.fw_700 {
	font-weight: 700
}
.fw_800 {
	font-weight: 800
}
.fw_900 {
	font-weight: 900
}
.lh_1 {
	line-height: 1
}
.lh_1_1 {
	line-height: 1.1
}
.lh_1_2 {
	line-height: 1.2
}
.lh_1_3 {
	line-height: 1.3
}
.lh_1_4 {
	line-height: 1.4
}
.lh_1_6 {
	line-height: 1.6
}
.lh_1_7 {
	line-height: 1.7
}
.lh_1_8 {
	line-height: 1.8
}
.lh_2 {
	line-height: 2
}
.ls_non {letter-spacing: 0}
.ls_nega {letter-spacing: -.075em}
.flex_wrapper{
　　display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
}
.flex-wrap_par{
	flex-wrap: wrap;
	display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;	
	display: flex;		
}
.flex-rev{
	flex-flow: row-reverse;
}
.jus_bet{justify-content: space-between}
.jus_cent{justify-content: center}
.jus_end{justify-content: flex-end}
.jus_stat{justify-content: flex-start}
.an_stat{align-items: flex-start}
.an_bl{align-items: baseline}
.an_cent{align-items: center}
.block_link{
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%	
}
@media (hover: hover) {
.hover{
	transition-property: all;
  	transition: 0.15s linear;
}
.hover:hover{
	opacity: 0.75;
}
.brightness {
  transition: filter 0.3s ease;
  filter: brightness(
    1
  ); 
}
.brightness:hover {
  filter: brightness(1.2);
}
}
.pc{display: block}
.sp{display: none!important}
*, *:before, *:after {
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
         -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
            box-sizing: border-box;
}
.max_img{
	max-width: 100%;
	height: auto;
	display: block;
}
.img_w100{width: 100%; height: auto}
.img_w50{width: 50%; height: auto}
.img_w40{width: 40%; height: auto}
.img_w30{width: 30%; height: auto}
.img_w20{width: 20%; height: auto}
.centered {
	display: block;
	margin-left: auto;
	margin-right: auto;
	}
.alignright {
	margin: 0 0 0 3%;
	display: inline;
	}
.alignleft {
	margin: 0 3% 0 0;
	display: inline;
	}
.alignright {
	float: right;
	}
.alignleft {
	float: left;
	}
.clear{clear: both}
.pos_rel{position: relative}
.inl_b {display: inline-block}
.inl {display: inline}
/*-------------------------------------
ラッパー
--------------------------------------*/
.wrap_870 {
	max-width: 870px;
	margin-left: auto;
	margin-right: auto;
}
.wrap_960 {
	max-width: 960px;
	margin-left: auto;
	margin-right: auto;
}
.wrap_1180 {
	max-width: 1180px;
	margin-left: auto;
	margin-right: auto;
}
.wrap_1500 {
	max-width: 1500px;
	margin-left: auto;
	margin-right: auto;
}
/*-------------------------------------
リスト
--------------------------------------*/
.list_type_num li,
.list_type_1 li {
	position: relative;
	padding-left: 16px;
	margin-bottom: 1%;
}
.list_type_num li:last-child,
.list_type_1 li:last-child {
	margin-bottom: 0;
}
.list_type_1 li::after {
    content: "・";  
	position: absolute;
	top: 0;
	left: 0;
}
.list_type_2 li {
	position: relative;
	padding-left: 17px;
	margin-bottom: 0;
}
.list_type_2 li::after {
    content: "※";  
	position: absolute;
	top: 0;
	left: 0;	
}

.list_type_num {
	counter-reset: number 0;
}
.list_type_num li {
	position: relative;
}
.list_type_num li::before {
	position: absolute;
	top: 0;
	left: 0;	
  counter-increment: number 1;
  content: counter(number) ".";
}

/*-------------------------------------
ボックス
--------------------------------------*/
.bx_type_1 {
}
/*-------------------------------------
ボタン
--------------------------------------*/
.btn_tp_1 {
	position: relative;
	padding: 8px min(2.27vw, 34px);
	background: #FFF;
	border-radius: 28px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	column-gap: min(2.67vw, 40px);
}
.btn_tp_1 .icon {
	display: block;
	width: min(2.47vw, 37px);
	height: auto
}
.btn_tp_1 .mn {
	font-size: clamp(13px, 1.2vw, 18px);	
	font-weight: 600;
	color: #4d4d4d;
	text-align: center;
	letter-spacing: .0em;
	line-height: 1;
	font-feature-settings: "palt";
	padding-left: 5%
}
.btn_tp_2 {
	padding: 24px 0;
	position: relative;
	background: linear-gradient(90deg,rgba(199, 178, 153, 1) 0%, rgba(153, 134, 117, 1) 100%);
}
.btn_tp_2::after {
	content: "";
	position: absolute;
	top: 0;
	bottom:0;
	right: min(2.67vw, 40px);
	width: min(2vw, 30px);
	height: min(2vw, 30px);
	margin: auto;
	background: url("../img/btn_tp_2.png") no-repeat center / cover
}
.btn_tp_2 .txt {
	font-family: zen-old-mincho, sans-serif;
	font-size: clamp(22px, 2vw, 30px);	
	font-weight: 500;
	color: #FFF;
	text-align: center;
	letter-spacing: .025em;
	font-feature-settings: "palt";
}

/*-------------------------------------
見出し
--------------------------------------*/
.h_type_1 .en_wrap {
	display: flex;
	font-family: garamond-premier-pro, serif;
	font-size: clamp(20px, 9.33vw, 140px);	
	font-weight: 500;
	letter-spacing: .05em;
	font-feature-settings: "palt";
}
.h_type_1 .ttl {
	font-family: zen-old-mincho, sans-serif;
	font-size: clamp(20px, 2.67vw, 40px);	
	font-weight: 500;
	text-align: center;
	letter-spacing: .05em;
	font-feature-settings: "palt";
}
.h_type_1 .ttl .in {
	display: inline-block;
	position: relative
}
.h_type_1 .ttl .in::before,
.h_type_1 .ttl .in::after {
	content: "";
	position: absolute;
	top: 0;
	bottom:0;
	width: min(3.6vw, 54px);
	height: 2px;
	margin: auto;
	background: #000
}
.h_type_1 .ttl .in::before {
	left: calc(min(5.33vw, 80px) * -1)
}
.h_type_1 .ttl .in::after {
	right: calc(min(5.33vw, 110px) * -1)
}
.h_type_1 .ttl .in span.txs_30 {
    position: relative;
	bottom: min(0.59vw, 7px)
}
.h_type_2 .en {
	font-family: garamond-premier-pro, serif;
	font-size: clamp(36px, 4vw, 60px);
	font-weight: 500;
	letter-spacing: .05em;
	font-feature-settings: "palt";
}
.h_type_2 .ttl {
	font-family: zen-old-mincho, sans-serif;
	font-size: clamp(20px, 2vw, 40px);	
	font-weight: 500;
	letter-spacing: .05em;
	font-feature-settings: "palt";
	margin-top: min(1.33vw, 20px);
	padding-bottom: min(1.33vw, 20px);
	position: relative;
}
.h_type_2 .ttl::after {
	content: "";
	position: absolute;
	bottom:0;
	left: 0;
	right: 0;
	width: 30px;
	height: 2px;
	margin: auto;
	background: var(--clr_base)
}
.h_type_3 {
	font-family: zen-old-mincho, sans-serif;
	font-size: clamp(17px, 1.47vw, 22px);	
	font-weight: 600;
	line-height: 1.3
}
.h_type_3 span {
	display: inline-block;
	padding-left: 15px;
	position: relative;
}
.h_type_3 span::before {
	content: "";
	position: absolute;
	top: .2em;
	bottom:0;
	left: 0;
	width: 4px;
	height: 100%;
	margin: auto;
}
.h_type_4 {
	font-family: 'yug_b';
	font-size: clamp(22px, 2vw, 30px);	
	font-weight: 600;
	text-align: center;
	letter-spacing: .05em;
	font-feature-settings: "palt";
	position: relative;
	padding-bottom: 10px
}
.h_type_4::after {
	content: "";
	position: absolute;
	bottom:0;
	left: 0;
	right: 0;
	width: 100%;
	max-width: 500px;
	height: 2px;
	margin: auto;
	background: var(--clr_blue)
}

/*-------------------------------------
ggmap
--------------------------------------*/
.ggmap {
position: relative;
padding-bottom: 44.25%;
padding-top: 30px;
height: 0;
overflow: hidden;
}
.ggmap iframe,
.ggmap object,
.ggmap embed {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}
/*-------------------------------------
余白
--------------------------------------*/
/* --- Padding --- */
.sec_pad_20 { padding: min(1.33vw, 20px) 0; }
.sec_pad_20_t { padding-top: min(1.33vw, 20px); }
.sec_pad_20_b { padding-bottom: min(1.33vw, 20px); }

.sec_pad_30 { padding: min(2vw, 30px) 0; }
.sec_pad_30_t { padding-top: min(2vw, 30px); }
.sec_pad_30_b { padding-bottom: min(2vw, 30px); }

.sec_pad_40 { padding: min(2.67vw, 40px) 0; }
.sec_pad_40_t { padding-top: min(2.67vw, 40px); }
.sec_pad_40_b { padding-bottom: min(2.67vw, 40px); }

.sec_pad_50 { padding: min(3.33vw, 50px) 0; }
.sec_pad_50_t { padding-top: min(3.33vw, 50px); }
.sec_pad_50_b { padding-bottom: min(3.33vw, 50px); }

.sec_pad_60 { padding: min(4vw, 60px) 0; }
.sec_pad_60_t { padding-top: min(4vw, 60px); }
.sec_pad_60_b { padding-bottom: min(4vw, 60px); }

.sec_pad_70 { padding: min(4.67vw, 70px) 0; }
.sec_pad_70_t { padding-top: min(4.67vw, 70px); }
.sec_pad_70_b { padding-bottom: min(4.67vw, 70px); }

.sec_pad_80 { padding: min(5.33vw, 80px) 0; }
.sec_pad_80_t { padding-top: min(5.33vw, 80px); }
.sec_pad_80_b { padding-bottom: min(5.33vw, 80px); }

.sec_pad_90 { padding: min(6vw, 90px) 0; }
.sec_pad_90_t { padding-top: min(6vw, 90px); }
.sec_pad_90_b { padding-bottom: min(6vw, 90px); }

.sec_pad_100 { padding: min(6.67vw, 100px) 0; }
.sec_pad_100_t { padding-top: min(6.67vw, 100px); }
.sec_pad_100_b { padding-bottom: min(6.67vw, 100px); }

.sec_pad_110 { padding: min(7.33vw, 110px) 0; }
.sec_pad_110_t { padding-top: min(7.33vw, 110px); }
.sec_pad_110_b { padding-bottom: min(7.33vw, 110px); }

.sec_pad_120 { padding: min(8vw, 120px) 0; }
.sec_pad_120_t { padding-top: min(8vw, 120px); }
.sec_pad_120_b { padding-bottom: min(8vw, 120px); }

.sec_pad_130 { padding: min(8.67vw, 130px) 0; }
.sec_pad_130_t { padding-top: min(8.67vw, 130px); }
.sec_pad_130_b { padding-bottom: min(8.67vw, 130px); }

.sec_pad_140 { padding: min(9.33vw, 140px) 0; }
.sec_pad_140_t { padding-top: min(9.33vw, 140px); }
.sec_pad_140_b { padding-bottom: min(9.33vw, 140px); }

.sec_pad_150 { padding: min(10vw, 150px) 0; }
.sec_pad_150_t { padding-top: min(10vw, 150px); }
.sec_pad_150_b { padding-bottom: min(10vw, 150px); }

.sec_pad_160 { padding: min(10.67vw, 160px) 0; }
.sec_pad_160_t { padding-top: min(10.67vw, 160px); }
.sec_pad_160_b { padding-bottom: min(10.67vw, 160px); }

.sec_pad_170 { padding: min(11.33vw, 170px) 0; }
.sec_pad_170_t { padding-top: min(11.33vw, 170px); }
.sec_pad_170_b { padding-bottom: min(11.33vw, 170px); }

.sec_pad_180 { padding: min(12vw, 180px) 0; }
.sec_pad_180_t { padding-top: min(12vw, 180px); }
.sec_pad_180_b { padding-bottom: min(12vw, 180px); }

.sec_pad_190 { padding: min(12.67vw, 190px) 0; }
.sec_pad_190_t { padding-top: min(12.67vw, 190px); }
.sec_pad_190_b { padding-bottom: min(12.67vw, 190px); }

.sec_pad_200 { padding: min(13.33vw, 200px) 0; }
.sec_pad_200_t { padding-top: min(13.33vw, 200px); }
.sec_pad_200_b { padding-bottom: min(13.33vw, 200px); }

/* --- Margin --- */
.mgn_auto { margin-inline: auto; }
.mgn_t_5 { margin-top: 5px }
.mgn_t_10 { margin-top: min(0.67vw, 10px) }
.mgn_t_15 { margin-top: min(1vw, 15px) }
.mgn_t_20 { margin-top: min(1.33vw, 20px) }
.mgn_t_25 { margin-top: min(1.67vw, 25px) }
.mgn_t_30 { margin-top: min(2vw, 30px) }
.mgn_t_35 { margin-top: min(2.33vw, 35px) }
.mgn_t_40 { margin-top: min(2.67vw, 40px) }
.mgn_t_45 { margin-top: min(3vw, 45px) }
.mgn_t_50 { margin-top: min(3.33vw, 50px) }
.mgn_t_55 { margin-top: min(3.67vw, 55px) }
.mgn_t_60 { margin-top: min(4vw, 60px) }
.mgn_t_65 { margin-top: min(4.33vw, 65px) }
.mgn_t_70 { margin-top: min(4.67vw, 70px) }
.mgn_t_75 { margin-top: min(5vw, 75px) }
.mgn_t_80 { margin-top: min(5.33vw, 80px) }
.mgn_t_85 { margin-top: min(5.67vw, 85px) }
.mgn_t_90 { margin-top: min(6vw, 90px) }
.mgn_t_95 { margin-top: min(6.33vw, 95px) }
.mgn_t_100 { margin-top: min(6.67vw, 100px) }
.mgn_t_105 { margin-top: min(7vw, 105px) }
.mgn_t_110 { margin-top: min(7.33vw, 110px) }
.mgn_t_115 { margin-top: min(7.67vw, 115px) }
.mgn_t_120 { margin-top: min(8vw, 120px) }
.mgn_t_125 { margin-top: min(8.33vw, 125px) }
.mgn_t_130 { margin-top: min(8.67vw, 130px) }
.mgn_t_135 { margin-top: min(9vw, 135px) }
.mgn_t_140 { margin-top: min(9.33vw, 140px) }
.mgn_t_145 { margin-top: min(9.67vw, 145px) }
.mgn_t_150 { margin-top: min(10vw, 150px) }
.mgn_t_155 { margin-top: min(10.33vw, 155px) }
.mgn_t_160 { margin-top: min(10.67vw, 160px) }
.mgn_t_165 { margin-top: min(11vw, 165px) }
.mgn_t_170 { margin-top: min(11.33vw, 170px) }
.mgn_t_175 { margin-top: min(11.67vw, 175px) }
.mgn_t_180 { margin-top: min(12vw, 180px) }
.mgn_t_185 { margin-top: min(12.33vw, 185px) }
.mgn_t_190 { margin-top: min(12.67vw, 190px) }
.mgn_t_195 { margin-top: min(13vw, 195px) }
.mgn_t_200 { margin-top: min(13.33vw, 200px) }

/* --- Gap --- */
.gap_15 { column-gap: min(1vw, 15px); }
.gap_16 { column-gap: min(1.07vw, 16px); }
.gap_17 { column-gap: min(1.13vw, 17px); }
.gap_18 { column-gap: min(1.2vw, 18px); }
.gap_19 { column-gap: min(1.27vw, 19px); }
.gap_20 { column-gap: min(1.33vw, 20px); }
.gap_21 { column-gap: min(1.4vw, 21px); }
.gap_22 { column-gap: min(1.47vw, 22px); }
.gap_23 { column-gap: min(1.53vw, 23px); }
.gap_24 { column-gap: min(1.6vw, 24px); }
.gap_25 { column-gap: min(1.67vw, 25px); }
.gap_26 { column-gap: min(1.73vw, 26px); }
.gap_27 { column-gap: min(1.8vw, 27px); }
.gap_28 { column-gap: min(1.87vw, 28px); }
.gap_29 { column-gap: min(1.93vw, 29px); }
.gap_30 { column-gap: min(2vw, 30px); }
.gap_31 { column-gap: min(2.07vw, 31px); }
.gap_32 { column-gap: min(2.13vw, 32px); }
.gap_33 { column-gap: min(2.2vw, 33px); }
.gap_34 { column-gap: min(2.27vw, 34px); }
.gap_35 { column-gap: min(2.33vw, 35px); }
.gap_36 { column-gap: min(2.4vw, 36px); }
.gap_37 { column-gap: min(2.47vw, 37px); }
.gap_38 { column-gap: min(2.53vw, 38px); }
.gap_39 { column-gap: min(2.6vw, 39px); }
.gap_40 { column-gap: min(2.67vw, 40px); }
.gap_41 { column-gap: min(2.73vw, 41px); }
.gap_42 { column-gap: min(2.8vw, 42px); }
.gap_43 { column-gap: min(2.87vw, 43px); }
.gap_44 { column-gap: min(2.93vw, 44px); }
.gap_45 { column-gap: min(3vw, 45px); }
.gap_46 { column-gap: min(3.07vw, 46px); }
.gap_47 { column-gap: min(3.13vw, 47px); }
.gap_48 { column-gap: min(3.2vw, 48px); }
.gap_49 { column-gap: min(3.27vw, 49px); }
.gap_50 { column-gap: min(3.33vw, 50px); }
.gap_51 { column-gap: min(3.4vw, 51px); }
.gap_52 { column-gap: min(3.47vw, 52px); }
.gap_53 { column-gap: min(3.53vw, 53px); }
.gap_54 { column-gap: min(3.6vw, 54px); }
.gap_55 { column-gap: min(3.67vw, 55px); }
.gap_56 { column-gap: min(3.73vw, 56px); }
.gap_57 { column-gap: min(3.8vw, 57px); }
.gap_58 { column-gap: min(3.87vw, 58px); }
.gap_59 { column-gap: min(3.93vw, 59px); }
.gap_60 { column-gap: min(4vw, 60px); }
.gap_61 { column-gap: min(4.07vw, 61px); }
.gap_62 { column-gap: min(4.13vw, 62px); }
.gap_63 { column-gap: min(4.2vw, 63px); }
.gap_64 { column-gap: min(4.27vw, 64px); }
.gap_65 { column-gap: min(4.33vw, 65px); }
.gap_66 { column-gap: min(4.4vw, 66px); }
.gap_67 { column-gap: min(4.47vw, 67px); }
.gap_68 { column-gap: min(4.53vw, 68px); }
.gap_69 { column-gap: min(4.6vw, 69px); }
.gap_70 { column-gap: min(4.67vw, 70px); }
.gap_71 { column-gap: min(4.73vw, 71px); }
.gap_72 { column-gap: min(4.8vw, 72px); }
.gap_73 { column-gap: min(4.87vw, 73px); }
.gap_74 { column-gap: min(4.93vw, 74px); }
.gap_75 { column-gap: min(5vw, 75px); }
.gap_76 { column-gap: min(5.07vw, 76px); }
.gap_77 { column-gap: min(5.13vw, 77px); }
.gap_78 { column-gap: min(5.2vw, 78px); }
.gap_79 { column-gap: min(5.27vw, 79px); }
.gap_80 { column-gap: min(5.33vw, 80px); }
.gap_81 { column-gap: min(5.4vw, 81px); }
.gap_82 { column-gap: min(5.47vw, 82px); }
.gap_83 { column-gap: min(5.53vw, 83px); }
.gap_84 { column-gap: min(5.6vw, 84px); }
.gap_85 { column-gap: min(5.67vw, 85px); }
.gap_86 { column-gap: min(5.73vw, 86px); }
.gap_87 { column-gap: min(5.8vw, 87px); }
.gap_88 { column-gap: min(5.87vw, 88px); }
.gap_89 { column-gap: min(5.93vw, 89px); }
.gap_90 { column-gap: min(6vw, 90px); }
.gap_91 { column-gap: min(6.07vw, 91px); }
.gap_92 { column-gap: min(6.13vw, 92px); }
.gap_93 { column-gap: min(6.2vw, 93px); }
.gap_94 { column-gap: min(6.27vw, 94px); }
.gap_95 { column-gap: min(6.33vw, 95px); }
.gap_96 { column-gap: min(6.4vw, 96px); }
.gap_97 { column-gap: min(6.47vw, 97px); }
.gap_98 { column-gap: min(6.53vw, 98px); }
.gap_99 { column-gap: min(6.6vw, 99px); }
.gap_100 { column-gap: min(6.67vw, 100px); }
img.obj {
	position: absolute;
	display: block;
	height: auto;
	z-index: 0
}
.no_link{
	pointer-events: none;
	cursor: default;
	text-decoration:none;
}
.yaku {	font-feature-settings: "palt";}
.han_br{
	word-wrap: break-word;
    overflow-wrap: break-word;
}
.v_mid {
    vertical-align: middle;
}
.idt{
  text-indent: 1em;
}
header.general {
	width: 100%;
	height: 146px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	background: #FFF;
}
header.general .logos {
	display: flex;
	flex-wrap: wrap;
	align-content: center
}
header.general .logo img {
	display: block;
	width:min(41.67vw, 625px);
	height: auto
}

header.general .logos .supp {
	display: block;
	width: 100%;
	margin-top: 10px;
	font-size: 10px;	
	font-weight: 500;
	color: #666666;
	letter-spacing: .0em;
}
header.general .info .btn a {
	padding: min(1.73vw, 26px) min(2.27vw, 34px);
	border-radius: 46px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(90deg,rgba(85, 196, 77, 1) 0%, rgba(0, 181, 128, 1) 100%);
}
header.general .tels a img {
	display: block;
	width:min(22.33vw, 335px);
	height: auto
}
nav.general {
	width: 100%;
	position: absolute;
	top: 146px;
	left: 0;
	z-index: 9999
}
nav.general::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(0deg,rgba(199, 178, 153, 1) 0%, rgba(153, 134, 117, 1) 100%);	
	z-index: -1;
	opacity: .92
}
nav.general ul {
	display: flex;
    flex-wrap: wrap;
}
nav.general ul li {
	flex: 1;
	position: relative;
}
nav.general li a {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 20px 0;
	height: 100%;
	position: relative;
}
nav.general li a::after {
	content: "";
	position: absolute;
	top: 0;
	bottom:0;
	right: 0;
	width: 1px;
	height: 70%;
	margin: auto;
	background: #FFF
}
nav.general li:last-child a::after {
	display: none
}
nav.general li a span  {
	display: block
}
nav.general li a span.jp {
	width: 100%;
	font-family: zen-old-mincho, sans-serif;
	font-size: clamp(13px, 1.2vw, 18px);	
	font-weight: 500;
	color: #FFF;
	text-align: center;
	letter-spacing: .0em;
	font-feature-settings: "palt";
}
nav.general li a span.en {
	font-family: "futura-pt", sans-serif;
	font-size: 12px;	
	font-weight: 300;
	color: #FFF;
	text-align: center;
	letter-spacing: .35em;
	font-feature-settings: "palt";
	padding-top: 5px;
}
.fv {
	position: relative
}
.fv .in_wrap {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	padding-bottom: min(7vw, 105px)
}
.fv .in_wrap .in_sepa {
	width: 100%;
	height: 100%;
	display: flex;
	justify-content: center;
	align-items: flex-end;	
}
.fv .in_wrap .in_sepa .en {
	width: min(42.47vw, 637px);
}
.fv .in_wrap .in_sepa .jp {
	width: min(26.67vw, 400px);
}
.home_msg {
	background: url("../img/home_msg_bg.jpg") no-repeat top / cover
}
.home_msg .inn {
	background: rgba(255,255,255,.74);
	padding-right: min(2.4vw, 36px);
	padding-left: min(2.4vw, 36px);	
}
.home_msg .inn .h_type_1 .en_wrap {
	color: #998675
}
.home_msg .inn .sepa .item {
	flex: 1
}
.home_msg .inn .sepa .tx {
	padding: 4% 0 0 min(2vw, 30px)
}
.home_msg .inn .sepa .big_nam {
	position: absolute;
	bottom: 2%;
	display: flex;
	justify-content: space-between;
	width: 60%;
	margin-left: 40%
}
.home_msg .inn .sepa .big_nam .en {
	color: #534741
}
.home_msg .inn .sepa .big_nam .jp {
	padding-top: 9%
}
.home_msg .inn .dtl_sepa .item {
	flex: 1;
	padding: 26px;
	background: var(--clr_brown_2)
}

.home_jc {
	background: var(--clr_brown_3) url("../img/home_jc_bg.png") no-repeat top / 100%;
}
.home_jc .block {
	display: flex;
	max-height: 314px
}
.home_jc .block .px {
	width: 46.1%;
}
.home_jc .block .px img {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover
}
.home_jc .block .tx {
	width: calc(100% - 46.1%);	
	padding: 0 min(2.13vw, 32px) 0;
	display: flex;
	align-items: flex-end;
	column-gap: min(0.85vw, 10px);
	justify-content: space-between		
}
.home_jc .block.flex-rev .tx {
	flex-flow: row-reverse;
	text-align: right
}

.home_jc .block .tx .in_tx {
    width: 100%;	
	padding-bottom: 20px;
	color: #FFF;
	text-shadow: 3px 3px 2px rgba(51,44,40,0.15);	
}
.home_jc .block .en {
	font-family: "futura-pt", sans-serif;
	font-size: clamp(13px, 1.33vw, 20px);	
	font-weight: 500;
	letter-spacing: .05em;
	font-feature-settings: "palt";
}

.home_jc .block .ttl {
	margin: 3% 0 5% 0;
	font-family: zen-old-mincho, sans-serif;
	font-size: clamp(20px, 2.67vw, 40px);	
	font-weight: 500;
	letter-spacing: .05em;
	font-feature-settings: "palt";
}
.home_jc .block .tx .in_tx .msg {
	font-size: clamp(13px, 1.2vw, 18px);	
	font-weight: 600;
	letter-spacing: 0;
	font-feature-settings: "palt";
	line-height: 1.8
}
.home_jc .btn_tp_1 {
	margin-top: 4%;
	text-shadow: none;
}

.home_jc .block.no1 {
	background: #8fd3f0
}
.home_jc .block.no2 {
	background: #9ed9c1
}
.home_jc .block.no3 {
	background: #f4b6c2
}
.home_jc .block.no4 {
	background: #f6c1a1
}
.home_jc .block.no5 {
	background: #aee3cd
}
.home_jc .block.no6 {
	background: #e8a5a5
}
.home_jc .block.no3 .tx .in_tx .ttl {
	letter-spacing: -.05em;
}

.last_btn {
	max-width: 720px;
	margin-inline: auto;		
}
.last_btn .human_wrap {
	display: flex;
	justify-content: flex-end;
	padding-right: 3%;
}
.home_fif header {
	background: url("../img/home_fif_hd_bg.png") no-repeat top / cover
}
.home_fif header .ttl img {
	display: block;
	width:min(42.07vw, 631px);
	height: auto
}
.hf_block.no1 { background: #edf9f4; }
.hf_block.no2 { background: #e8f6fc; }
.hf_block.no3 { background: #fff3f4; }
.hf_block.no4 { background: #fef3ef; }

.hf_block {
  padding: calc(80px + 5vw) 40px;
  position: relative;
}
.hf_block:not(.no1) {
  margin-top: -5vw;
}
.hf_block.no2 { z-index: 1; }
.hf_block.no3 { z-index: 2; }
.hf_block.no4 { z-index: 3; }

/* no1: 底辺 ／ */
.hf_block.no1 {
  clip-path: polygon(0 0, 100% 0, 100% calc(100% - 5vw), 0 100%);
}
/* no2のみ: 上辺 ／ 底辺 ＼ */
.hf_block.no2 {
  clip-path: polygon(0 5vw, 100% 0, 100% 100%, 0 calc(100% - 5vw));
}
/* no3: 上辺 ＼ 底辺 ／ */
.hf_block.no3 {
  clip-path: polygon(0 0, 100% 5vw, 100% calc(100% - 5vw), 0 100%);
}
/* no4: 上辺 ／ 底辺ストレート */
.hf_block.no4 {
  clip-path: polygon(0 5vw, 100% 0, 100% 100%, 0 100%);
}
.hf_block .box {
	display: flex;
	flex-wrap: wrap;
}
.hf_block .box .col_1 {
	width: 11.27%;	
}
.hf_block .box .col_2 {
	width: calc(100% - 11.27%);	
}
.hf_block .box .ttl_big {
	display: inline-block;
	font-family: zen-old-mincho, sans-serif;
	font-size: clamp(18px, 2.53vw, 38px);	
	font-weight: 500;
	color: #FFF;
	text-align: center;
	letter-spacing: .1em;
	line-height: 1;
	padding: 12px;
}
.hf_block .box .col_2 .wide_bx  {
	width: 43.51%;
}
.hf_block .box .col_2 .tiny_bxs  {
	width: calc(100% - 43.51%);
}
.hf_block .box .col_2 .tiny_bxs .row {
	display: flex;
}
.hf_block .box .col_2 .tiny_bxs .row .item {
	flex: 1
}
.hf_block .box .col_2 .tiny_bxs .row .tx {
	padding-left: 4%
}

.hf_block .box .col_2 .tx .msg  {
	margin-top: min(1vw, 15px);
	font-feature-settings: "palt";
}
.hf_block .box .ttl_big_wrap {
	width: 100%;
	display: flex
}
.hf_block .box .ttl_big {
	padding: 12px 20px
}

/***パーツ毎***/
/*hf_block.no1*/
.hf_block.no1 .box .ttl_big,
.hf_block.no1 .h_type_3 span::before {
	background: #22b573
}
/*hf_block.no2*/
.hf_block.no2 .box .ttl_big,
.hf_block.no2 .h_type_3 span::before {
	background: #29abe2
}
.hf_block.no2 .box .ttl_big_wrap {
	justify-content: flex-end
}
.hf_block.no2 .box .ttl_big {
	padding-left: min(5.33vw, 80px)
}
.hf_block.no2 .box .h_type_3,
.hf_block.no4 .box .tiny_bxs .h_type_3 {
	text-align: right
}
.hf_block.no2 .box .h_type_3 span,
.hf_block.no4 .box .tiny_bxs .h_type_3 span {
	padding-left: 0;
	padding-right: 15px;
}
.hf_block.no2 .box .h_type_3 span::before,
.hf_block.no4 .box .tiny_bxs .h_type_3 span::before {
	left: unset;
	right: 0
}
.hf_block.no2 .box .col_2 .in_sepa .pxs {
	padding-left: 3%;
}
/*hf_block.no3*/
.hf_block.no3 .box .ttl_big,
.hf_block.no3 .h_type_3 span::before {
	background: #ff7b89
}
.hf_block.no3 .box.tp2 .col_2 .in_sepa {
	flex-flow: row-reverse;
}
.hf_block.no3 .box .col_2 .in_sepa .pxs {
    padding-right: 3%;
}
/*hf_block.no4*/
.hf_block.no4 .box .ttl_big,
.hf_block.no4 .h_type_3 span::before {
	background: #f15a24
}
.hf_block.no4 .box,
.hf_block.no4 .box.tp1 .col_2,
.hf_block.no4 .box .col_2 .tiny_bxs .row {
	flex-flow: row-reverse;
}
.hf_block.no4 .box .col_1 {
    display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	justify-content: flex-end
}
.hf_block.no4 .box .col_2 .tiny_bxs .row .tx {
    padding-left: 0;
    padding-right: 4%;
}
/*box.tp1*/
.hf_block .box.tp1 .ttl_big {
	padding: 12px 16px min(5.33vw, 80px);
  	-ms-writing-mode: tb-rl;
  	writing-mode: vertical-rl;
	letter-spacing: -0.4em; 
    font-feature-settings: "normal"	
}
.hf_block .box.tp1 .col_2  {
	display: flex;
	column-gap: min(1.2vw, 18px);
}

/*box.tp2*/
.hf_block .box.tp2 .col_2 .in_sepa  {
	display: flex
}
.hf_block .box.tp2 .col_2 .in_sepa .txs {
	width: 36.26%;
}
.hf_block .box.tp2 .col_2 .in_sepa .pxs {
	width: calc(100% - 36.26%);
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	align-content: flex-start;
	gap: min(1.2vw, 18px);
}
.hf_block .box.tp2 .col_2 .in_sepa .px {
	display: block;
	width: calc((100% - min(1.2vw, 18px)) / 2);
}
.hf_block .box.tp2 .col_2 .in_sepa .pxs img {
	display: block;
	width: 100%;
	height: auto
}
.home_tour {
	background: linear-gradient(90deg,rgba(137, 214, 182, .3) 0%, rgba(0, 171, 217, .3) 100%);
}
.home_tour .inn {
	background: #FFF
}
.home_tour .ttl span {
	position: relative;
}
.home_tour .ttl span::before,
.home_tour .ttl span::after {
	content: "";
	position: absolute;
}
.home_tour .ttl span::before {
	bottom: calc(min(1.67vw, 25px) * -1);
	left: calc(min(1vw, 15px) * -1);
	right: 0;
	width: min(13.13vw, 197px);
	height: min(2.6vw, 39px);
	margin: auto;
	background: url("../img/home_tour_ttl_pbj_1.png") no-repeat center / cover
}
.home_tour .ttl span::after {
	top: min(0.53vw, 8px);
	right: calc(min(4vw, 60px) * -1);
	width: min(2.6vw, 39px);
	height: min(2.07vw, 31px);	
	background: url("../img/home_tour_ttl_pbj_2.png") no-repeat center / cover
}
.home_tour .splide img {
	display: block;
	width: 100%;
	height: auto
}
.home_tour .inn.no2 {
	padding-right: min(3.67vw, 55px);
	padding-left: min(3.67vw, 55px);
}
.time_sepa .item {
	flex: 1;
	position: relative;
}
.time_sepa .item::after {
	content: "";
	position: absolute;
	top: min(1.33vw, 20px);
	right: calc(min(2.27vw, 34px) * -1);
	width: min(3.2vw, 48px);
	height: min(2.6vw, 39px);
	margin: auto;
	background: url("../img/time_sepa_arrw.png") no-repeat center / cover
}	
.time_sepa .item:last-child::after {
	display: none
}	
.time_sepa .item .clocks {
	margin-bottom: 6px
}
.time_sepa .item .clocks .en {
	font-family: "futura-pt", sans-serif;
	font-size: clamp(22px, 2vw, 30px);	
	font-style: italic;
	font-weight: 500;
	color: var(--clr_blue);
	text-align: center;
	letter-spacing: .025em;
	font-feature-settings: "palt";
	margin-top: 6px
}
.time_sepa .item header {
	padding: 25px 2%;
	font-size: clamp(14px, 1.73vw, 26px);	
	font-weight: 600;
	color: #FFF;
	text-align: center;
	letter-spacing: .025em;
	line-height: 1.15;
	font-feature-settings: "palt";
}

.time_sepa .item.no1 header {
	background: url("../img/time_sepa_bg_1.webp") repeat-y top / 100%;
}
.time_sepa .item.no2 header {
	background: url("../img/time_sepa_bg_2.webp") repeat-y top / 100%;	
}
.time_sepa .item.no3 header {
	background: url("../img/time_sepa_bg_3.webp") repeat-y top / 100%;	
}
.home_tour .btn_tp_2 {
	max-width: 720px;
	margin-inline: auto;		
}
.ov_lay {
	position: relative;
	z-index: 10
}
.home_staff {
	background-image: url("../img/home_staff_bg.webp");
	background-repeat: no-repeat;
	background-position: top;
	background-size: 100%;
}
.home_staff .inn {
	background: #FFF;
	padding-right: 16px;
	padding-left: 16px;
}
.home_staff .inn .ttl_gld {
	top: calc(min(1.2vw, 18px) * -1);
	position: relative;
	z-index: 20
}
.ttl_gld .mn {
	padding: min(1.8vw, 27px) 2%;	
	background: linear-gradient(90deg,rgba(137, 214, 182, 1) 0%, rgba(0, 171, 217, 1) 100%);
	border-radius: 50px;
	font-family: zen-old-mincho, sans-serif;
	font-size: clamp(22px, 2vw, 30px);	
	font-weight: 600;
	color: #FFF;
	text-align: center;
	letter-spacing: .05em;
	line-height: 1.5;
	font-feature-settings: "palt";	
}
.big_en {
	font-family: garamond-premier-pro, serif;
	font-size: clamp(20px, 9.33vw, 140px);	
	font-weight: 500;
	letter-spacing: .05em;
	line-height: 0.9;
	font-feature-settings: "palt";
}
.career-plan {
	margin-top: min(17.33vw, 260px);
}
.tab-container {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start
}
.content-item {
    display: block !important; /* JSの状態に関わらずPCでは全表示 */
    width: calc((100% - min(2.67vw, 40px)) / 3); /* gap_20分を引いて3分割 */
	border-radius: 8px;
	position: relative;
	border: 2px solid var(--clr_wht);
}
.content-item .in_ttl {
    padding: 12px 2% 18px;
	font-family: zen-old-mincho, sans-serif;
	font-size: clamp(18px, 1.8vw, 27px);	
	font-weight: 600;
	color: #FFF;
	text-align: center;
	letter-spacing: .0em;
	line-height: 1;
	font-feature-settings: "palt";	
	text-shadow: 3px 3px 3px rgba(35, 16, 19, 0.2);
}
.content-item .in_ttl span {
	font-size: clamp(36px, 3.67vw, 55px);	
}
.content-item .in_wrap {
	padding: 30px 13px;
	font-family: zen-old-mincho, sans-serif;
	font-weight: 500;
	letter-spacing: .0em;
	line-height: 1.65;
	font-feature-settings: "palt";
}
.content-item .in_wrap .ttl_s {
	font-size: clamp(15px, 1.33vw, 20px);
	letter-spacing: .0em;
	font-feature-settings: "palt";	
}
.content-item .in_wrap p,
.content-item .in_wrap li {
	font-size: clamp(13px, 1.07vw, 16px);	
}
.content-item .list_type_1 li::after {
    color: var(--clr_org_2)
}
.content-item#year1 {
	border-color: #8bdabf;
}
.content-item#year1 .in_ttl {
	background: #8bdabf
}
.content-item#year1 .obj {
	width:min(23.6vw, 354px);
	right: calc(min(0.67vw, 10px) * -1);
	top: calc(min(15.67vw, 235px) * -1)
}
.content-item#year2 {
	border-color: #79d4f2;
}
.content-item#year2 .in_ttl {
	background: #79d4f2
}
.content-item#year2 .obj {
	width:min(23.6vw, 354px);
	right: 0;
	top: calc(min(14.67vw, 220px) * -1)
}
.content-item#year3 {
	border-color: #ffb2c1;
}
.content-item#year3 .in_ttl {
	background: #ffb2c1
}
.content-item#year3 .obj {
	width:min(22.67vw, 340px);
	right: 0;
	left: 0;
	margin: auto;
	top: calc(min(14.67vw, 220px) * -1)
}
.home_staff .big_ttl {
	max-width: 864px;
	margin-inline: auto;
	position: relative
}
.home_staff .big_ttl figcaption {
	position: absolute;
	width: 100%;
	bottom: 0;
	left: 0;
	padding: 18px 2%;
	background: rgba(255,123,137,.7)
}
.home_staff .big_ttl figcaption {
	font-size: clamp(18px, 1.87vw, 28px);	
	font-weight: 500;
	color: #FFF;
	text-align: center;
	letter-spacing: .0em;
	font-feature-settings: "palt";
	text-shadow: 5px 5px 3px rgba(35,16,19,0.5);
}
.home_staff .sepa .px {
	width: min(29vw, 435px)
}
.home_staff .sepa .tx {
	width: min(33.67vw, 505px)
}
.home_staff .sepa .tx::before,
.home_staff .sepa .tx::after {
	content: "";
	position: absolute;
	width: 52px;
	height: 109px;
	background: url("../img/home_staff_sepa_tx_obj.png") no-repeat center /cover
}
.home_staff .sepa .tx::before {
	top: 0;
	left: 0
}
.home_staff .sepa .tx::after {
	bottom: 0;
	right: 0;
	transform: rotate(-180deg);
}
.home_staff .sepa .obj {
	width:min(30.53vw, 458px);
	bottom: calc(min(7.73vw, 116px) * -1);
	left: min(29vw, 435px)
}
.faq_wrap {
	padding: min(6.33vw, 95px) 38px min(4.67vw, 70px);
	background: #fff0f2
}
.faq_wrap .ttl {
	font-style: italic
}
.faq_wrap .block .q_area {
	display: flex;
	padding-bottom: 12px;
	margin-bottom: 12px;
	border-bottom: 1px solid var(--clr_pink_2);
}
.faq_wrap .block .q_area .circ {
	width: min(4.67vw, 70px);
	height: min(4.67vw, 70px);
	border-radius: 50%;
	background: #FFF;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: clamp(22px, 2vw, 30px);	
	font-weight: 600;
	color: var(--clr_pink_2);
	text-align: center;
	letter-spacing: .0em;
	line-height: 1.5;	
}
.faq_wrap .block .q_area .mn {
	padding-left: 14px;
	font-size: clamp(17px, 1.47vw, 22px);	
	font-weight: 600;
	color: var(--clr_pink_2);
	letter-spacing: .0em;
	font-feature-settings: "palt";
	padding-top: min(1.33vw, 20px)
}
.faq_wrap .block .a_area .mn {
	padding-left:  calc(min(4.67vw, 70px) + 14px);
	font-weight: 500;
	letter-spacing: .0em;
	font-feature-settings: "palt";
	line-height: 1.8
}
.balloon {
  position: relative;
  display: block;
  padding: min(1.2vw, 18px) 2%;
  border: 2px solid #ff8e9c; /* 本体は2px */
  background-color: #fff;
  max-width: 720px;
  margin-inline: auto;  
}
.balloon .obj {
	width:min(2.67vw, 40px);
	top: calc(min(2.13vw, 32px) * -1);
	right: calc(min(2.13vw, 32px) * -1)
}

/* 吹き出しの三角形：外枠（ピンク） */
.balloon::before {
  content: "";
  position: absolute;
  bottom: -26px; 
  left: 50%;
  transform: translateX(-50%);
  border-left: 11.5px solid transparent;
  border-right: 11.5px solid transparent;
  border-top: 26px solid #ff8e9c; /* ここが三角形の「塗り」のサイズ */
}

/* 吹き出しの三角形：内側（白） */
.balloon::after {
  content: "";
  position: absolute;
  /* 
     bottomの値を「-26px + 枠線の太さ」にするのがコツです。
     今回は太く見せるために -23px 程度まで持ち上げます。
  */
  bottom: -23px; 
  left: 50%;
  transform: translateX(-50%);
  /* 
     外側の11.5pxに対して、左右を2.5pxずつ削って 9px に。
     これで斜め線の厚みが増します。
  */
  border-left: 9px solid transparent;
  border-right: 9px solid transparent;
  /* 高さも外側の26pxに対して、3px削って 23px に。 */
  border-top: 23px solid #fff;
}
.home_au .block {
	padding-bottom: min(7.33vw, 110px);
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start
}
.home_au .block .px {
	width: 51.56%
}
.home_au .block .tx {
	width: calc(100% - 51.56%);
	padding-top: min(8.33vw, 160px)
}
.home_au .block .en {
	font-family: zen-old-mincho, sans-serif;
	font-size: clamp(36px, 4vw, 60px);	
	font-weight: 500;
	color: var(--clr_brown);
	letter-spacing: .05em;
	font-feature-settings: "palt";
}
.home_au .block .en {
	font-family: zen-old-mincho, sans-serif;
	font-size: clamp(36px, 4vw, 60px);	
	font-weight: 500;
	color: var(--clr_brown);
	letter-spacing: .05em;
	font-feature-settings: "palt";
}
.home_au .block .ttl {
	margin-top: min(4.9vw, 94px);
	width: min(1.56vw, 30px);
	position: relative;
	font-family: zen-old-mincho, sans-serif;
	font-size: clamp(22px, 2vw, 30px);	
	font-weight: 500;
	letter-spacing: -.4em;
	font-feature-settings: "palt";
  	-ms-writing-mode: tb-rl;
  	writing-mode: vertical-rl;
	text-align: center
}
.home_au .block .ttl {
	display: flex;
	align-items: center;
	margin-top: min(4.38vw, 84px);
	width: min(1.56vw, 30px);
	position: relative;
	font-family: zen-old-mincho, sans-serif;
	font-size: clamp(22px, 2vw, 30px);	
	font-weight: 500;
	letter-spacing: -.4em;
	font-feature-settings: "palt";
  	-ms-writing-mode: tb-rl;
  	writing-mode: vertical-rl;
}
.home_au .block .ttl::before {
	content: "";
	position: absolute;
	top: calc(min(3.02vw, 58px) * -1);
	left: 0;
	right: 0;
	margin: auto;
	width: 1px;
	height: min(2.81vw, 54px);
	background: #000
}
.home_au .block .in_bx {
	margin-top: min(2.08vw, 40px);
}
.home_au .block .ttl_s {
	display: inline-block;
	font-family: garamond-premier-pro, serif;
	font-size: clamp(36px, 3.33vw, 50px);	
	font-weight: 500;
	color: #303030;
	letter-spacing: .05em;
	font-feature-settings: "palt";
	border-bottom: 1px solid #303030;	
	padding-bottom: 2%
}
.home_au .block .msg {
	margin-top: 7%;
	font-family: zen-old-mincho, sans-serif;
	font-size: clamp(13px, 1.47vw, 22px);	
	font-weight: 500;
	letter-spacing: .025em;
	line-height: 1.8;
	font-feature-settings: "palt";	
}





.home_au .block.tx_l .tx {
	padding-left: 19.01%
}
.home_au .block.tx_l .in_bx {
	display: flex;
	justify-content: flex-end;
	text-align: right;
	padding-right: min(2.2vw, 33px)
}
.home_au .block.tx_l .msg {
	text-align: right
}

.home_au .block.tx_r .tx {
	padding-right: 19.01%
}
.home_au .block.tx_r .ttl_wrap {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end
}
.home_au .block.tx_r .in .ttl {
	float: right
}
.home_au .block.tx_r .in_bx {
	padding-left: min(2.2vw, 33px)
}
.home_au .block.no3 .tx {
    padding-top: min(7.81vw, 150px);
}
.home_au .block.no3 .in_bx {
    margin-top: 0
}
.home_ggp .inn {
	padding: min(7.63vw, 90px) min(12.2vw, 144px);
	background: #FFF
}
.home_ggp .row {
	padding-bottom: 15px;
	border-bottom: 1px solid #956d3d;
}
.home_ggp .row:last-child {
	padding-bottom: 0;
	border-bottom: none;
}
.home_ggp .row .in_ttl {
	font-family: zen-old-mincho, sans-serif;
	font-size: clamp(22px, 2vw, 30px);	
	font-weight: 500;
	text-align: center;
	letter-spacing: .05em;
	line-height: 1.5;
	font-feature-settings: "palt";
}
.home_ggp .row .msg {
	text-align: center;
	margin-top: 2%
}
.group_clinic .ttl_mid {
	padding: 23px 2%;
	background: linear-gradient(90deg, rgba(199, 178, 153, 1) 0%, rgba(153, 134, 117, 1) 100%);
	font-family: zen-old-mincho, sans-serif;
	font-size: clamp(22px, 2vw, 30px);	
	font-weight: 500;
	color: #FFF;
	text-align: center;
	letter-spacing: .1em;
	font-feature-settings: "palt";
} 
.group_clinic .sepa_block .map {
	width: 56.44%;
} 
.group_clinic .sepa_block .map iframe {
	width: 100%;
	height: 100%;
} 
.group_clinic .sepa_block .tx {
	width: calc(100% - 56.44%);
} 
.cap_ico {
	display: inline-block;
	margin: 0 4px 4px 0;
}
.time_tbl {
	padding: 10px 0;
	border-top: 1px solid var(--clr_base);
	border-bottom: 1px solid var(--clr_base);
}
.time_tbl .row {
	display: flex;
	align-items: center
}
.time_tbl .row .hd {
	width: 25.96%
}
.time_tbl .row .cell {
	text-align: center
}
.time_tbl .row .bse {
	width: calc((100% - 25.96%) / 8)
}
.time_tbl .row.no2 .cell {
	font-size: clamp(13px, 1.33vw, 20px);	
	font-family: "futura-pt", sans-serif;	
	color: var(--clr_brown)
}
.time_tbl .row.no2 .hd {
	line-height: 1.2
}
.cta_low {
	background: linear-gradient(90deg,rgba(199, 178, 153, 1) 0%, rgba(153, 134, 117, 1) 100%);
}
.cta_low .bar {
	margin: 1% auto 0;
	display: block;
	width:min(32vw, 480px);
	min-width: 375px;
	height: auto
}
.cta_low .sepa .in_tel {
	margin-left: min(5.33vw, 80px)
}
.cta_low .sepa .in_btn {
	margin-left: min(1.8vw, 27px)
}
.last_info {
	background: #808080
}
.last_info .bnr_row {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	justify-content: center;
	column-gap: 17px;
}
.last_info .bnr_row.no2 {
	margin-top: 17px
}
.last_info .last_lists {
	border-top: 1px solid var(--clr_wht)
}
.last_info .last_lists ul {
	justify-content: center;
    list-style: none;
    padding: 0;
}
.last_info .last_lists ul li a {
	display: block;
	padding:  0 20px;
	color: #FFF;
	letter-spacing: .0em;
	line-height: 1.25;
	font-feature-settings: "palt";	
	border-right: 1px solid var(--clr_wht)
}
.last_info .last_lists ul li:first-child a {
	padding-left: 0
}
.last_info .last_lists ul li:last-child a {
	padding-right: 0;
	border: none
}
.under_fv {
	position: relative;
	background: #ffffff
}
.under_fv .in_wrap {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: flex-end;
}
.under_fv .in_wrap .ttl_wrap {
	width: 100%;
	align-items: center;
	column-gap: min(8.65vw, 166px)
}
/*jjjjjjjjjjjjjjjjjjjjj*/
.sec_no_1 .box_wrap.no3 .obj {
    width: min(23.6vw, 354px);
	top: calc(min(7.67vw, 115px) * -1);
	right: calc(min(3.67vw, 55px) * -1)
}
.dental-hygienist .under_fv .in_wrap .ttl_wrap {
    column-gap: 10px;
	align-items: flex-start
}	
.dental-hygienist .under_fv .in_wrap .ttl_wrap .ttl,
.radiological-technologist .under_fv .in_wrap .ttl_wrap .ttl {
	position: relative;
    bottom: min(4.17vw, 80px);
}
.radiological-technologist .under_fv .in_wrap .ttl_wrap {
	column-gap: min(2.67vw, 40px)
}
.registered-dietitian .under_fv .in_wrap .ttl_wrap {
	align-items: flex-end
}	
.dental-technician .under_fv .in_wrap .ttl_wrap {
	align-items: flex-end;
	column-gap: min(2.67vw, 40px)
}	
.dental-assistant .under_fv .in_wrap .ttl_wrap {
	align-items: flex-end
}

.under_fv .in_wrap .ttl_wrap .ttl {
	font-family: zen-old-mincho, sans-serif;
	font-size: clamp(20px, 1.88vw, 36px);	
	font-weight: 500;
	letter-spacing: .055em;
	line-height: 1.5;
	font-feature-settings: "palt";
    text-shadow: 2px 2px 2px rgba(255, 255, 255, 0.5);		
}
.under .sec_no_1 {
	background: url("../img/under_sec_no_1.png") no-repeat top / cover
}
.under .box_wrap {
	background: #FFF;
}
.under .sec_no_1 .box_wrap.no1 .sepa {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 24px
}
.under .sec_no_1 .box_wrap.no1 .sepa .item {
	width: 274px;
}
.under .sec_no_1 .box_wrap.no1 .sepa .item .human {
	position: relative;
	z-index: 1;
}
.under .sec_no_1 .box_wrap.no1 .sepa .item .maru {
	position: relative;
	z-index: 10;
	margin-top: -33px;
	width: 274px;
	height: 274px;
	display: flex;
	justify-content: center;
	align-items: center;
}
.under .sec_no_1 .box_wrap.no1 .sepa .item .maru p.in {
	font-family: 'yug_b';	
	font-size: 24px;	
	font-weight: 500;
	color: #FFF;
	text-align: center;
	letter-spacing: .05em;
	line-height: 1.5;
	font-feature-settings: "palt";
	position: relative;
	z-index: 10
}
.under .sec_no_1 .box_wrap.no1 .sepa .item .maru.pt1 {
	background: url("../img/maru1.png") no-repeat center / cover
}
.under .sec_no_1 .box_wrap.no1 .sepa .item .maru.pt2 {
	background: url("../img/maru2.png") no-repeat center / cover
}
.under .sec_no_1 .box_wrap.no1 .sepa .item .maru.pt3 {
	background: url("../img/maru3.png") no-repeat center / cover
}

.under .sec_no_1 .box_wrap.no2 .sepa .item {
	box-shadow: 5px 5px 3px 0px rgba(29,35,14,0.25);
	background: #FFF;
	flex: 1;
	position: relative
}
.under .sec_no_1 .box_wrap.no2 .sepa .item {
	box-shadow: 5px 5px 3px 0px rgba(29,35,14,0.25);
	background: #FFF;
	flex: 1;
	position: relative
}
.under .sec_no_1 .box_wrap.no2 .sepa .tx {
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	padding: 14px 0;
	background: rgba(255,113,133,.7);
	font-size: clamp(16px, 1.6vw, 24px);	
	color: #FFF;
	text-align: center;
	letter-spacing: .05em;
	line-height: 1.35;
	font-feature-settings: "palt";
    text-shadow: 5px 5px 3px rgba(27, 35, 14, 0.5);		
}
.under .sec_no_1 .box_wrap.no3 {
    padding-right: 16px;
    padding-left: 16px;
	position: relative;
}
.content-item#year2 .obj.ver2 {
    top: calc(min(16vw, 240px) * -1);
}
.content-item#year3 .obj.ver3 {
    width: min(23.2vw, 348px);
    top: calc(min(16.67vw, 250px) * -1);
}
.msgz img {
	display: none
}
.home_msg .inn .sepa.flex-rev .tx {
    padding: 4% min(2vw, 30px) 0 0;
}	
.under_rec {
	background: #f2ede7 url("../img/under_rec_bg.png") no-repeat top / 100%;
}
.under_rec .box_wrap,
.under_app .box_wrap {
	padding-right: min(3.07vw, 46px);
	padding-left: min(3.07vw, 46px);
}
.lines .row {
	display: flex;
}
.lines .row:nth-child(odd) {
	background: #f2ede7
}
.lines .row .cell {
	padding: 24px 0;
	font-family: 'yug_b';
	font-size: clamp(16px, 1.2vw, 18px);	
	font-weight: 500;
	letter-spacing: .05em;
	line-height: 1.5;
	font-feature-settings: "palt";
}
.lines .row .hd {
	width: 26.38%;
	padding-left: 7.08%;
	display: flex;
}
.lines .row .hd.txa {
	align-items: flex-start
}

.lines .row .bse {
	width: calc(100% - 26.38%);
	padding-right: 3%
}
.under_app {
	background: #f2ede7 url("../img/under_app_bg.png") no-repeat top / 100%;
}
.under_app .in_sepa {
	display: flex;
	align-items: center;
	column-gap: 8px
}
.under_app .in_sepa .req {
	font-size: 13px;	
	font-weight: 500;
	color: #FFF;
	text-align: center;
	letter-spacing: .0em;
	line-height: 1;
	font-feature-settings: "palt";
	background: #ff4b00;
	border-radius: 5px;
	padding: 4px
}
.radio_wrap .wpcf7-list-item {
	padding-right: 20px
}
.under_app input[type="text"],
.under_app input[type="email"],
.under_app input[type="tel"],
.under_app textarea {
    width: 100%; /* 親要素いっぱいに広げる */
    padding: 10px;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-size: 16px; /* モバイルでのズーム防止（16px以上推奨） */
    background-color: #fff;
    box-sizing: border-box; /* パディングを含めた幅計算 */
    transition: border-color 0.3s, box-shadow 0.3s;
    appearance: none;
	max-width: 480px
}
.under_app input[type="email"] {
	max-width: 630px
}
.under_app select {
    padding: 3px 10px;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-size: 16px; /* モバイルでのズーム防止（16px以上推奨） */
    background-color: #fff;
    box-sizing: border-box; /* パディングを含めた幅計算 */
}
.under_app textarea,
.wpcf7-form-control.wpcf7-textarea {
    display: block;
    width: 100%;
	max-width: inherit;	
    min-height: 200px; /* 最低限の高さを確保 */
    line-height: 1.6;
    resize: vertical; /* 縦方向にのみ伸ばせるようにする（横に広がるとレイアウトが壊れるため） */
}
/* フォーカス時のスタイル */
.under_app input[type="text"]:focus {
    border-color: #007bff; /* 医院のメインカラーなどに合わせる */
    box-shadow: 0 0 5px rgba(0, 123, 255, 0.2);
    outline: none;
}

/* プレースホルダーのスタイル */
::placeholder {
    color: #999;
}
.wpcf7-acceptance input[type="checkbox"] {
    margin-right: 10px;
    width: 18px;
    height: 18px;
}
.wpcf7-acceptance label {
    display: inline-flex;
    align-items: center;
    cursor: pointer;
}
.wpcf7-submit {
    border: none;
    appearance: none;
	background: none;
    color: #fff;
	font-family: zen-old-mincho, sans-serif;	
    font-size: clamp(22px, 2vw, 30px);
    font-weight: 500;
	letter-spacing: .025em;
	line-height: 1;
	font-feature-settings: "palt";		
}
.submit_wrap .btn_wrap{
    cursor: pointer;	
    display: inline-block;
    width: 100%; /* デザインに合わせて調整 */
    max-width: 480px;
    padding: 18px 20px;
    background: linear-gradient(90deg, rgba(199, 178, 153, 1) 0%, rgba(153, 134, 117, 1) 100%);
	position: relative;
    transition: all 0.25s;	
}
.submit_wrap .btn_wrap:hover{
    opacity: .5	
}

.submit_wrap .btn_wrap::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    right: min(2.67vw, 40px);
    width: min(2vw, 30px);
    height: min(2vw, 30px);
    margin: auto;
    background: url(../img/btn_tp_2.png) no-repeat center / cover;
}
.add_info .catch {
    display: inline-block;
	position: relative;
	padding: 30px 16px
}
.add_info .catch::before,
.add_info .catch::after {
	content: "";
	position: absolute;
	width: min(6.1vw, 72px);
	height: min(12.71vw, 150px);
	margin: auto;
	background: url("../img/add_info_catch_obj.svg") no-repeat center /cover
}
.add_info .catch::before {
	top: 0;
	left: 0
}
.add_info .catch::after {
	bottom: 0;
	right: 0;
	transform: rotate(180deg);
}
.dental-hygienist .add_info {
	position: relative;
	top: calc(min(10.42vw, 200px) * -1)
}















/* ==========================================================================
   Author's custom styles
   ========================================================================== */


@media screen and (max-width:1536px){
.wrap_1500 {
	padding-right: 0.8rem;
	padding-left: 0.8rem;
}	
.home_au .block.tx_l .tx {
	padding-left: 2%
}
.home_au .block.tx_r .tx {
	padding-right: 2%
}
.sec_no_1 .box_wrap.no3 .obj {
    width: min(23.6vw, 354px);
	top: calc(min(7.67vw, 115px) * -1);
	right: 0
}	
}
@media screen and (max-width:1210px){}
@media screen and (max-width:1090px){
.home_msg .inn .sepa {
	flex-wrap: wrap
}	
.home_msg .inn .sepa .big_nam {
	position: relative;
	width: 100%;
	margin-left: 0;
	bottom: 0;
	justify-content: flex-end;
	align-items: center;
	column-gap: 20px;
	margin-top: 10px;
}
.home_msg .inn .sepa .big_nam .jp {
	padding-top: 0
}
.group_clinic .sepa_block .item {
	width: 50%;
} 
	
}

@media screen and (max-width:767px){
/* ==========================================================================
   Commons styles
   ========================================================================== */
.flex_wrapper, .flex-wrap_par{
    display: block;
}
.flex_sp{
	display: -webkit-flex!important;
    display: -moz-flex!important;
    display: -ms-flex!important;
    display: -o-flex!important;
    display: flex!important;
	flex-wrap: wrap!important;
}	
.pc{display: none!important}
.sp{display: block!important}	
a[href^="tel:"] {
	pointer-events: auto;
	cursor: pointer;
}	
.wrap_1500,.wrap_1180,.wrap_960,.wrap_870 {
    width: 100%;
	max-width: 100%;
    height: auto;
	margin-left: auto;
	margin-right: auto;
    padding-right: 0.8rem!important;
    padding-left: 0.8rem!important;
}	
.sp_no_pad {
	padding-right: 0!important;
	padding-left: 0!important;	
}
.sp_on_pad {
	padding-right: 0.8rem!important;
	padding-left: 0.8rem!important;
}
.sp_width {
	width: calc(100% - 1.6rem);
	margin-left: auto;
	margin-right: auto;
}
.sp_width_over {
	width: calc(100% + 1.6rem);
	margin-left: -0.8rem;
}
.sp_width_over.max_img {
	max-width: calc(100% + 1.6rem);
}
.sp_tx_cent {
	text-align: center
}
.sp_yaku {
	font-feature-settings: "palt";
}
.tab-item {
    flex: 1;
    background: #e0ddda;
    padding: 15px 0;
    text-align: center;
    cursor: pointer;
    font-weight: 600;
    color: #fff;	
  }
  /* activeクラスで色を変える（SP.pngのイメージ） */
  .tab-item.year1.active {
    background: #8bdabf;
  }
  .tab-item.year2.active {
    background: #79d4f2;
  }
  .tab-item.year3.active {
    background: #ffb2c1;
  }
.tab-menu{
	width: 100%;
	display: flex!important;
	flex-wrap: wrap;
	gap: 5px;
}	
.tab-menu li {
	flex: none;	
	width: calc(50% - 2.5px);
	border-radius: 5px;
    font-weight: 600;
    color: #FFF;
    text-align: center;
    letter-spacing: .0em;
    line-height: 1;
    font-feature-settings: "palt";
    text-shadow: 3px 3px 3px rgba(35, 16, 19, 0.2);	
}	
.tab-menu li span {
	font-size: 8.21vw
}
.tab-container {
    display: block;
}	
.content-item .obj {
    display: none
}
.content-item {
    display: block;
    width: 100%;
    border-radius: 0;
    position: relative;
    border: 2px solid var(--clr_wht);
}
.content-item .in_ttl {
    display: none
}	
  /* SP時は一旦すべて非表示にし、activeのみ表示 */
  .content-item {
    display: none!important;
	  background: #FFF;
    margin-top: 20px;
  }
  .content-item.active {
    display: block!important;
  }	
header.general {
    width: 100%;
    height: 80px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: #FFF;
}	
header.general .info  {
    display: none
}
header.general .logos .supp {
    display: block;
    width: 100%;
    margin-top: 5px;
    font-size: 8px;
    font-weight: 500;
    color: #666666;
    letter-spacing: .0em;
}	
header.general .logo img {
    display: block;
    width: 80%;
    height: auto;
}	
.sp_ham {
	margin: 20px 0.8rem 0 0;
    width: 45px;
    height: 45px;
	position: fixed;
	z-index: 9999999;
	top: 0;
	right: 0;	
	display: flex!important;
	align-items: center;
	align-content: center;
	justify-content: center;
	flex-wrap: wrap;
    background: linear-gradient(90deg, rgba(199, 178, 153, 1) 0%, rgba(153, 134, 117, 1) 100%);
	transition-property: all;
  	transition: 0.15s linear;				
}	
.sp_ham.set {
	margin-top: 0;
}	
.sp_ham p {
	width: 100%;	
	padding-top: 10px;
  	color: #FFF;
	font-size: 9px;
	font-weight: 600;
	font-family: zen-old-mincho, sans-serif;
	text-align: center;
	line-height: 1
}	
.menu-trigger,
.menu-trigger span {
  display: inline-block;
  transition: all .4s;
  box-sizing: border-box;
}
.menu-trigger {
 	position: relative;
	width: 19px;
	height: 15px;
	top: 5px
}
.menu-trigger span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #FFF;
}
.menu-trigger span:nth-of-type(1) {
  top: 0;
}
.menu-trigger span:nth-of-type(2) {
  top: calc(50% - 1px);
}
.menu-trigger span:nth-of-type(3) {
  bottom: 0;
}
.menu-trigger.active span:nth-of-type(1) {
	transform: rotate(-45deg);
	top: 50%;
}
.menu-trigger.active span:nth-of-type(2) {
  opacity: 0;
}
.menu-trigger.active span:nth-of-type(3) {
	transform: rotate(45deg);
	top: 50%;
}				
nav.general {
	display: none;
	position: fixed;
    width: 100%;
	height: 100vh;
    top: 0;
    left: 0;
    z-index: 9999;
	padding-top: 80px;
}	
nav.general ul {
	height: 100%;
    display: flex;
    flex-wrap: wrap;
	overflow-y: scroll
}	
nav.general ul {
    display: block;
	padding: 0!important
}	
nav.general li {
	border-bottom: 1px solid var(--clr_wht)
}	
nav.general li a::after {
    display: none
}	
/*qqqqqqqqqqqqq*/
.sec_pad_60 {
    padding: 7.5vw 0;
}	
.sec_pad_60_b {
    padding-bottom: 7.5vw;
}	
.sec_pad_80 {
    padding:9.5vw 0;
}	
.sec_pad_120_t {
    padding-top: 13vw;
}
.sec_pad_120 {
    padding: 13vw 0;
}	
.sec_pad_140 {
    padding: 13vw 0;
}	
.mgn_t_10 {
    margin-top: 2.5vw;
}	
.mgn_t_15 {
    margin-top: 3vw;
}	
.mgn_t_25 {
    margin-top: 4vw
}	
.mgn_t_30 {
    margin-top: 4.5vw
}	
.mgn_t_35 {
    margin-top: 5vw
}	
.mgn_t_40 {
    margin-top: 5.5vw
}	
.mgn_t_45 {
    margin-top: 6vw
}
.mgn_t_50 {
    margin-top: 6.5vw
}
.mgn_t_60 {
    margin-top: 7.5vw
}	
.mgn_t_75 {
    margin-top: 9vw;
}
.mgn_t_70 {
    margin-top: 8.5vw;
}	
.mgn_t_90 {
    margin-top: 10.5vw;
}	
.mgn_t_110 {
    margin-top: 13vw;
}	
.txs_66 {
    font-size: 12.82vw
}	
.txs_42 {
    font-size: 5.64vw;
}	
.txs_18 {
    font-size: 16px
}	
.txs_20, .txs_22 {
    font-size: 4.62vw;
}
.txs_24, .txs_26 {
    font-size: 6.15vw
}	
.txs_30 {
    font-size: 4.62vw
}	
.txs_60 {
    font-size: 15.38vw
}	
/*qqqqqqqqqqqqq*/
.h_type_1 .en_wrap {
    font-size: 15.38vw;
}	
.h_type_1 .ttl {
    font-size: 5.64vw;
}	
.h_type_1 .ttl .in::before, .h_type_1 .ttl .in::after {
    width: 50px;
    height: 1px;
}	
.h_type_1 .ttl .in::before {
	left: -70px
}
.h_type_1 .ttl .in::after {
	right: -70px
}
.home_msg .inn .sepa .tx {
    padding: 5.5vw 0 0;
}	
.home_msg .inn .sepa .tx .msg {
    position: relative;
}	
.fake_bg {
	content: "";
	position: absolute;
	top: 0;
	left: -0.8rem;
	right: 0;
	z-index: 0;
	width: calc(100% + 1.6rem);
	height: 100%;
	background: #E5E5E5
}	
.home_msg .inn .sepa .big_nam {
    position: relative;
    bottom: 0;
    display: block;
    justify-content: space-between;
    width: 100%;
    margin-left: 0;
	margin: 0;
	text-align: right;
	padding: 4vw 0
}	
.home_msg .inn .sepa .big_nam .txs_64 {
    font-size: 7.95vw;
}	
.home_msg .inn .sepa .big_nam .txs_26 {
    font-size: 4.62vw
}	
.home_msg .dtl_sepa {
    margin-top: 0;
	padding-top: 5vw
}	
.home_msg .inn .dtl_sepa .item {
    padding: 5vw 4vw;
} 	
.h_type_2 .en {
    font-size: 15vw;
}	
.h_type_2 .ttl {
    font-size: 5.64vw;
    margin-top: 0;
    padding-bottom: 4vw;
}	
.h_type_2 .ttl::after {
    width: 50px;
}	
.home_jc .block {
    display: block;
    max-height: inherit;
	padding-bottom: 7vw
}	
.home_jc .block .px {
    width: 100%;
}	
.home_jc .block .tx {
    width: 100%;
    padding: 7vw 0.8rem 0;
    display: flex;
    align-items: flex-end;
    column-gap: min(0.85vw, 10px);
    justify-content: space-between;
}	
.home_jc .btn_tp_1 {
    margin: 6vw auto 0;
	width: calc(100% - 1.8rem);
    text-shadow: none;
}	
.btn_tp_1 {
    position: relative;
    padding: 3vw;
    background: #FFF;
    border-radius: 40px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    column-gap: min(2.67vw, 40px);
}
.btn_tp_1 .mn {
    font-size: 4.62vw;
    padding-left: 5%;
}	
.btn_tp_1 .icon {
    width: 36px;
}	
.home_jc .block .en {
    font-size: 16px;
}	
.home_jc .block .ttl {
    margin: 3% 0 5% 0;
    font-size: 7.69vw;
}	
.home_jc .block .tx .in_tx .msg {
    font-size: 16px;
    font-weight: 600;
    letter-spacing: 0;
    font-feature-settings: "palt";
    line-height: 1.8;
}	
.home_jc .block .human {
    max-width: inherit;
    width: 40%
}	
.home_jc .block .tx .in_tx {
    padding-bottom: 0;
}	
.home_jc .block.mgn_t_50 {
    margin-top: 5.13vw;
}
.home_jc .block.no3 .tx {
	padding-top: 0;
}
.home_jc .block .for_sp {
	width: 100%;
	padding-top: 7vw;
    padding-bottom: 0;
    color: #FFF;
    text-shadow: 3px 3px 2px rgba(51, 44, 40, 0.15);	
}
.home_jc .block .ttl {
	margin: 3% 0 5% 0;
	font-family: zen-old-mincho, sans-serif;
	font-size: 7.69vw;	
	font-weight: 500;
	letter-spacing: .05em;
	font-feature-settings: "palt";
}
.btn_tp_2 {
    padding: 4vw 0;
}	
.btn_tp_2 .txt {
    font-size: 4.62vw;
	text-align: left;
	padding-left: 5%;
    letter-spacing: .025em;
}	
.btn_tp_2::after {
    right: 5vw;
    width: 29px;
    height: 29px;
}	
.home_fif header .ttl img {
    display: block;
    width: 80%;
}	
.home_fif header {
    padding: 9vw 0 6vw
}	
.hf_block {
    padding: 10vw 0;
    position: relative;
}	
.hf_block .wrap_1180 {
	padding-right: 0!important;
	padding-left: 0!important;
}	
.hf_block .box {
    display: block;
}	
.hf_block .box .col_1 {
    width: 50%;
}	
.hf_block .box.tp1 .ttl_big {
	display: block;
    padding: 4vw 4vw 4vw 8vw;
	margin-bottom: 7vw;
	text-align: left;
    writing-mode: horizontal-tb;
    letter-spacing: 0.05em;
}	
.hf_block .box .ttl_big {
    padding: 4vw;	
	font-size: 5.64vw;
    letter-spacing: 0.05em;
}	
.hf_block.no2 .box .ttl_big {
    padding-left: 8vw;
	font-size: 5.64vw;
	text-align: right
}	
.hf_block .box.tp1 .col_2 {
    display: block;
}
.hf_block.no1 .box .col_2 {
    width: 100%;
	padding-right: 0.8rem;
	padding-left: 0.8rem;
}	
.hf_block .box .col_2 .wide_bx {
    width: 100%;
}	
.h_type_3 {
    font-size: 4.62vw;
    font-weight: 600;
    line-height: 1.3;
}
.hf_block .box .col_2 .tx .msg {
    margin-top: 3vw;
}	
.hf_block .box .col_2 .tiny_bxs {
    width: 100%;
	margin-top: 5vw
}	
.hf_block .box .col_2 .tiny_bxs .row {
    display: block;
}	
.hf_block .box .col_2 .tiny_bxs .row .tx {
    padding: 3vw 0 0;
}	
.hf_block .box .col_2 .tiny_bxs .mgn_t_15 {
    margin-top: 5vw;
}		
.hf_block .box .col_2 {
    width: 100%;
}	
.hf_block .box.tp2 .col_2 .in_sepa .px {
    display: none
}	
.hf_block .box.tp2 .col_2 .in_sepa .txs {
    width: 100%;
	padding-right: 0.8rem;
	padding-left: 0.8rem;	
}	
.hf_block .box.tp2 .col_2 .in_sepa {
    display: block;
}	
.hf_block.no2 .box .h_type_3, .hf_block.no4 .box .tiny_bxs .h_type_3 {
    text-align: left;
}
.hf_block.no2 .box .h_type_3 span::before, .hf_block.no4 .box .tiny_bxs .h_type_3 span::before {
    left: 0;
    right: unset;
}	
.hf_block.no2 .box .h_type_3 span, .hf_block.no4 .box .tiny_bxs .h_type_3 span {
    padding-left: 15px;
    padding-right: 0;
}	
.hf_block .box.tp2 .col_2 .in_sepa .px {
	padding-bottom: 3vw
}	
.sp_mgn_t_5vw {
	margin-top: 5vw
}	
.hf_block .box.tp2 .col_2 .in_sepa .px {
	display: block;
	width: 100%;
	height: auto
}	
.hf_block .box.tp2 .col_2 .in_sepa .pxs {
    display: none
}	
.hf_block.no3 .box .col_1,
.hf_block.no4 .box .col_1	{
    width: 100%;
}	
.hf_block.no3 .box.tp1 .ttl_big,
.hf_block.no4 .box.tp1 .ttl_big {
    width: 50%;
}	
.hf_block.no4 .box .col_2 {
	padding-right: 0.8rem;
	padding-left: 0.8rem;
}	
.hf_block.no3 .box .ttl_big {
    width: 50%;
	text-align: left
}	
.home_tour {
    padding: 10vw 0.8rem
}	
.home_tour .ttl span::before {
    bottom: -4vw;
    left: -3vw;
    right: 0;
    width: 27.69vw;
    height: 5.13vw;
}	
.home_tour .ttl span::after {
    top: 2vw;
    right: -9vw;
    width: 6.41vw;
    height: 5.13vw;
}	
.home_tour .leade_msg {
	margin-top: 10vw;
	font-size: 4.36vw
}	
.h_type_4 {
    font-size: 4.62vw;
    padding-bottom: 5px;
}	
.time_sepa .item {
    display: flex;
	align-items: center;
	margin-bottom: 14vw;
	position: relative;
}	
.time_sepa .item:last-child {
	margin-bottom: 0
}	
.time_sepa .item .clocks {
    margin-bottom: 0;
	width: 30%;
}	
.time_sepa .item .px {
	width: 70%;
}	
.time_sepa .item .clocks .en {
    font-size: 7.69vw;
    margin-top: 6px;
	line-height: 1.1
}	
.time_sepa .item .clocks img {
    font-size: 7.69vw;
    margin-top: 6px;
}	
.time_sepa .item header {
    padding: 4vw 2%;
    font-size: 16px;
    font-weight: 600;
    color: #FFF;
    text-align: center;
    letter-spacing: .025em;
    line-height: 1.5;
    font-feature-settings: "palt";
}	
.time_sepa .item::after {
    content: "";
    position: absolute;
    top: unset;
	bottom: -14vw;
	left: 7vw;
    width: 12.31vw;
    height: 10vw;
	margin: 0;
	right: 0;
	transform: rotate(90deg);
}	
.ttl_gld .mn {
    padding: 3vw 2%;
    border-radius: 50px;
    font-size: 5.64vw;
    letter-spacing: .05em;
    line-height: 1.5;
}	
.home_staff .inn .ttl_gld {
    top: -6vw
}	
.home_staff .big_ttl figcaption {
    font-size: 16px;
	padding: 2vw 0
}
.home_staff {
    background: #f9f7f4;
}	
.home_staff .inn {
	background: none;
    padding-right: 4vw;
    padding-left: 4vw;
}	
.big_en {
    font-size: 14.87vw;
    line-height: 1.1;
}
.big_en {
    font-size: 14.87vw;
    line-height: 1;
}
.big_en.mgn_t_90 {
        margin-top: 0;
    }	
.for_sp_2 {
	margin-top: 10.5vw;
    padding: 6vw 0;
	background: #FFF
}
.career-plan {
    margin-top: 8vw
}	
.content-item .in_wrap {
    padding: 5vw 4vw;
	height: 337px;
	overflow-y: scroll
}	
.content-item .in_wrap .ttl_s {
    font-size: 4.62vw
}	
.content-item .in_wrap .ttl_cover {
    display: flex;
	column-gap: 10px;
	align-items: flex-start
}	
.content-item .in_wrap .ttl_cover .ttl_s  {
    line-height: 1.3
}	
.content-item .in_wrap p, .content-item .in_wrap li {
    font-size: 15px
}	
.content-item .in_wrap .msgz {
    display: flex;
	column-gap: 10px;
	align-items: center
}	
.content-item .in_wrap .msgz img {
    width: 30%;
	height: auto;
	display: block
}	
.content-item .ttl_s.ver2 {
    padding: 1vw 4vw
}	
.content-item#year1 .ttl_s.ver2 {
    background: #8bdabf;
}	
.content-item#year2 .ttl_s.ver2 {
    background: #79d4f2;
}	
.content-item#year3 .ttl_s.ver2 {
    background: #ffb2c1;
}	
.content-item#year3 .in_wrap .msgz img {
    width: 20%;
}	
.for_sp_3 {
    margin-top: 0;
	padding: 13vw 4vw 2vw;
	display: block!important;
	background: #FFF
}	 	
.for_sp_bg_wht {
	background: #FFF
}	 	
.sp_mgn_t_0 {
	margin-top: 0
}	 	
.sp_pad_b_10 {
	padding-bottom: 10vw
}	 	
.home_staff .sepa {
    background: #FFF;
	padding-right: 4vw;
	padding-left: 4vw;
	padding-bottom: 6vw
}	
.home_staff .sepa .px {
    width: 100%
}	
.home_staff .sepa .tx {
    width: 100%;
	margin-top: 5vw
}	
.home_staff .sepa .obj {
	position: relative;
    width: auto;
	max-width: 100%;
    bottom: 0;
    left: 0;
	margin-inline: auto;	
	margin-top: 6vw
}	
.home_staff .faq_wrap.sp_width_over {
	max-width: calc(100% + 1.6rem);
	margin-top: 10vw
}
.faq_wrap {
    padding: 10vw 0.8rem;
}	
.faq_wrap .block .q_area .circ {
    width: 40px;
    height: 40px;
    font-size: 17px;
    font-weight: 600;
    line-height: 1;
}	
.faq_wrap .block .q_area .mn {
	width: calc(100% - 54px);
    padding-left: 14px;
    font-size: 4.62vw;
    font-weight: 600;
    color: var(--clr_pink_2);
    letter-spacing: .0em;
    font-feature-settings: "palt";
    padding-top: 1.5vw;
}	
.faq_wrap .block .q_area {
	align-items: flex-start;
	flex-wrap: wrap;
    padding-bottom: 2vw;
    margin-bottom: 2vw;
}	
.faq_wrap .block .a_area .mn {
    padding-left: 0;
    font-weight: 500;
    letter-spacing: .0em;
    font-feature-settings: "palt";
    line-height: 1.8;
}	
.balloon {
	width: 90%;
	margin-inline: auto;		
    padding: 5vw 2%;
    border: 2px solid #ff8e9c;
}	
.balloon .obj {
    width: 10.77vw;
    top: -10vw;
    right: -8vw
}	
.home_au .block .en {
	width: 100%;
    font-size: 15.38vw;
}	
.home_au .block .px {
    width: 75%;
}	
.home_au .block .tx {
    width: 25%;
    padding-top: min(8.33vw, 160px);
}	
.home_au .block .ttl_wrap {
    padding-left: 0.8rem
}	
.home_au .block .ttl {
    margin-top: 40px;
    width: min(1.56vw, 30px);
    font-size: 6.67vw;
    letter-spacing: 0em;
}	
.home_au .block .ttl::before {
    top: -55px;
    height: 50px;
}	
.home_au .block.tx_l .in_bx {
	width: 100%;
    display: flex;
    justify-content: flex-end;
    text-align: right;
    padding-left: 0.8rem;
    padding-right: 0.8rem;
}	
.home_au .block .ttl_s {
    font-size: 12.82vw;
    border-bottom: 1px solid #303030;
    padding-bottom: 1%;
}	
.home_au .block .msg {
    margin-top: 3%;
    font-size: 16px;
    font-weight: 500;
    letter-spacing: .025em;
    line-height: 1.8;
    font-feature-settings: "palt";
}	
.home_au .block.tx_r .en {
    text-align: right
}		
.home_au .block.tx_r .ttl_wrap {
    padding-left: 0;
    padding-right: 0.8rem
}	
.home_au .block.tx_r .in_bx {
    padding-left: 0.8rem;
    padding-right: 0.8rem	
}	
.home_ggp .ff_en.txs_60.tx_cent {
    line-height: 1;
	text-align: left;
}	
.h_type_1 .ttl {
	margin-top: 4vw
} 	
.h_type_1 .ttl .in span.txs_30 {
	font-size: 5.64vw;
    position: relative;
    bottom: 0;
	display: block
} 	
.home_ggp .row .in_ttl {
    font-size: 5.38vw;
    line-height: 1.5;
    font-feature-settings: "palt";
}	
.home_ggp .row .msg {
    text-align: left;
    margin-top: 2%;
}	
.group_clinic .ttl_mid {
    padding: 4vw 2%;
    font-size: 4.62vw;
    letter-spacing: .1em;
}	
.sp_tx_lef {
    text-align: left
}	
.group_clinic .sp_tx_lef {
    margin-bottom: 5vw
}	
.group_clinic .sepa_block .map {
    width: 100%;
	height: 270px
}	
.group_clinic .sepa_block .tx,
.group_clinic .sepa_block .item	{
    width: 100%;
}	
.group_clinic .sepa_block .item	{
   text-align: center;
	margin-bottom: 2vw
}	
.group_clinic .sepa_block .in_btn img {
	margin-inline: auto;
	margin-bottom: 5vw
}	
.cta_low .ff_min.txs_30 {
	font-size: 6.67vw
}	
.cta_low .bar {
    margin: 5% auto 6vw;
    display: block;
    width: 100%;
    min-width: inherit;
    height: auto;
}
.cta_low .in_logo img {
	margin-inline: auto;
}
.cta_low .sepa .in_tel {
	margin-inline: auto;
} 	
.cta_low .sepa .in_tel img {
	margin: 8vw auto 6vw
} 	
.last_info .bnr_row.no1 img {
    margin-bottom: 6vw
}	
.last_info .bnr_row.no2 {
    margin-top: 0;
}	
.last_info .bnr_row.no2 img {
    margin-bottom: 6vw
}	
.last_info .bnr_row.no2 a:last-child img {
    margin-bottom: 0
}	
.last_info .last_lists ul li {
    margin-bottom: 2.6vw
}	
.last_info .last_lists ul li:last-child {
    margin-bottom: 0
}	
.last_info .last_lists ul li a {
    display: block;
    padding: 0 0;
    color: #FFF;
    letter-spacing: .0em;
    line-height: 1.25;
    font-feature-settings: "palt";
    border-right: none
}	
.cp {
    margin-top: 14vw
}	
.last_info {
    padding-bottom: 4vw
}	
footer {
    margin-bottom: 65px
}	
.sp_fix_nvs {
    width: 100%;
	height: 65px;
	position: fixed;
	bottom: 0;
	left: 0;
	z-index: 9998;
	display: flex;
}	
.sp_fix_nvs .item {
    flex: 1;
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
}
.sp_fix_nvs .item.tels {
    background: #FFF
}	
.sp_fix_nvs .item.mail {
    background: linear-gradient(90deg,rgba(85, 196, 77, 1) 0%, rgba(0, 181, 128, 1) 100%);
}	
.msgz img {
	display: block
}
.under_fv .in_wrap .ttl_wrap {
    width: 100%;
    align-items: center;
    column-gap: min(8.65vw, 166px);
	padding-right: 0.8rem;
	padding-left: 0.8rem;
}	
.under_fv .in_wrap .ttl_wrap img {
    margin-bottom: 11vw
}	
.under_fv .in_wrap .ttl_wrap .ttl {
    font-family: zen-old-mincho, sans-serif;
    font-size: 5.9vw;
    line-height: 1.65;
}	
/*下層kvkkkkkkkkkk*/	
.dentist .under_fv .in_wrap .ttl_wrap img {
    width: 65%
}
.under .sec_no_1 {
	background: #ffffff url("../img/under_sec_no_1_sp.png") no-repeat top / cover
}
.under .sec_no_1 .box_wrap.no1 .sepa {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0;
}	
.under .sec_no_1 .box_wrap.no1 .sepa .item {
    width: 150px;
}	
.under .sec_no_1 .box_wrap.no1 .sepa .item:nth-child(2n) {
    margin-top: 50px
}	
.under .sec_no_1 .box_wrap.no1 .sepa .item:nth-child(3)	{
    margin-top: -40px
}	
.under .sec_no_1 .box_wrap.no1 .sepa .item:nth-child(5)	{
    margin-top: -40px
}	
.under .sec_no_1 .box_wrap.no1 .sepa .item:nth-child(4),
.under .sec_no_1 .box_wrap.no1 .sepa .item:nth-child(6)	{
    margin-top: 10px
}	
.under .sec_no_1 .box_wrap.no1 .sepa .item .maru {
    position: relative;
    z-index: 10;
    margin-top: -33px;
    width: 150px;
    height: 150px;
    display: flex;
    justify-content: center;
    align-items: center;
}	
.under .sec_no_1 .box_wrap.no1 .sepa .item .human img {
    width: auto;
	max-width: inherit;
	height: 180px
}	
.under .sec_no_1 .box_wrap.no1 .sepa .item .maru p.in {
    font-size: 14px;
    font-weight: 500;
    color: #FFF;
    text-align: center;
    letter-spacing: 0em;
    line-height: 1.5;
    font-feature-settings: "palt";
    position: relative;
    z-index: 10;
}	
.dentist .sec_no_1 .box_wrap.no3 .obj {
    width: 37.69vw;
	top: 0;
	right: 0
}
.add_info {
    margin-top: 6vw
}
.add_info .catch {
	width: 100%;
    margin-top: 6vw;	
    display: block;
	position: relative;
	padding: 5vw 0.8rem
}
.add_info .catch::before, .add_info .catch::after {
    width: 10.77vw;
    height:22.56vw;
}	
.under .home_msg .inn .h_type_1 .en_wrap {
    justify-content: flex-end
}	
.lines .row {
    display: block;
	padding: 4vw 0
}	
.lines .row .cell {
    padding: 5px 4vw;
}	
.lines .row .hd {
    font-size: 18px;	
    width: 100%;
    padding-left: 4vw;
    display: flex;
}	
.lines .row .bse {
    width: 100%;
    padding-right: 4vw;
}	
.add_btn .btn_tp_2 .txt {
    font-size: 4.62vw;
	text-align: center;
	padding-left: 0%;
    letter-spacing: .025em;
}	
.under .box_wrap.insta_wrap  {
   padding: 12vw 0.8rem
}	
.under_rec {
   padding-bottom: 0
}	
.under_app {
    background: #f2ede7 url(../img/under_app_bg_sp.png) no-repeat top / 100%;
}	
.under_app select {
	width: 100%;
    padding: 3px 10px;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-size: 16px;
    background-color: #fff;
    box-sizing: border-box;
}	
.wpcf7-acceptance label {
    align-items: flex-start;
	text-align: left
}	
.wpcf7-acceptance input[type="checkbox"] {
    margin-top: .15em
}	
.submit_wrap .btn_wrap::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    right: min(2.67vw, 40px);
    width: 29px;
    height: 29px;
    margin: auto;
    background: url(../img/btn_tp_2.png) no-repeat center / cover;
}	
.under .sec_no_1 .box_wrap.no2 .sepa .tx {
    padding: 14px 0;
    background: rgba(255, 113, 133, .7);
    font-size: 4.82vw;
    line-height: 1.35;
}	
.under .sec_no_1 .box_wrap.no2 .sepa .item:first-child {
    margin-bottom: 5.5vw
}	
.dental-hygienist .under_fv .in_wrap,
.dental-assistant .under_fv .in_wrap,
.registered-dietitian .under_fv .in_wrap,
.dental-technician .under_fv .in_wrap,
.radiological-technologist .under_fv .in_wrap,
.entry .under_fv .in_wrap {
    align-items: flex-start;
	padding-top: 10vw
}	
.dental-hygienist .under_fv .in_wrap .ttl_wrap .ttl {
    text-align: right
}	
.sec_no_1 .box_wrap.no3 .obj {
    width: 37.69vw;
	top: 0;
	right: 0
}	
.dental-hygienist .add_info {
    position: relative;
    top: unset;
}	
.registered-dietitian .under_fv .in_wrap .ttl_wrap img,
.dental-technician .under_fv .in_wrap .ttl_wrap img,
.radiological-technologist .under_fv .in_wrap .ttl_wrap img	{
    margin-bottom: 4vw
}	
.entry .under_fv .in_wrap .ttl_wrap img	{
    width: 60%
}	
	
	
	
	
	
	
	
	
	
	
}
/* ==========================================================================
   Helper classes
   ========================================================================== */

/*
 * Hide visually and from screen readers
 */

.hidden,
[hidden] {
  display: none !important;
}

/*
 * Hide only visually, but have it available for screen readers:
 * https://snook.ca/archives/html_and_css/hiding-content-for-accessibility
 *
 * 1. For long content, line feeds are not interpreted as spaces and small width
 *    causes content to wrap 1 word per line:
 *    https://medium.com/@jessebeach/beware-smushed-off-screen-accessible-text-5952a4c2cbfe
 */

.visually-hidden {
  border: 0;
  clip: rect(0, 0, 0, 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  white-space: nowrap;
  width: 1px;
  /* 1 */
}

/*
 * Extends the .visually-hidden class to allow the element
 * to be focusable when navigated to via the keyboard:
 * https://www.drupal.org/node/897638
 */

.visually-hidden.focusable:active,
.visually-hidden.focusable:focus {
  clip: auto;
  height: auto;
  margin: 0;
  overflow: visible;
  position: static;
  white-space: inherit;
  width: auto;
}

/*
 * Hide visually and from screen readers, but maintain layout
 */

.invisible {
  visibility: hidden;
}

/*
 * Clearfix: contain floats
 *
 * The use of `table` rather than `block` is only necessary if using
 * `::before` to contain the top-margins of child elements.
 */

.clearfix::before,
.clearfix::after {
  content: "";
  display: table;
}

.clearfix::after {
  clear: both;
}

/* ==========================================================================
   EXAMPLE Media Queries for Responsive Design.
   These examples override the primary ('mobile first') styles.
   Modify as content requires.
   ========================================================================== */

@media only screen and (min-width: 35em) {
  /* Style adjustments for viewports that meet the condition */
}

@media print,
  (-webkit-min-device-pixel-ratio: 1.25),
  (min-resolution: 1.25dppx),
  (min-resolution: 120dpi) {
  /* Style adjustments for high resolution devices */
}

/* ==========================================================================
   Print styles.
   Inlined to avoid the additional HTTP request:
   https://www.phpied.com/delay-loading-your-print-css/
   ========================================================================== */

@media print {
  *,
  *::before,
  *::after {
    background: #fff !important;
    color: #000 !important;
    /* Black prints faster */
    box-shadow: none !important;
    text-shadow: none !important;
  }

  a,
  a:visited {
    text-decoration: underline;
  }

  a[href]::after {
    content: " (" attr(href) ")";
  }

  abbr[title]::after {
    content: " (" attr(title) ")";
  }

  /*
   * Don't show links that are fragment identifiers,
   * or use the `javascript:` pseudo protocol
   */
  a[href^="#"]::after,
  a[href^="javascript:"]::after {
    content: "";
  }

  pre {
    white-space: pre-wrap !important;
  }

  pre,
  blockquote {
    border: 1px solid #999;
    page-break-inside: avoid;
  }

  tr,
  img {
    page-break-inside: avoid;
  }

  p,
  h2,
  h3 {
    orphans: 3;
    widows: 3;
  }

  h2,
  h3 {
    page-break-after: avoid;
  }
}

