@charset "utf-8";
/* --------------------------------------------------
	reset
-------------------------------------------------- */
*,
::before,
::after { box-sizing: border-box;}

html { line-height: 1.15; -webkit-text-size-adjust: 100%; -webkit-tap-highlight-color: transparent;}
body { margin: 0;}
main { display: block;}
p, table, blockquote, address, pre, iframe, form, figure, dl { margin: 0;}
h1, h2, h3, h4, h5, h6 { font-size: inherit; font-weight: inherit; margin: 0;}
ul, ol { margin: 0; padding: 0; list-style: none;}
dd { margin-left: 0;}
hr { box-sizing: content-box; height: 0; overflow: visible; border-top-width: 1px; margin: 0; clear: both; color: inherit;}
pre { font-family: monospace, monospace; font-size: inherit;}
address { font-style: inherit;}
a { background-color: transparent; text-decoration: none; color: inherit;}
abbr[title] { text-decoration: underline dotted;}
code, kbd, samp { font-family: monospace, monospace; font-size: inherit;}
small { font-size: 80%;}
sub,
sup { line-height: 0; position: relative; vertical-align: baseline;}

svg, img, embed, object, iframe { vertical-align: bottom;}

/* Forms */
/* ============================================ */
button, input, optgroup, select, textarea { padding: 0; margin: 0; border-radius: 0;
 color: inherit; font: inherit; text-align: inherit; text-transform: inherit; vertical-align: middle;
}
button, [type="button"], [type="reset"], [type="submit"] { cursor: pointer;}
button:disabled, [type="button"]:disabled, [type="reset"]:disabled, [type="submit"]:disabled { cursor: default;}
:-moz-focusring { outline: auto;}
select:disabled { opacity: inherit;}
option { padding: 0;}
fieldset { margin: 0; padding: 0; min-width: 0;}
legend { padding: 0;}

progress { vertical-align: baseline;}
textarea { overflow: auto;}
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button { height: auto;}
[type="search"] { outline-offset: -2px;}
[type="search"]::-webkit-search-decoration { -webkit-appearance: none;}

::-webkit-file-upload-button { -webkit-appearance: button; font: inherit;}
[type="number"] { -moz-appearance: textfield;}
label[for] { cursor: pointer;}
details { display: block;}
summary { display: list-item;}
[contenteditable]:focus { outline: auto;}

table { border-color: inherit; border-collapse: collapse;}
td,
th { vertical-align: top; padding: 0;}


/*	Slider */
.slick-slider { position: relative; display: block; box-sizing: border-box;
-webkit-user-select: none;
   -moz-user-select: none;
    -ms-user-select: none;
        user-select: none;

-webkit-touch-callout: none;
	-khtml-user-select: none;
	-ms-touch-action: pan-y;
  	  touch-action: pan-y;
-webkit-tap-highlight-color: transparent;
}

.slick-list { position: relative; display: block; overflow: hidden; margin: 0; padding: 0;}
.slick-list:focus { outline: none;}
.slick-list.dragging{ cursor: pointer; cursor: hand;}
.slick-slider .slick-track,
.slick-slider .slick-list{
-webkit-transform: translate3d(0, 0, 0);
   -moz-transform: translate3d(0, 0, 0);
    -ms-transform: translate3d(0, 0, 0);
     -o-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
}
.slick-track { position: relative; top: 0; left: 0; display: block;}
.slick-track:before,
.slick-track:after { display: table; content: '';}
.slick-track:after { clear: both;}
.slick-loading .slick-track { visibility: hidden;}
.slick-slide { display: none; float: left; height: 100%; min-height: 1px;}
[dir='rtl'] .slick-slide { float: right;}
.slick-slide img { display: block; }
.slick-slide.slick-loading img { display: none;}
.slick-slide.dragging img { pointer-events: none;}
.slick-initialized .slick-slide { display: block; outline: none;}
.slick-loading .slick-slide { visibility: hidden;}
.slick-vertical .slick-slide{ display: block; height: auto;}
.slick-arrow.slick-hidden { display: none;}

.slick-arrow{ width: 30px; height: 68px; position: absolute; top: 50%; transform: translateY(-50%);
 background: none; border: none; z-index: 100;
 text-indent: -9999em; outline: none;
}
.slick-arrow:before{ position: absolute; content: ''; display: block; width: 0px; height: 0px; top: 50%; transform: translateY(-50%);}

/** Dots */
.slick-dotted.slick-slider{ margin-bottom: 30px;}
.slick-dots { position: absolute; bottom: -25px; display: block; width: 100%; padding: 0; margin: 0; text-align: center;}
.slick-dots li { position: relative; display: inline-block; width: 20px; height: 20px; margin: 0 5px; padding: 0; cursor: pointer;}
.slick-dots li button { font-size: 0; line-height: 0; display: block; width: 20px; height: 20px; padding: 5px; cursor: pointer;
 color: transparent; border: 0; outline: none; background: transparent; 
}
.slick-dots li button:hover,
.slick-dots li button:focus{ outline: none;}
.slick-dots li button:hover:before,
.slick-dots li button:focus:before { opacity: 1;}
.slick-dots li button:before { font-family: 'slick'; font-size: 6px; line-height: 20px; position: absolute; top: 0; left: 0;
	width: 20px; height: 20px; content: '•'; text-align: center; opacity: .25; color: black;
}
.slick-dots li.slick-active button:before { opacity: .75; color: black;}

@media (max-width: 481px) {
}



html{
  height: -webkit-fill-available;
}
body{
  min-height: 100vh;
  min-height: -webkit-fill-available;
}


/*		font-style
-------------------------------------------------- */
body { width: 100%;
	font-family: "Hiragino Kaku Gothic Pro","ヒラギノ角ゴ Pro W3","メイリオ","Meiryo","ＭＳ Ｐゴシック",sans-serif;
	font-size: 16px;
	*font-size:small;
	*font:x-small;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
input, textarea { font-family: "Hiragino Kaku Gothic Pro","ヒラギノ角ゴ Pro W3","メイリオ","Meiryo","ＭＳ Ｐゴシック",sans-serif;}

body.fixed { position: fixed;}
.min { font-family: "Hiragino Mincho ProN","ヒラギノ明朝 Pro", "游明朝", "Yu Mincho", "YuMincho", serif;}

::selection{ background: #feffaf; color: #000;}
::-moz-selection{ background: #feffaf; color: #000;}


a { color:#002159; text-decoration: underline; text-underline-offset: 2px; text-decoration-thickness: 1px;}
a:link   { color:#002159;}
a:visited{ color:#002159;}
a:hover  { color:#002159;}
a:active { color:#002159;}

em{ font-style: normal;}


/*		utility
-------------------------------------------------- */
.cf{ clear: both;}
.cf:after{ content: ''; display: block; clear: both;}

@media (max-width: 641px) {
}
@media (max-width: 481px) {
}



#contact ul li label.error {
	position: absolute; top: -30px; left: -10px;
	padding: 5px 8px;
	background: #d00; border-radius: 5px;
	color: #fff; font-size: 12px;
	opacity: 0;
	animation: .5s showError linear forwards .2s;
}
#contact ul li label.error:before{ content: ''; display: block; width: 8px; height: 8px; background: #d00;
	transform: rotate(45deg);
	position: absolute; bottom: -4px; left: 20px;
}
@keyframes showError{
	100%{ opacity: 1;}
}


#hd { width: 100%; position: fixed; left: 0; top: 0; background: #fff; z-index: 101;}
#hd .inner-hd { position: relative; width: 95%; margin: 0 auto; padding: 12px 0 18px;}
#hd .hd-ctn { position: relative; display: flex; justify-content: space-between; align-items: center;}
#hd .hd-logo { width: 15%;}
#hd .hd-nav { width: 84%;}
#hd .hd-logo h1 {}
#hd .hd-logo h1 img { width: 100%; max-width: 180px;}
#hd .hd-nav ul { font-size: 0px; text-align: right;}
#hd .hd-nav ul li { display: inline-block; padding: 0 10px; font-size: 15px; vertical-align: middle;}
#hd .hd-nav ul li a { position: relative; color: #000; text-decoration: none; font-weight: 700; letter-spacing: 0.06rem;}
#hd .hd-nav ul li a:hover { text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px;}
#hd .hd-nav ul li.estimate { font-size: 16px;}
#hd .hd-nav ul li.contact { font-size: 16px;}
#hd .hd-nav ul li.estimate a { display: block; width: 180px; padding: 7px 0px; border-radius: 50px;
 background: #f6c853; border: solid 2px #f6c853; box-shadow: 4px 4px 0 #d2a636; color: #280003; letter-spacing: 0.1rem; text-align: center;
}
#hd .hd-nav ul li.contact a { display: block; width: 180px; padding: 7px 0px; border-radius: 50px;
 background: #fff; border: solid 2px #234089; box-shadow: 4px 4px 0 #a5b5ce; color: #280003; letter-spacing: 0.1rem; text-align: center;
}
#hd .hd-nav ul li.estimate a:after,
#hd .hd-nav ul li.contact a:after { content: ''; display: block; width: 10px; height: 10px;
 border-top: solid 2px #280003; border-right: solid 2px #280003;
 position: absolute; right: 8%; top: 50%; transform: translateY(-50%) rotate(45deg);
}

#hd .hd-nav ul li.estimate a:hover { text-decoration: none; opacity: 0.8;}
#hd .hd-nav ul li.contact a:hover { text-decoration: none; opacity: 0.8;}
#hd .sp-menu { display: none; width: 40px; height: 40px; position: absolute; right: 0; top: 50%; transform: translateY(-50%);}
#hd .sp-menu div { position: relative; width: 100%; height: 100%; cursor: pointer;	}
#hd .sp-menu div span { display: block; width: 30px; height: 2px; background: #000; position: absolute; left: 50%; opacity: 1;}
#hd .sp-menu div span:nth-child(1) { top: 12px; transform: translate(-50%, 0px);}
#hd .sp-menu div span:nth-child(2) { top: 20px; transform: translate(-50%, 0px);}
#hd .sp-menu div span:nth-child(3) { top: 28px; transform: translate(-50%, 0px);}
#hd .sp-menu.active div span:nth-child(1) { transform: translate(-50%, 8px) rotate(45deg);}
#hd .sp-menu.active div span:nth-child(2) { opacity: 0;}
#hd .sp-menu.active div span:nth-child(3) { transform: translate(-50%, -8px) rotate(-45deg);}

@media (max-width: 1401px) {
	#hd .hd-nav ul li { padding: 0 8px; font-size: 13px;}
	#hd .hd-nav ul li.estimate { font-size: 14px;}
	#hd .hd-nav ul li.contact { font-size: 14px;}
	#hd .hd-nav ul li.estimate a { width: 150px; padding: 5px 0px;}
	#hd .hd-nav ul li.contact a { width: 150px; padding: 5px 0px;}
}
@media (max-width: 1201px) {
	#hd .hd-nav ul li { padding: 0 5px; font-size: 12px;}
	#hd .hd-nav ul li.estimate { font-size: 12px;}
	#hd .hd-nav ul li.contact { font-size: 12px;}
	#hd .hd-nav ul li.estimate a { width: 120px; padding: 5px 0px;}
	#hd .hd-nav ul li.contact a { width: 120px; padding: 5px 0px;}
	#hd .hd-nav ul li.estimate a:after,
	#hd .hd-nav ul li.contact a:after { width: 6px; height: 6px; right: 6px;}
}
@media (max-width: 1001px) {
	#hd .inner-hd { padding: 12px 0 14px;}
	#hd .hd-logo { width: 32%;}
	#hd .hd-nav { width: 68%; padding-right: 40px;}
	#hd .hd-nav ul li.pc { display: none;}
	#hd .sp-menu { display: block;}
	#hd .hd-nav ul li.estimate a { border-width: 1px; box-shadow: 2px 2px 0 #d2a636;}
	#hd .hd-nav ul li.contact a { border-width: 1px; box-shadow: 2px 2px 0 #a5b5ce;}
}
@media (max-width: 481px) {
	#hd .hd-logo { width: 25%;}
	#hd .hd-nav { width: 75%;}
	#hd .hd-nav ul li { padding: 0 4px;}
	#hd .hd-nav ul li.estimate { font-size: 11px;}
	#hd .hd-nav ul li.contact { font-size: 11px;}
	#hd .hd-nav ul li.estimate a { width: 100px; padding: 4px 0; letter-spacing: 0.05rem;}
	#hd .hd-nav ul li.contact a { width: 100px; padding: 4px 0; letter-spacing: 0.05rem;}
}
@media (max-width: 401px) {
	#hd .hd-nav ul li.estimate { font-size: 10px;}
	#hd .hd-nav ul li.contact { font-size: 10px;}
	#hd .hd-nav ul li.estimate a { width: 80px;}
	#hd .hd-nav ul li.contact a { width: 80px;}
}

.sp-nav { position: fixed; left: 0; top: -600px; z-index: 100;
 width: 100%; background: #234089; visibility: hidden;
 transition: 0.3s linear;
}
.sp-nav.open { top: 0; visibility: visible;}
.sp-nav .inner { width: 100%; padding: 80px 0 30px;}
.sp-nav ul { text-align: center;}
.sp-nav ul li { padding: 8px 0; font-size: 16px;}
.sp-nav ul li a { color: #fff; font-weight: 700; text-decoration: none;}


#ft { background: #234089;}
#ft .inner-ft { width: 100%; max-width: 980px; margin: 0 auto; padding: 50px 0;}
#ft .ft-ctn { display: flex; justify-content: space-between; flex-direction: row-reverse; width: 100%; }
#ft .ft-logo { width: 25%;}
#ft .ft-nav { width: 72%;}
#ft .ft-logo h3 { margin-bottom: 25px;}
#ft .ft-logo h3 span { display: block; width: 100%; max-width: 180px;}
#ft .ft-logo h3 span img { width: 100%;}
#ft .ft-logo p { color: #fff; font-size: 12px;}

#ft .ft-nav ul { font-size: 0;}
#ft .ft-nav ul li { display: inline-block; width: 32%; vertical-align: top;}
#ft .ft-nav ul li dl dt { color: #fff; font-size: 20px; font-weight: 700;}
#ft .ft-nav ul li dl dd { position: relative; padding: 2px 10px; font-size: 18px;}
#ft .ft-nav ul li dl dd:before { content: ''; display: block; width: 5px; height: 2px; background: #fff;
 position: absolute; left: 0; top: 50%;
}
#ft .ft-nav ul li dl dd a { color: #fff; text-decoration: none;}
#ft .ft-nav ul li dl dd a:hover { text-decoration: underline;}
@media (max-width: 1001px) {
	#ft .ft-nav ul li dl dt { font-size: 16px;}
	#ft .ft-nav ul li dl dd { font-size: 14px;}
	#ft .ft-logo { padding-left: 20px;}
}
@media (max-width: 801px) {
	#ft .inner-ft { padding: 40px 0 20px;}
	#ft .ft-ctn { display: block;}
	#ft .ft-nav { width: 100%; padding: 20px;}
	#ft .ft-nav ul li dl { padding-left: 20px;}
	#ft .ft-logo { width: 100%; padding: 20px 40px;}
}
@media (max-width: 481px) {
	#ft .ft-nav { padding: 20px;}
	#ft .ft-nav ul li:nth-child(even) { width: 40%; float: right;}
	#ft .ft-nav ul li:nth-child(odd) { width: 60%;}
	#ft .ft-nav ul li:nth-child(1) { margin-bottom: 12px;}
	#ft .ft-nav ul li dl { padding-left: 10px;}
	#ft .ft-nav ul li dl dd { font-size: 13px;}

	#ft .ft-logo { width: 100%; padding: 20px 30px;}
	#ft .ft-logo h3 span { width: 30%;}
}


