@charset "utf-8";

/*----------------------------------------------------------------------------------------------------------------------------

reset & root set

----------------------------------------------------------------------------------------------------------------------------*/

/* reset
--------------------------------------------------------------*/

*,*::before,*::after { box-sizing: border-box; }
ul,ol { margin: 0; padding: 0; list-style: none; }
body,h1,h2,h3,h4,h5,p,figure,blockquote,dl,dd { margin: 0; font-size: inherit; font-weight: normal; }
img { max-width: 100%; height: auto; display: block; }
header,footer,main,aside,picture { display: block; }


/* iOS Safari tap reset */
body {-webkit-tap-highlight-color: transparent;}

input,
textarea,
select {font-size: 1.6rem;}



/* print set
--------------------------------------------------------------*/
@media print{
html { width: 1280px; }
.header { position: relative !important; }/* fixheader clear */
}


/* root set
--------------------------------------------------------------*/

/* color */
:root {
    --cl-key01: #E89843;
    --cl-txt: #333;
    --cl-wh: #fff;
    --cl-error: #E30000;
    --cl-bg: #FAF6ED;
    --cl-bg-sub: #FDFBF6;
    --cl-bg-dark: #796A56;
    --cl-boder: #ccc;
}

/* fixheader height */
:root { --header-height: 6rem; }
@media print, screen and (min-width: 640px) {
:root { --header-height: 8rem; }
}

/* font set */
:root {
    /* font: style weight size / line-height family */
    --ff-base: normal 400 1.4rem / 1.6 "Kiwi Maru", serif;
    --ff01f: ;
    --ff01w: ;
}




/*----------------------------------------------------------------------------------------------------------------------------

base set

----------------------------------------------------------------------------------------------------------------------------*/
html { font-size:calc(100vw / 37.5); scroll-behavior: smooth; scroll-padding-top: var(--header-height); }
html:has( body._fixed) { overflow: hidden;}
body { min-height: 100vh; text-rendering: optimizeSpeed; -webkit-text-size-adjust:100%; text-size-adjust: 100%; color: var(--cl-txt); background-color: var(--cl-bg); font: var(--ff-base); overflow-x: hidden; }
a { color: var(--cl-txt); outline:none; text-decoration:none; }
a[href^="tel:"] { pointer-events:auto;}
.page-wrapper { overflow-x: hidden; }

@media print, screen and (min-width: 640px) {
html { font-size: calc(100vw / 128); }
body { font-size: 1.6rem; }
.page-wrapper { overflow-x: visible; }
a[href^="tel:"] { pointer-events:none;}
}

@media print, screen and (min-width: 1280px) {
html { font-size:62.5%; }
body { font-size: 1.6rem; }
a { transition: 0.5s; }
a:hover { opacity: 0.7; }
button:hover { opacity: 0.7; }
}



/*----------------------------------------------------------------------------------------------------------------------------

utility

----------------------------------------------------------------------------------------------------------------------------*/

/* utility - base
---------------------------------------------------- */

/* utility - base responsive */
.u-inner { max-width: 100rem; margin: 0 auto; width: 90%; }
.u-inner._min { max-width: 80rem;}
.u-only-pc { display: none; }

@media print, screen and (min-width: 640px) {
.u-only-sp { display: none !important; }
.u-only-pc { display: inherit; }
}


/* utility - base */
.u-ff01 { font-family: var(--ff01f); font-weight: var(--ff01w); }
.u-cl-txt { color: var(--cl-txt); }
.u-cl-wh { color: var(--cl-wh); }
.u-cl-key01 { color: var(--cl-key01); }
.u-cl-key02 { color: var(--cl-key02); }
.u-iframebox { position:relative; padding-bottom:56.25%; height:0; }
.u-iframebox iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.u-w30 { width: 30% !important; }
.u-w50 { width: 50% !important; }
.u-mt01 { margin-top: 1rem !important; }
.u-mt02 { margin-top: 2rem !important; }
.u-mt03 { margin-top: 3rem !important; }
.u-mb01 { margin-bottom: 1rem !important; }
.u-mb02 { margin-bottom: 2rem !important; }
.u-mb03 { margin-bottom: 3rem !important; }

/*----------------------------------------------------------------------------------------------------------------------------

base layout

----------------------------------------------------------------------------------------------------------------------------*/

/* body
--------------------------------------------------------------*/
body._fixed { overflow: hidden;}



/* header
--------------------------------------------------------------*/

/* header */
.header { position: fixed; top: 0; left: 0; width: 100%; height: var(--header-height); display: flex; align-items: center; justify-content: space-between; padding: 1rem 2rem; margin: 0 auto; z-index: 20; background: var(--cl-wh); transition: box-shadow 0.3s ease;}

.header.is-scrolled { box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);}

.header-logo { }
.header-logo-link { display: block; width: 70%; }
.header-logo-pic { width: 11.8rem; }
.header-nav { display: none; }

@media print, screen and (min-width: 640px) {
.header { position: fixed; top: 0; left: 50%; transform: translateX(-50%); padding: 1.8rem 3rem;}
.header-logo-link { display: block; width: 100%; }
.header-nav { display: flex; align-items: center; gap: 3rem;}
.header-navlist { display: flex; flex-direction: row; gap: 3rem;}
.header-nav-contact { }
.contactlink { display: flex; flex-direction: column; align-items: center; padding: 1rem; border-radius: 1.5rem; background-color: var(--cl-key01); color: var(--cl-wh); }
.contactlink-num { display: flex; flex-direction: row; align-items: center; gap: 0.5rem; font-size: 1.8rem; line-height: 1.25em;}
.contactlink-txt {font-size: 1.4rem; line-height: 1em;}
}







/* footer
--------------------------------------------------------------*/

/* footer */
.footer { background: var(--cl-bg-dark); padding: 3rem 2rem 6.5rem;}
.footer-wrap { display: flex; flex-direction: column; gap: 2rem; justify-content: space-between;}
.footer-info { margin-bottom: 1.5rem;}
.footer-info-logo { width: 16.8rem; margin: 1.5rem 0; }
.footer-info-txt { font-size: 1.4rem;color: var(--cl-wh);}
.footer-copy { font-size: 1.2rem; margin-top: 1rem; color: var(--cl-wh);}

.footer-policy { font-size: 1.4rem; text-decoration: underline; color: var(--cl-wh);}
.footer-policy:hover { text-decoration: none;}

.fmenu {}
.fmenu-list { display: flex; flex-direction: column; gap: 1rem;}
.fmenu-list-item {}
.fmenu-list-item a { color: var(--cl-wh);}

.tellink { color: var(--cl-wh);}

.sns { display: flex; gap: 2rem; justify-content: flex-end; margin: -3rem 0 3rem;}
.sns-item {}


@media print, screen and (min-width: 640px) {
.footer { padding: 6rem 4rem 2rem;}
.footer-wrap { flex-direction: row; gap: 2rem;}
.footer-info { margin-bottom: 5rem;}
.footer-info-logo { width: 18.3rem; margin: 0 0 3rem; }
.footer-copy { font-size: 1.4rem; margin-top: 2rem; }

.fmenu {}
.fmenu-list { flex-direction: row; gap: 2rem;}
.fmenu-list-item {}
.fmenu-list-item a { color: var(--cl-wh);}

.sns { margin: 2rem 0 0;}
}


/* spitem
--------------------------------------------------------------*/

/* spitem
--------------------------------------------------------------*/

/* spnav-btn */
.spitem-btn { position: fixed; top: 0; right: 0; -webkit-appearance: none; -moz-appearance: none; appearance: none; border: none; background-color:var(--cl-key01); cursor: pointer; width: 6rem; height: 6rem; border-radius: 0; outline: none; transition:0.5s; z-index: 130; cursor: pointer;}
.spitem-btn::before,
.spitem-btn::after { content: ""; position: absolute; left: 50%; width: 2.2rem; height: 3px; background-color: var(--cl-wh); transform: translateX(-50%); transition:0.3s; }
.spitem-btn::before { top: 2.2rem; }
.spitem-btn::after  { bottom: 2.1rem; }
.spitem-btn-line { position: absolute; top: 0; right: 0; bottom: 0; left: 0; margin: auto; width: 2.2rem; height: 3px; background-color: var(--cl-wh); transition: 0.3s; overflow: hidden; color: var(--cl-wh);}

._close.spitem-btn { }
._close.spitem-btn::before,
._close.spitem-btn::after { content: ""; position: absolute; left: 50%; background-color:var(--cl-wh); transform: translateX(-50%); transition:0.3s; }
._close.spitem-btn::before { top: 50%; transform: translate(-50%,-50%) rotate(45deg) ; left: 50%; }
._close.spitem-btn::after  { bottom: auto; top: 50%; transform: translate(-50%,-50%) rotate(-45deg); left: 50%;}
._close.spitem-btn .spitem-btn-line { display: none; }

@media print, screen and (min-width: 640px) {
.spitem { display: none; }
.spitem-btn { display: none; }
}


/* spnav [wrap] */
.spmenu { opacity: 0; visibility: hidden; position: fixed; top: var(--header-height); right: 0; width: 100%; z-index: 100; transition: 0.3s; }
.spmenu._spopen { opacity: 1; visibility: visible; }
.spmenu-inner { width: 100%; height: calc(100vh - var(--header-height)); padding: 2rem 2rem; overflow-y: scroll; background-color: var(--cl-bg);}


/* spnavMenu */
.spnav {  }
.spnav-item { font-size: 1.6rem; font-weight: var(--ff-base-bold); letter-spacing: 0.18em; }
.spnav-item-link { display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 1rem; width: 100%; }
.spnav-item-link::before { content: ''; width: 3rem; height: 3rem; background: no-repeat left center / contain; }



/* footnav */

.footnav { position: fixed; left: 0; bottom: 0; width: 100%;}
.contactlink { display: flex; flex-direction: column; align-items: center; padding: 1rem; background-color: var(--cl-key01); color: var(--cl-wh); }
.contactlink-num { display: flex; flex-direction: row; align-items: center; gap: 0.5rem; font-size: 1.8rem; line-height: 1.25em; white-space: nowrap;}
.contactlink-txt {font-size: 1.4rem; line-height: 1em;}




/* main contents
--------------------------------------------------------------*/
.main { min-height: 50vh;}
@media print, screen and (min-width: 640px) {
.main { }
}





/*----------------------------------------------------------------------------------------------------------------------------

component

----------------------------------------------------------------------------------------------------------------------------*/
/* c-modal
--------------------------------------------------------------*/

/* c-modal
--------------------------------------------------------------*/

/* c-modal */
.c-modal { position: fixed; top: 0; left: 0; width: 100%; height: 100vh; opacity: 0; visibility: hidden; transition: 0.2s; z-index: 200;background-color: rgba(0,0,0,0.5);  }
.c-modal-body { position: absolute; top: 50%; left: 50%; width: calc(100% - 4rem); padding: 5rem 2rem 2rem; background-color: var(--cl-wh); transform: translate(-50%,-45%); transition: 0.5s; border-radius: 1rem; }
.c-modal-contents { overflow-y: scroll; max-height: 70vh; }
._view.c-modal { opacity: 1; visibility: visible !important; }
._view .c-modal-body { transform: translate(-50%,-50%); }
@media print, screen and (min-width: 640px) {
.c-modal-body { padding: 10rem 8rem 8rem; max-width: 117rem; }
}



.c-modal-close { position: absolute; top: 1rem; right: 1rem; -webkit-appearance: none; -moz-appearance: none; appearance: none; border: none; width: 3rem; height: 3rem; outline: none; border-radius: 100%; }
.c-modal-close::before,
.c-modal-close::after { content: ""; position: absolute; left: 50%; width: 2rem; height: 2px; background-color: var(--cl-key01); transform: translateX(-50%); }
.c-modal-close::before { top: calc(50% - 1px); transform: translateX(-50%) rotate(45deg); }
.c-modal-close::after  { bottom: calc(50% - 1px); transform: translateX(-50%) rotate(-45deg); }

@media print, screen and (min-width: 640px) {

.c-modal-close { top: 2rem; right: 2rem; }
.c-modal-close::before,
.c-modal-close::after { width: 3rem; }

}



/* title
--------------------------------------------------------------*/
.pagettl { position: relative; background: var(--cl-key01); min-height: 16rem; width: 100%; margin-top: var(--header-height);}
.pagettl::after { content: ""; display: inline-block; background: url(/assets/images/deco02.png) no-repeat center bottom; background-size: 50%; width: 100%; height: 6.5rem; position: absolute; bottom: -2rem; left: 50%; transform: translateX(-50%);}
.pagettl-ttl { position: absolute; top: 50%; left: 50%; transform: translateX(-50%) translateY(-50%); text-align: center;}
.pagettl-ttl-en { color: var(--cl-wh); font-size: 1.4rem;}
.pagettl-ttl-jp { color: var(--cl-wh); font-size: 2.6rem;}
@media print, screen and (min-width: 640px) {
.pagettl { min-height: 30rem;}
.pagettl-ttl { }
.pagettl::after { background-size: contain; width: 100%; height: 11rem; bottom: -2rem;}
.pagettl-ttl-en { font-size: 1.4rem;}
.pagettl-ttl-jp { font-size: 3.2rem;}
}




/* c-sec
--------------------------------------------------------------*/
.c-sec { padding: 6rem 0;}
.c-sec._bg { background-color: var(--cl-bg-sub);}
.c-sec-ttl { text-align: center; font-size: 2.2rem; font-weight: 700; color: var(--cl-key01); margin-bottom: 2rem;}
.c-sec-ttl-jp { font-size: 2rem; color: var(--cl-txt);}
.c-sec-ttl-en { font-size: 1.2rem;}
.c-sec-catchtxt { font-size: 1.6rem; line-height: 1.8em; color: var(--cl-txt); margin-bottom: 2rem; text-align: center;}
.c-sec-leadtxt { font-size: 1.4rem; line-height: 1.8em; color: var(--cl-txt); margin-bottom: 2rem; text-align: center;}
.c-sec-line { margin: 0 auto;}
.c-sec-line img { margin: 0 auto;}
@media print, screen and (min-width: 640px) {
.c-sec { padding: 10rem 0;}
.c-sec-ttl { font-size: 4.3rem; margin-bottom: 4rem;}
.c-sec-ttl-jp { font-size: 2.8rem;}
.c-sec-ttl-en { font-size: 1.4rem;}
.c-sec-catchtxt { font-size: 1.8rem; margin-bottom: 4rem;}
.c-sec-leadtxt { font-size: 1.6rem; margin-bottom: 5rem;}
.c-sec-line { margin: 0 auto;}
.c-sec-line img { margin: 0 auto;}
}


/* c-content
--------------------------------------------------------------*/
.c-content {}
.c-content-ttl { margin: 0 auto 2rem;}
.c-content-ttl._center { text-align: center;}
.c-content-subttl { font-size: 1.6rem; color: var(--cl-key01); margin-bottom: 0.5rem;}
.c-content-lead { font-size: 1.6rem; text-align: left; margin-bottom: 4rem;}
.c-content-ttl > span { font-size: 1.8rem; display: inline-block; border-bottom: 3px dotted var(--cl-key01);}
.c-content-txt { margin: 2rem 0;}
.c-content-txt._center { text-align: center;}
@media print, screen and (min-width: 640px) {
.c-content {}
.c-content-ttl { margin: 0 auto 4rem;}
.c-content-ttl._center { }
.c-content-subttl { font-size: 1.8rem; margin-bottom: 1rem;}
.c-content-lead { font-size: 1.8rem; margin-bottom: 4rem;}
.c-content-ttl > span { font-size: 2.2rem; border-bottom: 5px dotted var(--cl-key01);}
.c-content-txt { margin: 4rem 0;}
}



/* boxwrap
--------------------------------------------------------------*/
.boxwrap { max-width: 80rem; width: 100%; margin: 0 auto;}


/* contentlist
--------------------------------------------------------------*/
.contentlist {}
.contentlist-item { display: flex; flex-direction: column; align-items: flex-start; padding: 1rem; border-bottom: 1px dotted var(--cl-boder);}
.contentlist-item:first-child { border-top: 1px dotted var(--cl-boder);}
.contentlist-ttl { font-size: 1.4rem;}
.contentlist-txt { font-size: 1.4rem;}
@media print, screen and (min-width: 640px) {
.contentlist {}
.contentlist-item { flex-direction: row; align-items: center; padding: 1.5rem;}
.contentlist-item:first-child {}
.contentlist-ttl { font-size: 1.4rem; width: 15%;}
.contentlist-txt { font-size: 1.6rem; width: 85%;}
}



/* cta
--------------------------------------------------------------*/
.cta { background-color: var(--cl-wh); position: relative; margin-top: 6rem; padding-top: 6rem; border-top-left-radius: 50%; border-top-right-radius: 50%; margin-left: -10rem; margin-right: -10rem; padding-left: 10rem; padding-right: 10rem;}
.cta::before { display: inline-block; content: ""; background: url(/assets/images/deco02.png) no-repeat center bottom; background-size: 50%; width: 50%; height: 5.5rem; position: absolute; top: -4rem; left: 50%; transform: translateX(-50%);}
.cta-info { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4rem;}
.cta-info-item { display: flex; flex-direction: column; justify-content: center; align-items: center;}
.cta-info-txt { font-size: 1.6rem; color: var(--cl-key01);}
.cta-info-num { font-size: 2.5rem; color: var(--cl-key01); display: flex; align-items: center; gap: 1rem;}
.cta-info-time { font-size: 1.6rem; color: var(--cl-key01);}
.cta-btn {}
.c-btn.cta-btn .cta-btn-link { display: flex; align-items: center; font-size: 1.8rem; gap: 1rem;}
@media print, screen and (min-width: 640px) {
.cta { margin-top: 12rem; padding-top: 12rem;}
.cta::before { background-size: contain; width: 100%; height: 11rem; top: -8rem;}
.cta-info { flex-direction: row; gap: 4rem;}
.cta-info-item { width: calc((100% - 4rem) / 2); display: flex; flex-direction: column; justify-content: center; align-items: center;}
.cta-info-txt { font-size: 1.8rem; }
.cta-info-num { font-size: 3.6rem;}
.cta-info-time { font-size: 1.8rem;}
.cta-btn {}
.c-btn.cta-btn .cta-btn-link { display: flex; align-items: center; font-size: 2.2rem;}
}



/* btn
--------------------------------------------------------------*/
.c-btn { display: flex; justify-content: center;}
.c-btn a { display: inline-block; background-color: var(--cl-key01); color: var(--cl-wh); font-size: 1.6rem; text-align: center; padding: 1.5rem 2rem; margin: 0 auto; border-radius: 1rem;}
@media print, screen and (min-width: 640px) {
.c-btn a { font-size: 1.8rem; text-align: center; padding: 2rem 3rem; border-radius: 1.5rem;}
}



/* form
--------------------------------------------------------------*/
.form {}
.form-list { display: flex; flex-direction: column;}
.form-list + .form-list { margin-top: 2rem;}
.form-list dt { width: auto;}
.form-list dd { width: 100%;}
.form-disc { font-size: 1.2rem; color: var(--cl-txt); margin: 0.5rem 0 0.5rem;}

.addresswrap { }
.addresswrap input + input { margin-top: 1rem;}
.addresswrap .zip { width: 10em;}
.addresswrap .zipbox { display: flex; align-items: center; gap: 0.5rem;}


.errTitle { font-size: 1.6rem; color: var(--cl-error); text-align: center; margin: 2rem auto;}
.error { font-size: 1.4rem; color: var(--cl-error); margin-bottom: 2rem; text-align: center;}
.error li { }
.required { color: var(--cl-key01);}

.formblock { background-color: var(--cl-wh); border-radius: 2rem; padding: 2rem ; margin: 4rem auto;}

.fill { }
.fill  { border-radius: 1rem; padding: 1rem; width: 100%; border: 1px solid var(--cl-boder);}
.page-contactconfirm .fill { border: none; padding: 0 1rem;}

.formpolicy { text-align: center; margin: 2rem;}
.formpolicy-link { text-decoration: underline; color: var(--cl-key01);}
.formpolicy-link:hover { text-decoration: none;}

.form-btn { margin-top: 2rem;}

@media print, screen and (min-width: 640px) {
.form-list { flex-direction: row;}
.form-list dt { width: 25%; margin-left: 1rem;}
.form-list dd { width: calc(75% - 1rem);}
.formblock { border-radius: 4rem; padding: 4rem; margin: 4rem auto;}

}




/* utility
--------------------------------------------------------------*/
.u-contentwrap { background-color: var(--cl-wh); border-radius: 2rem; padding: 2rem;}
.u-contentwrap + .u-contentwrap { margin-top: 4rem;}
@media print, screen and (min-width: 640px) {
.u-contentwrap { border-radius: 4rem; padding: 4rem;}
}

/*----------------------------------------------------------------------------------------------------------------------------

page unique

----------------------------------------------------------------------------------------------------------------------------*/


/* kv
--------------------------------------------------------------*/
.kv {}
.kv-wrap { position: relative;}
.kv-txt { position: absolute; left: -1rem; bottom: -13rem; width: 80%;}
.kv-img {margin: 0 auto;}
.kv-img img {margin: 0 auto;}

@media print, screen and (min-width: 640px) {
.kv { }
.kv-txt { width: auto; left: 0; bottom: -12rem;}
}




/* page-home
--------------------------------------------------------------*/
.servicewrap {}
.hareicon { display: flex; justify-content: center; margin-bottom: 0.5rem;}
.hareicon > img { width: 6.6rem; height: 6.6rem;}
.servicewrap-img { display: flex; gap: 1rem; align-items: center; justify-content: space-between;}
.servicewrap-img-item { width: calc((100% - 2rem) / 3);}
.servicewrap-img-item img { width: 100%; height: auto;}


.concept { padding: 0;}
.contentlist + .c-content-subttl { margin-top: 2rem;}
p + .contentlist { margin-top: 2rem;}

.office-content { display: flex; flex-direction: column; gap: 2rem;}
.office-content + .office-content { margin-top: 2rem;}
.office-content-item { }
.office-map { height: 20rem;}
.office-map iframe { width: 100%; height: 100%; border-radius: 2rem;}

@media print, screen and (min-width: 640px) {
.servicewrap-img { gap: 2rem;}
.servicewrap-img-item { width: calc((100% - 4rem) / 3);}

.contentlist + .c-content-subttl { margin-top: 4rem;}
p + .contentlist { margin-top: 4rem;}

.office-content { flex-direction: row;  gap: 4rem;}
.office-content + .office-content { margin-top: 4rem;}
.office-content-item { width: calc((100% - 4rem) / 2);}
.office-map { height: 35rem;}
.office-map iframe { border-radius: 4rem;}
}
/* page-contact page-recruit
--------------------------------------------------------------*/
.page-recruit .c-sec-line { margin: 4rem auto;}
.page-recruit .c-btn { margin: 2rem auto 4rem;}



/* 404
--------------------------------------------------------------*/
.page-404 .c-pagettl { background: var(--cl-bg-grn) url(/assets/images/bg_404_ttl.png) no-repeat top right; background-size: cover; }
.page-404 .c-sec { text-align: center;}


/* flyer
--------------------------------------------------------------*/
.flyer { }
.flyer-pic { margin: 3rem auto; max-width: 50rem; height: auto; width: 100%;}
.flyer-pic img { border: 5px solid var(--cl-wh);}
.flyer .c-sec-line { margin-top: 6rem;}

/* reservelink
--------------------------------------------------------------*/
.reservelink { display: inline-block; position: fixed; bottom: 30%; right: 1.5%;}
.reservelink-link { display: flex; justify-content: center; align-items: center; background-color: var(--cl-key01); color: var(--cl-wh); font-size: 1.3rem; text-align: center; border-radius: 50%; width: 10rem; height: 10rem; line-height: 1.25; border: 1px solid var(--cl-wh);}
.reservelink-link:hover { opacity: 1; background-color: #F2AF68;}

@media print, screen and (min-width: 640px) {
.reservelink { bottom: 50%; right: 3%;}
.reservelink-link { font-size: 1.8rem; width: 16rem; height: 16rem; border: 3px solid var(--cl-wh);}
}