@charset "utf-8";
/*
Template: 
Theme Name: 
*/

/* reset ---------------------------------------*/
body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,textarea,p,blockquote,th,td,img {
    padding: 0;
    margin: 0;
}

*, *:before, *:after {
    box-sizing: border-box;
}

table {
    border-collapse: collapse;
    border-spacing: 0;
    margin-bottom: 30px;
    width: 100%;
    table-layout: fixed;
}

fieldset,img {
    border: 0;
    vertical-align: middle;
}

address,caption,cite,code,dfn,th,var {
    font-weight: normal;
    font-style: normal;
}

ol,ul {
    list-style: none;
}

caption,th {
    text-align: left;
}

h1,h2,h3,h4,h5,h6 {
    font-weight: normal;
    font-size: 100%;
}

abbr,acronym {
    border: 0;
}

*:focus {
    outline: none !important;
}

:root {
    --primary-color: #008edf;
    --secondary-color: #f76ba6;
	--tertiary-color: #002a9d;
    --background-color1: #c8e8fa;
    --font-color-base: #000;
    --font-color-red: #d72630;
    --border-color: #888;
    --font-family-base: "Inter", "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
    --font-size-base: 17px;
    --font-weight-base: 500;
    --line-height-base: 1.8;
    --letter-spacing: 1.5px;
    --max-width: 1100px;
}

p {
    font-family: var(--font-family-base);
    line-height: 1.8;
    letter-spacing: 1.5px;
    font-size: 17px;
    color: var(--font-color-base);
    margin-bottom: 20px;
    display: block;
    font-variant-numeric: tabular-nums;
}

.ti {
    text-align: left;
    text-indent: 1em;
    list-style-type: none;
}

.bold {
    font-size: clamp(17px, 2vw, 19px);
    font-weight: 500;
}

.under {
    background: linear-gradient(transparent 60%, rgb(145 222 246 / 50%) 50%);
    padding: 0 5px 3px;
}

.under_pink {
    background: linear-gradient(transparent 60%, rgb(247 107 166 / 50%) 50%);
    padding: 0 5px 3px;
}

input[type="image"] {
    -webkit-appearance: none;
    border-radius: 0;
}

li {
    line-height: 1.8;
}

li.de {
    list-style-type: decimal;
    margin-left: 25px;
    margin-bottom: 5px;
}

li.di {
    list-style-type: disc;
    margin-left: 25px;
    margin-bottom: 5px;
}

ul.ti {
    padding-left: 1em;
}

ul.ti li {
    text-indent: -1em;
}


@media screen and (max-width: 768px) {

:root {
    --font-size-base: 16px;
}

p {
    font-size: var(--font-size-base);
}

li.de {
    list-style-type: decimal;
    margin-left: 20px;
}

li.di {
    list-style-type: disc;
    margin-left: 20px;
    margin-bottom: 10px;
}

}


/* default ---------------------------------------*/

html,
body {
    margin: 0;
    padding: 0;
    min-width: 100%;
    min-height: 100%;
    height: auto !important;
    -webkit-text-size-adjust: 100%;
    image-rendering: -webkit-optimize-contrast;
}

body,
.wrapper {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

html {
    overflow-y: scroll;
}

body {
    font-family: var(--font-family-base);
    font-size: var(--font-size-base);
    line-height: 1.8;
    letter-spacing: 1.5px;
    color: var(--font-color-base);
    background: #fff;
    font-variant-numeric: tabular-nums;
}

.pc_none {
    display: none !important;
}

.iframe-content {
    margin: 0 0 15px;
}

iframe[src^="https://www.google.com/maps/"] {
    width: 100%;
}


@media screen and (max-width: 768px) {

body {
    font-size: var(--font-size-base);
}

.iframe-content {
    position: relative;
    width: 100%;
    padding: 75% 0 0 0;
    margin: 0 0 5px;
}

.iframe-content iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.pc_none {
    display: block !important;
}

.sp_none {
    display: none !important;
}

}


/*----------------------------------------------------
	基本設定、リンクカラーなど
----------------------------------------------------*/

img {
    max-width: 100%;
    height: auto;
    width: auto;
    vertical-align: middle;
    -ms-interpolation-mode: bicubic;
}

.border_radius {
    border-radius: 10px;
}

.ofi {
    -o-object-fit: cover;
    object-fit: cover;
    font-family: 'object-fit: cover;';
}

#contents {
    width: 100%;
}

a,
a:hover,
a:active {
    -webkit-tap-highlight-color: transparent;
    opacity: 1.0;
}

a:link {
    color: var(--font-color-base);
    text-decoration: underline;
    background: inherit;
    opacity: 1.0;
}

a:visited {
    color: var(--font-color-base);
    text-decoration: underline;
    background: inherit;
    opacity: 1.0;
}

a:hover {
    color: var(--font-color-base);
    text-decoration: none;
    background: inherit;
    transition: 0.5s;
    opacity: 1.0;
}

a:active {
    color: var(--font-color-base);
    text-decoration: underline;
    background: inherit;
    opacity: 1.0;
}

.op:hover {
    opacity: 0.7;
    background: inherit;
    transition: 0.5s;
}

.none,
.none:active,
.none:hover {
    text-decoration: none !important;
    opacity: 1.0;
}

.tel_sp a {
    cursor: default;
    pointer-events: none;
    text-decoration: none;
}


@media screen and (max-width: 768px) {

.tel_sp a {
    cursor: pointer;
    pointer-events: auto;
}

.tel_sp a:hover {
    text-decoration: none;
}

}


/*--------------------------------------------------------
    フォントサイズ
----------------------------------------------------------*/

.f14 { font-size: 14px !important; }
.f20 { font-size: 20px !important; }

.wb { font-weight: bold; }
.dib { display: inline-block; }
.pc_dib { display: inline-block; }

@media screen and (max-width: 768px) {

.db { display: block; }
.pc_dib { display: initial; }

}


/* -----------------------------------------------------------
	フォントカラー
----------------------------------------------------------- */

.font_color1 { color: var(--primary-color) !important; }
.font_color2 { color: var(--secondary-color) !important; }


/* ----------------------------------------------------
	text-align
---------------------------------------------------- */

.tc { text-align: center !important; }
.tr { text-align: right !important; }
.tl { text-align: left !important; }
.pc_tc { text-align: center !important; }


@media screen and (max-width: 768px) {

.pc_tc { text-align: left !important; }

}


/* ----------------------------------------------------
	float
---------------------------------------------------- */

.fr { float: right !important; }
.fl { float: left !important; }
.fn { float: none !important; }
.ov { overflow: hidden !important; }


/*----------------------------------------------------
	Font Awesome icon
----------------------------------------------------*/

.fa-solid {
    display: inline-block;  
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    font-style: normal;
    line-height: 1;
    padding-left: 2px;
    padding-right: 5px !important;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}


/* ----------------------------------------------------
	margin
---------------------------------------------------- */

.mt0 { margin-top: 0px !important; }
.mt5 { margin-top: 5px !important; }
.mt10 { margin-top: 10px !important; }
.mt15 { margin-top: 15px !important; }
.mt20 { margin-top: 20px !important; }
.mt25 { margin-top: 25px !important; }
.mt30 { margin-top: 30px !important; }
.mt35 { margin-top: 35px !important; }
.mt40 { margin-top: 40px !important; }
.mt50 { margin-top: 50px !important; }
.mt60 { margin-top: 60px !important; }


.mr0 { margin-right: 0px !important; }
.mr5 { margin-right: 5px !important; }
.mr10 { margin-right: 10px !important; }
.mr15 { margin-right: 15px !important; }
.mr20 { margin-right: 20px !important; }
.mr25 { margin-right: 25px !important; }
.mr26 { margin-right: 26px !important; }
.mr30 { margin-right: 30px !important; }
.mr35 { margin-right: 35px !important; }
.mr40 { margin-right: 40px !important; }


.mb0 { margin-bottom: 0px !important; }
.mb5 { margin-bottom: 5px !important; }
.mb10 { margin-bottom: 10px !important; }
.mb15 { margin-bottom: 15px !important; }
.mb20 { margin-bottom: 20px !important; }
.mb25 { margin-bottom: 25px !important; }
.mb30 { margin-bottom: 30px !important; }
.mb35 { margin-bottom: 35px !important; }
.mb40 { margin-bottom: 40px !important; }
.mb50 { margin-bottom: 50px !important; }
.mb60 { margin-bottom: 60px !important; }


.ml0 { margin-left: 0px !important; }
.ml5 { margin-left: 5px !important; }
.ml10 { margin-left: 10px !important; }
.ml15 { margin-left: 15px !important; }
.ml20 { margin-left: 20px !important; }
.ml25 { margin-left: 25px !important; }
.ml30 { margin-left: 30px !important; }
.ml35 { margin-left: 35px !important; }
.ml40 { margin-left: 40px !important; }


@media screen and (max-width: 900px) {

.w900_mb20 { margin-bottom: 20px !important; }

}


@media screen and (max-width: 768px) {

.sp_mt0 { margin-top: 0px !important; }
.sp_mt20 { margin-top: 20px !important; }
.sp_mb20 { margin-bottom: 20px !important; }
.sp_mb25 { margin-bottom: 25px !important; }

}


/* ----------------------------------------------------
	padding
---------------------------------------------------- */

.pt0 { padding-top: 0px !important; }
.pt5 { padding-top: 5px !important; }
.pt10 { padding-top: 10px !important; }
.pt15 { padding-top: 15px !important; }
.pt20 { padding-top: 20px !important; }
.pt25 { padding-top: 25px !important; }
.pt30 { padding-top: 30px !important; }
.pt35 { padding-top: 35px !important; }
.pt40 { padding-top: 40px !important; }
.pt50 { padding-top: 50px !important; }


.pr0 { padding-right: 0px !important; }
.pr5 { padding-right: 5px !important; }
.pr10 { padding-right: 10px !important; }
.pr15 { padding-right: 15px !important; }
.pr20 { padding-right: 20px !important; }
.pr25 { padding-right: 25px !important; }
.pr30 { padding-right: 30px !important; }
.pr35 { padding-right: 35px !important; }
.pr40 { padding-right: 40px !important; }


.pb0 { padding-bottom: 0px !important; }
.pb5 { padding-bottom: 5px !important; }
.pb10 { padding-bottom: 10px !important; }
.pb15 { padding-bottom: 15px !important; }
.pb20 { padding-bottom: 20px !important; }
.pb25 { padding-bottom: 25px !important; }
.pb30 { padding-bottom: 30px !important; }
.pb35 { padding-bottom: 35px !important; }
.pb40 { padding-bottom: 40px !important; }
.pb50 { padding-bottom: 50px !important; }


.pl0 { padding-left: 0px !important; }
.pl5 { padding-left: 5px !important; }
.pl10 { padding-left: 10px !important; }
.pl15 { padding-left: 15px !important; }
.pl20 { padding-left: 20px !important; }
.pl25 { padding-left: 25px !important; }
.pl30 { padding-left: 30px !important; }
.pl35 { padding-left: 35px !important; }
.pl40 { padding-left: 40px !important; }

@media screen and (max-width: 768px) {

.sp_pt40 { padding-top: 40px !important; }

}

/*----------------------------------------------------
	width
----------------------------------------------------*/

.w200 { width: 200px!important; }
.w25 { width: 25%!important; }


@media screen and (max-width: 768px) {

.w25 { width: 100%!important; }

}


/* ----------------------------------------------------
	clear
---------------------------------------------------- */

.clear { clear: both;}