/*! 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; }

.img01 { background: #C9D3D1; padding-bottom: 2rem; }
.img01 .img { width: 90%; max-width: 1400px; margin-right: auto; margin-left: auto; width: 100%; }
@media screen and (max-width: 1400px) { .img01 { padding-bottom: 0; } }

.designer { margin-top: 2rem; background: #C9D3D1; /*	@media screen and (max-width:1150px){
		grid-template-columns: 1fr;
		.txt-box{
			.lead{
				width: 35%;
			}
			.prof-img{
				width: 35%;
			}
			.prof-txt{
				width: 25%;
			}
		}
	}*/ }
.designer .txt-box { padding: 2rem; display: -webkit-box; display: flex; flex-wrap: wrap; -webkit-box-pack: justify; justify-content: space-between; -webkit-box-align: start; align-items: flex-start; }
.designer .txt-box * { min-height: 0%; }
.designer .txt-box .prof-copy { width: 55%; }
.designer .txt-box .prof-detail { margin: 1rem auto 0 auto; width: 40%; max-width: 300px; display: grid; gap: 20px; grid-template-columns: 45% 1fr; }
.designer .txt-box .prof-detail .prof-img-txt { grid-column: 1 / 3; }
.designer .txt-box .prof-detail .prof-txt { border-top: solid 1px #000; border-bottom: solid 1px #000; padding: .5rem 0; }
.designer .txt-box .prof-detail .prof-txt .p-ttl { text-align: center; font-size: 14px; letter-spacing: .5em; }
.designer .txt-box .prof-detail .prof-txt p { margin-top: .5rem; font-size: 11px; line-height: 1.4; }
.designer .txt-box .komidashi { width: 100%; line-height: 1.6; }
.designer .txt-box .lead { width: 100%; margin-top: 1rem; }
@media screen and (max-width: 768px) { .designer .txt-box .prof-copy { width: 100%; }
  .designer .txt-box .prof-detail { width: 100%; margin-top: 2rem; } }
@media screen and (max-width: 600px) { .designer .txt-box .prof-detail { grid-template-columns: 40% 1fr; max-width: inherit; }
  .designer .txt-box .prof-detail .prof-img-txt { grid-column: 1 / 2; }
  .designer .txt-box .prof-detail .prof-txt { grid-column: 1 / 4; }
  .designer .txt-box .prof-detail .prof-img { grid-column: 3 / 4; } }

.komidashi.line { border-bottom: solid 1px #000; padding-bottom: .5rem; }
.komidashi.line + .lead { margin-top: .5rem; }

.mate { margin-top: 3rem; display: -webkit-box; display: flex; flex-wrap: wrap; -webkit-box-pack: justify; justify-content: space-between; -webkit-box-align: stretch; align-items: stretch; }
.mate * { min-height: 0%; }
.mate .img-box { width: 30%; }
.mate .txt-box { width: 68%; }
@media screen and (max-width: 500px) { .mate .img-box { width: 100%; }
  .mate .txt-box { margin-top: 1rem; width: 100%; } }

.img04 .img { width: 90%; max-width: 1400px; margin-right: auto; margin-left: auto; width: 100%; }
.img04 + .inner02 { margin-top: 2rem; }

.skhi { width: 100%; max-width: 800px; margin: 3rem auto 0 auto; }

.img08 { width: 100%; margin: 5rem 0 0 0; }

.green { /*background: url("../images/design/green-bg.jpg") no-repeat 0% 0%;
background-size: cover;
color: #fff;*/ padding: 30px; position: relative; }
.green > .cap { font-size: 11px; line-height: 1; position: absolute; bottom: 5px; right: 5px; color: #fff; }
.green .flx { margin-top: 2rem; display: -webkit-box; display: flex; flex-wrap: wrap; -webkit-box-pack: justify; justify-content: space-between; -webkit-box-align: stretch; align-items: stretch; }
.green .flx * { min-height: 0%; }
.green .img-box { width: 30%; display: grid; gap: 0; grid-template-columns: repeat(2, 1fr); }
.green .txt-box { width: 68%; }
.green .txt-box .line { border-top: solid 1px #fff; border-bottom: solid 1px #fff; padding: 5px 0; }
@media screen and (max-width: 768px) { .green { padding: 20px; }
  .green .img-box { width: 40%; }
  .green .txt-box { width: 58%; } }
@media screen and (max-width: 500px) { .green { background: url("../images/design/green-bg.jpg") no-repeat 0% 0%; background-size: auto 100%; padding: 20px 10px; }
  .green .img-box { width: 100%; }
  .green .txt-box { margin-top: 1rem; width: 100%; } }

.view { /*margin-top: 3rem;*/ }
@media screen and (max-width: 600px) { .view .img { overflow-x: scroll; padding: 10px 0; }
  .view .img img { height: 300px; width: auto; } }

#d03 .midashi { margin-top: 2rem; }
#d03 .img06 { width: 100%; max-width: 800px; margin: 2rem auto 0 auto; }

#d04 { margin-top: 5rem; background: #C9D3D1; }
#d04 .inner02 { padding-bottom: 5rem; }
#d04 ul { margin-top: 2rem; display: grid; gap: 30px; grid-template-columns: repeat(3, 1fr); }
#d04 ul li .li-ttl { margin-top: .5rem; display: -webkit-box; display: flex; flex-wrap: wrap; -webkit-box-pack: justify; justify-content: space-between; -webkit-box-align: stretch; align-items: stretch; }
#d04 ul li .li-ttl * { min-height: 0%; }
#d04 ul li .li-ttl .num { display: -webkit-box; display: flex; flex-wrap: wrap; -webkit-box-pack: center; justify-content: center; -webkit-box-align: center; align-items: center; width: 20px; height: 20px; position: relative; top: 2px; background: #001556; display: none; }
#d04 ul li .li-ttl .num * { min-height: 0%; }
#d04 ul li .li-ttl .num .txt { font-size: 16px; line-height: 1; color: #fff; }
#d04 ul li .li-ttl .ttl-txt { font-size: 16px; line-height: 1.4; }
#d04 ul li .li-txt { margin-top: .5rem; font-size: .875rem; line-height: 1.6; }
#d04 ul li .li-txt .note { margin-top: .5rem; }
@media screen and (max-width: 768px) { #d04 ul { gap: 20px; grid-template-columns: repeat(2, 1fr); } }
@media screen and (max-width: 500px) { #d04 ul { gap: 40px; grid-template-columns: 1fr; } }

.view { position: relative; }
.view .cap { font-size: 10px; line-height: 1.2; position: absolute; color: #fff; padding: 3px; background: rgba(0, 0, 0, 0.5); bottom: 0; right: 0; z-index: 2; }
.view + .inner02 .img06 .img { padding-bottom: 10px; }
.view + .inner02 .img06 .note { margin-top: .2rem; }
