/*
Theme Name: original_theme
Author: lucKs
Author URI: 
Version: 1.0
*/

*, *: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;
    backface-visibility: hidden;
}
html{ margin: 0; padding: 0; scroll-padding-top: 200px;}
body {
    margin: 0;
    padding: 0;
    font-family: "Noto Sans JP", "Hiragino Sans","Meiryo", sans-serif;
    font-size: 16px;
	font-weight:400;
    color:#222;
    line-height:200%;
    word-break: break-all;
    overflow-x: hidden;
    background: url("images/common/bg.webp") repeat top center;
}
div, p, ul, ul li, dl, dt, dd {
	margin: 0;
	padding: 0;
	font-size: 100%;
	list-style:none;
	box-sizing:border-box;
}
img, video, object {
    max-width: 100%;
    height: auto;
    border: none;
}
img{
	display: block;
	image-rendering: smoothe !important;
}
h1, h2, h3, h4, h5, h6 {
	margin: 0;
	padding: 0;
	font-size: 100%;
	line-height: 1.5;
}

a:link {color:blue; text-decoration: none; }
a:visited { color:blue;}
a[href^="tel:"] { text-decoration:none; pointer-events:none ; text-emphasis: none !important;}
a[href^="fax:"] { text-decoration:none; pointer-events:none ;}

.pc {display: inherit;}
.pctb {display: inherit;}
.tb {display: none;}
.tbsp {display: none;}
.sp {display: none;}

@media only screen and (min-width:768px){
    a:hover {color:red; text-decoration: underline; transition:0.3s; }
    a:hover img { opacity: 0.7; filter: alpha(opacity=70); -moz-opacity: 0.7;}
}
@media only screen and (max-width:768px){
    .pc {display:none;}
    .pctb {display:block;}
    .tb {display:block;}
    .tbsp {display: none;}
    .sp {display:none;}
}
@media only screen and (max-width:468px){
    .pc {display:none;}
    .pctb {display:none;}
    .tb {display:none;}
    .tbsp {display: block;}
    .sp {display:block;}
}


/* =========================================================================================
Layout
=========================================================================================*/
#wrapper{
    position:relative;
    margin:0;
    padding:0;
}
#container{
    margin:0;
    overflow: hidden;
}
article {
    background: #FFF;
}
section {
}
.inner {
    margin: 0 auto;
    padding: 100px 0;
    width: 90%;
    max-width: 1200px;
    position:relative;
    box-sizing:border-box;
}
@media only screen and (max-width:768px){
    .inner { padding: 80px 0;}
}
@media only screen and (max-width:468px){
    .inner { padding: 60px 0;}
}


/*=========================================================================================
Header
=========================================================================================*/
#header {
    position: sticky; top: 0; left: 0; z-index: 999;
    font-family: "Zen Maru Gothic", sans-serif;
    background: url("images/common/bg.webp") repeat top center;
}
#header .inner {
    display: flex; flex-wrap: wrap; justify-content:space-between; align-items: center; gap:20px;
    padding:20px 0;
    width: 96%; max-width: 1400px;
}

/* Logo */
#header h1 { width: 33%; max-width: 480px; height: auto;}
#header h1 a { display: block; width:100%; height:auto;aspect-ratio: 793 / 145;}
#header h1 a {
    text-indent: -9999px;
    background: url("images/common/logo.webp") no-repeat;
    background-size: 100% auto !important;
}

/* Navigation */
#nav {}
#nav ul { display: flex; align-items: center; gap:20px;}
#nav ul li { position: relative;}
#nav ul li a { display: block; text-decoration: none;}
#nav ul li p a {
    position: relative;
    display: block;
    color: #000;
    font-size:112.5%;
    font-weight: 500;
    text-align: center;
    text-decoration: none;
    line-height: 130%;
    box-sizing: border-box;
}
#nav ul li p a span { min-width: inherit;}
#nav ul li.contact {
    display: flex; flex-direction: column; justify-content:center; gap:5px;
    padding-left: 20px;
}
#nav ul li.contact span { display: block;}
#nav ul li.contact .tel a {
    cursor: pointer;
    padding-left: 25px;
    font-family: "Roboto", sans-serif;
    font-size: 175%;
    font-weight: 500;
    color: #12327F;
    letter-spacing: -1px;
    background: url("images/common/icon_tel.svg") no-repeat left center;
    background-size: 20px auto;
}
#nav ul li.contact .mail a {
    padding-right: 10px;
    font-size: 100%;
    font-weight: 600;
    color: #fff;
    text-align: center;
    letter-spacing: -1px;
    background:#D8452E url("images/common/arrow_w1.svg") no-repeat 95% center;
    background-size: 17px auto;
    border-radius: 5px;
}
@media only screen and (min-width:768px){
    #nav ul li a:hover {  color:#476BC4; text-decoration: none;}
    #nav ul li.contact a:hover { opacity: 0.7;}
}
@media only screen and (max-width:1370px){
    #header h1 { max-width: 300px;}
    #nav ul { gap:20px;}
    #nav ul li p a { font-size: 100%;}
    #nav ul li.contact .tel a {font-size:150%;}
}
@media only screen and (max-width:1135px){
    #header .inner { justify-content: center;}
    #header h1 { width:300px;}
    #header h1 a { background: url("images/common/logo3.webp") no-repeat; aspect-ratio: 455 / 267;}
}
@media only screen and (max-width:768px){
    #header { position:sticky; top: 0; left: 0; padding:0; z-index: 999;} 
    #header .inner { display: block; padding:15px 0; width: 100%; height: 70px;}
    #header h1 { position: relative; left: 10px; width:280px;}
    #header h1 a { background: url("images/common/logo4.webp") no-repeat; aspect-ratio: 570 / 88;}
    .nav_btn {
        display: block !important;
        cursor: pointer;
        position:fixed; top:0; right:0;
        width: 70px; height:70px;
        box-sizing: border-box;
        z-index: 999999999;
    }
    .nav_btn span {
        display: inline-block;
        position: absolute; left:0; right: 0; margin:auto;
        width:34px; height:3px;
        background:#071C4E;
        transition: all .3s;
        border-radius: 4px;
    }
    .nav_btn span:nth-of-type(1) { top:17px;}
    .nav_btn span:nth-of-type(2) { top:28px;}
    .nav_btn span:nth-of-type(3) { top:40px;}
    .nav_btn small { position: absolute; bottom:0; width: 100%; font-size: 10px; text-align: center;}
    .nav_btn.active span:nth-of-type(1) { top:28px; transform:rotate(-45deg);}
    .nav_btn.active span:nth-of-type(2) { opacity: 0;}
    .nav_btn.active span:nth-of-type(3) { top:28px; transform:rotate(45deg);}
    #header #nav {
        display:none;
        position: absolute;  top:70px; right: 0;
        width: 100%; height: calc(100vh - 70px);
        overflow: auto;
        background:#071C4E;
        border-top:1px solid #eee;
    }
    #nav ul { flex-direction: column; gap:0; padding:30px 30px 150px;}
    #nav ul li { position: relative; margin: auto; width:90%; border-bottom: 1px solid rgba(255,255,255,0.30);}    
    #nav ul li p a {
        padding:20px 25px;
        text-align: center;
        color: #fff;
    }    
    #nav ul li.contact { 
        margin:50px auto 0; padding:20px;
        width: 250px;
        background: #fff;
        border: none;
        border-radius: 10px;
    }
}
@media only screen and (max-width:468px){
	#header h1 { width:280px;}
}
@media only screen and (max-width:368px){
	#header h1 { width:240px;}
}

/* =========================================================================================
Footer
=========================================================================================*/
#footer { font-family: "Zen Maru Gothic", sans-serif; background:#fff; border-top:1px solid #ddd;}
#footer .inner {
    display: flex; flex-direction: column; gap:40px;
    padding:65px 0;
}
#footer .logo {
    margin: auto;
    width:70%; max-width: 500px; height:auto; aspect-ratio: 793 / 145;
    text-indent: -9999px;
    background: url("images/common/logo.webp") no-repeat;
    background-size: 100% auto;
}
#footer .f_nav {
    display: flex; flex-wrap: wrap; justify-content: center; gap:20px;
}
#footer .f_nav a {color: #222;}
#footer .add { font-size: 112.5%; text-align: center; line-height: 150%;}
#footer .add span { display: inline-block; margin:0 10px;}
#footer .copy {
    padding: 10px;
    font-size:75%;
    color: #fff;
    text-align: center;
    background:#414A60;
}
@media only screen and (min-width:768px){
    #footer .f_nav a:hover { color:#476BC4; text-decoration: none;}
}
@media only screen and (max-width:768px){
}
@media only screen and (max-width:468px){
    #footer .f_nav { display: none;}
}



/* =========================================================================================
Page Top
=========================================================================================*/
#page-top {
    position: fixed; right: 20px; bottom: 20px;
    z-index: 999;
}
#page-top a {
    display: block;
    width: 60px; height: 60px;
    text-indent: -9999px;
    background: #414A60 url("images/common/icon_pagetop.svg") no-repeat center center;
    background-size: 40px auto;
    border-radius: 100px;
}
@media only screen and (min-width:768px){
    #page-top a:hover{opacity: 0.7;}
}
@media only screen and (max-width:768px){
}
@media only screen and (max-width:468px){
    #page-top { right: 10px; bottom: 10px; }
    #page-top a { width: 50px; height: 50px; background-size: 35px auto; }
}



/* =========================================================================================
Post list
=========================================================================================*/
.post-list{
    border-top: 1px solid #000;
    border-bottom: 1px solid #000;
    padding: 30px 0;
}
.post-list ul{
    width: 100%;
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 20px;
}
.post-list ul li{
    display: flex;
    flex-wrap: wrap;
    justify-content: left;
    gap: 10px 20px;
}
.post-list ul li .thumbnail{
    position: relative;
    border: 1px solid #000;
}
.post-list ul li .thumbnail img{
    object-fit: cover;
    aspect-ratio: 3 / 2;
    width: 100%;
}
.post-list ul li .thumbnail .new{
    position: absolute;
    top: 10px;
    left: 10px;
    color: #FFF;
    font-size: small;
    background: #000;
    padding: 2px 10px 0;
}
.post-list .title{
    font-size: 1.25em;
    font-weight:700;
}
.post-list .title a{
    color: #000;
}
.post-list .title a:hover{
    text-decoration: none;
    opacity: 0.7;
}
.post-list ul li .date{
    width:100px;
}
.post-list ul li .cat{
    font-size: 0.9em;
    width:100px;
    height: auto;
    text-align: center;
    padding: 2px 5px 0;
    border: 1px solid #000;
}
.post-list ul li .tag{
    padding: 10px 0;
    display: flex;
    align-items: start;
    justify-content: left;
    flex-wrap: wrap;
    gap:10px;
}
.post-list ul li .tag .icon{
    font-size: 0.9em;
    height: auto;
    text-align: center;
    display: inline-block;
    padding: 0.25em 1.0em 0.2em;
    border: 1px solid #CCC;
    background: #CCC;
}

/* card */
.post-list.card ul{
    display: flex;
    flex-wrap: wrap;
    justify-content: left;
    align-items: stretch;
    flex-direction: row;
    gap: 30px;
}
.post-list.card li{
    padding: 1.0em;
    width: calc( ( 100% - 60px ) / 3 );
    border: 1px solid #000;
    flex-direction: column;
    gap: 20px;
}

@media only screen and (max-width:768px){
    .post-list ul li .cat{ width:fit-content;}
    .post-list ul li .title{ width: 100% }
    /* card */
    .post-list.card li{ width: calc( ( 100% - 30px ) / 2 ); }
}
@media only screen and (max-width:468px){
    /* card */
    .post-list.card li{ width: 100%; }
}



/* =========================================================================================
Archive-Page
=========================================================================================*/
.archive .post-list{
    border-top:none;
    border-bottom:none;
    padding:0;
}

/*pagination*/
.pagination { display: block; margin:0 auto 0;}
.pagination .page-numbers { display: flex; justify-content: center; align-items: center; gap:10px; }
.pagination .page-numbers li { margin: 0; }
.pagination .page-numbers li:first-child{ flex-grow: 2; }
.pagination .page-numbers li:first-child span{float: right; }
.pagination .page-numbers li:first-child a{float: none; }
.pagination .page-numbers li:last-child{ flex-grow: 2; }
.pagination .page-numbers li:last-child a{float: right; }
.pagination .page-numbers li a,
.pagination .page-numbers li span,
.pagination .page-numbers li .current {
    display: flex;  justify-content: center; align-items: center;
    width: 50px; height: 50px; line-height: 50px; border-radius: 50px;
    color: #000;
    background: #ccc;
}
.pagination .page-numbers li .current { color: #fff; background: #000;}
.pagination .page-numbers li .first,
.pagination .page-numbers li .prev,
.pagination .page-numbers li .next,
.pagination .page-numbers li .last {
    text-indent: -9999px;
    background-color:#fff;
    background-repeat: no-repeat !important;
    background-position: center center !important;
    background-size: 15px auto !important;
}
.pagination .page-numbers li .first { background-image:url(images/common/icon_first.svg);}
.pagination .page-numbers li .prev { background-image:url(images/common/icon_prev.svg);}
.pagination .page-numbers li .next { background-image:url(images/common/icon_next.svg);}
.pagination .page-numbers li .last { background-image:url(images/common/icon_last.svg);}
@media only screen and (max-width:768px){
}
@media only screen and (max-width:468px){
    .pagination .page-numbers li .first,
    .pagination .page-numbers li .last { display: none;}
}



/* =========================================================================================
Single-Page
=========================================================================================*/
.single .single-navi { display: flex; flex-wrap: wrap; justify-content: center; gap:20px 0; padding-top: 100px; margin-top: 0; padding-top: 0;}
.single .single-navi a { color: #000; box-sizing: border-box;}
.single .single-navi a:hover { text-decoration: none;}
.single .single-navi .list-nav a {
    display: block;
    padding: 5px 20px;
    color: #000;
    text-align: center;
    border: 1px solid #000;
}
.single .single-navi .prev-navi a,
.single .single-navi .next-navi a {
    display: block;
    padding: 5px 30px;
    color: #000;
    width: auto;
    box-sizing: border-box;
    background-repeat: no-repeat;
    background-size: 15px;
}
.single .single-navi .prev-navi a {
    text-align: left;
    background-image: url("images/common/pager_prev.svg");
    background-position: left;
}
.single .single-navi .next-navi a {
    text-align: right;
    background-image: url("images/common/pager_next.svg");
    background-position: right;
}
@media only screen and (max-width:768px){
}
@media only screen and (max-width:468px){
	.single .single-navi { padding-top:50px;}
    .single .single-navi a { font-size: 87.5%;}
    .single .single-navi div:nth-child(2) {display: none;}
    .single .single-navi .list-nav { width: 100%;}
    .single .single-navi .prev-navi,
    .single .single-navi .next-navi { width: 50%;}
    .single .single-navi .list-nav a,
    .single .single-navi .prev-navi a,
    .single .single-navi .next-navi a { padding: 5px 30px;}
}



/* =========================================================================================
 Header Title ( Single / Archive / Page )
=========================================================================================*/
.entry-header {
    padding: 50px 0;
    font-size:225%;
    text-align: center;
    color: #fff;
    background:url("images/common/tit_bg.webp") no-repeat center center;
    background-size: cover;
}
@media only screen and (max-width:768px){
    .entry-header { padding: 40px 0; font-size: 187%;}
}
@media only screen and (max-width:468px){
    .entry-header { padding: 40px 0 ;}
}



/* =========================================================================================
Breadcrumbs ( Single / Archive / Page )
=========================================================================================*/
.breadcrumbs {
    display: flex;
    margin: auto;
    padding: 20px 0;
    width: 90%; max-width: 1200px;
    font-size: 87.5%;
    border-bottom: 1px solid #dddd;
}
.breadcrumbs li + li::before { content:"-"; padding: 0 10px;}
.breadcrumbs li a { color: #000;}



/* =========================================================================================
  Editer
=========================================================================================*/
.sb_content { display: flex; flex-direction: column; gap:40px; max-width: 1000px; }

/*Hr*/
.wp-block-separator{
    height: 1px;
    border: none;
    background-color: #ddd;
    margin: 5vh 0;
}
.wp-block-separator.is-style-dots:before{
    font-size: 3.0em;
    letter-spacing: 1.0em;
    padding-left: 1.0em;
}

/*Midashi*/
h1.wp-block-heading {
    padding-bottom: 20px;
    font-size:200% !important;
	font-weight:700;
    color: #12327F;
    border-bottom: 3px solid #82263C;
}
h2.wp-block-heading {
    padding:10px 20px 20px;
    font-size:200% !important;
	font-weight:700;
    color: #476BC4;
    border-left: 7px solid #476BC4;
    border-bottom: 3px solid #476BC4;
}
h3.wp-block-heading {
    padding-left: 20px;
    font-size:125% !important;
	font-weight:700;
    color: rgba(87,167,64,0.80);
    border-left: 7px solid rgba(87,167,64,0.80);
}
h4.wp-block-heading {
    font-size: 125% !important;
	font-weight:700;
    color: #82263C;
}
h5.wp-block-heading { font-size: 112.5% !important; font-weight:700;}
h6.wp-block-heading { font-size: 100% !important; font-weight:700;}
@media only screen and (max-width:468px){
	h2.wp-block-heading { font-size:125% !important;}
	h3.wp-block-heading { font-size:112.5% !important; padding-left: 10px; line-height: 100%; }
	h4.wp-block-heading { font-size:112.5% !important;}
}


/* Button */
.btn { margin-top: 100px; width: 100%;}
.btn p { margin: auto; max-width: 460px;}
.btn p a {
    display: block;
    padding: 15px;
    font-size: 125%;
    font-weight:400;
    text-align: center;
    color: #333;
    background: #fff;
    box-shadow: 0px 0px 6px 0px rgba(0, 0, 0, 0.15);
    border-radius: 10px;
}

/*blockquote*/
blockquote{
    position:relative;
    padding: 20px;
    background:#f5f5f5;
}
blockquote cite {
    display: block;
    font-size: 0.8rem;
    text-align: right;
    color: #808080;
    padding-right:20px;
}
@media only screen and (min-width:768px){
}
@media only screen and (max-width:768px){
    /*Midashi*/
    h1.wp-block-heading { font-size: 162.5% !important;}
    h2.wp-block-heading { font-size: 162.5% !important; }
    h3.wp-block-heading { font-size: 150% !important; }
    h4.wp-block-heading { font-size: 137% !important; }
    h5.wp-block-heading { font-size: 112.5% !important; }
    h6.wp-block-heading { font-size: 100% !important; }
}
@media only screen and (max-width:468px){
}



/* =========================================================================================
Original_item
=========================================================================================*/

/* Background */
.bg_b { background:url("images/common/bg.webp") no-repeat center top;}
.bg_w { background:#fff;}


/* Indention */
.indention {
	clear:both;
	margin: 0 2%;
	height:20px;
	text-indent: -9999px;
}


/* Midashi */
.mid { text-align: center;}
.mid b {
    position: relative;
    font-size: 250%;
    font-weight: 700;
    letter-spacing: 2px;
}
.mid b span {position: relative;}
.mid b::before {
    display: block; clear: both; content:"";
    position: absolute; left: 0; right: 0; bottom:0;
    margin: auto;
    width: 100%; height: 20px;
    background:rgba(71,107,196,0.50);
    border-radius: 40px;
}
.mid.mid_b b::before { background:rgba(71,107,196,0.50);}
.mid.mid_g b::before { background:rgba(87,167,64,0.50);}
.mid2 {
    text-align: center;
    color: #476BC4;
    font-size: 187.5%;
}
@media only screen and (max-width:768px){
    .mid b { font-size:200%;}
    .mid2 {font-size: 150%;}
}
@media only screen and (max-width:468px){
    .mid b { font-size: 130%; letter-spacing: -1px;}
    .mid b::before { height: 15px;}
    .mid2 {font-size: 125%;}
}


/* Catch */
.catch {
    font-family: "Zen Maru Gothic", sans-serif;
    font-size:150%;
    font-weight:600;
	color: #000;
	line-height: 150%;
	/*text-align: center;*/
}
.catch2 {
    font-size:150%;
	line-height: 150%;
    font-weight:600;
	color: #82263C;
}
@media only screen and (max-width:468px){
    .catch { font-size:150%;}
}


/* Comment */
.come,
.comment {
	font-family: "Noto Sans JP", sans-serif;
	font-weight:400;
    font-size: 112.5%;
}
.come_sine { text-align: right; font-size: 95%; line-height:180%;}
.come_gray { padding:3%; background: #f6f6f6;}


/* Notes */
.notes { position: relative; padding-left: 15px; font-size: 87.5%; line-height: 150%;}
.notes::before { position: absolute; top:0; left: 0; content:"※";}


/* Link txt */
.link_txt { display: flex; justify-content: center; gap:20px;}
.link_txt p a {
    display: block;
    padding: 10px 30px 10px 10px;
	color: #222;
    text-align: center;
    border-bottom: 1px solid #000;
    background: url("images/common/arrow_b.png") no-repeat right center;
    background-size: 20px auto;
}
@media only screen and (min-width:768px){
    .link_txt p a:hover { color: #82263C; border-color: #82263C; text-decoration: none;}
}


/* Temp box */
.temp_box1 { display: flex; flex-wrap:wrap; gap:40px;}
.temp_box1 .photo { display: flex; flex-direction: column; gap:10px; width: 46%; text-align: center;}
.temp_box1 .photo img { width: 100%; height: auto;}
.temp_box1 .photo .caption {
	font-family: "Noto Sans JP", sans-serif;
	font-weight:400;
}
.temp_box1 .cont { 
    display: flex; flex-direction: column; gap:40px;
    width: calc(100% - 46% - 40px);
}
.temp_box1 .cont.full-width { width: 100%;}
.temp_box1.row-re { flex-direction: row-reverse;}
@media only screen and (max-width:768px){
    .temp_box1 { flex-direction: column;}
    .temp_box1 .photo,
    .temp_box1 .cont { width: 100%;}
}


/* Temp box */
.temp_box2 { overflow: hidden;}
.temp_box2 .photo.pic_r { float: right; width: 46%; margin-left: 40px; margin-bottom: 20px;}
.temp_box2 .photo.pic_l { float: left; width: 46%; margin-right: 40px; margin-bottom: 20px;}
.temp_box2 .photo img { width: 100%; height: auto;}
@media only screen and (max-width:468px){
    .temp_box2 { display: flex; flex-direction: column-reverse; gap:40px;}
    .temp_box2 .photo,
    .temp_box2 .come { float: none; width: 100% !important; margin: 0 !important;}
}


/* Gallery*/
.gallery { display: flex; flex-wrap: wrap; gap:20px;}
.gallery.col2 p { width : calc(100% / 2 - 10px) ; }
.gallery.col3 p { width : calc(100% / 3 - 13.33px) ; }
.gallery.col4 p { width : calc(100% / 4 - 15px) ; }
.gallery.col5 p { width : calc(100% / 5 - 16px) ; }
.gallery p.col2 { width : calc(100% / 2 - 10px) ; }
.gallery p.col3 { width : calc(100% / 3 - 13.33px) ; }
.gallery p.col4 { width : calc(100% / 4 - 15px) ; }
.gallery p.col5 { width : calc(100% / 5 - 16px) ; }
.gallery p img {
    width : 100%; height: auto;
	aspect-ratio: 6 / 4; 
	object-fit: cover;
}
.gallery .caption {
	display: block; font-size: 87.5%; text-align:center;
    padding-top: 20px;
	font-family: "Noto Sans JP", sans-serif; font-weight:400; color: #555;
}
@media only screen and (max-width:468px){
    .gallery p,
    .gallery.col2 p,
    .gallery.col3 p,
    .gallery.col4 p,
	.gallery.col5 p{ width : calc(100% / 2 - 10px) !important; }
    .gallery.sp_col2 p { width : calc(100% / 2 - 10px) !important; }
    .gallery.sp_col3 p { width : calc(100% / 3 - 13.33px) !important; }
    .gallery.sp_col4 p { width : calc(100% / 4 - 15px) !important; }
    .gallery.sp_col5 p { width : calc(100% / 5 - 16px) !important; }
}


/* Category tab */
.cate_tab { display: flex; justify-content: center; gap:20px; margin: auto; width:100%; max-width:1200px;}
.cate_tab p a {
	display: block;
	padding: 5px 25px 5px 5px;
	font-family: "Noto Sans JP", sans-serif;
	font-weight:400;
	color: #414A60;
	border-bottom: 1px solid #414A60;
    background: url("images/common/arrow_anchor.svg") no-repeat right center;
    background-size: 15px auto;
}
.cate_tab p.active a { color: #fff; background: #414A60;}
.cate_tab p + p a { border-left: 0;}


/* Button */
.b_more { margin: auto; width: 100%; max-width: 340px;}
.b_more a {
    display: block;
    padding: 20px;
    color: #fff;
    font-size: 162.5%;
    font-weight:700;
    text-align: center;
    text-decoration: none;
    background:#476BC4 url("images/common/arrow_w1.svg") no-repeat 90% center;
    background-size: 20px auto;
    border-radius: 100px;
    box-shadow: 0px 0px 6px rgba(0, 0, 0, 0.20);
    transform: .3s;
}
@media only screen and (min-width:768px){
    .b_more a:hover {
        opacity: 0.8;
        background-position: 92% center;
    }
}
@media only screen and (max-width:768px){
    .b_more a { padding: 17px; font-size: 137%;}
}
@media only screen and (max-width:468px){
    .b_more a { padding: 15px; font-size: 125%;}
}



/* =========================================================================================
 About
=========================================================================================*/
.about .inner { display: flex; flex-direction: column; gap:40px;}
.about .pic { margin:0 auto; width: 90%; max-width: 890px;}
.about .come { text-align: center;}
.about ul.about_slide { margin:0 auto 150px; width:380px;}
.about ul.about_slide li { margin: 0 10px;}
.about ul.about_slide img { max-width:100%; height:auto; border-radius: 30px;}
.about ul.about_slide .slick-list { overflow:visible;}
.dekiru .inner { 
    display: flex; flex-direction: column; gap:40px;
    background-image: url("images/dekiru_bg1.webp"), url("images/dekiru_bg2.webp");
    background-repeat: no-repeat, no-repeat;
    background-position: left 50px, right 50px;
    background-size: 20% auto, 20% auto;
}
.dekiru h3::before {
    position: absolute; top:-150px; left: 0; right: 0;
    display:block; clear: both; content:"";
    margin: auto;
    width: 190px; height: auto;
    aspect-ratio: 286 / 358;
    background: url("images/dekiru_main.webp") no-repeat;
    background-size: 100% auto;
}
.dekiru .come { text-align: center;}
.dekiru .gallery img {
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-radius: 500px;
}
@media only screen and (max-width:768px){
    .about ul.about_slide { margin:0 auto 100px;}
    .dekiru h3::before { top:-100px; width:120px;}
}
@media only screen and (max-width:468px){
    .about ul.about_slide { width:300px;}
    .about { overflow: hidden;}
    .about .come { text-align: left;}
    .dekiru .come { text-align: left;}
}



/* houchi */
.houchi { display:flex; flex-direction:row; gap:40px;}
.houchi .box {
	display:flex; flex-direction: column; gap:10px;
	padding:30px;
	width:50%;
    border-radius:30px;
	background:url("images/common/bg.webp") no-repeat center top;
}
.houchi .box b,
.houchi .box span { display:block;}
.houchi .box ul {display:flex; flex-direction: column; gap:20px;}
.houchi .box ul li {display:flex; gap:5px 20px;}
.houchi .box .pic { width:100px;}
.houchi .box .come { width:calc(100% - 100px - 10px); text-align:left;}
@media only screen and (max-width:768px){
    .houchi { flex-direction: column; gap:20px;}
    .houchi .box { margin: auto; width:100%;}
    .houchi .box .pic { width:80px;}
    .houchi .box .come { width:calc(100% - 80px - 10px);}
}
@media only screen and (max-width:468px){
    .houchi .box ul li { flex-direction: column;}
    .houchi .box .pic { margin: auto;}
    .houchi .box .come { width:100%;}
    .houchi .box .come b { width:100%; text-align: center;}
}



/* =========================================================================================
 How to
=========================================================================================*/
.howto .inner { display: flex; flex-direction: column; gap:40px;}
.howto .howto_flow dl { display: flex; flex-direction: column; gap:20px;}
.howto .howto_flow dl + dl:before {
    display: block; clear: both; content:"";
    margin:30px auto 0;
    width: 114px; height: auto;
    aspect-ratio: 114 / 47;
    background: url("images/arrow.webp") no-repeat;
    background-size: 100% auto;
}
.howto .howto_flow dl dt { font-weight: 600;}
.howto .howto_flow dl dd { display: flex; gap:40px;}
.howto .howto_flow dl dd .box {
    position: relative;
    display: flex; flex-direction: column; gap:20px;
    padding: 5%;
    background: #fff;
    border-radius: 30px;
}
.howto .howto_flow dl dd.col1 .box { width:100%;}
.howto .howto_flow dl dd.col2 .box { width: 50%; padding: 150px 5% 5%;}
.howto .howto_flow dl dd .box .pic {
    position: absolute; top:-50px; left: 0; right: 0;
    margin: auto;
    width: 50%; max-width: 250px;
}
.howto .howto_flow dl dd .box .mm { font-size:162.5%; font-weight: 600; text-align: center;}
.howto .howto_flow dl dd .box .btn { margin: 0;}
.howto .howto_flow .b_contact {
    display: flex; flex-direction: column; gap:5px;
    margin: auto; width: 230px;
}
.howto .howto_flow .b_contact span { display: block;}
.howto .howto_flow .b_contact span a { 
    display: block;
    padding:10px;
    width: 100%;
    text-decoration: none;
    border-radius: 50px;
    box-sizing: border-box;
}
.howto .howto_flow .b_contact .tel a {
    cursor: pointer;
    padding-left: 25px;
    font-family: "Roboto", sans-serif;
    font-size: 175%;
    font-weight: 500;
    color: #12327F;
    letter-spacing: -1px;
    background: url("images/common/icon_tel.svg") no-repeat left center;
    background-size: 20px auto;
}
.howto .howto_flow .b_contact .btn a {
    padding-right: 10px;
    font-size: 100%;
    font-weight: 600;
    color: #fff;
    text-align: center;
    letter-spacing: -1px;
    background:#D8452E url("images/common/arrow_w1.svg") no-repeat 95% center;
    background-size: 17px auto;
}
@media only screen and (max-width:768px){
    .howto .howto_flow dl dd { flex-direction: column;}
    .howto .howto_flow dl dd.col2 .box { width:100%; padding-top: 100px;}
    .howto .howto_flow dl dd .box .pic { top:-20px; max-width: 150px;}
}
@media only screen and (max-width:468px){
    .howto .howto_flow dl dd .box .mm { font-size:125%;}
    .howto .howto_flow dl + dl:before { width: 50px;}
}



.sagyou_flow {
    display: flex; flex-direction: column;
}
.sagyou_flow dl {
    position: relative;
    padding: 50px 50px 50px 200px;
}
.sagyou_flow dl + dl { border-top:1px solid #ddd;}
.sagyou_flow dl dt {margin-bottom: 10px; font-size:125%; font-weight: bold;}
.sagyou_flow dl:before {
    position: absolute; top:0; left: 20px; bottom: 0;
    display: block; clear: both; content:"";
    margin: auto;
    width: 150px; height: 150px; aspect-ratio: 1 / 1;
    background-size:cover !important;
    border-radius: 150px;
}
.sagyou_flow dl::after {
    position: absolute; top:30px; left: -10px;
    display: block; clear: both; content:"";
    width: 60px; height: auto; aspect-ratio: 1 / 1.1;
    background-size: 100% auto !important;
}
.sagyou_flow dl:nth-child(1)::before { background:url("images/step_icon1.png") no-repeat center center;}
.sagyou_flow dl:nth-child(2)::before { background:url("images/step_icon2.png") no-repeat center center;}
.sagyou_flow dl:nth-child(3)::before { background:url("images/step_icon3.png") no-repeat center center;}
.sagyou_flow dl:nth-child(4)::before { background:url("images/step_icon4.png") no-repeat center center;}
.sagyou_flow dl:nth-child(5)::before { background:url("images/step_icon5.png") no-repeat center center;}
.sagyou_flow dl:nth-child(1)::after { background:url("images/step1.webp") no-repeat;}
.sagyou_flow dl:nth-child(2)::after { background:url("images/step2.webp") no-repeat;}
.sagyou_flow dl:nth-child(3)::after { background:url("images/step3.webp") no-repeat;}
.sagyou_flow dl:nth-child(4)::after { background:url("images/step4.webp") no-repeat;}
.sagyou_flow dl:nth-child(5)::after { background:url("images/step5.webp") no-repeat;}
@media only screen and (max-width:768px){

}
@media only screen and (max-width:468px){
    .sagyou .sb_content { gap:0;}
    .sagyou_flow dl { padding:40px 0;}
    .sagyou_flow dl:before { position: static; margin-bottom: 20px; width: 100px; height:100px;}
    .sagyou_flow dl:after { top:30px; left:28%; width: 40px;}
    .sagyou_flow dl dt { text-align: center;}
}



.jirei .inner { display: flex; flex-direction: column; gap:40px;}
.jirei .jirei_list { display: flex; flex-direction: column; gap:20px;}
.jirei .box {
    position: relative;
    display: flex; flex-direction: column; gap:20px;
    padding: 5%;
    color: #222;
    background: #fff;
    border-radius: 30px;   
}
.jirei .box .pic { display: flex; gap:40px;}
.jirei .box .pic img { width: 100%; height: auto; aspect-ratio: 6 / 5; object-fit: cover; border-radius: 30px;}
.jirei .box .pic p { position: relative; width: 50%;}
.jirei .box .pic p::before {
    position: absolute; top:0; left: 0; z-index: 9;
    display: block; clear: both; content:"";
    width: 70px; height: auto; aspect-ratio: 1 / 1;
    background-size: 100% auto !important;
}
.jirei .box .pic p:nth-child(1)::before { background: url("images/before.webp") no-repeat;}
.jirei .box .pic p:nth-child(2)::before { background: url("images/after.webp") no-repeat;}
.jirei .box .pic p + p::after {
    display: block; clear: both; content:"";
	position:absolute; top:44%; left:-30px;
    width: 25px; height: auto; aspect-ratio: 47 / 114;
    background: url("images/arrow2.webp") no-repeat;
	background-size:100% auto !important;
}
.jirei .box .come {text-align: center; font-weight: bold;}
@media only screen and (max-width:768px){
}
@media only screen and (max-width:468px){
    .jirei .inner { padding-top:0;}
    .jirei .box { padding: 10px; border-radius:20px;}
    .jirei .box .pic { gap:20px;}
    .jirei .box .pic img { border-radius: 10px;}
    .jirei .box .pic p::before { width: 50px;}
    .jirei .box .pic p + p::after { width: 13px; left:-15px; top:40%;}
}



/* =========================================================================================
 Voice
=========================================================================================*/
/* Voice list */
.voice_list { display: flex; gap:50px 35px; }
.voice_list .box { display: flex; flex-direction: column; gap:20px; }
.voice_list .box .pic img {
    width: 100%; height: auto;
    aspect-ratio: 6 / 4;
    object-fit: cover;
    border-radius: 30px;
}
.voice_list .box .cont { display: flex; flex-direction: column; gap:20px; }
.voice_list .box .b_more { max-width: 250px;}
.voice_list .box .b_more a {
    padding: 10px;
    font-size: 125%;
}
@media only screen and (max-width:768px){
    .voice_list .voice_cont { flex-direction: column; }
    .voice_list .box { flex-direction: row; }
    .voice_list .box .pic { width: 55%;}
    .voice_list .box .cont { width:calc(55% - 20px);}
}
@media only screen and (max-width:468px){
    .voice_list .voice_cont { flex-direction: column; }
    .voice_list .box { flex-direction: column; }
    .voice_list .box .pic,
    .voice_list .box .cont { width:100%;}
    .voice_list .box .b_more a { font-size: 112.5%;}
}


/* Voice detail */
.voice_detail { display: flex; flex-direction: column; gap:100px;}
.voice_detail .profile { display: flex; flex-wrap:wrap; gap:40px;}
.voice_detail .profile .photo { width: 30%;}
.voice_detail .profile img { width: 100%; height: auto; aspect-ratio: 47 / 60; object-fit: cover;}
.voice_detail .profile.cont { 
    display: flex; flex-direction: column;
    width: calc(100% - 30% - 40px);
}
.voice_detail .profile .catch { font-size: 225%; line-height: 150%; text-align: left;}
.voice_detail .profile .gakunen { font-size: 100%; margin: 30px 0; width:180px; text-align: center; color: #fff; background: #000;}
.voice_detail .profile .namae { margin-bottom: 20px;}
.voice_detail .profile .namae b { font-size: 225%;}
.voice_detail .profile .namae small { font-size: 87.5%; margin-left: 20px; color: #555;}
.voice_detail .profile .now { font-size: 125%;}
.voice_detail .profile .other { font-size: 100%;}
.voice_detail .message {
    position: relative;
    padding:40px 30px 30px;
    background: url("images/come_bg.jpg") repeat center center;
}
.voice_detail .message h4 {
    position: absolute; top: -15px; left: 0;
    width: 100%;
    font-size: 162.5%;
    text-align: center;
}
@media only screen and (max-width:768px){
    .voice_detail .profile .catch { font-size: 162.5%;}
    .voice_detail .profile .gakunen { font-size: 87.5%; margin: 15px 0;}
    .voice_detail .profile .namae { margin-bottom: 10px;}
    .voice_detail .profile .namae b { font-size: 162.5%;}
    .voice_detail .profile .namae small { font-size: 75%;}
    .voice_detail .profile .now { font-size: 100%;}
    .voice_detail .profile .other { font-size: 87.5%;}
}
@media only screen and (max-width:468px){
	.voice_detail .profile .catch p { display:inline;}
    .voice_detail .profile .photo { margin: auto; width: 280px;}
    .voice_detail .profile.cont {  width: 100%;}
    .voice_detail .message h4 { font-size: 137%;}
}



/* =========================================================================================
 Faq
=========================================================================================*/
.faq_list { display: flex; flex-wrap: wrap; flex-direction: column; gap:0;}
.faq_list dl { display: flex; flex-direction: column; gap:15px; padding:50px;}
.faq_list dl:nth-child(odd) { background: url("images/common/bg.webp") repeat top center;}
.faq_list dt,
.faq_list dd { position: relative; line-height: 1.5;}
.faq_list dt { padding-left:50px; font-size:125%; font-weight:700; color: #12327F;}
.faq_list dd { padding-left:50px;}
.faq_list dt:before,
.faq_list dd:before {
    display: block; clear: both;
    position: absolute; left: 0; top:0;
    font-family: "Noto Serif JP", serif;
    font-size: 30px;
    line-height: 1.5;
}
.faq_list dt:before { content:"Q"; top:-5px; color: #12327F;}
.faq_list dd:before { content:"A"; opacity: 0.5; color:#D8452E;}
.faq_list dd a { text-decoration: underline;}
@media only screen and (max-width:768px){
	.faq_list dl { padding:30px;}
}
@media only screen and (max-width:468px){
	.faq_list dl { padding:20px;}
	.faq_list dt { padding-left:30px;}
	.faq_list dd { padding-left:30px;}
}



/* =========================================================================================
 News
=========================================================================================*/
.news_list { display: flex; flex-direction: column; gap:5px; border-top: 1px solid #ddd;}
.news_list ul { display: flex; gap:0 20px; padding: 20px; border-bottom: 1px solid #ddd;}
.news_list ul li:nth-child(1) { width: 90px;}
.news_list ul li:nth-child(2) { width:calc(100% - 90px - 20px);}
.news_list ul li:nth-child(2) a { color: #222;}
@media only screen and (max-width:468px){
    .news_list ul { flex-direction: column;}
    .news_list ul li:nth-child(1),
    .news_list ul li:nth-child(2) { width:100%; line-height: 150%;}
}



/* =========================================================================================
 News
=========================================================================================*/
.one_plan {
    margin: auto;
    max-width: 800px;
    padding: 20px 40px;
    background: #fff;
    border-radius: 100px;
}
@media only screen and (max-width:468px){
    .one_plan { border-radius: 10px;}
}

.plan { display: flex; flex-direction: column; gap:40px;}
.plan h3 { margin: 0; font-size:187.5%; color:#476BC4; text-align: center; text-decoration: underline;}
.plan .come { text-align: center;}
.plan .plan_list { 
    display: flex;
    padding: 20px 0;
    background: #fff;
    border-radius: 30px;
    box-shadow: 0px 0px 6px rgba(0, 0, 0, 0.15);
}
.plan .plan_list .box { padding: 0 20px; width: 33.3%;}
.plan .plan_list .box + .box { border-left: 1px solid #ddd;}
.plan .plan_list .box p { margin: auto; padding: 20px 0; width: 100%; max-width: 235px;}
.plan .plan_list .box ul { display: flex; flex-wrap: wrap; justify-content: center; gap: 5px;}
.plan .plan_list .box ul li { width:calc(50% - 2.5px); min-width: 130px;}
.plan .plan_list .box ul li a {
    display: block;
    padding:5px 15px;
    color: #fff;
    font-size: 100%;
    font-weight:700;
    text-decoration: none;
    background-size: 20px auto !important;
    border-radius: 100px;
}
.plan .plan_list .box ul li:nth-child(1) a {
    color: #476BC4;
    background:#ECF0F9 url("images/common/arrow_b1.svg") no-repeat 90% center;
}
.plan .plan_list .box ul li:nth-child(2) a {
    color: #fff;
    background:url("images/common/arrow_w1.svg") no-repeat 90% center;
}
.plan .plan_list .box:nth-child(1) ul li:nth-child(2) a { background-color:#5F7DC6;}
.plan .plan_list .box:nth-child(2) ul li:nth-child(2) a { background-color:#49B3A5;}
.plan .plan_list .box:nth-child(3) ul li:nth-child(2) a { background-color:#E1B720;}
@media only screen and (min-width:768px){
    .plan .plan_list .box ul li a:hover {
        opacity: 0.8;
        background-position: 92% center;
    }
}
@media only screen and (max-width:768px){
    .plan h3 { font-size:162.5%;}
}
@media only screen and (max-width:468px){
    .plan h3 { font-size:137.5%;}
    .plan .come { text-align:left;}
    .plan .plan_list  { flex-direction: column; padding: 0;}
    .plan .plan_list .box { padding: 20px 10px; width:100%;}
    .plan .plan_list .box + .box { border-left: none; border-top: 1px solid #ddd;}
    .plan .plan_list .box p {max-width: 300px;}
}



.option ul.option_list { position: relative; display:flex; flex-wrap: wrap; gap:20px;}
.option ul.option_list::before {
    position: absolute; top: -230px; right: 2%;
    display: block; clear: both; content:"";
    width: 100%; width: 200px; height: auto; 
    aspect-ratio: 426 / 500;
    background: url("images/plan_man.png") no-repeat;
    background-size: 100% auto;
}
.option ul.option_list li {
    padding: 20px;
    width:calc(50% - 10px);
    text-align: center;
    background: #F2ECE2;
    border-radius: 30px;
}
.option ul.option_list li img {
    width: 100%; max-width: 360px;
    height: auto;
    aspect-ratio: 734 / 170;
}
.option .come { text-align: center;}
.option .btn_box { display:flex; gap:10px 40px; margin: auto; width: 100%; max-width: 750px;}
.option .btn_box .b_more { width: 50%;}
@media only screen and (max-width:768px){
    .option ul.option_list::before { width: 150px; top:-175px;}
    .option .btn_box { flex-direction: column;}
    .option .btn_box .b_more { width: 100%;}
}
@media only screen and (max-width:468px){
    .option ul.option_list::before { width: 100px; top:-200px; left: 0; right: 0; margin: auto;}
    .option ul.option_list { flex-direction: column; gap:10px;}
    .option ul.option_list li { padding: 10px; width: 100%; border-radius: 10px;}
    .option .come { text-align:left;}
}



/* =========================================================================================
Page(404)
=========================================================================================*/
.error404 .entry-header{
    text-align: center;
    padding:40px 20px;
    margin: 0 ;
    display: flex; justify-content: space-between; border-bottom: 1px solid #ddd;
    
}

.error404 .error-message{
    padding: 20px;
    margin-bottom: 30px;
    text-align: center;
}
    .error404 .error-message p img{
        margin: 0 auto 80px;
        max-width: 250px;
    }

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



/* =========================================================================================
Page(ALL)
=========================================================================================*/
@media only screen and (max-width:768px){
}
@media only screen and (max-width:468px){
}



/* =========================================================================================
Page(×××××××)
=========================================================================================*/
@media only screen and (max-width:768px){
}
@media only screen and (max-width:468px){
}



/* =========================================================================================
Page(contact)
=========================================================================================*/
#contact { margin: auto; width: 100%; max-width: 800px;}
#contact form {
    position: relative;
    margin: 0 auto;
    box-sizing: border-box;
    background: #fff;
}
#contact label {font-weight:700;}
#contact input[type="tel"],
#contact input[type="text"],
#contact input[type="email"],
#contact textarea {
	padding:5px 10px;
	border:1px solid #EEE;
	background:#f6f6f6;
	box-sizing:border-box;
	border-radius:5px;
}
#contact textarea { width:100%; height:120px;}
#contact select { padding:5px 10px; border:1px solid #EEE; background:#FAFAFA; appearance:auto !important; }
#contact input[type="file"] { display:block; padding:5px; background:#F6F6F6;}
#contact input:focus,
#contact textarea:focus {
    background:rgba(144,202,197,0.10);
}
#contact .b_btn,
#contact .b_back {
    display: block;
    margin: 40px auto 0;
    padding: 0 30px;
    width: 300px; height: 60px; line-height: 60px;
    font-size: 125%;
    font-weight:700;
    text-align: center;
    color: #fff;
    box-sizing: border-box;
    border: none;
    border-radius: 100px;
}
#contact .b_btn { background: #000;}
#contact .b_back { background: #777;}
#contact .b_btn:hover,
#contact .b_back:hover {
    opacity: 0.7;
    transition: 0.3s;
}
#contact .hissu {
    position: relative; top: 5px;
    display: inline-block;
    margin-left:10px;
    width: 50px; height: 20px; line-height: 20px;
    color: #fff;
    font-size: 10px;
    text-align: center;
    background:rgba(217,66,68,1.00);
    border-radius: 30px;
}
#contact dl { display: flex; flex-wrap: wrap; border-top: 1px solid #ddd; border-bottom: 1px solid #ddd;}
#contact dl + dl {border-top:none;}
#contact dt,
#contact dd { padding: 20px;}
#contact dt { display: flex; justify-content: space-between; width: 250px; font-weight:700;}
#contact dd { display: flex; flex-direction: column; gap:10px; width: calc(100% - 250px);}
#contact dd p { display: flex; gap:10px;}
#contact dd .w20 { width: 100%; max-width: 200px;}
#contact dd .w30 { width: 100%; max-width: 300px;}
#contact dd .w100 { width: 100% !important; }
@media only screen and (max-width:768px){
    #contact dl { flex-direction: column;}
    #contact dl + dl {border-top:none;}
    #contact dt { width: 100%; padding:10px 10px 0;}
    #contact dd { width: 100%; padding:5px 10px 20px;}
    #contact dt span.hissu { margin-left: 10px;}
    #contact input[type="tel"],
    #contact input[type="text"],
    #contact input[type="email"],
    #contact textarea { width: 100%; }
	#contact .b_btn,
	#contact .b_back {
		padding: 0 10px;
		width: 120px; height: 40px; line-height: 40px;
		font-size: 125%;
	}
}
@media only screen and (max-width:468px){
}