﻿@charset "UTF-8";

html {
    color: #000;
    background: #fff;
}

body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
code,
form,
fieldset,
legend,
input,
textarea,
p,
blockquote,
th,
td {
    margin: 0;
    padding: 0;
}	

table {
    border-collapse: collapse;
    border-spacing: 0;
	width: 100%
}

fieldset,
img {
    border: 0;
}

address,
caption,
cite,
code,
dfn,
em,
strong,
th,
var {
    font-style: normal;
    font-weight: normal;
}

ol,
ul {
    list-style: none;
}

caption,
th {
    text-align: left;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-size: 100%;
    font-weight: normal;
	font-family: "Times New Roman",Times,"Yu Mincho","游明朝","游明朝体","Hiragino Mincho Pro",serif;
}

q:before,
q:after {
    content: "";
}

abbr,
acronym {
    border: 0;
    font-variant: normal;
}

sup {
    vertical-align: text-top;
}

sub {
    vertical-align: text-bottom;
}

input,
textarea,
select,
button {
    font-family: inherit;
    font-size: inherit;
    font-weight: inherit;
    line-height: inherit;
    *font-size: 100%;
}

legend {
    color: #000;
}

*::before,
*::after {
    box-sizing: border-box;
}

/* base */
/* ---------------- */

* {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-family: Arial,"Hiragino Sans","Yu Gothic Medium","Meiryo",sans-serif;
    box-sizing: border-box;
}

body {
    line-height: 1.8;
    line-height: 2;
    font-size: 14px;
}

a {
    text-decoration: none;
    color: inherit;
}

img {
    max-width: 100%;
	width: auto;
	height: auto;
}

header {
	min-height: 68px;
	background: #000;
	line-height: 68px;
}

/*header .logo {
	max-width: 1200px;
	margin: 0 auto;
}*/

header .logo img {
	max-height: 60px;
	vertical-align: middle;
}

.container {
    width: 100%;
    margin: 100px auto;
    max-width: 800px;
	padding: 0 20px;
}

.title {
    text-align: center;
    font-weight: bold;
    font-size: 30px;
	margin-bottom: 50px;
	line-height: 1.5;
}

.title br {
	display: none;
}

.cnt {
	text-align: center;
}

.form {
    margin-top: 40px;
}

.form-item {
    padding: 20px 0 0 0;
}

.form-item-name {
    display: block;
    font-weight: bold;
}

.form-item-body {
    margin-top: 4px;
}

.error {
    margin-top: 4px;
    color: #dc3232;
}


/* input text */
/* ---------------- */

.form-item-text{
    width: 100%;
}

.c-form-text {
    height: 2.4em;
    width: 100%;
    padding: 0 10px;
    border: none;
    box-shadow: 0 0 0 1px #ccc inset;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
}

.c-form-text-s {
    height: 2.4em;
    width: 100px;
    padding: 0 10px;
    border: none;
    box-shadow: 0 0 0 1px #ccc inset;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
}

.c-form-text:focus,
.c-form-text-s:focus {
	outline: none;
	border: 1px solid #bbb;
	-webkit-box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.2);
	box-shadow: inner 0 0 5px rgba(0, 0, 0, 0.2);
}

/* radio */
/* ---------------- */

.c-form-radio{
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.c-form-radio input {
    position: absolute;
    white-space: nowrap;
    width: 1px;
    height: 1px;
    overflow: hidden;
    border: 0;
    padding: 0;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    margin: -1px;
}

.c-form-radio-name {
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    color: #666;
}

.c-form-radio-name:before {
    content: "";
    display: inline-block;
    width: 1.2em;
    height: 1.2em;
    border: 1px solid #ccc;
    border-radius: 50%;
    margin-right: 6px;
    flex-shrink: 0;
}

.c-form-radio input:checked + .c-form-radio-name {
    color: #b69e84;
}

.c-form-radio input:checked + .c-form-radio-name:before {
    border: 0.35em solid #b69e84;
}

.c-form-radio input:focus-visible + .c-form-radio-name .c-form-radio-text {
    background: linear-gradient(transparent 90%, rgba(33, 150, 243, 0.3) 90%);
}

/* checkbox */
/* ---------------- */

.c-form-checkbox{
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.c-form-checkbox input {
    position: absolute;
    white-space: nowrap;
    width: 1px;
    height: 1px;
    overflow: hidden;
    border: 0;
    padding: 0;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    margin: -1px;
}

.c-form-checkbox-name {
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    color: #666;
    position: relative;
}

.c-form-checkbox-name:before {
    content: "";
    display: inline-block;
    width: 1.2em;
    height: 1.2em;
    border: 1px solid #ccc;
    border-radius: 3px;
    margin-right: 6px;
    flex-shrink: 0;
}

.c-form-checkbox input:checked + .c-form-checkbox-name {
    color: #b69e84;
}

.c-form-checkbox input:checked + .c-form-checkbox-name:before {
    border: 1px solid #b69e84;
    background-color: #b69e84;
}

.c-form-checkbox input:checked + .c-form-checkbox-name:after {
    content: "";
    position: absolute;
    border: solid #fff;
    border-width: 0 2px 2px 0;
    left: 0.4em;
    top: 0;
    bottom: 0;
    margin: auto;
    width: 0.4em;
    height: 0.65em;
    transform: translateY(-1px) rotate(45deg);
}

.c-form-checkbox input:focus-visible + .c-form-checkbox-name .c-form-checkbox-text {
    background: linear-gradient(transparent 90%, rgba(33, 150, 243, 0.3) 90%);
}

/* select */
/* ---------------- */

.form-item-select{
    max-width: 300px;
}

.c-form-select {
    position: relative;
}

.c-form-select:before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    right: 12px;
    width: 8px;
    height: 8px;
    border-top: 2px solid #333;
    border-right: 2px solid #333;
    transform: rotate(135deg);
    pointer-events: none;
}

.c-form-select select {
    height: 2.4em;
    width: 100%;
    padding: 0 8px;
    border-radius: 4px;
    border: none;
    box-shadow: 0 0 0 1px #ccc inset;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    cursor: pointer;
	color: #000;
}

.c-form-select select::-ms-expand {
    display: none;
}

.c-form-select select:focus {
    outline: 0;
    border: 1px solid #bbb;
	-webkit-box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.2);
	box-shadow: inner 0 0 5px rgba(0, 0, 0, 0.2);
}

/* textarea */
/* ---------------- */

.c-form-textarea,
.c-form-textarea-s {
    display: block;
    width: 100%;
    padding: 4px 16px;
    border: none;
    box-shadow: 0 0 0 1px #ccc inset;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    resize: vertical;
}

.c-form-textarea {
	height: 300px;
}


.c-form-textarea-s {
	height: 100px;
}

.c-form-textarea:focus {
    outline: 0;
    border: 1px solid #bbb;
	-webkit-box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.2);
	box-shadow: inner 0 0 5px rgba(0, 0, 0, 0.2);
}

/* file */
/* ---------------- */

.c-form-file {
    padding: 10px;
	border: 1px #ccc solid;
	background: #fafafa;
}

/* input submit */
/* button */
/* ---------------- */

.form-submit {
    margin: 60px auto 0;
    width: 300px;
}

.c-form-submit-button {
    display: inline-block;
    width: 100%;
    padding: 8px;
    border: none;
    background-color: #000;
    color: #fff;
    font-weight: bold;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    cursor: pointer;
    border: 2px solid transparent;
}

.c-form-back-button {
    display: inline-block;
    width: 100%;
    padding: 8px;
    border: none;
    background-color: #ccc;
    color: #000;
    font-weight: bold;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    cursor: pointer;
    border: 2px solid transparent;
	margin-right: 20px;
}

.c-form-submit-button:hover {
    background-color: #555;
}

.c-form-back-button:hover {
    background-color: #ddd;
}

.c-form-submit-button:focus {
    outline: 0;
    background-color: #000;
}

.c-form-back-button:focus {
    outline: 0;
    background-color: #ddd;
}

.c-form-top-button {
    width: 300px;
    padding: 8px;
    border: none;
    background-color: #b69e84;
    color: #fff;
    font-weight: bold;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    cursor: pointer;
    border: 2px solid transparent;
	margin: 50px auto;
	text-align: center;
}

.c-form-top-button:hover {
    background-color: #92785f;
}


/* 確認画面 */
table.formTable {
	margin-top: 50px;
	word-break: break-all;
	overflow-wrap: break-word;
}
table.formTable tr {
	border-bottom: 1px solid #ccc;
}

table.formTable th,
table.formTable td {
	padding: 24px 0;
	border: none;
}

table.formTable th {
	width: 30%;
	font-weight: bold;
	vertical-align: top;
}

table.formTable td {
	color: #666;
	word-break: break-all;
	overflow-wrap: break-word;
}

.confirm_btn {
	display: flex;
	width: 620px;
	margin: 60px auto;
}

p.error_messe{
	margin: 5px 0;
	color: #dc3232;
}

@media screen and (max-width:420px) {
.c-form-top-button {
    width: 100%;
}
}

@media screen and (max-width:572px) {
table.formTable th, table.formTable td {
	width:auto;
	display:block;
}
table.formTable th {
	margin-top:5px;
	border-bottom:0;
}
form input[type="submit"], form input[type="reset"], form input[type="button"] {
	display:block;
	width:100%;
}
table.formTable th,
table.formTable td {
	display: block;
	padding: 0;
}

table.formTable th {
    width: 100%;
}

table.formTable td {
	padding-bottom: 5px;
}
}

@media screen and (max-width:600px) {
header .logo img {
	max-height: inherit;
	max-width: 100%;
	width: 100px;
	vertical-align: middle;
}
.title br {
	display: block;
}
.cnt br.sp {
	display: none;
}
}

@media only screen and (max-width: 767px) {
.container {
    margin: 50px auto;
}

.cnt {
	text-align: left;
}

.c-form-file {
    display: grid;
}

.c-form-file label {
    padding: 10px 0;
	width: 150px;
	text-align: center;
}

.c-form-file p {
	margin-left: 0;
	margin-top: 10px;
}

.confirm_btn {
	display: flex;
    width: 100%;
    margin: 40px auto;
    flex-wrap: wrap;
}

.confirm_btn .c-form-back-button {
	margin-right: 0;
	margin-top: 20px;
    order: 2;
}
}