/* === YWCA Evanston/North Shore Volunteer Form - Modern Enhanced Theme === */

body {
  font-family: "Open Sans", Arial, FreeSans, sans-serif;
  background: linear-gradient(135deg, #fff8f5, #ffece3);
  color: #333;
  margin: 0;
  padding: 0;
}

/* --- Main Form Container --- */
.cssForm {
  background: #fff;
  max-width: 850px;
  margin: 60px auto;
  padding: 50px 60px;
  border-radius: 16px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
  position: relative;
  overflow: hidden;
  animation: fadeIn 0.6s ease;
}

/* --- Header Section --- */
.form-header {
  text-align: center;
  background: linear-gradient(90deg, #f15a22, #ff814e);
  color: #fff;
  padding: 35px 25px;
  border-radius: 14px 14px 0 0;
  margin: -50px -60px 40px -60px;
  position: relative;
  box-shadow: inset 0 -4px 0 rgba(255,255,255,0.2);
}

.form-header h1 {
  margin: 0;
  font-size: 2em;
  font-weight: 800;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

/* --- Optional subtitle for header --- */
.form-header p {
  margin-top: 10px;
  font-size: 1em;
  font-weight: 400;
  opacity: 0.9;
}

/* --- Section Headers --- */
.cssForm h2, .cssForm h3 {
  color: #f15a22;
  font-size: 1.3em;
  font-weight: 700;
  margin-bottom: 20px;
  border-left: 6px solid #f15a22;
  padding-left: 12px;
}

/* --- Table Layout --- */
.cssForm table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0 18px;
}

/* --- Label Column --- */
.cssLabelsColumn {
  width: 200px;
  text-align: right;
  vertical-align: middle;
  font-weight: 600;
  font-size: 0.95em;
  color: #333;
  padding-right: 25px;
}

/* --- Input Fields Column --- */
.cssInputFieldsColumn {
  vertical-align: top;
  padding-bottom: 12px;
}

/* --- Input Fields Styling --- */
.cssInputFields input[type="text"],
.cssInputFields input[type="email"],
.cssInputFields input[type="tel"],
.cssInputFields input[type="number"],
.cssInputFields select,
.cssInputFields textarea {
  width: 100%;
  max-width: 400px;
  padding: 14px 16px;
  border: 1px solid #ddd;
  border-radius: 8px;
  background-color: #fff;
  font-size: 15px;
  transition: all 0.3s ease;
}

.cssInputFields input:focus,
.cssInputFields select:focus,
.cssInputFields textarea:focus {
  border-color: #f15a22;
  box-shadow: 0 0 8px rgba(241, 90, 34, 0.3);
  outline: none;
}

/* --- Textarea --- */
.cssTextArea {
  width: 100%;
  max-width: 400px;
  min-height: 110px;
  border-radius: 8px;
}

/* --- Submit Button --- */
input[type="submit"],
button[type="submit"] {
  background: linear-gradient(90deg, #f15a22, #ff814e);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 15px 35px;
  font-size: 16px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  cursor: pointer;
  transition: all 0.3s ease;
  display: inline-block;
  margin-top: 30px;
  box-shadow: 0 4px 10px rgba(241, 90, 34, 0.3);
}

input[type="submit"]:hover {
  background: #d84c1c;
  transform: translateY(-2px);
  box-shadow: 0 6px 15px rgba(241, 90, 34, 0.35);
}

/* --- Info Note --- */
.note {
  background-color: #fff6f2;
  border-left: 5px solid #f15a22;
  padding: 14px 18px;
  margin-bottom: 25px;
  color: #333;
  font-size: 14px;
  border-radius: 6px;
}

/* --- Responsive Design --- */
@media (max-width: 768px) {
  .cssForm {
    padding: 30px 25px;
  }

  .form-header {
    margin: -30px -25px 30px -25px;
    padding: 25px;
  }

  .form-header h1 {
    font-size: 1.6em;
  }

  .cssLabelsColumn {
    width: 100%;
    text-align: left;
    padding-bottom: 5px;
  }

  .cssInputFieldsColumn {
    display: block;
    width: 100%;
  }

  .cssInputFields input,
  .cssInputFields select,
  .cssInputFields textarea {
    max-width: 100%;
  }

  input[type="submit"] {
    width: 100%;
  }
}

/* --- Animation --- */
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}
