/* WySync — booking form styles */

.book-form {
  display: flex;
  flex-direction: column;
  gap: 20px;
  max-width: 720px;
  margin: 0 auto;
  width: 100%;
}

.book-row { display: grid; gap: 16px; }
.book-row-2 { grid-template-columns: 1fr 1fr; }
@media (max-width: 660px) {
  .book-row-2 { grid-template-columns: 1fr; }
}

.book-field {
  display: flex; flex-direction: column;
  gap: 8px;
}

.book-label {
  color: var(--fg-3);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.book-form input[type="text"],
.book-form input[type="email"],
.book-form input[type="url"] {
  background: var(--bg);
  border: 1px solid var(--line);
  padding: 12px 14px;
  font-size: 14px;
  color: var(--fg);
  font-family: var(--font-sans);
  transition: border-color .15s;
}
.book-form input::placeholder { color: var(--fg-3); }
.book-form input:focus {
  outline: none;
  border-color: var(--accent);
}

.book-seg {
  display: flex; flex-wrap: wrap; gap: 8px;
}
.book-seg-opt {
  background: var(--bg);
  border: 1px solid var(--line);
  padding: 9px 14px;
  font-size: 13px;
  color: var(--fg-2);
  font-family: var(--font-sans);
  font-weight: 500;
  letter-spacing: 0.01em;
  transition: background .15s, color .15s, border-color .15s;
}
.book-seg-opt:hover {
  border-color: var(--fg);
  color: var(--fg);
}
.book-seg-opt.on {
  background: var(--accent);
  color: var(--accent-fg);
  border-color: var(--accent);
}

.book-submit {
  align-self: flex-start;
  margin-top: 12px;
  padding: 14px 28px;
  font-size: 14px;
}
.book-submit:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.book-foot {
  color: var(--fg-3);
  font-size: 11px;
  letter-spacing: 0.04em;
  margin-top: 4px;
}

.book-error {
  background: color-mix(in oklab, var(--bad), transparent 88%);
  border: 1px solid var(--bad);
  color: var(--bad);
  padding: 12px 14px;
  font-size: 12px;
  letter-spacing: 0.03em;
}

.book-form-success {
  background: color-mix(in oklab, var(--good), transparent 92%);
  border: 1px solid var(--good);
  padding: 28px;
  max-width: 720px;
  margin: 0 auto;
}

/* Surrounding wrapper when used as the main #book section */
.book-section {
  border: 1px solid var(--line);
  background: var(--bg-2);
  padding: clamp(32px, 5vw, 56px);
}
@media (max-width: 660px) {
  .book-section { padding: 28px 20px; }
}
