/**
 * Strona Zapisy — dopasowanie do layoutu Maris + panele formularzy
 */

/* Sekcja formularzy — tło jak w motywie Maris */
.zapisy-form-section {
  margin: 0 var(--space-4) var(--space-12);
  border-radius: var(--radius-xl);
  overflow: hidden;
  background: linear-gradient(160deg, #1a3360 0%, #1e3c72 45%, #0f1f3d 100%);
  box-shadow: var(--shadow-lg);
}

@media (min-width: 768px) {
  .zapisy-form-section {
    margin: 0 var(--space-6) var(--space-12);
  }
}

/* Spójna czcionka z resztą witryny (maris-form.css używa Satoshi) */
.zapisy-form-section .maris-form-container {
  font-family: var(--font-sans, "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
}

/* Tylko jeden panel naraz */
.maris-form-panel[data-form-panel] {
  display: none;
}

.maris-form-panel[data-form-panel].is-active {
  display: block;
}

/* Honeypot FormSubmit + pole legacy „website_url” */
.zapisy-honey,
.zapisy-form-section input[name="website_url"] {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  opacity: 0 !important;
}

.zapisy-form-section form.maris-form {
  position: relative;
}

.zapisy-form-section .maris-form-container {
  max-width: 1040px;
  padding-bottom: var(--space-10);
}

.zapisy-form-note {
  margin: var(--space-8) auto 0;
  max-width: 52rem;
  padding: 0 var(--space-5) var(--space-6);
  font-size: 0.8125rem;
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.55);
  text-align: center;
  display: none;
}

/* Podpowiedzi i opisy pól — ciemniejszy tekst (czytelność na jasnym tle formularza) */
.zapisy-form-section .maris-form-hint,
.zapisy-form-section small.maris-form-hint,
.zapisy-form-section .maris-form-group .maris-form-hint {
  color: rgba(17, 24, 39, 0.88) !important;
  font-size: 0.9em;
  line-height: 1.45;
  display: block;
  margin-top: 0.35rem;
}

.zapisy-form-section label em.maris-form-hint {
  display: inline;
  font-style: normal;
  font-weight: 400;
  color: rgba(17, 24, 39, 0.78) !important;
}

.zapisy-form-section .maris-form-subtitle {
  color: rgba(17, 24, 39, 0.82) !important;
}

/* Obozy — dwa obozy w jednym rzędzie */
.maris-radio-group--camps {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

@media (max-width: 520px) {
  .maris-radio-group--camps {
    grid-template-columns: 1fr;
  }
}

.maris-radio-option--disabled input:disabled + .maris-radio-label {
  opacity: 0.68;
  cursor: not-allowed;
  filter: grayscale(0.15);
}

.maris-camp-badge {
  display: inline-block;
  margin-top: 0.35rem;
  padding: 0.15em 0.5em;
  font-size: 0.75rem;
  font-weight: 700;
  color: #991b1b;
  background: rgba(254, 226, 226, 0.95);
  border-radius: 6px;
}

/* Nauka pływania — typ zajęć 50/50 */
.maris-radio-group--split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

@media (max-width: 480px) {
  .maris-radio-group--split {
    grid-template-columns: 1fr;
  }
}

/* Gimnastyka — grupy 2×2 */
.maris-radio-group--grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

@media (max-width: 560px) {
  .maris-radio-group--grid-2 {
    grid-template-columns: 1fr;
  }
}

/*
  Wiersz pól: 20% / 20% / 20% / 40% (proporcje jak fr: 2+2+2+4).
  Nadpisuje domyślny flex z maris-form.css (40% / reszta).
*/
.zapisy-form-section .maris-form-row--quad-20 {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 2fr) minmax(0, 2fr) minmax(0, 4fr);
  gap: var(--space-3);
  align-items: end;
  margin-bottom: 12px;
}

.zapisy-form-section .maris-form-row--quad-20 .maris-form-group {
  flex: unset;
  margin-bottom: 0;
  min-width: 0;
}

.zapisy-form-section .maris-form-row--quad-20 .maris-form-group:first-child,
.zapisy-form-section .maris-form-row--quad-20 .maris-form-group:last-child {
  flex: unset;
}

@media (max-width: 900px) {
  .zapisy-form-section .maris-form-row--quad-20 {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 520px) {
  .zapisy-form-section .maris-form-row--quad-20 {
    grid-template-columns: 1fr;
  }
}

/* Obozy — preferencje zakwaterowania | zainteresowania 50/50 */
.zapisy-form-section .maris-form-row--split-50 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
  align-items: start;
  margin-bottom: 12px;
}

.zapisy-form-section .maris-form-row--split-50 .maris-form-group {
  flex: unset;
  margin-bottom: 0;
  min-width: 0;
}

.zapisy-form-section .maris-form-row--split-50 .maris-form-group:first-child,
.zapisy-form-section .maris-form-row--split-50 .maris-form-group:last-child {
  flex: unset;
}

@media (max-width: 900px) {
  .zapisy-form-section .maris-form-row--split-50 {
    grid-template-columns: 1fr;
  }
}

/* Wycieczki — siatka 2 × 3 (pięć przycisków) */
.maris-trip-picker {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-rows: repeat(3, auto);
  gap: 10px;
  margin-top: 0.35rem;
}

@media (max-width: 560px) {
  .maris-trip-picker {
    grid-template-columns: 1fr;
    grid-template-rows: none;
  }
}

.maris-trip-btn {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.2rem;
  width: 100%;
  padding: 0.85rem 1rem;
  text-align: left;
  font-family: inherit;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--color-primary, #1e3c72);
  background: linear-gradient(135deg, #fff 0%, #f1f5f9 100%);
  border: 2px solid rgba(30, 60, 114, 0.18);
  border-radius: var(--radius-md, 10px);
  cursor: pointer;
  transition:
    border-color 0.2s ease,
    box-shadow 0.2s ease,
    background 0.2s ease;
}

.maris-trip-btn:hover {
  border-color: rgba(30, 60, 114, 0.45);
  box-shadow: 0 4px 14px rgba(30, 60, 114, 0.1);
}

.maris-trip-btn.is-selected {
  border-color: var(--color-primary, #1e3c72);
  border-width: 3px;
  background: linear-gradient(135deg, rgba(30, 60, 114, 0.08) 0%, rgba(255, 255, 255, 0.98) 100%);
  box-shadow: 0 6px 20px rgba(30, 60, 114, 0.15);
}

.maris-trip-btn__date {
  font-size: 0.85rem;
  font-weight: 600;
  color: rgba(30, 60, 114, 0.55);
}
