/*! destyle.css v4.0.0 | 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; }

/* 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; }

.design-head { background-color: #200b03; color: #fff; text-align: center; }
.design-head .en-title img { height: 35px; width: auto; }
.design-head .komidashi { margin-top: 30px; }
@media screen and (max-width: 768px) { .design-head { position: relative; z-index: 1; }
  .design-head .en-title img { height: 30px; } }
@media screen and (max-width: 480px) { .design-head .en-title img { height: 25px; } }

.section { position: relative; z-index: 1; overflow-x: hidden; }

.inner, .inner2 { font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif"; max-width: 1050px; }

#contents .category-name img { width: 100%; height: auto; }
#contents .komidashi { font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif"; font-size: 22px; line-height: 1.6; font-feature-settings: "palt"; text-align: center; }
#contents * + .lead { margin-top: 30px; }
#contents .komidashi + .lead, #contents .category-name + .lead { text-align: center; }

@media screen and (max-width: 480px) { #contents .komidashi { font-size: 5vw; }
  #contents * + .lead { margin-top: 20px; }
  #contents .komidashi + .lead, #contents .category-name + .lead { text-align: left; } }
/*******************************

comfort-resort

*******************************/
#comfort-resort { background-color: #200b03; color: #fff; }
#comfort-resort > .img { font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif"; }
#comfort-resort .inner .komidashi, #comfort-resort .inner .img { margin-top: 80px; }

@media screen and (max-width: 480px) { #comfort-resort .inner .komidashi { margin-top: 40px; }
  #comfort-resort .inner .img { margin: 40px calc(50% - 50vw ) 0; } }
/*******************************

facade-design

*******************************/
#facade-design { background-color: #200b03; color: #fff; padding: 80px 0; }
#facade-design .inner { background-color: #494646; padding: 50px 70px 60px; }
#facade-design .category-name { width: clamp(130px, 35vw, 259px); margin-inline: auto; }
#facade-design .designer { max-width: 745px; margin-inline: auto; display: grid; grid-template-columns: 145px 1fr; column-gap: 40px; margin-top: 60px; }
#facade-design .designer .img { grid-row: span 4; }
#facade-design .designer .position-en { color: #ab9d7b; font-size: 20px; }
#facade-design .designer .position-jp { font-size: 24px; font-weight: bold; margin-top: 15px; }
#facade-design .designer .person { display: flex; column-gap: 30px; margin-top: 25px; border-top: 1px solid #fcfefe; padding-top: 25px; }
#facade-design .designer .person .company { font-size: 15px; line-height: 1.4; }
#facade-design .designer .person .name { font-size: 28px; }
#facade-design .designer .person .name .en { font-size: 67%; margin-left: 10px; }
#facade-design .block .komidashi, #facade-design .block .lead { text-align: left; }
#facade-design .block01 { border-top: 1px solid #867d68; margin-top: 60px; padding-top: 60px; }
#facade-design .block01 .img { margin-top: 40px; }
#facade-design .block01 .img .cap { margin-top: 20px; }
#facade-design .block02 { margin-top: 60px; }

@media screen and (max-width: 768px) { #facade-design { padding-bottom: 0; }
  #facade-design .inner { width: 100%; padding: 40px 30px 30px; }
  #facade-design .designer { column-gap: 20px; grid-template-columns: 0.6fr 1fr; }
  #facade-design .designer .person { flex-direction: column; row-gap: 10px; padding-top: 15px; margin-top: 15px; }
  #facade-design .designer .lead { margin-top: 15px; } }
@media screen and (max-width: 480px) { #facade-design { padding-top: 30px; }
  #facade-design .inner { padding: 30px 20px; }
  #facade-design .designer { column-gap: 10px; margin-top: 30px; }
  #facade-design .designer .position-en { font-size: 18px; }
  #facade-design .designer .position-jp { font-size: 22px; }
  #facade-design .designer .person .company { font-size: 14px; }
  #facade-design .designer .person .name { font-size: 24px; }
  #facade-design .designer .person .name .en { display: block; margin-left: 0; }
  #facade-design .designer .lead { font-size: 12px; }
  #facade-design .block01 { margin-top: 30px; padding-top: 30px; } }
/*******************************

landscape-design

*******************************/
#landscape-design { background-color: #fff; padding-top: 100px; }
#landscape-design .block01 .category-name { width: clamp(163px, 35vw, 327px); margin-inline: auto; }
#landscape-design .block01 .img { margin-top: 40px; }
#landscape-design .block01 .point { /*max-width: 550px;*/ max-width: 620px; background-color: #eeebd1; padding: 30px; margin-inline: auto; margin-top: 60px; }
#landscape-design .block01 .point .title { font-size: 25px; color: #863e0f; line-height: 1.4; }
#landscape-design .block01 .point .list { display: flex; flex-direction: column; row-gap: 10px; margin-top: 20px; }
#landscape-design .block01 .point .list li { border-bottom: 1px solid #cbbbb3; padding-bottom: 10px; font-size: 20px; display: flex; column-gap: 10px; }
#landscape-design .block01 .point .list li .number { background-color: #b35721; flex-shrink: 0; color: #fff; width: 22px; height: 22px; display: grid; place-content: center; border-radius: 50%; }
#landscape-design .block02 { margin-top: 80px; }
#landscape-design .block02 .img { font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif"; margin-top: 30px; }
#landscape-design .block03 { margin-top: 80px; }
#landscape-design .block03 .img01 { max-width: 830px; margin-top: 20px; margin-inline: auto; }
#landscape-design .block03 .img01 .cap { text-align: left; }
#landscape-design .block03 .river { display: grid; grid-template-columns: 0.53fr 1fr; align-items: flex-start; column-gap: 40px; margin-top: 40px; }

@media screen and (max-width: 768px) { #landscape-design .block03 .river { grid-template-columns: 1fr; }
  #landscape-design .block03 .river .img { margin-top: 20px; } }
@media screen and (max-width: 480px) { #landscape-design { padding-top: 60px; }
  #landscape-design .block01 .point { padding: 20px; margin-top: 25px; }
  #landscape-design .block01 .point .title { font-size: 22px; }
  #landscape-design .block01 .point .title br { display: none; }
  #landscape-design .block01 .point .list li { font-size: 16px; }
  #landscape-design .block01 .point .list li .number { width: 18px; height: 18px; } }
/*******************************

entrance

*******************************/
#entrance { background-color: #fff; padding-top: 100px; }
#entrance .category-name { width: clamp(76px, 35vw, 153px); margin-inline: auto; }
#entrance .img01 { margin-top: 40px; font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif"; }
#entrance .img02 { margin-top: 80px; }
#entrance .point { display: grid; grid-template-columns: 0.9fr 1fr; column-gap: 20px; max-width: 550px; background-color: #e9e6d2; padding: 30px 40px 0; margin-inline: auto; margin-top: 80px; }
#entrance .point .title { grid-column: span 2; color: #806e41; font-size: 25px; }
#entrance .point .img { align-self: flex-end; grid-row: span 2; }
#entrance .point .lead { text-align: left; padding-bottom: 10px; }
#entrance .point .note { padding-bottom: 30px; }

@media screen and (max-width: 480px) { #entrance { padding-top: 60px; }
  #entrance .img02 { width: 100vw; margin: 20px calc(50% - 50vw) 0; /*margin-top: 40px;*/ }
  #entrance .point { padding: 20px 20px 0; grid-template-columns: 1fr; margin-top: 40px; }
  #entrance .point .title { font-size: 22px; grid-column: span 1; order: 1; }
  #entrance .point .lead { order: 2; }
  #entrance .point .img { width: 60%; margin-inline: auto; grid-area: span 1; order: 4; margin-top: 10px; }
  #entrance .point .note { padding-bottom: 0; order: 3; } }
/*******************************

community-space

*******************************/
#community-space { background-color: #fff; padding-top: 100px; }
#community-space .category-name { width: clamp(163px, 35vw, 327px); margin-inline: auto; }
#community-space .detail { display: grid; grid-template-columns: 0.78fr 1fr; column-gap: 6.5%; margin-top: 40px; }
#community-space .detail .map-image { order: 2; }
#community-space .detail .public-space { order: 1; grid-row: span 3; }
#community-space .detail .public-space .facility-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; margin-top: 20px; }
#community-space .detail .public-space .text { font-size: 16px; line-height: 1.4; margin-top: 5px; text-align: center; }
#community-space .detail .public-space .note:last-child { margin-top: 20px; text-align: right; }
#community-space .detail .garden { order: 3; margin-top: 20px; }
#community-space .detail .garden .lead { text-align: left; margin-top: 10px; }

@media screen and (max-width: 768px) { #community-space .detail { grid-template-columns: 1fr; }
  #community-space .detail .map-image { order: 1; }
  #community-space .detail .public-space { order: 2; margin-top: 40px; } }
@media screen and (max-width: 480px) { #community-space { padding-top: 60px; }
  #community-space .detail .public-space .text { font-size: 13px; }
  #community-space .detail .garden .lead { font-size: 13px; line-height: 1.4; } }
/*******************************

lounge

*******************************/
#lounge { background-color: #fff; padding-top: 100px; }
#lounge .category-name { width: clamp(66px, 35vw, 133px); margin-inline: auto; }
#lounge .img01 { font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif"; margin-top: 40px; }
#lounge .img02 { margin-top: 60px; }

@media screen and (max-width: 480px) { #lounge { padding-top: 60px; }
  #lounge .img02 { width: 100vw; margin: 20px calc(50% - 50vw) 0; /*margin-top: 40px;*/ } }
/*******************************

mobility

*******************************/
#mobility { background-color: #fff; padding-top: 100px; }
#mobility .category-name { width: clamp(75px, 35vw, 149px); margin-inline: auto; }
#mobility .facility-list { display: grid; grid-template-columns: repeat(4, 1fr); gap: 26px; margin-top: 30px; }
#mobility .facility-list .facility:last-of-type { grid-column: span 2; }
#mobility .facility-list .text { font-size: 16px; line-height: 1.4; text-align: center; margin-top: 5px; }
#mobility .facility-list .note { margin-top: 5px; }
#mobility .facility-list + .note { text-align: right; }
#mobility .note.sp { text-align: left; margin-top: 10px; }
#mobility .planting { background-color: #ecebe2; padding: 40px 0 20px; margin-top: 40px; }
#mobility .planting .flower-list { margin-top: 30px; display: grid; grid-template-columns: repeat(6, 1fr); gap: 12px; }
#mobility .planting .flower-list .name { font-size: 12px; margin-top: 5px; }
#mobility .planting + .note { font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif"; margin-top: 20px; max-width: 1050px; width: 90%; margin-inline: auto; }
#mobility .summer { margin-top: 100px; }
#mobility .summer .img { margin-top: 20px; font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif"; }

@media screen and (max-width: 768px) { #mobility .facility-list { grid-template-columns: repeat(2, 1fr); gap: 20px; }
  #mobility .facility-list .facility + .note { grid-column: span 2; margin-top: 0; text-align: right; }
  #mobility .planting .flower-list { grid-template-columns: repeat(3, 1fr); }
  #mobility .summer { padding-bottom: 40px; }
  #mobility .summer .img .cap { right: inherit; left: 5px; }
  #mobility .summer .img + .picture { margin-top: -10%; position: relative; z-index: 1; text-align: right; padding-right: 5%; } }
@media screen and (max-width: 480px) { #mobility { padding-top: 60px; }
  #mobility .facility-list .text { font-size: 13px; }
  #mobility .facility-list .facility:last-of-type .text { text-align: left; }
  #mobility .planting .flower-list { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  #mobility .summer { margin-top: 40px; } }
