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

.zeh-bg { background: #fff; position: relative; z-index: 1; padding-bottom: 80px; }

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

.section { margin-top: 60px; }

.kind .inner2 { background-color: #dbe6cc; padding: 50px; }
.kind .inner2 > .title { background-color: #005e3c; outline: 1px solid #fff; outline-offset: -2px; font-size: 25px; text-align: center; color: #fff; font-feature-settings: "palt"; letter-spacing: 0.1em; font-weight: 500; padding: 10px; }
.kind .inner2 > .title .large { font-size: 140%; }

@media screen and (max-width: 768px) { .section { margin-top: 50px; }
  .kind .inner2 { padding: 40px; width: 100%; } }
@media screen and (max-width: 480px) { .zeh-bg { padding-bottom: 40px; }
  .section { margin-top: 40px; }
  .kind .inner2 { padding: 30px; }
  .kind .inner2 > .title { font-size: 20px; } }
/*******************************

about

*******************************/
.about { margin-top: 0; }
.about .detail-list { row-gap: 1px; border: 1px solid #000; border-width: 1px 0; display: grid; grid-template-columns: repeat(2, 1fr); position: relative; }
.about .detail-list::before, .about .detail-list::after { content: ''; width: 100%; height: 2px; background-color: #000; left: 0; position: absolute; }
.about .detail-list::before { top: -5px; }
.about .detail-list::after { bottom: -5px; }
.about .detail { padding: 40px; text-align: center; display: grid; grid-template-rows: subgrid; grid-row: span 2; row-gap: 20px; }
.about .detail .title { font-feature-settings: "palt"; font-size: 22px; line-height: 1.4; align-self: center; }
.about .detail .text { font-size: 16px; line-height: 1.8; }
.about hr { background-color: #ccc; position: absolute; content: ''; width: 1px; height: calc(100% - 80px); left: 50%; top: 50%; translate: 0 -50%; }
.about .note { margin-top: 10px; }

@media screen and (max-width: 768px) { .about .detail-list { grid-template-columns: 1fr; }
  .about hr { width: 100%; height: 1px; position: static; translate: 0 0; opacity: 0.3; } }
@media screen and (max-width: 480px) { .about .detail { padding: 30px 0; }
  .about .detail .title { font-size: 18px; } }
/*******************************

merit

*******************************/
.merit .title { color: #005e3c; font-size: 30px; font-weight: 500; text-align: center; font-feature-settings: "palt"; letter-spacing: 0.05em; }
.merit .title .large { font-size: 180%; }
.merit .list { margin-top: 40px; display: flex; justify-content: center; gap: 35px; flex-wrap: wrap; }
.merit .list li { width: 35.36%; }
.merit .arrow { width: 155px; margin-inline: auto; margin-top: 60px; }

@media screen and (max-width: 768px) { .merit .list { flex-direction: column; }
  .merit .list li { margin-inline: auto; text-align: center; width: 100%; max-width: 400px; } }
@media screen and (max-width: 480px) { .merit .list { gap: 25px; margin-top: 15px; }
  .merit .arrow { margin-top: 40px; } }
/*******************************

cost

*******************************/
.cost .point-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 40px; margin-top: 40px; }
.cost .point { display: grid; grid-template-rows: subgrid; grid-row: span 2; row-gap: 10px; }
.cost .point .point-header { background-color: #fff; border: 1px solid #006e5b; display: grid; grid-template-columns: 80px 1fr; position: relative; }
.cost .point .point-header .number { background-color: #006e5b; display: flex; flex-direction: column; justify-content: center; place-items: center; line-height: 1; font-family: "Oswald", sans-serif; font-optical-sizing: auto; font-weight: 500; font-style: normal; letter-spacing: 0.05em; font-size: 12px; color: #fff; }
.cost .point .point-header .number .no { font-size: 50px; line-height: 1; }
.cost .point .point-header .title { color: #005e3c; font-weight: 600; padding: 15px; }
.cost .point .point-header .title .sub { font-size: 18px; }
.cost .point .point-header .title .main { font-size: 25px; }
.cost .point .point-header .button { content: ''; display: none; cursor: pointer; position: absolute; right: 15px; top: 50%; translate: 0 -50%; content: ''; width: 27px; height: 27px; background: url(../img/zeh/icon_close.png) no-repeat center center; background-size: 100% auto; }
.cost .point.open .button { background-image: url(../img/zeh/icon_open.png); }
.cost .point .point-body { background-color: #fff; padding: 25px 30px; }
.cost .point .point-body .text { font-size: 16px; line-height: 1.4; }
.cost .point .point-body * + .img, .cost .point .point-body .note { margin-top: 15px; }
.cost .point .point-body .note { line-height: 1.4; }

@media screen and (max-width: 768px) { .cost .point-list { grid-template-columns: 1fr; gap: 0; }
  .cost .point .point-header .title { padding: 15px 40px 15px 15px; }
  .cost .point .point-header .button { display: block; }
  .cost .point .point-body { display: none; margin-bottom: 15px; } }
@media screen and (max-width: 480px) { .cost .point-list { margin-top: 30px; }
  .cost .point .point-header { grid-template-columns: 70px 1fr; }
  .cost .point .point-header .number { font-size: 10px; }
  .cost .point .point-header .number .no { font-size: 40px; }
  .cost .point .point-header .title { padding: 10px 40px 10px 10px; }
  .cost .point .point-header .title .sub { font-size: 12px; }
  .cost .point .point-header .title .main { font-size: 20px; }
  .cost .point .point-body { padding: 20px; } }
/*******************************

health

*******************************/
.health .inner2 { display: grid; grid-template-columns: repeat(2, 1fr); column-gap: 40px; }
.health .inner2 > .title { grid-column: span 2; order: 1; margin-bottom: 60px; }
.health .inner2 .text { font-size: 16px; line-height: 1.8; margin-top: 15px; }
.health .overview { order: 2; }
.health .overview .title { font-size: 22px; }
.health .detail { order: 4; margin-top: 20px; }
.health .detail .sub-title { background-color: #006e5b; color: #fff; text-align: center; padding: 10px; font-size: 18px; line-height: 1.3; }
.health .img { order: 3; grid-row: span 2; padding: 0 20px; }

@media screen and (max-width: 768px) { .health .inner2 { grid-template-columns: 1fr; }
  .health .inner2 > .title { grid-column: span 1; margin-bottom: 40px; }
  .health .overview { text-align: center; }
  .health .overview .text { border: 1px solid #444; border-width: 1px 0; padding: 15px 0; }
  .health .detail { order: 3; margin-top: 40px; }
  .health .img { order: 4; margin-top: 40px; max-width: 480px; margin-inline: auto; } }
/*******************************

environment

*******************************/
.environment .text { font-size: 16px; line-height: 1.8; margin-top: 15px; }
.environment .overview { text-align: center; margin-top: 40px; }
.environment .overview .title { font-size: 22px; }
.environment .detail-list { margin-top: 40px; display: grid; grid-template-columns: repeat(2, 1fr); column-gap: 40px; }
.environment .detail .sub-title { background-color: #006e5b; color: #fff; text-align: center; padding: 10px; font-size: 18px; line-height: 1.3; }
.environment .detail .img { margin-top: 25px; padding: 0 20px; }
.environment .detail .note { margin-top: 20px; line-height: 1.4; }

@media screen and (max-width: 768px) { .environment .overview .text { border: 1px solid #444; border-width: 1px 0; padding: 15px 0; }
  .environment .detail-list { grid-template-columns: 1fr; row-gap: 40px; }
  .environment .detail .img { max-width: 420px; margin-inline: auto; } }
@media screen and (max-width: 480px) { .environment .detail .img { padding: 0; } }
/*******************************

equipment

*******************************/
.equipment .list { background-color: #006e5b; padding: 50px; }
.equipment .list .title { font-size: 22px; text-align: center; background-color: #fff; font-feature-settings: "palt"; letter-spacing: 0.1em; font-weight: 500; padding: 20px 10px; }
.equipment .list .item-list { margin-top: 50px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; }
.equipment .list .item .name { color: #fff; position: relative; padding-right: 50px; /*font-size: 18px;*/ font-size: 16px; margin-top: 15px; }
.equipment .list .item .name::after { position: absolute; right: 0; top: 50%; translate: 0 -50%; content: ''; width: 47px; height: 26px; background: url(../img/zeh/icon_eco.png) no-repeat center center; background-size: 100% auto; }
.equipment .list .item .text { color: #fff; font-size: 14px; line-height: 1.6; margin-top: 10px; }
.equipment .list .item .text + .note { margin-top: 10px; color: #fff; }
.equipment .certification { background-color: #609984; padding: 50px 50px 70px; color: #fff; text-align: center; }
.equipment .certification .title { font-size: 30px; font-weight: 500; line-height: 1.4; font-feature-settings: "palt"; letter-spacing: 0.05em; }
.equipment .certification .sub-title { font-size: 22px; font-weight: 500; line-height: 1.4; margin-top: 40px; font-feature-settings: "palt"; letter-spacing: 0.05em; }
.equipment .certification .text { margin-top: 10px; font-size: 16px; line-height: 1.8; }
.equipment .certification .img { max-width: 441px; margin-inline: auto; margin-top: 60px; }

@media screen and (max-width: 768px) { .equipment .inner2 { width: 100%; }
  .equipment .list { padding: 40px; }
  .equipment .list .item-list { grid-template-columns: repeat(2, 1fr); gap: 30px; }
  .equipment .certification { padding: 50px 40px 60px; }
  .equipment .certification .text { text-align: left; } }
@media screen and (max-width: 480px) { .equipment .list { padding: 30px; }
  .equipment .list .title { font-size: 20px; }
  .equipment .list .item-list { margin-top: 30px; gap: 30px 20px; }
  .equipment .list .item .name { font-size: 16px; padding-right: 37px; }
  .equipment .list .item .name::after { width: 37px; height: 20px; }
  .equipment .list .item .text { font-size: 14px; }
  .equipment .list .item .cap { right: 1px; bottom: 1px; }
  .equipment .certification { padding: 40px 30px; }
  .equipment .certification .title { font-size: 26px; }
  .equipment .certification .sub-title { font-size: 20px; margin-top: 30px; }
  .equipment .certification .img { margin-top: 40px; } }
