﻿@charset "UTF-8";
body, button, input, select, option, textarea {
  font-family: "Zen Maru Gothic", sans-serif;
	font-style: normal;
}
.font_sans {
	font-family: 'Noto Sans JP', sans-serif;
	font-optical-sizing: auto;
	font-style: normal;
}

/*
.font_serif {
	font-family: 'Shippori Mincho', serif;
}
*/

/*
Noto Sans Japanese
Regular 400

Zen Maru Gothic
Regular 400
Medium 500
Bold 700
*/

/*----------------------------------------------------
	Structure Module
----------------------------------------------------*/
html {
  /* overflow-y: scroll; */
}

body {
  margin: 0;
  padding: 0;
  color: #333333;
  /* text-align: center; */
  line-height: 1.65;
  letter-spacing: 1px;
  word-break: break-all;
  -ms-word-break: break-all;
  word-wrap: break-word;
  -webkit-text-size-adjust: 100%;

	text-align: justify;
	text-justify: inter-ideograph;
	text-justify: inter-character;

	font-feature-settings: "palt" 1;
}

/*----------------------------------------------------
	Headings Module
----------------------------------------------------*/
h1, h2, h3, h4, h5, h6 {
  margin: 0;
  padding: 0;
}

/*----------------------------------------------------
	Phrasing Module
----------------------------------------------------*/
p {
  margin: 0;
  padding: 0;
}

cite, dfn, address, i, em {
  font-style: normal;
}

strong, em, b {
  font-weight: normal;
}

u {
  text-decoration: none;
}

abbr {
  border: 0 none;
}

mark {
  background-color: transparent;
}

q {
  quotes: none;
}

button {
  text-align: left;
  cursor: pointer;
}

input:focus, button:focus, select:focus, textarea:focus {
  outline: none;
}

/*----------------------------------------------------
	Hypertext Module
----------------------------------------------------*/
a {
  outline: none;
  text-decoration: none;
  -webkit-tap-highlight-color: rgba(152, 152, 152, .3);
}

a:link,
a:visited {
  color: #ff0000;
}

a:hover {
  text-decoration: underline;
}

a:active,
a:focus {
  background-color: transparent;
}

/*----------------------------------------------------
	Image Module
----------------------------------------------------*/
img {
  border: 0;
  vertical-align: bottom;
}

/*----------------------------------------------------
	Embedded Module
----------------------------------------------------*/
object, embed {
  outline: none;
}

/*----------------------------------------------------
	List Module
----------------------------------------------------*/
ul, ol, dl, dt, dd, li {
  margin: 0;
  padding: 0;
}

ul li {
  list-style: none;
}

ol li {
  list-style: none;
}

/*----------------------------------------------------
	Table Module
----------------------------------------------------*/
table {
  border-collapse: separate;
  border-spacing: 0;
}

th, td {
  font-weight: normal;
  vertical-align: top;
  text-align: left;
}

/*----------------------------------------------------
	Forms Module
----------------------------------------------------*/
form, button, input, select, option, textarea {
  margin: 0;
  padding: 0;
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
}

textarea {
  width: 350px;
}

input {
  border: 0 none;
  border-radius: 0px;
}

button {
  background: none;
  border: 0 none;
  overflow: visible;
}

/*----------------------------------------------------
	HTML5 Reset
----------------------------------------------------*/
article, aside, figure, figcaption, dialog, details,
footer, header, menu, main, nav, section, summary {
  display: block;
}

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, dialog, figure, footer, header,
menu, nav, section,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
}

/*
*  大阪市教員採用イベント情報
*  ---------------------------------------------------
*  BaseFont
*  Optimization
*  BaseColor
*  Animation
*  ---------------------------------------------------
*  Z-Index
*  ---------------------------------------------------
*  layout[ALL]
*    html
*    Body
*    Wrapper
*    Header
*    Container/Content
*    Footer

//PCファースト
*  --------------------------------------------------
*  Media Queries for window size under 1280px
*  --------------------------------------------------
*  Media Queries for window size under 767px
*  --------------------------------------------------
*/




/*==================================================

  Optimization

====================================================*/
/*  html
--------------------------*/
html {
  font-size: 62.5%; /* 10px */
}


/*  Body
--------------------------*/
body,
body *,
body *::before,
body *::after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

body {
  letter-spacing: 0px;
}

button, input, select, option, textarea {
  border: 0 none;
  letter-spacing: 0px;
  border-radius: 0px;
  background-color: transparent;
  -webkit-appearance: none;
  -moz-appearance: none;
  -ms-appearance: none;
  -o-appearance: none;
  appearance: none;
}
button:disabled, input:disabled, select:disabled, option:disabled, textarea:disabled {
  background-color: transparent;
}

select::-ms-expand {
  display: none;
}

textarea {
  resize: none;
  vertical-align: bottom;
}

img {
  -webkit-touch-callout: none;
	vertical-align: top;
	max-width: 100%;
	height: auto;
}

a:hover {
  text-decoration: none;
}

i {
}

h1, h2, h3, h4 {
  font-size: 100%;
  font-weight: 400;
}

table {
  border-collapse: collapse;
}

/*==================================================

  BaseColor

====================================================*/
/* テキスト
--------------------------*/
body {
  color: #000;
  width: 100%;
}

button, input, select, option, textarea {
  color: #fff;
}

input:-moz-placeholder {
  color: #bbbbbb;
}
input::-webkit-input-placeholder {
  color: #bbbbbb;
}

textarea:-moz-placeholder {
  color: #bbbbbb;
}
textarea::-webkit-input-placeholder {
  color: #bbbbbb;
}

/* リンク
--------------------------*/
a:link,
a:visited {
  color: #000;
}

/*==================================================

  Animation

====================================================*/
@keyframes anim_opct0-1 {
	0% {opacity: 0;}
	100% {opacity: 1;}
}
/*==================================================

  Z-Index

====================================================*/

/*==================================================

  layout[ALL]

====================================================*/
.pc {
	display: inline;
}
.sp {
	display: none;
}


.event_disable {
	pointer-events: none;
	user-select: none;
}
.opct_0 {
	opacity: 0;
}
a:hover {
	transition: opacity 300ms ease 0s;
}
.fadein {
	opacity: 0;
	transform: translateY(20rem);
}
.fadein.view {
	opacity: 1;
	transform: translateY(0);
	transition: all 1200ms ease 500ms;
}
.fadein_2 {
	opacity: 0;
	transform: translateY(20rem);
}
.fadein_2.view {
	opacity: 1;
	transform: translateY(0);
	transition: all 1200ms ease 800ms;
}
.fadein_3 {
	opacity: 0;
	transform: translateY(20rem);
}
.fadein_3.view {
	opacity: 1;
	transform: translateY(0);
	transition: all 1200ms ease 1000ms;
}
/*  Html
--------------------------*/
html {
	font-size: 1px;
	scroll-behavior: smooth;
}
/*  Body
--------------------------*/
body {
	background-color: #fff;
}
body:has(.modal) {
	overflow: hidden;
}

/*  Wrapper
--------------------------*/
#wrapper {
	background-color: #f9dfe2;
}
#container {
	inline-size: 768rem;
	margin-inline: auto;
	background-color: #fdf1f3;
}
#pc_header {
	background-color: #fff;
	padding-block-start: 22rem;
	padding-block-end: 16rem;
	padding-inline-start: 23rem;
}
#pc_header .headr_txt {
}
#pc_header .headr_txt > span {
	display: block;
	line-height: 1;
}
#pc_header .headr_txt .ja {
	font-size: 30.7rem;
	font-weight: 700;
	letter-spacing: .05em;
}
#pc_header .headr_txt .en {
	font-size: 26.6rem;
	padding-block-start: 7rem;
	letter-spacing: .1em;
}

/*  main
--------------------------*/
#main {
	block-size: 472rem;
	background-image: url(../img/mainv.webp);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}
#site_name {
	text-align: center;
	color: #fff;
}
#site_name > span {
	display: block;
	font-weight: 700;
	letter-spacing: .1em;
}
#site_name .ja {
	font-size: 67.5rem;
	line-height: 1.3;
	padding-block-start: 115rem;
}
#site_name .en {
	font-size: 43rem;
	line-height: 1;
	padding-block-start: 10rem;
}

/*  about
--------------------------*/
#about {
	text-align: center;
}
#about .sec_ttl {
	font-size: 34.8rem;
	font-weight: 700;
	color: #ec759e;
	line-height: 1.7;
	letter-spacing: .05em;
	padding-block-start: 46rem;
}
#about .parag {
	font-size: 28.6rem;
	line-height: 1.57;
	letter-spacing: .1em;
	font-weight: 500;
	padding-block-start: 20rem;
}
#about_slide {
	padding-block-start: 32rem;
	inline-size: 565rem;
	margin-inline: auto;
}
#about_slide .slider img {
	cursor: pointer;
}
#about_slide .slick-dots {
	display: flex;
	flex-flow: row wrap;
	justify-content: center;
	align-items: center;
	padding-block-start: 25rem;
}
#about_slide .slick-dots > li {
	padding-inline: 18rem;
}
#about_slide .slick-dots > li button {
	inline-size: 16rem;
	block-size: 16rem;
	border-radius: 50%;
	background-color: #f4acc5;
	overflow: hidden;
	text-indent: 100%;
	cursor: pointer;
}
#about_slide .slick-dots > li.slick-active button {
	background-color: #ec759e;
	cursor: default;
}




/*  page_anchor
--------------------------*/
#page_anchor {
	padding-block-start: 85rem;
}
#page_anchor > li {
	padding-block: 13rem;
}
#page_anchor a {
	display: block;
	inline-size: 645rem;
	block-size: 106rem;
	position: relative;
	margin-inline: auto;
}
#page_anchor a::before {
	content: "";
	display: block;
	inline-size: 638rem;
	block-size: 100rem;
	background-color: #dfb6c0;
	border-radius: 12rem;

	position: absolute;
	inset-inline-end: 0;
	inset-block-end: 0;
}
#page_anchor .front {
	display: flex;
	flex-flow: row wrap;
	justify-content: space-between;
	align-items: center;

	inline-size: 638rem;
	block-size: 100rem;
	border-radius: 12rem;
	padding-inline: 40rem 24rem;

	font-size: 57.3rem;
	line-height: 1;
	font-weight: 700;
	color: #fff;
	letter-spacing: .1em;

	position: absolute;
	inset-inline-start: 0;
	inset-block-start: 0;
}
#page_anchor .hiroba .front {
	background-color: #ec759e;
}
#page_anchor .sq .front {
	background-color: #65c4d4;
}
#page_anchor .setsumei .front {
	background-color: #6fb989;
}
#page_anchor .arw {
	display: block;
	inline-size: 74rem;
}
#page_anchor a:hover .front {
	inset-inline-start: auto;
	inset-inline-end: 0;
	inset-block-start: auto;
	inset-block-end: 0;
}






/*  hiroba
--------------------------*/
#hiroba {
	padding-block-start: 110rem;
}
#hiroba .cont_wrap {
	inline-size: 646rem;
	margin-inline: auto;
	background-color: #fff;
	border: 8rem solid #ec759e;
	box-shadow: 12rem 12rem 0 0 #dfb6c0;
	padding-block-end: 110rem;
}
#hiroba .sec_image {
}
#hiroba .sec_ttl {
	color: #ec759e;
	font-size: 49rem;
	font-weight: 700;
	line-height: 1;
	letter-spacing: .05em;
	text-align: center;
	padding-block-start: 74rem;
}
#hiroba .sec_exp {
	inline-size: 564rem;
	margin-inline: auto;
	font-size: 24.5rem;
	line-height: 1.75;
	font-weight: 500;
	letter-spacing: .03em;
	padding-block-start: 30rem;
}

#hiroba_anc {
	padding-block-start: 90rem;
}
#hiroba_anc .art_ttl {
	inline-size: 568rem;
	margin-inline: auto;
	color: #ec759e;
	font-size: 40rem;
	font-weight: 700;
	text-align: center;
	line-height: 1;
	letter-spacing: .05em;
	background-image: url(../img/hiroba_line.webp);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: contain;
	padding-block-end: 25rem;
}
#hiroba_anc .anc_list {
	padding-block-start: 30rem;
}
#hiroba_anc .anc_list > li {
	padding-block: 15rem;
}
#hiroba_anc .item {
	background-color: #fdf1f3;
	border-radius: 14rem;
	inline-size: 563rem;
	margin-inline: auto;
	padding-block-end: 30rem;
}
#hiroba_anc .req {
	text-align: center;
	font-size: 28.6rem;
	font-weight: 500;
	line-height: 1.5;
	padding-block-start: 25rem;
	padding-block-end: 15rem;
}
#hiroba_anc .item a {
	display: block;
	inline-size: 510rem;
	block-size: 60rem;
	position: relative;
	margin-inline: auto;
}
#hiroba_anc .item a::before {
	content: "";
	display: block;
	inline-size: 503rem;
	block-size: 53rem;
	position: absolute;
	inset-inline-end: 0;
	inset-block-end: 0;
	background-color: #dfb6c0;
	border-radius: 8rem;
}
#hiroba_anc .item .front {
	color: #fff;
	font-size: 30rem;
	font-weight: 700;
	line-height: 1;
	background-color: #ec759e;
	border-radius: 8rem;
	display: flex;
	flex-flow: row wrap;
	justify-content: center;
	align-items: center;
	inline-size: 503rem;
	block-size: 53rem;
	position: absolute;
	inset-inline-start: 0;
	inset-block-start: 0;
}
#hiroba_anc .item a:hover .front {
	inset: auto 0 0 auto;
}
#hiroba_anc .item .arw {
	inline-size: 42rem;
	position: absolute;
	inset-inline-end: 8rem;
	inset-block-start: 5rem;
}

#hiroba_sch {
	padding-block-start: 95rem;
}
#hiroba_sch .art_ttl {
	inline-size: 568rem;
	margin-inline: auto;
	color: #ec759e;
	font-size: 40rem;
	font-weight: 700;
	text-align: center;
	line-height: 1;
	letter-spacing: .05em;
	background-image: url(../img/hiroba_line.webp);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: contain;
	padding-block-end: 25rem;
}
#hiroba_sch .sch_list {
	padding-block-start: 20rem;
}
#hiroba_sch .year {
	font-size: 30rem;
	font-weight: 500;
	line-height: 1;
	letter-spacing: .1em;
	padding-inline-start: 67rem;
	padding-block-start: 20rem;
}
#hiroba_sch .item {
	display: flex;
	flex-flow: row wrap;
	justify-content: flex-start;
	align-items: center;
	font-size: 28.6rem;
	line-height: 1;
	font-weight: 500;
	letter-spacing: .1em;
	padding-inline-start: 48rem;
	padding-block: 7rem;
}
#hiroba_sch .item dt {
	color: #ec759e;
}
#hiroba_sch .item dd {
}


#hiroba_cont {
	padding-block-start: 110rem;
}
#hiroba_cont .art_ttl {
	inline-size: 568rem;
	margin-inline: auto;
	color: #ec759e;
	font-size: 40rem;
	font-weight: 700;
	text-align: center;
	line-height: 1;
	letter-spacing: .05em;
	background-image: url(../img/hiroba_line.webp);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: contain;
	padding-block-end: 25rem;
}

#cont_minna {
	padding-block-start: 60rem;
}
#cont_minna .art_image {
	inline-size: 564rem;
	margin-inline: auto;
}
#cont_minna .cont_ttl {
	text-align: center;
	font-size: 40rem;
	font-weight: 700;
	line-height: 1;
	letter-spacing: .1em;
	padding-block-start: 80rem;
}
#cont_minna .theme {
	inline-size: 147rem;
	block-size: 47rem;
	background-color: #ec759e;
	margin-inline-start: 34rem;
	margin-block-start: 40rem;
	color: #fff;
	line-height: 47rem;
	font-size: 32.7rem;
	font-weight: 700;
	text-align: center;
}
#cont_minna .cont_dfl {
	font-weight: 500;
}
#cont_minna .cont_dfl dt {
	line-height: 1;
}
#cont_minna .cont_dfl dt .num {
	display: block;
	color: #ec759e;
	font-size: 28.6rem;
	letter-spacing: .1em;
	padding-inline-start: 15rem;
	padding-block-start: 45rem;
}
#cont_minna .cont_dfl dt .main {
	display: block;
	font-size: 28.6rem;
	padding-inline-start: 30rem;
	padding-block-start: 15rem;
}
#cont_minna .cont_dfl dt .sub {
	display: block;
	font-size: 26rem;
	padding-inline-start: 30rem;
	padding-block-start: 15rem;
}
#cont_minna .cont_dfl dd {
	font-size: 22.5rem;
	line-height: 1.45;
	padding-inline-start: 30rem;
	padding-inline-end: 30rem;
	padding-block-start: 20rem;
	letter-spacing: .1em;
}
#cont_minna .voice {
}
#cont_minna .voice dt {
	inline-size: 208rem;
	block-size: 47rem;
	background-color: #ec759e;
	margin-inline: auto;
	margin-block-start: 80rem;
	color: #fff;
	line-height: 43rem;
	font-size: 32.7rem;
	font-weight: 700;
	letter-spacing: .1em;
	text-align: center;
}
#cont_minna .voice dd {
	inline-size: 563rem;
	margin-inline: auto;
	background-color: #fdf1f3;
	border-radius: 22rem;
	position: relative;
	padding: 40rem;
	font-size: 22.5rem;
	line-height: 1.45;
	letter-spacing: .1em;

	margin-block-start: 40rem;
}
#cont_minna .voice dd::before {
	content: "";
	display: block;
	background-image: url(../img/hiroba_bubble_p.webp);
	inline-size: 33rem;
	block-size: 37rem;
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;

	position: absolute;
	inset-inline-end: 74rem;
	inset-block-end: -20rem;
}
#cont_zadan {
	padding-block-start: 110rem;
}
#cont_zadan .inner {
	background-color: #fdf1f3;
	padding-block-end: 75rem;
}
#cont_zadan .cont_ttl {
	text-align: center;
	font-size: 40rem;
	font-weight: 700;
	line-height: 1;
	padding-block-start: 40rem;
	letter-spacing: .1em;
}
#cont_zadan .art_image {
	inline-size: 564rem;
	margin-inline: auto;
	padding-block-start: 30rem;
}

#cont_zadan .voice {
}
#cont_zadan .voice dt {
	inline-size: 208rem;
	block-size: 47rem;
	background-color: #ec759e;
	margin-inline: auto;
	margin-block-start: 80rem;
	color: #fff;
	line-height: 43rem;
	font-size: 32.7rem;
	font-weight: 700;
	letter-spacing: .1em;
	text-align: center;
}
#cont_zadan .voice dd {
	inline-size: 563rem;
	margin-inline: auto;
	background-color: #fff;
	border-radius: 22rem;
	position: relative;
	padding: 40rem;
	font-size: 22.5rem;
	line-height: 1.45;
	letter-spacing: .1em;

	margin-block-start: 40rem;
}
#cont_zadan .voice dd::before {
	content: "";
	display: block;
	background-image: url(../img/hiroba_bubble_w.webp);
	inline-size: 33rem;
	block-size: 37rem;
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;

	position: absolute;
	inset-inline-end: 74rem;
	inset-block-end: -20rem;
}

#cont_kobetsu {
	padding-block-start: 80rem;
}
#cont_kobetsu .cont_ttl {
	text-align: center;
	font-size: 40rem;
	font-weight: 700;
	line-height: 1;
	padding-block-start: 30rem;
	letter-spacing: .1em;
}
#cont_kobetsu .art_image {
	inline-size: 564rem;
	margin-inline: auto;
	padding-block-start: 30rem;
}

#cont_kobetsu .voice {
}
#cont_kobetsu .voice dt {
	inline-size: 208rem;
	block-size: 47rem;
	background-color: #ec759e;
	margin-inline: auto;
	margin-block-start: 80rem;
	color: #fff;
	line-height: 43rem;
	font-size: 32.7rem;
	font-weight: 700;
	letter-spacing: .1em;
	text-align: center;
}
#cont_kobetsu .voice dd {
	inline-size: 563rem;
	margin-inline: auto;
	background-color: #fdf1f3;
	border-radius: 22rem;
	position: relative;
	padding: 40rem;
	font-size: 22.5rem;
	line-height: 1.45;
	letter-spacing: .1em;

	margin-block-start: 40rem;
}
#cont_kobetsu .voice dd::before {
	content: "";
	display: block;
	background-image: url(../img/hiroba_bubble_p.webp);
	inline-size: 33rem;
	block-size: 37rem;
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;

	position: absolute;
	inset-inline-end: 74rem;
	inset-block-end: -20rem;
}

#hiroba_place {
	padding-block-start: 110rem;
}
#hiroba_place .art_ttl {
	inline-size: 568rem;
	margin-inline: auto;
	color: #ec759e;
	font-size: 40rem;
	font-weight: 700;
	text-align: center;
	line-height: 1;
	letter-spacing: .05em;
	background-image: url(../img/hiroba_line.webp);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: contain;
	padding-block-end: 25rem;
}
#hiroba_place .place_dfl {
	padding-inline-start: 60rem;
}
#hiroba_place .place_dfl dt {
	font-size: 30rem;
	font-weight: 500;
	line-height: 1;
	letter-spacing: .1em;
	padding-block-start: 45rem;
}
#hiroba_place .place_dfl dd {
	font-size: 26rem;
	font-weight: 500;
	line-height: 1.3;
	letter-spacing: .1em;
	padding-block-start: 10rem;
}

#hiroba_place .btn_gmap {
	padding-block-start: 23rem;
}
#hiroba_place .btn_gmap a {
	display: block;
	inline-size: 510rem;
	block-size: 60rem;
	position: relative;
	margin-inline: auto;
}
#hiroba_place .btn_gmap a::before {
	content: "";
	display: block;
	inline-size: 503rem;
	block-size: 53rem;
	position: absolute;
	inset-inline-end: 0;
	inset-block-end: 0;
	background-color: #dfb6c0;
	border-radius: 8rem;
}
#hiroba_place .btn_gmap .front {
	color: #fff;
	font-size: 32.7rem;
	font-weight: 700;
	line-height: 1;
	background-color: #ec759e;
	border-radius: 8rem;
	display: flex;
	flex-flow: row wrap;
	justify-content: flex-start;
	align-items: center;
	inline-size: 503rem;
	block-size: 53rem;
	padding-inline-start: 42rem;
	position: absolute;
	inset-inline-start: 0;
	inset-block-start: 0;
}
#hiroba_place .btn_gmap a:hover .front {
	inset: auto 0 0 auto;
}
#hiroba_place .btn_gmap .arw {
	inline-size: 42rem;
	position: absolute;
	inset-inline-end: 8rem;
	inset-block-start: 5rem;
}

#hiroba_yoyaku {
	padding-block-start: 85rem;
}
#hiroba_yoyaku .art_ttl {
	inline-size: 568rem;
	margin-inline: auto;
	color: #ec759e;
	font-size: 40rem;
	font-weight: 700;
	text-align: center;
	line-height: 1;
	letter-spacing: .05em;
	background-image: url(../img/hiroba_line.webp);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: contain;
	padding-block-end: 25rem;
}
#hiroba_yoyaku .exp {
	font-size: 30rem;
	font-weight: 500;
	line-height: 1;
	letter-spacing: .1em;
	padding-block-start: 30rem;
	text-align: center;
}

#hiroba_yoyaku .btn_yoyaku {
	padding-block-start: 26rem;
}
#hiroba_yoyaku .btn_yoyaku a {
	display: block;
	inline-size: 570rem;
	block-size: 107rem;
	position: relative;
	margin-inline: auto;
}
#hiroba_yoyaku .btn_yoyaku a::before {
	content: "";
	display: block;
	inline-size: 563rem;
	block-size: 100rem;
	position: absolute;
	inset-inline-end: 0;
	inset-block-end: 0;
	background-color: #dfb6c0;
	border-radius: 12rem;
}
#hiroba_yoyaku .btn_yoyaku .front {
	color: #ec759e;
	font-size: 34.8rem;
	font-weight: 700;
	line-height: 1;
	background-color: #fee495;
	border-radius: 12rem;
	display: flex;
	flex-flow: row wrap;
	justify-content: flex-start;
	align-items: center;
	inline-size: 563rem;
	block-size: 100rem;
	padding-inline-start: 72rem;
	position: absolute;
	inset-inline-start: 0;
	inset-block-start: 0;
}
#hiroba_yoyaku .btn_yoyaku a:hover .front {
	inset: auto 0 0 auto;
}
#hiroba_yoyaku .btn_yoyaku .arw {
	inline-size: 75rem;
	position: absolute;
	inset-inline-end: 10rem;
	inset-block-start: 13rem;
}















/*  sq
--------------------------*/
#sq {
	padding-block-start: 110rem;
}
#sq .cont_wrap {
	inline-size: 645rem;
	margin-inline: auto;
	background-color: #fff;
	border: 8rem solid #65c4d4;
	box-shadow: 12rem 12rem 0 0 #dfb6c0;
	padding-block-end: 100rem;
}
#sq .sec_image {
}
#sq .sec_ttl {
	color: #65c4d4;
	font-size: 49rem;
	font-weight: 700;
	line-height: 1;
	letter-spacing: .05em;
	text-align: center;
	padding-block-start: 74rem;
}
#sq .sec_exp {
	inline-size: 564rem;
	margin-inline: auto;
	font-size: 24.5rem;
	line-height: 1.75;
	font-weight: 500;
	letter-spacing: .03em;
	padding-block-start: 30rem;
}

#sq_can {
	padding-block-start: 80rem;
}
#sq_can .art_ttl {
	inline-size: 568rem;
	margin-inline: auto;
	color: #65c4d4;
	font-size: 40rem;
	font-weight: 700;
	text-align: center;
	line-height: 1.25;
	letter-spacing: .05em;
	background-image: url(../img/sq_line.webp);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: contain;
	padding-block-end: 25rem;
}
#sq_can .can_exp_1 {
	inline-size: 564rem;
	margin-inline: auto;
	font-size: 24.5rem;
	font-weight: 500;
	letter-spacing: .1em;
	padding-block-start: 25rem;
}
#sq_can .can_exp_2 {
	inline-size: 564rem;
	margin-inline: auto;
	font-size: 22.5rem;
	font-weight: 500;
	letter-spacing: .1em;
	padding-block-start: 5rem;
}

#sq_sch {
	padding-block-start: 80rem;
}
#sq_sch .art_ttl {
	inline-size: 568rem;
	margin-inline: auto;
	color: #65c4d4;
	font-size: 40rem;
	font-weight: 700;
	text-align: center;
	line-height: 1.25;
	letter-spacing: .05em;
	background-image: url(../img/sq_line.webp);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: contain;
	padding-block-end: 25rem;
}
#sq_sch .sch_exp {
	text-align: center;
	font-size: 30rem;
	font-weight: 500;
	letter-spacing: .1em;
	padding-block-start: 30rem;
}

#sq_cont {
	padding-block-start: 80rem;
}
#sq_cont .art_ttl {
	inline-size: 568rem;
	margin-inline: auto;
	color: #65c4d4;
	font-size: 40rem;
	font-weight: 700;
	text-align: center;
	line-height: 1.25;
	letter-spacing: .05em;
	background-image: url(../img/sq_line.webp);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: contain;
	padding-block-end: 25rem;
}

#sq_slide {
	padding-block-start: 60rem;
	inline-size: 565rem;
	margin-inline: auto;
}
#sq_slide .slider img {
	cursor: pointer;
}
#sq_slide .slick-dots {
	display: flex;
	flex-flow: row wrap;
	justify-content: center;
	align-items: center;
	padding-block-start: 25rem;
}
#sq_slide .slick-dots > li {
	padding-inline: 18rem;
}
#sq_slide .slick-dots > li button {
	inline-size: 16rem;
	block-size: 16rem;
	border-radius: 50%;
	background-color: #b2e1e9;
	overflow: hidden;
	text-indent: 100%;
	cursor: pointer;
}
#sq_slide .slick-dots > li.slick-active button {
	background-color: #65c4d4;
	cursor: default;
}
#sq_slide .sq_slide_exp {
	font-size: 22.5rem;
	font-weight: 500;
	letter-spacing: .1em;
	padding-block-start: 30rem;
}




#sq_cont .theme {
	inline-size: 147rem;
	block-size: 47rem;
	background-color: #65c4d4;
	margin-inline: auto;
	margin-block-start: 100rem;
	color: #fff;
	line-height: 47rem;
	font-size: 32.7rem;
	font-weight: 700;
	text-align: center;
}




#sq_cont .cont_dfl {
	font-weight: 500;
	padding-inline-start: 30rem;
}
#sq_cont .cont_dfl dt {
	line-height: 1.47;
	color: #65c4d4;
	font-size: 28.6rem;
	letter-spacing: .1em;
	padding-block-start: 45rem;
}
#sq_cont .cont_dfl dd {
	font-size: 22.5rem;
	line-height: 1.45;
	padding-inline-end: 30rem;
	padding-block-start: 10rem;
	letter-spacing: .1em;
}




#sq_cont .voice {
}
#sq_cont .voice dt {
	inline-size: 208rem;
	block-size: 47rem;
	background-color: #65c4d4;
	margin-inline: auto;
	margin-block-start: 90rem;
	color: #fff;
	line-height: 43rem;
	font-size: 32.7rem;
	font-weight: 700;
	letter-spacing: .1em;
	text-align: center;
}
#sq_cont .voice dd {
	inline-size: 563rem;
	margin-inline: auto;
	background-color: #b2e1e9;
	border-radius: 22rem;
	position: relative;
	padding: 40rem;
	font-size: 22.5rem;
	line-height: 1.45;
	letter-spacing: .1em;

	margin-block-start: 40rem;
}
#sq_cont .voice dd::before {
	content: "";
	display: block;
	background-image: url(../img/sq_bubble.webp);
	inline-size: 33rem;
	block-size: 37rem;
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;

	position: absolute;
	inset-inline-end: 74rem;
	inset-block-end: -20rem;
}




#sq_time-sch {
	padding-block-start: 110rem;
}
#sq_time-sch .art_ttl {
	inline-size: 568rem;
	margin-inline: auto;
	color: #65c4d4;
	font-size: 40rem;
	font-weight: 700;
	text-align: center;
	line-height: 1;
	letter-spacing: .05em;
	background-image: url(../img/sq_line.webp);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: contain;
	padding-block-end: 25rem;
}

#sq_time-sch .btn_time-sch {
	padding-block-start: 23rem;
}
#sq_time-sch .btn_time-sch a {
	display: block;
	inline-size: 510rem;
	block-size: 60rem;
	position: relative;
	margin-inline: auto;
}
#sq_time-sch .btn_time-sch a::before {
	content: "";
	display: block;
	inline-size: 503rem;
	block-size: 53rem;
	position: absolute;
	inset-inline-end: 0;
	inset-block-end: 0;
	background-color: #dfb6c0;
	border-radius: 8rem;
}
#sq_time-sch .btn_time-sch .front {
	color: #fff;
	font-size: 32.7rem;
	font-weight: 700;
	line-height: 1;
	background-color: #65c4d4;
	border-radius: 8rem;
	display: flex;
	flex-flow: row wrap;
	justify-content: flex-start;
	align-items: center;
	inline-size: 503rem;
	block-size: 53rem;
	padding-inline-start: 16rem;
	position: absolute;
	inset-inline-start: 0;
	inset-block-start: 0;
}
#sq_time-sch .btn_time-sch a:hover .front {
	inset: auto 0 0 auto;
}
#sq_time-sch .btn_time-sch .arw {
	inline-size: 42rem;
	position: absolute;
	inset-inline-end: 8rem;
	inset-block-start: 5rem;
}






#sq_place {
	padding-block-start: 110rem;
}
#sq_place .art_ttl {
	inline-size: 568rem;
	margin-inline: auto;
	color: #65c4d4;
	font-size: 40rem;
	font-weight: 700;
	text-align: center;
	line-height: 1;
	letter-spacing: .05em;
	background-image: url(../img/sq_line.webp);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: contain;
	padding-block-end: 25rem;
}
#sq_place .place_dfl {
	padding-inline-start: 60rem;
}
#sq_place .place_dfl dt {
	font-size: 30rem;
	font-weight: 500;
	line-height: 1;
	letter-spacing: .1em;
	padding-block-start: 45rem;
}
#sq_place .place_dfl dd {
	font-size: 26rem;
	font-weight: 500;
	line-height: 1.3;
	letter-spacing: .1em;
	padding-block-start: 10rem;
}

#sq_place .btn_gmap {
	padding-block-start: 23rem;
}
#sq_place .btn_gmap a {
	display: block;
	inline-size: 510rem;
	block-size: 60rem;
	position: relative;
	margin-inline: auto;
}
#sq_place .btn_gmap a::before {
	content: "";
	display: block;
	inline-size: 503rem;
	block-size: 53rem;
	position: absolute;
	inset-inline-end: 0;
	inset-block-end: 0;
	background-color: #dfb6c0;
	border-radius: 8rem;
}
#sq_place .btn_gmap .front {
	color: #fff;
	font-size: 32.7rem;
	font-weight: 700;
	line-height: 1;
	background-color: #65c4d4;
	border-radius: 8rem;
	display: flex;
	flex-flow: row wrap;
	justify-content: flex-start;
	align-items: center;
	inline-size: 503rem;
	block-size: 53rem;
	padding-inline-start: 52rem;
	position: absolute;
	inset-inline-start: 0;
	inset-block-start: 0;
}
#sq_place .btn_gmap a:hover .front {
	inset: auto 0 0 auto;
}
#sq_place .btn_gmap .arw {
	inline-size: 42rem;
	position: absolute;
	inset-inline-end: 8rem;
	inset-block-start: 5rem;
}

#sq_yoyaku {
	padding-block-start: 85rem;
}
#sq_yoyaku .art_ttl {
	inline-size: 568rem;
	margin-inline: auto;
	color: #65c4d4;
	font-size: 40rem;
	font-weight: 700;
	text-align: center;
	line-height: 1;
	letter-spacing: .05em;
	background-image: url(../img/sq_line.webp);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: contain;
	padding-block-end: 25rem;
}
#sq_yoyaku .exp {
	font-size: 24.5rem;
	font-weight: 500;
	line-height: 1;
	letter-spacing: .1em;
	padding-block-start: 30rem;
	text-align: center;
}

#sq_yoyaku .btn_yoyaku {
	padding-block-start: 26rem;
}
#sq_yoyaku .btn_yoyaku a {
	display: block;
	inline-size: 570rem;
	block-size: 107rem;
	position: relative;
	margin-inline: auto;
}
#sq_yoyaku .btn_yoyaku a::before {
	content: "";
	display: block;
	inline-size: 563rem;
	block-size: 100rem;
	position: absolute;
	inset-inline-end: 0;
	inset-block-end: 0;
	background-color: #dfb6c0;
	border-radius: 12rem;
}

#sq_yoyaku .btn_yoyaku .front {
	text-align: center;
	color: #65c4d4;
	font-size: 34.8rem;
	font-weight: 700;
	line-height: 1.25;
	letter-spacing: .1em;
	background-color: #fee495;
	border-radius: 12rem;
	display: flex;
	flex-flow: row wrap;
	justify-content: center;
	align-items: center;

	inline-size: 563rem;
	block-size: 100rem;

	position: absolute;
	inset-inline-start: 0;
	inset-block-start: 0;
}
#sq_yoyaku .btn_yoyaku a:hover .front {
	inset: auto 0 0 auto;
}
#sq_yoyaku .btn_yoyaku .arw {
	inline-size: 75rem;
	position: absolute;
	inset-inline-end: 10rem;
	inset-block-start: 13rem;
}
#sq_yoyaku .btn_yoyaku.soon a::after {
	content: "coming soon";
	display: block;
	inline-size: 563rem;
	block-size: 100rem;
	font-size: 40rem;
	font-weight: 700;
	color: #fff;
	text-align: center;
	letter-spacing: .1em;
	padding-block-start: 11rem;
	position: absolute;
	inset-inline-start: 0;
	inset-block-start: 0;
	background-color: rgba(148, 63, 108, .6);
	border-radius: 12rem;
}
#sq_yoyaku .btn_yoyaku.soon a:hover .front {
	inset: 0 auto auto 0;
}
#sq_yoyaku .comment {
	inline-size: 564rem;
	margin-inline: auto;
	font-size: 22.5rem;
	font-weight: 500;
	letter-spacing: .1em;
	padding-block-start: 15rem;
}















/*  setsumei
--------------------------*/
#setsumei {
	padding-block-start: 110rem;
}
#setsumei .cont_wrap {
	inline-size: 645rem;
	margin-inline: auto;
	background-color: #fff;
	border: 8rem solid #6fb989;
	box-shadow: 12rem 12rem 0 0 #dfb6c0;
	padding-block-end: 100rem;
}
#setsumei .sec_image {
}
#setsumei .sec_ttl {
	color: #6fb989;
	font-size: 49rem;
	font-weight: 700;
	line-height: 1;
	letter-spacing: .05em;
	text-align: center;
	padding-block-start: 74rem;
}
#setsumei .sec_exp {
	inline-size: 564rem;
	margin-inline: auto;
	font-size: 24.5rem;
	line-height: 1.75;
	font-weight: 500;
	letter-spacing: .03em;
	padding-block-start: 30rem;
}

#setsumei_can {
	padding-block-start: 80rem;
}
#setsumei_can .art_ttl {
	inline-size: 568rem;
	margin-inline: auto;
	color: #6fb989;
	font-size: 40rem;
	font-weight: 700;
	text-align: center;
	line-height: 1.25;
	letter-spacing: .05em;
	background-image: url(../img/setsumei_line.webp);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: contain;
	padding-block-end: 25rem;
}
#setsumei_can .can_exp_1 {
	inline-size: 564rem;
	margin-inline: auto;
	font-size: 24.5rem;
	font-weight: 500;
	letter-spacing: .1em;
	padding-block-start: 25rem;
}
#setsumei_can .can_exp_2 {
	inline-size: 564rem;
	margin-inline: auto;
	font-size: 22.5rem;
	font-weight: 500;
	letter-spacing: .1em;
	padding-block-start: 5rem;
}

#setsumei_sch {
	padding-block-start: 80rem;
}
#setsumei_sch .art_ttl {
	inline-size: 568rem;
	margin-inline: auto;
	color: #6fb989;
	font-size: 40rem;
	font-weight: 700;
	text-align: center;
	line-height: 1.25;
	letter-spacing: .05em;
	background-image: url(../img/setsumei_line.webp);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: contain;
	padding-block-end: 25rem;
}
#setsumei_sch .sch_exp {
	text-align: center;
	font-size: 30rem;
	font-weight: 500;
	letter-spacing: .1em;
	padding-block-start: 30rem;
}

#setsumei_cont {
	padding-block-start: 80rem;
}
#setsumei_cont .art_ttl {
	inline-size: 568rem;
	margin-inline: auto;
	color: #6fb989;
	font-size: 40rem;
	font-weight: 700;
	text-align: center;
	line-height: 1.25;
	letter-spacing: .05em;
	background-image: url(../img/setsumei_line.webp);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: contain;
	padding-block-end: 25rem;
}

#setsumei_slide {
	padding-block-start: 60rem;
	inline-size: 565rem;
	margin-inline: auto;
}
#setsumei_slide .slider img {
	cursor: pointer;
}
#setsumei_slide .slick-dots {
	display: flex;
	flex-flow: row wrap;
	justify-content: center;
	align-items: center;
	padding-block-start: 25rem;
}
#setsumei_slide .slick-dots > li {
	padding-inline: 18rem;
}
#setsumei_slide .slick-dots > li button {
	inline-size: 16rem;
	block-size: 16rem;
	border-radius: 50%;
	background-color: #b7dcc4;
	overflow: hidden;
	text-indent: 100%;
	cursor: pointer;
}
#setsumei_slide .slick-dots > li.slick-active button {
	background-color: #6fb989;
	cursor: default;
}
#setsumei_slide .setsumei_slide_exp {
	font-size: 22.5rem;
	font-weight: 500;
	letter-spacing: .1em;
	padding-block-start: 30rem;
}

#setsumei_cont .voice {
}
#setsumei_cont .voice dt {
	inline-size: 208rem;
	block-size: 47rem;
	background-color: #6fb989;
	margin-inline: auto;
	margin-block-start: 80rem;
	color: #fff;
	line-height: 43rem;
	font-size: 32.7rem;
	font-weight: 700;
	letter-spacing: .1em;
	text-align: center;
}
#setsumei_cont .voice dd {
	inline-size: 563rem;
	margin-inline: auto;
	background-color: #cfe7d2;
	border-radius: 22rem;
	position: relative;
	padding: 40rem;
	font-size: 22.5rem;
	line-height: 1.45;
	letter-spacing: .1em;

	margin-block-start: 40rem;
}
#setsumei_cont .voice dd::before {
	content: "";
	display: block;
	background-image: url(../img/setsumei_bubble.webp);
	inline-size: 33rem;
	block-size: 37rem;
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;

	position: absolute;
	inset-inline-end: 74rem;
	inset-block-end: -20rem;
}

#setsumei_place {
	padding-block-start: 110rem;
}
#setsumei_place .art_ttl {
	inline-size: 568rem;
	margin-inline: auto;
	color: #6fb989;
	font-size: 40rem;
	font-weight: 700;
	text-align: center;
	line-height: 1;
	letter-spacing: .05em;
	background-image: url(../img/setsumei_line.webp);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: contain;
	padding-block-end: 25rem;
}
#setsumei_place .place_dfl {
	padding-inline-start: 60rem;
}
#setsumei_place .place_dfl dt {
	font-size: 30rem;
	font-weight: 500;
	line-height: 1;
	letter-spacing: .1em;
	padding-block-start: 45rem;
}
#setsumei_place .place_dfl dd {
	font-size: 26rem;
	font-weight: 500;
	line-height: 1.3;
	letter-spacing: .1em;
	padding-block-start: 10rem;
}

#setsumei_place .btn_gmap {
	padding-block-start: 23rem;
}
#setsumei_place .btn_gmap a {
	display: block;
	inline-size: 510rem;
	block-size: 60rem;
	position: relative;
	margin-inline: auto;
}
#setsumei_place .btn_gmap a::before {
	content: "";
	display: block;
	inline-size: 503rem;
	block-size: 53rem;
	position: absolute;
	inset-inline-end: 0;
	inset-block-end: 0;
	background-color: #dfb6c0;
	border-radius: 8rem;
}
#setsumei_place .btn_gmap .front {
	color: #fff;
	font-size: 32.7rem;
	font-weight: 700;
	line-height: 1;
	background-color: #6fb989;
	border-radius: 8rem;
	display: flex;
	flex-flow: row wrap;
	justify-content: flex-start;
	align-items: center;
	inline-size: 503rem;
	block-size: 53rem;
	padding-inline-start: 42rem;
	position: absolute;
	inset-inline-start: 0;
	inset-block-start: 0;
}
#setsumei_place .btn_gmap a:hover .front {
	inset: auto 0 0 auto;
}
#setsumei_place .btn_gmap .arw {
	inline-size: 42rem;
	position: absolute;
	inset-inline-end: 8rem;
	inset-block-start: 5rem;
}

#setsumei_yoyaku {
	padding-block-start: 85rem;
}
#setsumei_yoyaku .art_ttl {
	inline-size: 568rem;
	margin-inline: auto;
	color: #6fb989;
	font-size: 40rem;
	font-weight: 700;
	text-align: center;
	line-height: 1;
	letter-spacing: .05em;
	background-image: url(../img/setsumei_line.webp);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: contain;
	padding-block-end: 25rem;
}
#setsumei_yoyaku .exp {
	font-size: 24.5rem;
	font-weight: 500;
	line-height: 1;
	letter-spacing: .1em;
	padding-block-start: 30rem;
	text-align: center;
}

#setsumei_yoyaku .btn_yoyaku {
	padding-block-start: 26rem;
}
#setsumei_yoyaku .btn_yoyaku a {
	display: block;
	inline-size: 570rem;
	block-size: 107rem;
	position: relative;
	margin-inline: auto;
}
#setsumei_yoyaku .btn_yoyaku a::before {
	content: "";
	display: block;
	inline-size: 563rem;
	block-size: 100rem;
	position: absolute;
	inset-inline-end: 0;
	inset-block-end: 0;
	background-color: #dfb6c0;
	border-radius: 12rem;
}

#setsumei_yoyaku .btn_yoyaku .front {
	text-align: center;
	color: #6fb989;
	font-size: 34.8rem;
	font-weight: 700;
	line-height: 1.25;
	letter-spacing: .1em;
	background-color: #fee495;
	border-radius: 12rem;
	display: flex;
	flex-flow: row wrap;
	justify-content: center;
	align-items: center;

	inline-size: 563rem;
	block-size: 100rem;

	position: absolute;
	inset-inline-start: 0;
	inset-block-start: 0;
}
#setsumei_yoyaku .btn_yoyaku a:hover .front {
	inset: auto 0 0 auto;
}
#setsumei_yoyaku .btn_yoyaku .arw {
	inline-size: 75rem;
	position: absolute;
	inset-inline-end: 10rem;
	inset-block-start: 13rem;
}
#setsumei_yoyaku .btn_yoyaku.soon a::after {
	content: "coming soon";
	display: block;
	inline-size: 563rem;
	block-size: 100rem;
	font-size: 40rem;
	font-weight: 700;
	color: #fff;
	text-align: center;
	letter-spacing: .1em;
	padding-block-start: 11rem;
	position: absolute;
	inset-inline-start: 0;
	inset-block-start: 0;
	background-color: rgba(148, 63, 108, .6);
	border-radius: 12rem;
}
#setsumei_yoyaku .btn_yoyaku.soon a:hover .front {
	inset: 0 auto auto 0;
}
#setsumei_yoyaku .comment {
	inline-size: 564rem;
	margin-inline: auto;
	font-size: 22.5rem;
	font-weight: 500;
	letter-spacing: .1em;
	padding-block-start: 15rem;
}




















/*  footer
--------------------------*/
#footer {
	padding-block-start: 75rem;
	padding-block-end: 100rem;
	position: relative;
}
#footer_links {
	inline-size: 645rem;
	margin-inline: auto;
	display: flex;
	flex-flow: row wrap;
	justify-content: space-between;
	align-items: flex-start;
	padding-block-end: 75rem;
}
#footer_links li {
	padding-block-start: 20rem;
}
#footer_links li a {
	display: block;
	inline-size: 313rem;
	block-size: 84rem;
	position: relative;
}
#footer_links li a::before {
	content: "";
	display: block;
	inline-size: 307rem;
	block-size: 78rem;
	position: absolute;
	inset-inline-end: 0;
	inset-block-end: 0;
	background-color: #dfb6c0;
	border-radius: 12rem;
}
#footer_links li .front {
	color: #fff;
	font-size: 25rem;
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: .1em;

	background-color: #ec759e;
	border-radius: 12rem;
	display: flex;
	flex-flow: row wrap;
	justify-content: center;
	align-items: center;
	inline-size: 307rem;
	block-size: 78rem;

	position: absolute;
	inset-inline-start: 0;
	inset-block-start: 0;
}
#footer_links li a:hover .front {
	inset: auto 0 0 auto;
}
#footer_links li .logo {
	inline-size: 46rem;
	margin-inline-end: 16rem;
}


#footer_links li:first-child a {
	inline-size: 645rem;
}
#footer_links li:first-child a::before {
	inline-size: 639rem;
}
#footer_links li:first-child .front {
	font-size: 36.8rem;
	inline-size: 639rem;
}

#copyright {
	display: block;
	inline-size: 341rem;
	padding-inline-start: 70rem;
}

#pagetop {
	display: block;
	inline-size: 130rem;
	block-size: 130rem;
	border-radius: 50%;
	position: absolute;
	inset-inline-end: 64rem;
	inset-block-start: 360rem;
}

#pagetop .front {
	display: block;
	inline-size: 124rem;
	position: absolute;
	inset-inline-start: 0;
	inset-block-start: 0;
}
#pagetop::before {
	content: "";
	display: block;
	inline-size: 124rem;
	block-size: 124rem;
	border-radius: 50%;
	background-color: #dfb6c0;
	position: absolute;
	inset-inline-end: 0;
	inset-block-end: 0;
}
#pagetop:hover .front {
	inset-inline-start: auto;
	inset-block-start: auto;
	inset-inline-end: 0;
	inset-block-end: 0;
}
















/*  nav
--------------------------*/
#pc_nav {
	position: fixed;
	inset-inline-start: 50%;
	inset-block-start: 50%;
	transform: translate(-686rem, -50%);
}
#pc_menu {
	inline-size: 264rem;
	background-color: #fff;
	border-radius: 24rem;
	text-align: center;
	padding-inline: 23rem;
}
#pc_menu .menu_ttl {
	font-size: 28rem;
	font-weight: 700;
	line-height: 1;
	letter-spacing: .1em;
	padding-block-end: 11rem;
	padding-block-start: 38rem;
}
#pc_menu .page_menu {
	padding-block-start: 18rem;
	padding-block-end: 12rem;
	background-image: url(../img/pc_nav_line.webp);
	background-repeat: no-repeat;
	background-position: center top;
	background-size: contain;
}
#pc_menu .page_menu > li {
	padding-block: 14rem;
}
#pc_menu .page_menu a {
	font-size: 19rem;
	font-weight: 700;
	letter-spacing: .1em;
	line-height: 1;
}
#pc_menu .page_menu .top a {
	color: #000;
}
#pc_menu .page_menu .hiroba a {
	color: #ec759e;
}
#pc_menu .page_menu .sq a {
	color: #65c4d4;
}
#pc_menu .page_menu .setsumei a {
	color: #6fb989;
}
#pc_menu .yoyaku_ttl {
	font-size: 16.8rem;
	font-weight: 700;
	letter-spacing: .1em;
	line-height: 1;
	padding-block-start: 27rem;
	background-image: url(../img/pc_nav_line.webp);
	background-repeat: no-repeat;
	background-position: center top;
	background-size: contain;
}
#pc_menu .yoyaku_exp {
	font-size: 12rem;
	font-weight: 500;
	line-height: 1;
	padding-block-start: 10rem;
}
#pc_menu .yoyaku_menu {
	padding-block-start: 15rem;
	padding-block-end: 33rem;
}
#pc_menu .yoyaku_menu > li {
	padding-block: 9rem;
}
#pc_menu .yoyaku_menu a {
	display: block;
	inline-size: 208rem;
	block-size: 35rem;
	margin-inline: auto;
	position: relative;
}
#pc_menu .yoyaku_menu a::before {
	content: "";
	display: block;
	inline-size: 204rem;
	block-size: 32rem;
	border-radius: 5rem;
	background-color: #dfb6c0;
	position: absolute;
	inset-inline-end: 0;
	inset-block-end: 0;
}
#pc_menu .yoyaku_menu .soon a::after {
	content: "coming soon";
	display: block;
	inline-size: 204rem;
	block-size: 32rem;
	border-radius: 5rem;
	background-color: rgba(148, 63, 108, .6);

	font-size: 19rem;
	font-weight: 700;
	color: #fff;
	line-height: 1;
	letter-spacing: .1em;
	padding-block-start: 3rem;

	position: absolute;
	inset-inline-start: 0;
	inset-block-start: 0;
}
#pc_menu .yoyaku_menu a .front {
	display: block;
	inline-size: 204rem;
	block-size: 32rem;
	border-radius: 5rem;
	background-color: #fee18a;
	padding-block-start: 7rem;

	font-size: 16.8rem;
	font-weight: 700;
	line-height: 1;
	letter-spacing: .1em;

	position: absolute;
	inset-inline-start: 0;
	inset-block-start: 0;
}
#pc_menu .yoyaku_menu a:hover .front {
	inset-inline-start: auto;
	inset-inline-end: 0;
	inset-block-start: auto;
	inset-block-end: 0;
}
#pc_menu .yoyaku_menu .hiroba a .front {
	color: #ec759e;
}
#pc_menu .yoyaku_menu .sq a .front {
	color: #65c4d4;
}
#pc_menu .yoyaku_menu .setsumei a .front {
	color: #6fb989;
}

#pc_menu .yoyaku_menu .soon a:hover .front {
	inset-inline-start: 0;
	inset-inline-end: auto;
	inset-block-start: 0;
	inset-block-end: auto;
}

#sp_nav {
	display: none;
}










/*==================================================

  Media Queries for window size over 1920px

====================================================*/
@media screen and (min-width: 1920px) {

  /*================================================
    Z-Index over 1920px
  ==================================================*/

  /*================================================
    layout[ALL] over 1920px
  ==================================================*/
	/*  Html over 1920px
	--------------------------*/
	html {
		/* font-size: calc(1 / 1920 * 100vw); */
	}
	/*  Body over 1920px
	--------------------------*/
	body {
	}

	/*  Wrapper over 1920px
	--------------------------*/
	#wrapper {
	}

}














/*==================================================

  Media Queries for window size under 1280px

====================================================*/
@media screen and (max-width: 1280px) {

  /*================================================
    Z-Index under 1280px
  ==================================================*/

  /*================================================
    layout[ALL] under 1280px
  ==================================================*/
	/*  Html under 1280px
	--------------------------*/
	html {
		/* font-size: calc(1 / 1280 * 100vw); */
	}
	/*  Body under 1280px
	--------------------------*/
	body {
	}

	/*  Wrapper under 1280px
	--------------------------*/
	#wrapper {
	}

}
































/*==================================================

  Media Queries for window size under 768px

====================================================*/
@media screen and (max-width: 768px) {

  /*================================================
    Z-Index under 768px
  ==================================================*/

  /*================================================
    layout[ALL] under 768px
  ==================================================*/
	/* img {
		width: 100%;
	} */

	.pc {
		display: none;
	}
	.sp {
		display: inline;
	}


	.fadein {
		opacity: 0;
		transform: translateY(20rem);
	}
	.fadein.view {
		opacity: 1;
		transform: translateY(0);
		transition: all 1200ms ease 500ms;
	}
	.fadein_2 {
		opacity: 0;
		transform: translateY(20rem);
	}
	.fadein_2.view {
		opacity: 1;
		transform: translateY(0);
		transition: all 1200ms ease 500ms;
	}
	.fadein_3 {
		opacity: 0;
		transform: translateY(20rem);
	}
	.fadein_3.view {
		opacity: 1;
		transform: translateY(0);
		transition: all 1200ms ease 500ms;
	}
	/*  Html under 768px
	--------------------------*/
	html {
		font-size: calc(1 / 768 * 100vw);
	}
	/*  Body under 768px
	--------------------------*/
	body {
	}

	/*  Wrapper under 768px
	--------------------------*/
	#wrapper {
	}
	
	/*  nav under 768px
	--------------------------*/
	#pc_nav {
		display: none;
	}

	#sp_nav {
		display: block;
		position: fixed;
		inset-inline-start: 0;
		inset-block-start: 0;
		inline-size: 100%;
	}
	#sp_header {
		background-color: #fff;
		padding-block-start: 22rem;
		padding-block-end: 16rem;
		padding-inline-start: 23rem;
	}
	#sp_header .headr_txt {
	}
	#sp_header .headr_txt > span {
		display: block;
		line-height: 1;
	}
	#sp_header .headr_txt .ja {
		font-size: 30.7rem;
		font-weight: 700;
		letter-spacing: .05em;
	}
	#sp_header .headr_txt .en {
		font-size: 26.6rem;
		padding-block-start: 7rem;
		letter-spacing: .1em;
	}
	#sp_header .sp_nav_open {
		inline-size: 278rem;
		position: absolute;
		inset-inline-end: 22rem;
		inset-block-start: 17rem;
	}

	#sp_menu {
		border: 8rem solid #fdf1f3;
		background-color: #fff;
		border-radius: 40rem 0 0 40rem;
		inline-size: 450rem;
		position: absolute;
		inset-inline-end: 0;
		inset-block-start: 0;

		display: none;
	}
	#sp_menu .page_menu {
		padding-inline-start: 30rem;
		padding-block-start: 110rem;
		padding-block-end: 22rem;
	}
	#sp_menu .page_menu > li {
		padding-block: 22rem;
	}
	#sp_menu .page_menu a {
		font-size: 32.7rem;
		font-weight: 700;
		letter-spacing: .1em;
		line-height: 1;
	}
	#sp_menu .page_menu .top a {
		color: #000;
	}
	#sp_menu .page_menu .hiroba a {
		color: #ec759e;
	}
	#sp_menu .page_menu .sq a {
		color: #65c4d4;
	}
	#sp_menu .page_menu .setsumei a {
		color: #6fb989;
	}

	#sp_menu .yoyaku_ttl {
		inline-size: 370rem;
		margin-inline: auto;
		padding-block-start: 44rem;
		background-image: url(../img/sp_nav_line.webp);
		background-repeat: no-repeat;
		background-position: center top;
		background-size: contain;

		text-align: center;
		font-size: 28.6rem;
		font-weight: 700;
		letter-spacing: .1em;
		line-height: 1;
	}
	#sp_menu .yoyaku_exp {
		font-size: 20rem;
		font-weight: 500;
		line-height: 1;
		padding-block-start: 18rem;
		text-align: center;
	}
	#sp_menu .yoyaku_menu {
		padding-block-start: 15rem;
		padding-block-end: 33rem;
	}
	#sp_menu .yoyaku_menu > li {
		padding-block: 16rem;
	}
	#sp_menu .yoyaku_menu a {
		display: block;
		inline-size: 354rem;
		block-size: 60rem;
		margin-inline: auto;
		position: relative;
	}
	#sp_menu .yoyaku_menu a::before {
		content: "";
		display: block;
		inline-size: 348rem;
		block-size: 53rem;
		border-radius: 8rem;
		background-color: #dfb6c0;
		position: absolute;
		inset-inline-end: 0;
		inset-block-end: 0;
	}
	#sp_menu .yoyaku_menu .soon a::after {
		content: "coming soon";
		display: block;
		inline-size: 348rem;
		block-size: 53rem;
		border-radius: 8rem;
		background-color: rgba(148, 63, 108, .6);
		padding-block-start: 5rem;

		text-align: center;
		font-size: 32rem;
		font-weight: 700;
		color: #fff;
		line-height: 1;
		letter-spacing: .1em;

		position: absolute;
		inset-inline-start: 0;
		inset-block-start: 0;
	}
	#sp_menu .yoyaku_menu a .front {
		display: block;
		inline-size: 348rem;
		block-size: 53rem;
		border-radius: 8rem;
		background-color: #fee18a;
		padding-block-start: 12rem;

		text-align: center;
		font-size: 28.6rem;
		font-weight: 700;
		line-height: 1;
		letter-spacing: .1em;

		position: absolute;
		inset-inline-start: 0;
		inset-block-start: 0;
	}
	#sp_menu .yoyaku_menu a:hover .front {
		inset-inline-start: auto;
		inset-inline-end: 0;
		inset-block-start: auto;
		inset-block-end: 0;
	}
	#sp_menu .yoyaku_menu .hiroba a .front {
		color: #ec759e;
	}
	#sp_menu .yoyaku_menu .sq a .front {
		color: #65c4d4;
	}
	#sp_menu .yoyaku_menu .setsumei a .front {
		color: #6fb989;
	}

	#sp_menu .yoyaku_menu .soon a:hover .front {
		inset-inline-start: 0;
		inset-inline-end: auto;
		inset-block-start: 0;
		inset-block-end: auto;
	}

	#sp_menu .sp_nav_close {
		inline-size: 53rem;
		position: absolute;
		inset-inline-end: 44rem;
		inset-block-start: 47rem;
	}







	/*  main under 768px
	--------------------------*/
	#main {
	}

	/*  footer under 768px
	--------------------------*/
	#footer {

	}






}
