/* contact-form.css — shared embedded form, used on every page */

.contact-section{padding:clamp(70px,9vw,130px) 0 clamp(60px,7vw,100px);background:var(--bg)}
.contact-wrap{
  max-width:1440px;margin-inline:auto;padding-inline:var(--gutter-tight);
}
.contact-card{
  background:var(--coral);color:#fff;border-radius:var(--radius-lg);
  padding:clamp(36px,5vw,72px);
  display:grid;gap:clamp(36px,4vw,56px);align-items:start;
  position:relative;overflow:hidden;
}
@media (min-width:880px){.contact-card{grid-template-columns:1fr 1.1fr}}

.contact-copy h2{color:#fff;font-style:italic;font-size:clamp(2.2rem,4.6vw,3.4rem);line-height:1.02;max-width:14ch}
.contact-copy p{color:rgba(255,255,255,.92);font-size:clamp(1rem,1.4vw,1.15rem);line-height:1.55;margin-top:22px;max-width:42ch}
.contact-copy .contact-meta{margin-top:32px;display:flex;flex-direction:column;gap:14px;color:rgba(255,255,255,.85);font-size:.95rem}
.contact-copy .contact-meta dl{display:grid;grid-template-columns:88px 1fr;gap:6px 18px;font-family:var(--sans)}
.contact-copy .contact-meta dt{color:rgba(255,255,255,.65);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;padding-top:3px}
.contact-copy .contact-meta dd{font-family:var(--serif);font-style:italic;font-size:1.08rem;color:#fff}
.contact-copy .contact-meta a{border-bottom:1px solid rgba(255,255,255,.4)}
.contact-copy .contact-meta a:hover{border-color:#fff}

/* form panel */
.contact-panel{
  background:#fff;color:var(--ink);border-radius:var(--radius);
  padding:clamp(26px,3vw,38px);
}
.contact-tabs{
  display:flex;gap:6px;padding:5px;background:#F1ECE0;border-radius:999px;margin-bottom:24px;
}
.contact-tab{
  flex:1;padding:.7rem 1rem;border-radius:999px;font-size:.95rem;font-weight:500;color:var(--ink-soft);
  transition:background .15s ease,color .15s ease;
}
.contact-tab.active{background:var(--ink);color:#fff}
.contact-panel form[data-mode="book"] .for-contact{display:none}
.contact-panel form[data-mode="contact"] .for-book{display:none}

.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field label{font-family:var(--sans);font-size:.82rem;letter-spacing:.02em;color:var(--ink);font-weight:500}
.field label .req{color:var(--coral)}
.field input,.field textarea,.field select{
  font:inherit;background:var(--surface);border:1px solid var(--line);border-radius:10px;
  padding:12px 14px;color:var(--ink);transition:border-color .15s ease,background .15s ease;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:0;border-color:var(--coral);background:#fff}
.field textarea{min-height:110px;resize:vertical;font-family:var(--sans)}
.field-row{display:grid;gap:12px}
@media (min-width:540px){.field-row{grid-template-columns:1fr 1fr}}

.checks{display:grid;gap:8px;margin-bottom:14px}
@media (min-width:540px){.checks{grid-template-columns:1fr 1fr}}
.checks label{display:flex;align-items:flex-start;gap:8px;cursor:pointer;font-size:.92rem;color:var(--ink-soft);padding:6px 0}
.checks input{margin-top:3px;accent-color:var(--coral)}

.honeypot{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

.contact-panel button[type=submit]{
  background:var(--ink);color:#fff;width:100%;justify-content:center;margin-top:14px;
}
.contact-panel button[type=submit]:hover{background:var(--coral);color:#fff}
.contact-panel .tiny{font-size:.78rem;color:var(--ink-mute);margin-top:14px;text-align:center}
.contact-panel .form-title{font-family:var(--serif);font-style:italic;font-size:1.5rem;margin-bottom:6px;color:var(--ink)}
.contact-panel .form-intro{color:var(--ink-soft);font-size:.95rem;margin-bottom:20px;font-family:var(--sans);font-style:normal}
