@charset "UTF-8";

/**
 * contact/style.css
 */

/*--------------------------------------------------
  Contact Form
--------------------------------------------------*/
.form-container {
    max-width: 700px;
    margin: 0 auto;
    background: var(--white);
    padding: 60px;
    border-radius: 20px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.03);
}

.form-row {
    margin-bottom: 30px;
}

.form-row label {
    display: block;
    font-weight: bold;
    margin-bottom: 10px;
    font-size: 0.95rem;
}

.required {
    background: #E74C3C;
    color: var(--white);
    font-size: 0.7rem;
    padding: 2px 8px;
    border-radius: 3px;
    margin-left: 10px;
    vertical-align: middle;
}

.form-row input,
.form-row select,
.form-row textarea {
    width: 100%;
    padding: 15px;
    border: 1px solid #ddd;
    border-radius: 8px;
    font-size: 1rem;
    font-family: var(--font-base);
}

.form-row input:focus,
.form-row textarea:focus {
    outline: none;
    border-color: var(--primary-color);
}

.form-submit button {
    border: none;
    cursor: pointer;
}

/*--------------------------------------------------
  Responsive
--------------------------------------------------*/

/* 【SM】 768px 以下 */
@media screen and (max-width: 768px) {
    .form-container { padding: 40px 20px; }
}

/* 【SP】 479px 以下 */
@media screen and (max-width: 479px) {
    .form-container { padding: 30px 15px; }
}
