/* themes/custom/mittelstrimmig_base/css/ms-reservations-form.css
   Reservierungsformular-Styling
   Layout/Struktur des Kalenders kommt aus /modules/custom/ms_reservations/css/calendar.css
*/

:root{
  --ms-soft-border: rgba(20, 38, 34, .10);
  --ms-soft-border-2: rgba(20, 38, 34, .14);
  --ms-card-bg: rgba(255,255,255,.88);
  --ms-card-bg-2: rgba(255,255,255,.80);
  --ms-ink: #0f1a16;
  --ms-muted: rgba(15,26,22,.65);
  --ms-green: #0b6a3a;
  --ms-green-2: #0a5e34;
  --ms-shadow: 0 16px 34px rgba(0,0,0,.12);
  --ms-radius-xl: 22px;
  --ms-radius-lg: 18px;
  --ms-radius-md: 14px;
}

/* Wrapper: Kalender + Form */
.msr-wrap{
  margin-top: 12px;
}

.msr-wrap > h2{
  font-size: 26px;
  margin: 0 0 12px;
}

.msr-wrap > div{
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, .95fr);
  gap: 22px;
  align-items: start;
}

/* Kalender-Card kommt aus calendar.css; hier nur Spacing */
.msr-wrap__calendar{
  min-width: 0;
}

/* Form-Card */
.msr-wrap__form{
  min-width: 0;
}

.ms-reservations-form{
  background: var(--ms-card-bg);
  border: 1px solid var(--ms-soft-border);
  border-radius: var(--ms-radius-xl);
  box-shadow: var(--ms-shadow);
  padding: 22px 22px 18px;
  overflow: hidden;
}

/* Hinweisbox im Formular */
.ms-reservations-form > p{
  margin: 0 0 18px;
  padding: 16px 18px;
  border-radius: var(--ms-radius-lg);
  border: 1px solid rgba(46, 204, 113, .35);
  background: linear-gradient(135deg, rgba(46, 204, 113, .14), rgba(46, 204, 113, .06));
  color: var(--ms-ink);
  font-size: 15.5px;
  line-height: 1.35;
}

.ms-reservations-form > p strong{
  display: block;
  font-size: 16px;
  margin-bottom: 6px;
}

/* Form elements */
.ms-reservations-form .form-item{
  margin: 0 0 14px;
}

.ms-reservations-form label{
  display: block;
  font-weight: 800;
  color: var(--ms-ink);
  margin: 0 0 8px;
  font-size: 16px;
}

.ms-reservations-form input.form-text,
.ms-reservations-form input.form-email,
.ms-reservations-form textarea.form-textarea{
  width: 100%;
  border-radius: 16px;
  border: 1px solid var(--ms-soft-border-2);
  background: rgba(255,255,255,.92);
  padding: 12px 14px;
  font-size: 16px;
  color: var(--ms-ink);
  outline: none;
  box-shadow: 0 8px 18px rgba(0,0,0,.06);
}

.ms-reservations-form textarea.form-textarea{
  min-height: 140px;
  resize: vertical;
}

/* Focus state */
.ms-reservations-form input.form-text:focus,
.ms-reservations-form input.form-email:focus,
.ms-reservations-form textarea.form-textarea:focus{
  border-color: rgba(11, 106, 58, .55);
  box-shadow: 0 0 0 4px rgba(11, 106, 58, .16), 0 10px 22px rgba(0,0,0,.08);
}

/* Submit button */
.ms-reservations-form .form-actions{
  margin-top: 10px;
  display: flex;
  justify-content: flex-end;
}

.ms-reservations-form .form-submit{
  appearance: none;
  border: 0;
  cursor: pointer;
  border-radius: 999px;
  padding: 12px 22px;
  font-weight: 900;
  letter-spacing: .2px;
  font-size: 15.5px;
  color: #fff;
  background: linear-gradient(180deg, var(--ms-green), var(--ms-green-2));
  box-shadow: 0 14px 26px rgba(11, 106, 58, .28);
  transition: transform .12s ease, box-shadow .12s ease, filter .12s ease;
}

.ms-reservations-form .form-submit:hover{
  transform: translateY(-1px);
  box-shadow: 0 18px 32px rgba(11, 106, 58, .34);
  filter: brightness(1.02);
}

.ms-reservations-form .form-submit:active{
  transform: translateY(0);
  box-shadow: 0 12px 26px rgba(11, 106, 58, .28);
}

/* Responsive */
@media (max-width: 980px){
  .msr-wrap > div{
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .ms-reservations-form{
    padding: 18px 16px 14px;
  }
}

/* Required field asterisk (Name, E-Mail) */
.ms-reservations-form label.form-required::after {
  content: "*";
  display: inline-block;
  margin-left: 0.35rem;
  font-weight: 800;
  color: #d11a2a;
  line-height: 1;
  background: none !important; /* override any core required-icon background */
}
/* Font Awesome Icon vor Blocktitel "Reservierungskalender" */
#block-mittelstrimmig-base-reservierungskalender > h2 {
  display: flex;
  align-items: center;
  gap: .55rem;
}

#block-mittelstrimmig-base-reservierungskalender > h2::before {
  /* Font Awesome Free (Solid) – Kalender-Icon */
  content: "\f073"; /* fa-calendar-days / fa-calendar */
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  display: inline-block;

  /* optisch passend */
  font-size: .95em;
  opacity: .9;
}
