/* =========================
   Reservation Page (Clean)
   - Button styling removed (CF7 default)
   - Unused styles removed
   - Scoped to this page content
   ========================= */

:root{
  --color-primary-blue:#1e3a8a;
  --color-accent-blue:#38bdf8;
  --color-border:#e2e8f0;
  --color-bg-gray:#f1f5f9;
  --overlay-navy-header: linear-gradient(135deg, rgba(2,6,23,.85) 0%, rgba(23,37,84,.8) 100%);
  --res-require:#ef4444;
  --res-any:#94a3b8;
}

/* ページ内だけに適用（他ページへ干渉しにくくする） */
.reservation-main,
.reservation-main *{
  box-sizing:border-box;
}

.reservation-main{
  padding-bottom:80px;
}

/* Utilities */
.sp-br{ display:none; }
@media (max-width:768px){
  .sp-br{ display:inline; }
}

/* =========================
   Header
   ========================= */
.page-header-section{
  width:100%;
  background: var(--overlay-navy-header), url('https://shuro-shien.or.jp/wp-content/uploads/2025/12/ヘッダー背景.png');
  background-size:cover;
  background-position:center;
  color:#fff;
  text-align:center;
  padding: clamp(80px, 12vw, 120px) 20px;
  position:relative;
  overflow:hidden;
}

.page-title{
  position:relative;
  display:inline-block;
  margin:0 0 30px 0;
  font-size: clamp(1.8rem, 5vw, 2.8rem);
  font-weight:700;
  letter-spacing:.1em;
  padding-bottom:20px;
  text-shadow:0 5px 20px rgba(0,0,0,.8);
}

.page-title::after{
  content:'';
  position:absolute;
  bottom:0;
  left:50%;
  transform:translateX(-50%);
  width:150px;
  height:3px;
  background: linear-gradient(90deg, transparent 0%, #D4AF37 30%, #C5A059 70%, transparent 100%);
}

.res-desc{
  max-width:800px;
  margin:0 auto;
  font-size:1rem;
  line-height:2;
  opacity:.95;
}

@media (max-width:768px){
  .page-header-section{
    background-image: var(--overlay-navy-header), url('https://shuro-shien.or.jp/wp-content/uploads/2025/12/ヘッダー背景_sp.png');
    padding:60px 20px 80px;
  }
  .page-title{
    margin-bottom:20px;
    font-size: clamp(1.5rem, 6vw, 2.0rem);
  }
  .res-desc{
    font-size:.9rem;
    line-height:1.8;
  }
}

/* =========================
   Card Container
   ========================= */
.reservation-container{
  max-width:800px;
  margin:-60px auto 0;
  position:relative;
  z-index:20;
  background:#fff;
  border-radius:12px;
  box-shadow:0 10px 40px rgba(0,0,0,.08);
  overflow:hidden;
}

.form-wrapper{
  padding:60px 40px;
}

@media (max-width:768px){
  .reservation-container{
    margin-top:-40px;
    border-radius:8px;
    width:92%;
  }
  .form-wrapper{
    padding:40px 20px;
  }
}

/* =========================
   Form (based on your CF7 markup)
   ========================= */
.form-group{
  margin-bottom:30px;
}

.form-label{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:10px;
  font-weight:700;
  margin-bottom:6px;
  font-size:1rem;
  color: var(--color-primary-blue);
}

.badge-require,
.badge-any{
  font-size:.75rem;
  padding:2px 8px;
  border-radius:4px;
  color:#fff;
  font-weight:500;
}

.badge-require{ background: var(--res-require); }
.badge-any{ background: var(--res-any); }

/* Inputs: CF7 default controls */
.form-group input[type="text"],
.form-group input[type="email"],
.form-group input[type="tel"],
.form-group textarea,
.wpcf7-form-control{
  width:100%;
  padding:14px 16px;
  font-size:1rem;
  border:2px solid var(--color-border);
  border-radius:8px;
  background:#fff;
  transition:border-color .2s, box-shadow .2s;
  font-family:inherit;
  appearance:none;
}

.form-group input:focus,
.form-group textarea:focus{
  outline:none;
  border-color: var(--color-accent-blue);
  box-shadow:0 0 0 3px rgba(56,189,248,.15);
}

/* CF7 validation */
.wpcf7-not-valid{
  border-color:#ef4444 !important;
  background:#fff5f5;
}

.wpcf7-not-valid-tip{
  color:#ef4444;
  font-size:.85rem;
  margin-top:5px;
  font-weight:700;
}

/* 送信ボタンはCF7デフォルトに任せる（装飾なし）
   ※中央寄せしたい場合だけ下の2行を残す/追加
*/
/*
.submit-wrapper{ text-align:center; margin-top:40px; }
*/
