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

.plan-head { background-color: #fff; color: #77623c; text-align: center; }
.plan-head sup { top: -1.3em; font-size: 45%; letter-spacing: 0; }
@media screen and (max-width: 768px) { .plan-head { position: relative; z-index: 1; } }

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

.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 .category-title + .lead { text-align: center; }

.subnav-s { max-width: 400px; }
.subnav-s ul li { width: 48%; }

.to-plan { max-width: 360px; width: 100%; margin-inline: auto; margin-top: 60px; }
.to-plan a { display: block; background-color: #a69a51; padding: 10px; font-size: 24px; color: #fff; text-align: center; }
.to-plan a:hover { filter: brightness(110%); }

.category-title { text-align: center; }
.category-title .category-name { margin-inline: auto; }
.category-title .category-name img { width: 100%; height: auto; }
.category-title .jp { font-size: 12px; color: #858586; margin-top: 10px; }

@media screen and (max-width: 768px) { .to-plan { max-width: 320px; }
  .to-plan a { font-size: 20px; } }
@media screen and (max-width: 480px) { #contents .komidashi { font-size: 5vw; }
  #contents * + .lead { margin-top: 20px; }
  #contents .category-title + .lead { text-align: left; }
  .to-plan { margin-top: 40px; max-width: 220px; }
  .to-plan a { font-size: 16px; padding: 5px; } }
/*******************************

features

*******************************/
#features { background-color: #ffffff; position: relative; z-index: 1; }
#features .subnav-s ul { padding-bottom: 2rem; }

.features-nav { font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif"; max-width: 1050px; width: 90%; margin-inline: auto; }
.features-nav ul { display: grid; grid-template-columns: repeat(2, 1fr); font-size: 26px; }
.features-nav ul li { display: flex; }
.features-nav ul li a { width: 100%; display: flex; flex-direction: column; justify-content: center; background-color: #d6d6d7; color: #7f7f7f; text-align: center; padding: 20px; }
.features-nav ul li a:hover { filter: brightness(110%); }
.features-nav ul li sup { top: -2.2em; font-size: 40%; }
.features-nav ul li.current a { color: #fff; }
.features-nav ul li.average53.current a { background-color: #3e5d33; }
.features-nav ul li.variation.current a { background-color: #9c3c1c; }

@media screen and (max-width: 768px) { #features { background-color: #f8f5e7; }
  .features-nav ul { font-size: 22px; } }
@media screen and (max-width: 480px) { .features-nav ul { font-size: 18px; } }
/*******************************

average53

*******************************/
#average53 { background-color: #ffffff; padding: 60px 0; }
#average53 .block { margin-top: 60px; }
#average53 .block01 { display: grid; grid-template-columns: 0.69fr 1fr; grid-template-rows: repeat(2, auto) 1fr; column-gap: 6.79%; }
#average53 .block01 .img { grid-row: span 3; }
#average53 .block01 .note { margin-top: 20px; }
#average53 .block02 { max-width: 820px; margin-inline: auto; }
#average53 .block02 .img { margin-top: 30px; }

@media screen and (max-width: 768px) { #average53 { background-color: #f8f5e7; }
  #average53 .block01 { grid-template-columns: 1fr; }
  #average53 .block01 .img { max-width: 420px; margin-inline: auto; grid-row: span 1; margin-top: 30px; } }
@media screen and (max-width: 768px) { #average53 { padding: 20px 0 60px; }
  #average53 .block { margin-top: 30px; } }
/*******************************

variation

*******************************/
#variation { background-image: url(../img/common/background_texture.webp); background-size: cover; background-repeat: no-repeat; background-position: center center; padding: 80px 0; }
#variation .variation-nav { max-width: 1468px; width: 90%; margin-inline: auto; margin-top: 60px; }
#variation .variation-nav ul { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
#variation .variation-nav ul li .text img { width: 100%; height: auto; }
#variation .variation-nav ul li.consevatory .text img { width: 283px; }
#variation .variation-nav ul li.open-air .text img { width: 284px; }
#variation .variation-nav ul li.balcony .text img { width: 271px; }
#variation .variation-nav ul li.terrace .text img { width: 290px; }
#variation .variation-nav a { position: relative; display: block; }
#variation .variation-nav a::after { transition: background-color .2s linear; display: block; mix-blend-mode: multiply; background-color: rgba(0, 0, 0, 0.7); content: ''; width: 100%; height: 100%; position: absolute; left: 0; top: 0; z-index: 1; }
#variation .variation-nav a .text { position: absolute; left: 50%; top: 50%; translate: -50% -50%; z-index: 2; }
#variation .variation-nav a:hover::after { background-color: rgba(0, 0, 0, 0.4); }

@media screen and (max-width: 1366px) { #variation .variation-nav ul li .text { scale: 0.7; } }
@media screen and (max-width: 768px) { #variation .variation-nav ul { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  #variation .variation-nav ul li .text { scale: 0.5; } }
@media screen and (max-width: 480px) { #variation { padding: 40px 0; }
  #variation .variation-nav { margin-top: 40px; } }
/*******************************

conservatory

*******************************/
#conservatory { background-color: #fff; padding-top: 80px; }
#conservatory .category-name { width: clamp(180px, 35vw, 361px); margin-top: 60px; }
#conservatory .figure { max-width: 490px; margin-inline: auto; margin-top: 50px; }
#conservatory .detail { display: flex; flex-direction: column; gap: 30px; margin-top: 20px; }
#conservatory .detail .situation { display: grid; grid-template-columns: repeat(4, 1fr); gap: 26px; }
#conservatory .detail .situation .title { grid-column: span 4; margin-bottom: -20px; }
#conservatory .detail .situation .space .text { font-size: 16px; line-height: 1.4; text-align: center; margin-top: 10px; }

@media screen and (max-width: 768px) { #conservatory .detail .situation { grid-template-columns: repeat(2, 1fr); }
  #conservatory .detail .situation .title { grid-column: span 2; } }
@media screen and (max-width: 480px) { #conservatory { padding-top: 60px; }
  #conservatory .category-name { margin-top: 30px; }
  #conservatory .figure { margin-top: 30px; }
  #conservatory .detail .situation { gap: 20px; }
  #conservatory .detail .situation .space .text { font-size: 13px; } }
/*******************************

open-air

*******************************/
#open-air { background-color: #fff; padding-top: 100px; }
#open-air .img01 { font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif"; }
#open-air .category-name { width: clamp(166px, 35vw, 335px); margin-top: 60px; }
#open-air .lead + .note { margin-top: 20px; text-align: center; }
#open-air .img02 { max-width: 854px; margin-inline: auto; margin-top: 50px; }
#open-air .facility-block { margin-top: 80px; }
#open-air .facility-block .facility-list { display: grid; grid-template-columns: repeat(4, 1fr); margin-top: 30px; gap: 26px; }
#open-air .facility-block .facility-list .name { text-align: center; font-size: 16px; margin-top: 10px; }

@media screen and (max-width: 768px) { #open-air .facility-block .facility-list { grid-template-columns: repeat(2, 1fr); } }
@media screen and (max-width: 480px) { #open-air { padding-top: 60px; }
  #open-air .category-name { margin-top: 30px; }
  #open-air .facility-block { margin-top: 40px; }
  #open-air .facility-block .facility-list { margin-top: 20px; gap: 20px; }
  #open-air .facility-block .facility-list .name { font-size: 13px; } }
/*******************************

balcony

*******************************/
#balcony { background-color: #fff; padding-top: 100px; }
#balcony .category-name { width: clamp(222px, 35vw, 445px); margin-top: 60px; }

@media screen and (max-width: 480px) { #balcony { padding-top: 60px; }
  #balcony .category-name { margin-top: 30px; } }
/*******************************

terrace

*******************************/
#terrace { font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif"; background-color: #fff; padding: 100px 0; display: grid; grid-template-columns: 1fr 0.91fr; column-gap: 50px; align-items: flex-start; }
#terrace .img02 { margin-top: 190px; grid-row: span 2; }
#terrace .copy { width: 65%; margin-left: auto; margin-top: 100px; }
#terrace .copy .category-title { text-align: left; width: clamp(155px, 35vw, 309px); }
#terrace .copy .lead { text-align: left; }
#terrace .copy .note { margin-top: 20px; }
#terrace .copy .to-plan { margin-inline: inherit; margin-right: auto; margin-left: 0; }

@media screen and (max-width: 768px) { #terrace { padding: 60px 5%; grid-template-columns: 1fr; grid-template-areas: "img02" "img01" "copy"; }
  #terrace .img01 { grid-area: img01; margin-top: 30px; }
  #terrace .img02 { grid-area: img02; /*margin-top: 30px;*/ margin-top: 0; grid-row: span 1; }
  #terrace .copy { grid-area: copy; width: 100%; margin-top: 60px; }
  #terrace .copy .category-title { margin-inline: auto; text-align: center; }
  #terrace .copy .to-plan { margin-inline: auto; margin-left: auto; margin-right: auto; } }
/*******************************

room-plan

*******************************/
#room-plan { background-color: #f8f5e7; position: relative; z-index: 1; padding: 60px 0; }
#room-plan .section-header { font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif"; position: relative; }
#room-plan .section-header .section-name { position: absolute; left: 50%; top: 50%; translate: -50% -50%; width: clamp(120px, 35vw, 239px); }
#room-plan .section-header .section-name img { width: 100%; height: auto; }
#room-plan .inner { max-width: 1100px; margin-top: 60px; }
#room-plan .plan-list { margin-top: 60px; display: grid; grid-template-columns: repeat(2, 1fr); gap: 32px; }
#room-plan .plan-list a img { transition: filter .2s linear; }
#room-plan .plan-list a:hover img { filter: brightness(105%); }
#room-plan .jcom { margin-top: 60px; background-color: #2b5c7d; color: #fff; display: grid; grid-template-columns: 0.62fr 1fr; gap: 20px; padding: 30px 45px; }
#room-plan .jcom .komidashi { grid-column: span 2; }
#room-plan .jcom .komidashi .large { font-size: 150%; font-weight: normal; display: inline-block; }
#room-plan .jcom .note { grid-column: span 2; }

@media screen and (max-width: 768px) { #room-plan .plan-list { max-width: 500px; margin-inline: auto; grid-template-columns: 1fr; }
  #room-plan .jcom { grid-template-columns: 1fr; gap: 20px; padding: 20px; }
  #room-plan .jcom .komidashi, #room-plan .jcom .note { grid-column: span 1; }
  #room-plan .jcom .lead { margin-top: 0; } }
@media screen and (max-width: 480px) { #room-plan { padding-top: 40px; }
  #room-plan .subnav-s ul { padding-bottom: 4rem; }
  #room-plan .plan-list { gap: 25px; margin-top: 30px; }
  #room-plan .jcom .komidashi { text-align: left; font-size: 18px; } }
/*******************************

mark

*******************************/
#mark { background-color: #fff; padding: 60px 0; }
#mark .list { /*max-width: 786px;*/ max-width: 916px; display: grid; /*grid-template-columns: 1fr 0.7fr;*/ grid-template-columns: repeat(2, 1fr); align-items: center; gap: 30px 40px; margin-inline: auto; }

@media screen and (max-width: 768px) { #mark .list { grid-template-columns: 1fr; max-width: 400px; }
  #mark .list li:nth-child(1) { width: 80%; margin-inline: auto; }
  #mark .list li:nth-child(2) { width: 50%; margin-inline: auto; } }
/*******************************

plan-detail

*******************************/
.plan-detail { background-color: #fff; padding: 50px 0 80px; }
.plan-detail.roof-balcony .inner { grid-template-columns: 0.65fr 1fr; }
.plan-detail .hanrei { padding-top: 1rem; order: 7; grid-column: span 2; }
.plan-detail .inner { max-width: 1100px; display: grid; /*grid-template-columns: repeat(2, 1fr);*/ grid-template-columns: 0.65fr 1fr; column-gap: 20px; }
.plan-detail .zeh { grid-column: span 2; background-color: #a1c86d; color: #fff; text-align: center; padding: 20px 10px; font-size: 26px; order: 1; margin-bottom: 50px; }
.plan-detail .zeh .yotei { font-size: 0.7em; }
.plan-detail .spec { order: 2; }
.plan-detail .spec .type-name { display: inline-block; background-color: #396141; padding: 5px 30px 15px; color: #fff; font-family: "Oswald", sans-serif; font-optical-sizing: auto; font-weight: 500; font-style: normal; letter-spacing: 0.05em; font-size: 30px; line-height: 1; text-align: center; }
.plan-detail .spec .type-name .large { font-size: 186%; }
.plan-detail .spec .type-name .medium { font-size: 116%; }
.plan-detail .spec .layout { font-family: "Oswald", sans-serif; font-optical-sizing: auto; font-weight: 500; font-style: normal; letter-spacing: 0.05em; display: flex; line-height: 1; align-items: flex-end; margin-top: 10px; padding-bottom: 5px; border-bottom: 1px solid #000; width: fit-content; }
.plan-detail .spec .layout .main { font-size: 38px; }
.plan-detail .spec .layout .main .large { font-size: 210%; }
.plan-detail .spec .layout .sub { font-size: 34px; }
.plan-detail .spec .private-size { display: flex; line-height: 1; align-items: flex-end; margin-top: 10px; }
.plan-detail .spec .private-size .meter { font-family: "Oswald", sans-serif; font-optical-sizing: auto; font-weight: 500; font-style: normal; letter-spacing: 0.05em; font-weight: bold; font-size: 46px; }
.plan-detail .spec .private-size .meter .large { font-size: 186%; }
.plan-detail .spec .private-size .tsubo { font-size: 18px; font-weight: bold; }
.plan-detail .spec .other-size { margin-top: 15px; display: flex; flex-direction: column; row-gap: 5px; font-size: 15px; }
.plan-detail .spec .other-size li { position: relative; padding-left: 1em; }
.plan-detail .spec .other-size li::before { content: '\025a1'; position: absolute; left: 0; top: 0; }
.plan-detail .figure { order: 3; text-align: right; grid-row: span 4; }
.plan-detail .figure img { max-width: 100%; height: auto; }
.plan-detail .summary { order: 4; width: 100%; max-width: 386px; margin-right: auto; margin-top: 80px; background-color: #396141; font-size: 18px; line-height: 1.4; color: #fff; text-align: center; padding: 5px; }
.plan-detail .point-list { order: 5; max-width: 386px; margin-right: auto; display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px 12px; margin-top: 40px; }
.plan-detail .point-list .name { font-size: 16px; line-height: 1.2; margin-top: 5px; text-align: center; }
.plan-detail .legend { order: 6; grid-column: span 2; margin-top: 80px; display: flex; gap: 5px 20px; }
.plan-detail .legend li { display: flex; align-items: center; column-gap: 5px; }
.plan-detail .return-to-list { order: 7; grid-column: span 2; margin-top: 80px; width: 186px; margin-inline: auto; }
.plan-detail .return-to-list a { display: block; font-size: 16px; text-align: center; padding: 15px 10px; background-color: #959595; color: #fff; }
.plan-detail .return-to-list a:hover { filter: brightness(110%); }

@media screen and (max-width: 768px) { .plan-detail { padding: 40px 0; }
  .plan-detail .inner { grid-template-columns: 25% 1fr !important; }
  .plan-detail .zeh { font-size: 22px; margin-bottom: 20px; }
  .plan-detail .spec { grid-column: span 2; display: grid; grid-template-columns: max-content repeat(2, 1fr); column-gap: 10px; }
  .plan-detail .spec .type-name { font-size: 22px; grid-row: span 2; align-self: flex-start; }
  .plan-detail .spec .layout { width: 100%; margin-top: 0; align-self: self-start; border-bottom: 0; padding-bottom: 0; }
  .plan-detail .spec .layout .main { font-size: 28px; }
  .plan-detail .spec .layout .sub { font-size: 22px; }
  .plan-detail .spec .private-size { margin-top: 0; flex-direction: column; margin-left: auto; row-gap: 5px; }
  .plan-detail .spec .private-size .meter { font-size: 30px; }
  .plan-detail .spec .private-size .tsubo { font-size: 14px; }
  .plan-detail .spec .other-size { font-size: 13px; grid-column: span 2; margin-top: 5px; }
  .plan-detail .figure { order: 5; margin-top: 30px; }
  .plan-detail .summary { order: 3; grid-column: span 2; max-width: 100%; width: 100%; margin-top: 30px; }
  .plan-detail .point-list { order: 4; grid-template-columns: 1fr; margin-top: 30px; gap: 10px; }
  .plan-detail .legend { margin-top: 40px; }
  .plan-detail .return-to-list { margin-top: 40px; } }
@media screen and (max-width: 480px) { .plan-detail { padding: 40px 0; }
  .plan-detail .zeh { font-size: 18px; padding: 10px; }
  .plan-detail .spec { grid-template-columns: 1fr; }
  .plan-detail .spec .type-name { grid-row: span 1; width: fit-content; margin-inline: auto; }
  .plan-detail .spec .layout { align-self: center; justify-content: center; margin-top: 10px; padding-bottom: 10px; border-bottom: 1px solid #000; }
  .plan-detail .spec .private-size { margin-top: 5px; margin-left: inherit; align-self: center; justify-content: center; margin-inline: auto; flex-direction: row; }
  .plan-detail .spec .other-size { grid-column: span 1; margin-top: 20px; font-size: 12px; }
  .plan-detail .point-list .name { font-size: 12px; }
  .plan-detail .legend { gap: 5px 15px; }
  .plan-detail .return-to-list a { font-size: 14px; padding: 10px; } }
