/*! destyle.css v4.0.1 | MIT License | https://github.com/nicolas-cusan/destyle.css */
/* Reset box-model and set borders */
/* ============================================ */
*, ::before, ::after { box-sizing: border-box; border-style: solid; border-width: 0; min-width: 0; }

/* Document */
/* ============================================ */
/** 1. Correct the line height in all browsers. 2. Prevent adjustments of font size after orientation changes in iOS. 3. Remove gray overlay on links for iOS. */
html { line-height: 1.15; /* 1 */ -webkit-text-size-adjust: 100%; /* 2 */ -webkit-tap-highlight-color: transparent; /* 3*/ }

/* Sections */
/* ============================================ */
/** Remove the margin in all browsers. */
body { margin: 0; }

/** Render the `main` element consistently in IE. */
main { display: block; }

/* Vertical rhythm */
/* ============================================ */
p, table, blockquote, address, pre, iframe, form, figure, dl { margin: 0; }

/* Headings */
/* ============================================ */
h1, h2, h3, h4, h5, h6 { font-size: inherit; font-weight: inherit; margin: 0; }

/* Lists (enumeration) */
/* ============================================ */
ul, ol { margin: 0; padding: 0; list-style: none; }

/* Lists (definition) */
/* ============================================ */
dt { font-weight: bold; }

dd { margin-left: 0; }

/* Grouping content */
/* ============================================ */
/** 1. Add the correct box sizing in Firefox. 2. Show the overflow in Edge and IE. */
hr { box-sizing: content-box; /* 1 */ height: 0; /* 1 */ overflow: visible; /* 2 */ border-top-width: 1px; margin: 0; clear: both; color: inherit; }

/** 1. Correct the inheritance and scaling of font size in all browsers. 2. Correct the odd `em` font sizing in all browsers. */
pre { font-family: monospace, monospace; /* 1 */ font-size: inherit; /* 2 */ }

address { font-style: inherit; }

/* Text-level semantics */
/* ============================================ */
/** Remove the gray background on active links in IE 10. */
a { background-color: transparent; text-decoration: none; color: inherit; }

/** 1. Remove the bottom border in Chrome 57- 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari. */
abbr[title] { text-decoration: underline dotted; /* 2 */ }

/** Add the correct font weight in Chrome, Edge, and Safari. */
b, strong { font-weight: bolder; }

/** 1. Correct the inheritance and scaling of font size in all browsers. 2. Correct the odd `em` font sizing in all browsers. */
code, kbd, samp { font-family: monospace, monospace; /* 1 */ font-size: inherit; /* 2 */ }

/** Add the correct font size in all browsers. */
small { font-size: 80%; }

/** Prevent `sub` and `sup` elements from affecting the line height in all browsers. */
sub, sup { font-size: 75%; line-height: 0; position: relative; vertical-align: baseline; }

sub { bottom: -0.25em; }

sup { top: -0.5em; }

/* Replaced content */
/* ============================================ */
/** Prevent vertical alignment issues. */
svg, img, embed, object, iframe { vertical-align: bottom; }

/* Forms */
/* ============================================ */
/** Reset form fields to make them styleable. 1. Make form elements stylable across systems iOS especially. 2. Inherit text-transform from parent. */
button, input, optgroup, select, textarea { -webkit-appearance: none; /* 1 */ appearance: none; vertical-align: middle; color: inherit; font: inherit; background: transparent; padding: 0; margin: 0; border-radius: 0; text-align: inherit; text-transform: inherit; /* 2 */ }

/** Correct cursors for clickable elements. */
button, [type="button"], [type="reset"], [type="submit"] { cursor: pointer; }

button:disabled, [type="button"]:disabled, [type="reset"]:disabled, [type="submit"]:disabled { cursor: default; }

/** Improve outlines for Firefox and unify style with input elements & buttons. */
:-moz-focusring { outline: auto; }

select:disabled { opacity: inherit; }

/** Remove padding */
option { padding: 0; }

/** Reset to invisible */
fieldset { margin: 0; padding: 0; min-width: 0; }

legend { padding: 0; }

/** Add the correct vertical alignment in Chrome, Firefox, and Opera. */
progress { vertical-align: baseline; }

/** Remove the default vertical scrollbar in IE 10+. */
textarea { overflow: auto; }

/** Correct the cursor style of increment and decrement buttons in Chrome. */
[type="number"]::-webkit-inner-spin-button, [type="number"]::-webkit-outer-spin-button { height: auto; }

/** Correct the outline style in Safari. */
[type="search"] { outline-offset: -2px; /* 1 */ }

/** Remove the inner padding in Chrome and Safari on macOS. */
[type="search"]::-webkit-search-decoration { -webkit-appearance: none; }

/** 1. Correct the inability to style clickable types in iOS and Safari. 2. Fix font inheritance. */
::-webkit-file-upload-button { -webkit-appearance: button; /* 1 */ font: inherit; /* 2 */ }

/** Fix appearance for Firefox */
[type="number"] { -moz-appearance: textfield; }

/** Clickable labels */
label[for] { cursor: pointer; }

/* Interactive */
/* ============================================ */
/* Add the correct display in Edge, IE 10+, and Firefox. */
details { display: block; }

/* Add the correct display in all browsers. */
summary { display: list-item; }

/* Remove outline for editable content. */
[contenteditable]:focus { outline: auto; }

/* Tables */
/* ============================================ */
/**
1. Correct table border color inheritance in all Chrome and Safari.
*/
table { border-color: inherit; /* 1 */ border-collapse: collapse; }

caption { text-align: left; }

td, th { vertical-align: top; padding: 0; }

th { text-align: left; font-weight: bold; }

/******************************************************

base

******************************************************/
html { font-size: 10px; }
@media screen and (max-width: 768px) { html { font-size: 8px; } }

body { font-family: "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif; background: #fff; color: #222; }

a { color: #000; text-decoration: none; transition: 200ms linear; display: inline-block; }
a[href*="tel:"] { pointer-events: none; }
@media screen and (max-width: 768px) { a[href*="tel:"] { pointer-events: initial; } }

img { display: inline-block; }

.aw { display: inline-block; }

.note { font-size: 10px; line-height: 1.6; }

.pc { display: block !important; }
@media screen and (max-width: 768px) { .pc { display: none !important; } }

.sp { display: none !important; }
@media screen and (max-width: 768px) { .sp { display: block !important; } }

.lead { font-size: 1.6rem; letter-spacing: 0.1em; line-height: 1.8; }

sup { font-size: 0.6em; vertical-align: text-top; }

.lead sup { top: 0.1em; }

.inner { width: 90%; max-width: 1000px; margin-right: auto; margin-left: auto; }

.img { position: relative; }
.img img { width: 100%; height: auto; display: inline-block; }
.img .cap { font-size: 10px; line-height: 1.2; position: absolute; bottom: 5px; right: 5px; color: #000; text-align: right; }
.img .w { color: #fff; text-shadow: 0 0 3px #000,0 0 5px #000; }
.img .l { right: auto; left: 5px; text-align: left; }
.img .out { bottom: -15px; right: 0; }
.img .rl { position: relative; bottom: auto; right: auto; text-align: right; }
.img .note { margin-top: 5px; text-align: left; }
.img .note.r { text-align: right; }

/******************************************************

header

******************************************************/
#header { position: fixed; z-index: 99999; top: 0; left: 0; display: block; width: 100%; background: #fff; }
#header .header-inner { padding: 2rem; display: grid; gap: 2rem; grid-template-columns: 340px 1fr; }
#header h1 a img { width: 100%; height: auto; }
#header .hnav ul { max-width: 600px; margin: 0 0 0 auto; display: grid; gap: 1rem; justify-content: right; grid-template-columns: repeat(3, 1fr); }
#header .hnav ul li a { border: solid 1px #222; padding: 1rem; text-align: center; position: relative; width: 100%; transition: .3s; }
#header .hnav ul li a:hover { filter: brightness(120%); }
#header .hnav ul li a .txt { font-size: 1.4rem; line-height: 1; letter-spacing: .1em; }
#header .hnav ul li a::after { content: ""; width: 1rem; height: 1rem; display: block; border-top: solid 1px #222; border-right: solid 1px #222; transform: translateY(-50%) rotate(45deg); position: absolute; top: 50%; right: 1rem; z-index: 2; }
#header .hnav ul li.map a:hover, #header .hnav ul li.outline a:hover { filter: none; background: rgba(0, 0, 0, 0.1); }
#header .hnav ul li.ent a { background: #C2AD6D; background: -webkit-linear-gradient(90deg, #c2ad6d 0%, #c7b7a9 50%, #c2ad6d 100%); background: -moz-linear-gradient(90deg, #c2ad6d 0%, #c7b7a9 50%, #c2ad6d 100%); background: linear-gradient(90deg, #c2ad6d 0%, #c7b7a9 50%, #c2ad6d 100%); filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#C2AD6D", endColorstr="#C2AD6D", GradientType=1); box-shadow: 2px 2px 3px rgba(0, 0, 0, 0.3); }
@media screen and (max-width: 1024px) { #header .header-inner { grid-template-columns: 35% 1fr; }
  #header .hnav ul li a { padding: 1rem .5rem; }
  #header .hnav ul li a .txt { font-size: 1.2rem; letter-spacing: .05em; }
  #header .hnav ul li a::after { width: .6rem; height: .6rem; } }
@media screen and (max-width: 768px) { #header .header-inner { padding: 1.5rem; grid-template-columns: 1fr; }
  #header .hnav { display: none; }
  #header h1 { width: calc(100% - 50px); max-width: 300px; } }

/******************************************************

footer

******************************************************/
#footer .contact { background: #C9BC9D; padding: 5rem 0; }
#footer .contact .contact-inner { width: 90%; max-width: 1000px; margin-right: auto; margin-left: auto; max-width: 900px; display: grid; gap: 2rem; grid-template-columns: 55% 1fr; grid-template-areas: "txt tel" "time tel"; color: #fff; }
#footer .contact .contact-inner .txt { grid-area: txt; font-size: 1.2rem; line-height: 1.6; text-align: center; }
#footer .contact .contact-inner .tel { grid-area: tel; align-self: center; }
#footer .contact .contact-inner .tel a img { width: 100%; height: auto; }
#footer .contact .contact-inner .time { grid-area: time; font-size: 1.2rem; line-height: 1.6; border: solid 1px #fff; padding: .5rem; text-align: center; }
#footer .contact .contact-inner .holiday { display: block; }
#footer .page-caption { padding: 50px 0; }
#footer .page-caption .note { line-height: 1.8; }
#footer .footer-logo { text-align: center; padding-bottom: 40px; }
#footer .footer-logo a { display: block; position: relative; padding-top: 15px; }
#footer .footer-logo a .txt { position: absolute; top: 0; font-size: 10px; }
#footer .footer-logo .taisei-logo { display: inline-block; }
#footer .footer-logo .taisei-logo a { position: relative; width: 280px; }
#footer .footer-logo .taisei-logo a .txt, #footer .footer-logo .taisei-logo a .img { display: block; }
#footer .footer-logo .taisei-logo a .txt { left: calc(66 / 263 * 100%); }
@media screen and (max-width: 1024px) { #footer .contact .contact-inner { grid-template-columns: 1fr; grid-template-areas: "txt" "tel" "time"; }
  #footer .contact .contact-inner .tel { max-width: 400px; margin: auto; } }
@media screen and (max-width: 768px) { #footer { padding-bottom: 100px; } }

/******************************************************

contents

******************************************************/
.conversion p { font-size: 1.6rem; line-height: 1.6; text-align: center; }
.conversion .conv-btns { margin-top: 3rem; display: grid; place-content: center; place-items: center; grid-auto-flow: column; grid-template-columns: 1fr; gap: 2rem; }
.conversion .conv-btns li { width: 90%; max-width: 420px; }
.conversion .conv-btns li a { width: 100%; padding: 1rem; display: grid; place-content: center; place-items: center; grid-auto-flow: column; gap: 1rem; transition: .3s; box-shadow: 2px 2px 3px rgba(0, 0, 0, 0.3); }
.conversion .conv-btns li a:hover { filter: brightness(120%); }
.conversion .conv-btns li a img { width: 100%; height: auto; }
.conversion .conv-btns li a .icon, .conversion .conv-btns li a .txt { display: inline-block; }
.conversion .conv-btns li a .icon { width: 3rem; }
.conversion .conv-btns li a .txt { color: #fff; font-size: 1.6rem; line-height: 1; letter-spacing: .1em; }
.conversion .conv-btns li.ent a { background: #74705D; background: -webkit-linear-gradient(90deg, #74705d 0%, #c8bc9b 50%, #74705d 100%); background: -moz-linear-gradient(90deg, #74705d 0%, #c8bc9b 50%, #74705d 100%); background: linear-gradient(90deg, #74705d 0%, #c8bc9b 50%, #74705d 100%); filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#74705D", endColorstr="#74705D", GradientType=1); }

#spnav { display: none; position: fixed; bottom: 0; left: 0; width: 100%; z-index: 99999; }
#spnav ul { background: #fff; display: grid; gap: 1px; grid-template-columns: repeat(4, 1fr); }
#spnav ul li a { width: 100%; height: 100%; padding: 10px 2px; display: grid; place-content: center; place-items: center; background: #666; color: #fff; }
#spnav ul li a .icon { display: block; width: 20px; margin: auto; }
#spnav ul li a .icon img { width: 100%; height: auto; }
#spnav ul li a .txt { display: block; text-align: center; margin-top: 5px; font-size: 10px; line-height: 1; }
#spnav ul li.ent a { background: #74705D; background: -webkit-linear-gradient(90deg, #74705d 0%, #c8bc9b 50%, #74705d 100%); background: -moz-linear-gradient(90deg, #74705d 0%, #c8bc9b 50%, #74705d 100%); background: linear-gradient(90deg, #74705d 0%, #c8bc9b 50%, #74705d 100%); filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#74705D", endColorstr="#74705D", GradientType=1); }
#spnav ul li.tel a { background: #C9BC9D; }
@media screen and (max-width: 768px) { #spnav { display: block; } }

/******************************************************

print

******************************************************/
@media print { .hnav, #spnav, .footer-logo, .nomv-btns, #pagetop { display: none; }
  #footer .contact { margin-top: 1rem; padding: 1rem; }
  .nomv-ttl { padding: 1rem; } }
