/*! destyle.css v4.0.1 | MIT License | https://github.com/nicolas-cusan/destyle.css */
/* Reset box-model and set borders */
/* ============================================ */
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New&display=swap");
*, ::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; }

@keyframes shine-run { 0% { transform: scale(0) rotate(50deg); opacity: 0; }
  40% { transform: scale(1) rotate(50deg); opacity: 1; }
  100% { transform: scale(250) rotate(50deg); opacity: 0; } }
#main { background: #E1E0E0; background: -webkit-linear-gradient(90deg, #e1e0e0 0%, #e7e7e7 100%); background: -moz-linear-gradient(90deg, #e1e0e0 0%, #e7e7e7 100%); background: linear-gradient(90deg, #e1e0e0 0%, #e7e7e7 100%); filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#E1E0E0", endColorstr="#E7E7E7", GradientType=1); overflow: hidden; }
#main img { width: 100%; height: auto; }

.loc-box { padding: 10rem 0 0 0; position: relative; }
@media screen and (max-width: 768px) { .loc-box { padding: 6rem 0 0 0; } }

.loc-ttl { width: 90%; max-width: 300px; padding-bottom: 3rem; }
@media screen and (max-width: 768px) { .loc-ttl { width: 45dvw; } }

.shopname { color: #03415c; font-size: 2rem; line-height: 1.2; }
.shopname .note { display: inline-block; line-height: 1.2; color: #040000; }
.shopname + .lead { margin-top: 1rem; }
@media screen and (max-width: 768px) { .shopname { font-size: 1.6rem; } }

#loc00 { width: 100%; overflow-x: hidden; z-index: 15; }
#loc00 .box { width: 90%; max-width: 1000px; margin-right: auto; margin-left: auto; position: relative; overflow-x: visible; display: grid; gap: 0 30px; grid-template-columns: 1fr 50%; grid-template-areas: "midashi midashi" "lead img"; }
#loc00 .box .midashi { grid-area: midashi; }
#loc00 .box .lead { grid-area: lead; }
#loc00 .box .img-box { grid-area: img; position: absolute; left: 0; bottom: 0; width: calc(50dvw - 5%); max-width: 700px; }
#loc00 .box .img-box .img img { object-fit: cover; }
#loc00 .box .img-box .img .min { position: absolute; top: 5.8%; left: 56.6%; width: 25%; }
@media screen and (max-width: 1024px) { #loc00 .box { gap: 0; grid-template-columns: 1fr; grid-template-areas: "midashi" "lead" "img"; }
  #loc00 .box .midashi br { display: none; }
  #loc00 .box .img-box { position: static; left: auto; bottom: auto; width: 100%; margin: 2rem auto 0 auto; } }

#loc01 { width: 100%; max-width: 1680px; margin: auto; z-index: 14; }
#loc01 .inner2 { position: relative; }
#loc01 .box { position: relative; }
#loc01 .box .box-inner { width: 90%; max-width: 1000px; margin-right: auto; margin-left: auto; overflow-x: visible; display: grid; gap: 0 30px; grid-template-columns: 1fr 65%; grid-template-areas: "midashi midashi" "lead img"; }
#loc01 .box .midashi { grid-area: midashi; }
#loc01 .box .lead { grid-area: lead; }
#loc01 .box .img-box { grid-area: img; position: absolute; right: 0; bottom: 0; width: calc(50dvw - 5% + 15%); max-width: 1000px; }
#loc01 .box .img-box .img img { object-fit: cover; }
#loc01 .img-list { display: grid; margin-top: 5rem; }
#loc01 .forest { grid-template-columns: 70% 1fr; gap: 30px; position: relative; z-index: 1; }
#loc01 .forest .forest-l, #loc01 .forest .forest-s { display: grid; gap: 20px; }
#loc01 .aeon { grid-template-columns: repeat(3, 1fr); gap: 20px; position: relative; }
#loc01 .aeon .img05 { grid-column: span 2; }
#loc01 .other { grid-template-columns: repeat(3, 1fr); gap: 20px; }
#loc01 .other .midashi { grid-column: span 3; }
#loc01 #circle-1 { top: 0; left: 0; width: 60%; }
#loc01 #circle-1 .circle-inner { transform: translate(calc(-35% + 40px), calc(-35% + 40px)); }
#loc01 #circle-2 { top: 0; right: -50%; width: 60%; z-index: -1; }
#loc01 #circle-2 .circle-inner { transform: translate(calc(-50%), calc(-50%)); }
@media screen and (max-width: 1024px) { #loc01 .box .box-inner { width: 100%; gap: 0; grid-template-columns: 1fr; grid-template-areas: "midashi" "lead" "img"; }
  #loc01 .box .box-inner .midashi { width: 90%; max-width: 1000px; margin-right: auto; margin-left: auto; }
  #loc01 .box .box-inner .midashi br { display: none; }
  #loc01 .box .box-inner .lead { width: 90%; max-width: 1000px; margin-right: auto; margin-left: auto; }
  #loc01 .box .box-inner .img-box { position: static; left: auto; bottom: auto; width: 100%; margin: 2rem auto 0 auto; } }
@media screen and (max-width: 768px) { #loc01 .img-list { margin-top: 3rem; }
  #loc01 .forest { grid-template-columns: 1fr; gap: 20px; }
  #loc01 .forest .forest-s { grid-template-columns: repeat(2, 1fr); }
  #loc01 .forest .forest-s .txt { grid-column: span 2; }
  #loc01 .aeon { grid-template-columns: repeat(2, 1fr); }
  #loc01 .aeon .txt { grid-column: span 2; }
  #loc01 .other { grid-template-columns: repeat(2, 1fr); }
  #loc01 .other .midashi { grid-column: span 2; } }
@media screen and (max-width: 480px) { #loc01 .forest .forest-s { grid-template-columns: 1fr; }
  #loc01 .forest .forest-s .txt { grid-column: span 1; }
  #loc01 .aeon { grid-template-columns: 1fr; }
  #loc01 .aeon .txt { grid-column: span 1; }
  #loc01 .aeon .img05 { grid-column: span 1; }
  #loc01 .other { grid-template-columns: 1fr; }
  #loc01 .other .midashi { grid-column: span 1; } }

#loc02 { width: 100%; max-width: 1680px; margin: auto; z-index: 13; }
#loc02 .inner2 { position: relative; }
#loc02 .box { position: relative; }
#loc02 .box .box-inner { width: 90%; max-width: 1000px; margin-right: auto; margin-left: auto; overflow-x: visible; display: grid; gap: 0 30px; grid-template-columns: 1fr 65%; grid-template-areas: "midashi midashi" "lead img"; }
#loc02 .box .midashi { grid-area: midashi; }
#loc02 .box .lead { grid-area: lead; }
#loc02 .box .img-box { grid-area: img; position: absolute; right: 0; bottom: 0; width: calc(50dvw - 5% + 15%); max-width: 1000px; }
#loc02 .box .img-box .img img { object-fit: cover; }
#loc02 .img-list { width: 90%; max-width: 1000px; margin-right: auto; margin-left: auto; margin-top: 5rem; display: grid; gap: 30px; grid-template-columns: 60% 1fr; }
#loc02 #circle-3 { top: 0; left: 0; width: 60%; }
#loc02 #circle-3 .circle-inner { transform: translate(calc(-35% + 40px), calc(-35% + 40px)); }
@media screen and (max-width: 1024px) { #loc02 .box .box-inner { width: 100%; gap: 0; grid-template-columns: 1fr; grid-template-areas: "midashi" "lead" "img"; }
  #loc02 .box .box-inner .midashi { width: 90%; max-width: 1000px; margin-right: auto; margin-left: auto; }
  #loc02 .box .box-inner .midashi br { display: none; }
  #loc02 .box .box-inner .lead { width: 90%; max-width: 1000px; margin-right: auto; margin-left: auto; }
  #loc02 .box .box-inner .img-box { position: static; left: auto; bottom: auto; width: 100%; margin: 2rem auto 0 auto; } }
@media screen and (max-width: 768px) { #loc02 .img-list { margin-top: 3rem; } }
@media screen and (max-width: 480px) { #loc02 .img-list { gap: 20px; grid-template-columns: 1fr; } }

#loc03 { z-index: 12; }
#loc03 .img-list { margin-top: 5rem; display: grid; gap: 30px 20px; grid-template-columns: 55% 1fr; }
#loc03 .img-list .img01 { grid-row: span 2; }
#loc03 .img-list .img01 .dep { margin-top: 2rem; padding: 0 2rem; border-right: solid 1px #040000; border-left: solid 1px #040000; position: relative; }
#loc03 .img-list .img01 .dep::before, #loc03 .img-list .img01 .dep::after { content: ""; display: block; width: 1.5rem; height: 100%; position: absolute; top: 0; border-top: solid 1px #040000; border-bottom: solid 1px #040000; }
#loc03 .img-list .img01 .dep::before { left: 0; }
#loc03 .img-list .img01 .dep::after { right: 0; }
#loc03 .img-list .img01 .dep .dep-txt { font-size: 1.2rem; line-height: 1.6; }
#loc03 .img-list .img01 .dep .aw { margin-right: 1rem; }
#loc03 #circle-4 { top: 0; left: 0; width: 60%; }
#loc03 #circle-4 .circle-inner { transform: translate(calc(-35% + 40px), calc(-35% + 40px)); }
@media screen and (max-width: 768px) { #loc03 .img-list { margin-top: 3rem; grid-template-columns: repeat(2, 1fr); }
  #loc03 .img-list .img01 { grid-column: span 2; grid-row: span 1; } }

#loc04 { z-index: 11; }
#loc04 .img-list { margin-top: 5rem; display: grid; gap: 20px 30px; grid-template-columns: 40% 1fr; }
#loc04 .img-list .img03 { grid-column: 2 / 3; grid-row: 1 / 3; }
#loc04 #circle-5 { top: 0; right: 0; width: 60%; }
#loc04 #circle-5 .circle-inner { transform: translate(calc(30% - 40px), calc(-20% + 40px)); }
@media screen and (max-width: 768px) { #loc04 .img-list { margin-top: 3rem; grid-template-columns: repeat(2, 1fr); }
  #loc04 .img-list .img03 { grid-column: span 2; grid-row: auto; } }
@media screen and (max-width: 480px) { #loc04 .img-list { grid-template-columns: 1fr; }
  #loc04 .img-list .img03 { grid-column: span 1; } }

#loc05 { z-index: 10; }
#loc05 .life-ttl { padding: 5rem 0; text-align: center; font-family: "Noto Sans JP", sans-serif; font-size: 2rem; letter-spacing: .1em; line-height: 1; }
#loc05 .life-list { display: grid; gap: 3rem 50px; grid-template-columns: repeat(2, 1fr); }
#loc05 .life-box + .life-box { margin-top: 3rem; }
#loc05 .category { display: flex; align-items: center; }
#loc05 .category .txt { white-space: nowrap; font-family: "Noto Sans JP", sans-serif; font-weight: bold; font-size: 1.2rem; line-height: 1.2; }
#loc05 .category .line { flex: 1; border-bottom: 1px solid #040000; margin: 0 .5rem; height: .5em; }
#loc05 ul li { margin-top: 1rem; font-family: "Noto Sans JP", sans-serif; display: flex; align-items: center; }
#loc05 ul li .l-name, #loc05 ul li .l-time { font-size: 1.1rem; line-height: 1.2; }
#loc05 ul li .line { flex: 1; border-bottom: 1px dotted #040000; margin: 0 .5rem; height: .5rem; }
#loc05 ul li .l-time { white-space: wrap; }
#loc05 ul li .l-time { white-space: nowrap; text-align: right; }
#loc05 #circle-6 { top: 0; left: 0; width: 60%; }
#loc05 #circle-6 .circle-inner { transform: translate(calc(-40% + 40px), calc(-40% + 40px)); }
@media screen and (max-width: 900px) { #loc05 .life-list { grid-template-columns: 1fr; } }
@media screen and (max-width: 768px) { #loc05 { margin-top: 6rem; }
  #loc05 .life-ttl { font-size: 1.8rem; } }
@media screen and (max-width: 480px) { #loc05 ul li { display: block; padding: 3px; margin-top: 3px; border-bottom: dotted 1px #040000; }
  #loc05 ul li .l-name, #loc05 ul li .l-time { width: 100%; display: block; }
  #loc05 ul li .l-time { margin-top: 2px; }
  #loc05 ul li .line { display: none; } }
