@charset "UTF-8";
/*
Theme Name: kuchokai_form
*/

/*----------------------------------------------------
 リセット部
------------------------------------------------------*/
html, body, div, span, h1, h2, h3, h4, h5, h6, p, a,
address, em, img, small, strong,
dl, dt, dd, ol, ul, li, fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video, form, input {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  vertical-align: bottom;
  box-sizing: border-box;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}
body {
  line-height: 1.5em;
}
ol, ul {
  list-style: none;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
img {
  max-width: 100%;
  height: auto;
  -webkit-backface-visibility: hidden;
}

input[type="submit"],
input[type="button"] {
  cursor: pointer;
}

/*----------------------------------------------------
 コンテンツ
------------------------------------------------------*/
body {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

header {
  width: clamp(250px, 100% - 2em, 715px);
  display: flex;
  margin: 0 auto;
  padding: 1em 0;
  justify-content: space-between;
}

.container {
  width: clamp(250px, 100% - 2em, 715px);
  margin: 0 auto;
}

h1 {
  margin-bottom: 1em;
  color: #000080;
  border-bottom-width: 1px;
  border-bottom-style: dashed;
  border-bottom-color: #cccccc;
  background-color: #f7f9f8;
  padding: 5px;
  line-height: 140%;
  font-size: 1.2em;
  font-weight: bold
}

h2 {
  margin-bottom: .5em;
  font-weight: bold;
  color: #000080;
}

p {
  margin-bottom: 1em;
}

.disc {
  list-style-type: disc;
  margin: 0 0 1em 1.5em;
}

.disc li {
  margin-bottom: .3em;
}

.disc .disc {
  list-style-type: circle;
}

fieldset {
  display: block;
  padding-bottom: 1em;
}

legend {
  font-weight: bold;
}

input[type="text"],
input[type="email"] {
  width: 100%;
  height: 2em;
  border: 1px solid #666;
  padding: 0 .2em;
}

.inq_add label {
  display: inline-flex;
  gap: .5em;
  align-items: baseline;
}

.inq_add label > span {
  line-height: 2em;
}

.inq_add label:first-child {
  margin-bottom: .5em;
}

.inq_add select {
  font-size: 1em;
  padding: .3em 0;
}

.inq_add span[data-name="inq_pref"],
.inq_add span[data-name="inq_city"] {
  max-width: calc(100% - 5.5em);
}

.inq_add option:disabled {
  opacity: .8;
}

textarea {
  width: 100%;
  line-height: 1.3em;
  border: 1px solid #666;
  box-sizing: border-box;
  resize: vertical;
  font-size: 1em;
  padding: .2em;
}

.wpcf7-list-item {
  margin-left: 0;
}

span[data-name="inq_resp"] .wpcf7-radio,
span[data-name="request-answer"] .wpcf7-radio {
  display: flex;
  gap: 1.5em;
}

span[data-name="inq_resp"] label,
span[data-name="request-answer"] label {
  display: flex;
  align-items: baseline;
}

input[type="radio"],
input[type="checkbox"] {
  margin-right: .2em;
}

.inq_btns {
  display: flex;
  gap: 1.5em;
  justify-content: center;
}

.inq_btns input[type="submit"],
.inq_btns input[type="button"] {
  min-height: 2em;
  min-width: 4em;
  padding: 0 .5em;
  border-radius: 3px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.inq_btns input[type="submit"] {
  background-color: #000080;
  border: 2px solid #000080;
  font-weight: bold;
  color: #fff;
}

.inq_btns input[type="submit"]:hover {
  color: #000080;
  background-color: #fff;
}

.inq_btns input[type="button"] {
  color: #000080;
  background-color: #fff;
  border: 1px solid;
}

.inq_btns .wpcf7-spinner {
  height: 0;
}

.inq_req {
  display: inline-block;
  margin-left: .5em;
  color: #C00;
}

.back_home::before {
  content: "\025c0";
  display: inline-block;
  padding-right: .3em;
  color: #000080;
}

address {
  background-color: #000080;
  color: #fff;
  font-size: 80%;
  padding: 3px;
  text-align: center;
  margin-top: auto;
}