/* nav透明 → 滚动后深色 */
.nav { background: transparent; }
.nav.scrolled { background: rgba(26,23,20,0.95); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); border-bottom: 1px solid rgba(200,169,110,0.2); }

/* ============================================================
   page-contact.css — お問い合わせ（2026-02統一改訂）
   inner max-width統一 / 正文16px / 金線装飾
   ============================================================ */

/* ===== CONTACT LEAD ===== */
.contact-lead-text {
  font-size: 15px; line-height: 1.9;
  color: var(--color-text-light);
  letter-spacing: 0.4px;
  margin-bottom: 36px;
}

/* ===== CONTACT FORM ===== */
.contact-form-section {
  padding: calc(var(--section-v) * 1.15) var(--page-pad);
  background: var(--color-offwhite);
  position: relative; overflow: hidden;
}
.contact-form-section .section-label { color: var(--color-accent); }
.contact-form-section .section-title { color: var(--color-primary); }
.contact-form-section .section-divider { background: var(--color-accent); }

.contact-form-inner {
  max-width: 760px; margin: 0 auto;
  position: relative; z-index: 1;
  background: #fff;
  border: 1px solid #e5e1d8;
  padding: 52px 56px;
  box-shadow: var(--shadow-sm);
}
.form-row {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 20px; margin-bottom: 20px;
}
.form-group { display: flex; flex-direction: column; gap: 8px; margin-bottom: 20px; }
.form-label {
  font-size: 11px; font-weight: 500;
  letter-spacing: 1px; text-transform: uppercase;
  color: var(--color-primary);
}
.form-label span { color: #e06060; margin-left: 4px; font-size: 10px; }
.form-input, .form-select, .form-textarea {
  background: #faf8f3;
  border: 1px solid #e5e1d8;
  color: var(--color-primary);
  font-family: var(--font-body); font-size: 15px;
  padding: 14px 18px; outline: none;
  transition: border-color 0.3s ease, background 0.3s ease;
  letter-spacing: 0.5px; width: 100%;
}
.form-input::placeholder, .form-textarea::placeholder {
  color: #bbb; font-size: 14px;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  border-color: rgba(200,169,110,0.7);
  background: #fff;
  box-shadow: 0 0 0 2px rgba(200,169,110,0.08);
}
.form-select {
  appearance: none; cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23c8a45a' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 18px center;
  padding-right: 44px;
}
.form-select option { background: #fff; color: var(--color-primary); }
.form-textarea { resize: vertical; min-height: 160px; max-height: 300px; line-height: 1.8; }
.form-note {
  font-size: 12px; color: #aaa;
  margin-bottom: 32px; line-height: 1.8; letter-spacing: 0.3px;
}
.form-note a { color: var(--color-accent); text-decoration: underline; }
.form-submit { display: flex; justify-content: center; }
.btn-submit {
  font-family: var(--font-body);
  font-size: 13px; font-weight: 500;
  letter-spacing: 2.5px;
  color: var(--color-dark); background: var(--color-accent);
  border: 1px solid var(--color-accent);
  padding: 18px 64px;
  cursor: pointer; transition: all 0.3s ease;
}
.btn-submit:hover {
  background: var(--color-accent-light);
  border-color: var(--color-accent-light);
  box-shadow: 0 8px 32px rgba(200,169,110,0.3);
  transform: translateY(-2px);
}
.btn-submit:active {
  transform: translateY(0);
  box-shadow: none;
  opacity: 0.82;
  transition-duration: 0.05s;
}

/* ===== FAQ ===== */
.faq-section {
  padding: var(--section-v) var(--page-pad);
  background: #fff;
}
.faq-inner { max-width: 760px; margin: 0 auto; }
.faq-item {
  background: var(--color-offwhite);
  margin-bottom: 8px;
  border: none;
}
.faq-question {
  width: 100%; text-align: left;
  background: none; border: none;
  padding: 20px 24px; cursor: pointer;
  display: flex; align-items: center;
  justify-content: space-between; gap: 16px;
  transition: color 0.3s ease;
}
.faq-question:hover { color: var(--color-accent); }
.faq-question-text {
  font-family: var(--font-heading);
  font-size: 15px; font-weight: 600;
  color: var(--color-primary);
  letter-spacing: 0.5px; line-height: 1.5;
  transition: color 0.3s ease; text-align: left;
}
.faq-question:hover .faq-question-text { color: var(--color-accent); }
.faq-icon {
  width: 24px; height: 24px; flex-shrink: 0;
  border: 1px solid var(--color-border);
  display: flex; align-items: center; justify-content: center;
  transition: all 0.3s ease; position: relative;
}
.faq-icon::before, .faq-icon::after {
  content: ''; position: absolute;
  background: var(--color-accent); transition: all 0.3s ease;
}
.faq-icon::before { width: 10px; height: 1px; }
.faq-icon::after { width: 1px; height: 10px; }
.faq-item.open .faq-icon { background: var(--color-accent); border-color: var(--color-accent); }
.faq-item.open .faq-icon::before { background: var(--color-dark); }
.faq-item.open .faq-icon::after { background: var(--color-dark); transform: rotate(90deg); opacity: 0; }
.faq-answer {
  max-height: 0; overflow: hidden;
  transition: max-height 0.4s var(--transition), padding 0.3s ease;
}
.faq-item.open .faq-answer { max-height: 800px; padding-bottom: 20px; }
.faq-answer-text {
  font-size: 15px; line-height: 1.8;
  color: var(--color-text-light);
  letter-spacing: 0.3px; padding: 0 24px;
}

/* ===== MAP ===== */
.map-section {
  padding: calc(var(--section-v) * 1.15) var(--page-pad); background: #fff;
}
.map-inner {
  max-width: var(--page-max); margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1.6fr;
  gap: 60px; align-items: stretch;
}
.map-info {
  background: #fff;
  border: 1px solid var(--color-border);
  box-shadow: 0 8px 32px rgba(10,10,20,0.07);
  padding: 40px 36px;
}
.map-access-items {
  margin-top: 32px; display: flex; flex-direction: column; gap: 24px;
}
.map-access-label {
  font-size: 10px; font-weight: 500;
  letter-spacing: 4px; text-transform: uppercase;
  color: var(--color-accent); margin-bottom: 6px;
}
.map-access-value {
  font-size: 15px; color: var(--color-text);
  line-height: 1.9; letter-spacing: 0.3px;
}
.map-embed {
  position: relative; width: 100%;
  padding-bottom: 62%; overflow: hidden;
}
.map-embed iframe {
  position: absolute; top: 0; left: 0;
  width: 100%; height: 100%; border: none;
}

/* ===== RESPONSIVE ===== */
@media (max-width: 1024px) {
  .map-inner { grid-template-columns: 1fr; }
  .map-embed { padding-bottom: 50%; }
}
@media (max-width: 768px) {
  .contact-form-section, .faq-section, .map-section { padding-left: 20px; padding-right: 20px; }
  .contact-form-inner { padding: 28px 20px; }
  .contact-form-header { margin-bottom: 24px; }
  .map-info { padding: 24px 20px; }
  .map-inner { gap: 24px; }
  .map-embed { padding-bottom: 56%; }
  .form-row { grid-template-columns: 1fr; gap: 0; }
  .form-input, .form-select, .form-textarea { font-size: 14px; padding: 12px 14px; }
  .btn-submit { padding: 15px 40px; font-size: 12px; letter-spacing: 2.5px; }
  .faq-question { padding: 16px 18px; }
  .faq-answer-text { padding: 0 18px; font-size: 13px; }
}

@media (max-width: 390px) {
  .contact-form-section, .faq-section, .map-section { padding: 36px 16px; }
  .contact-form-inner { padding: 24px 16px; }
  .form-input, .form-select, .form-textarea { font-size: 14px; padding: 10px 12px; }
  .btn-submit { padding: 14px 20px; font-size: 12px; width: 100%; box-sizing: border-box; }
  .faq-question { padding: 14px 14px; }
  .faq-question-text { font-size: 13px; }
  .faq-answer-text { font-size: 13px; padding: 0 14px; }
  .map-info { padding: 20px 16px; }
  .map-access-value { font-size: 13px; }
}

/* privacy checkbox */
.form-privacy-check {
  margin: 16px 0 8px;
}
.privacy-check-label {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  color: var(--color-text);
  cursor: pointer;
}
.privacy-check-label input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--color-accent);
  cursor: pointer;
  flex-shrink: 0;
}
.privacy-check-label a {
  color: var(--color-accent);
  text-decoration: underline;
}

/* フォーム送信ステータス */
.form-status {
  margin-top: 24px;
  padding: 16px 24px;
  border-radius: 2px;
  font-size: 14px;
  line-height: 1.6;
  display: none;
}
.form-status.success {
  display: block;
  background: rgba(39,174,96,0.08);
  border: 1px solid rgba(39,174,96,0.35);
  color: #1e7a45;
}
.form-status.error {
  display: block;
  background: rgba(192,57,43,0.07);
  border: 1px solid rgba(192,57,43,0.3);
  color: #a93226;
}
.btn-submit.loading {
  opacity: 0.65;
  pointer-events: none;
  cursor: not-allowed;
}
