.cglm-upcoming-events,
.cglm-home-box,
.cglm-reservation-form {
  --cglm-accent: #d94f70;
  --cglm-soft: #fffaf1;
  --cglm-line: #f0dfcf;
  position: relative;
  box-sizing: border-box;
  margin: clamp(34px, 7vw, 72px) 0;
  padding: clamp(24px, 5vw, 44px);
  overflow: hidden;
  background: linear-gradient(145deg, #ffffff 0%, #fffaf1 58%, #f2fbf7 100%);
  border: 1px solid var(--cglm-line);
  border-radius: 20px;
  box-shadow: 0 12px 34px rgba(91, 74, 54, 0.09);
}

.cglm-upcoming-events::before,
.cglm-home-box::before,
.cglm-reservation-form::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 7px;
  background: linear-gradient(90deg, #e85f7a 0 20%, #f2a33a 20% 40%, #f0cf45 40% 60%, #58ae7b 60% 80%, #4aa7d8 80% 100%);
}

.cglm-section-heading {
  text-align: center;
  margin-bottom: 26px;
}

.cglm-kicker {
  display: block;
  color: #cf4566;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.16em;
  margin-bottom: 8px;
}

.cglm-section-heading h2,
.cglm-home-box h2,
.cglm-reservation-form h2 {
  margin: 0;
  font-size: clamp(24px, 4vw, 34px);
  line-height: 1.4;
}

.cglm-event-list {
  display: grid;
  gap: 20px;
}

.cglm-event-card {
  --cglm-card-accent: #c9435d;
  --cglm-card-soft: #fff0f3;
  display: grid;
  grid-template-columns: minmax(150px, 210px) minmax(0, 1fr);
  overflow: hidden;
  background: #fff;
  border: 1px solid color-mix(in srgb, var(--cglm-card-accent) 25%, #ffffff);
  border-radius: 16px;
  box-shadow: 0 8px 22px rgba(70, 60, 48, 0.07);
}

.cglm-event-list .cglm-event-card:nth-child(4n + 1) {
  --cglm-card-accent: #c9435d;
  --cglm-card-soft: #fff0f3;
}

.cglm-event-list .cglm-event-card:nth-child(4n + 2) {
  --cglm-card-accent: #b86408;
  --cglm-card-soft: #fff5e7;
}

.cglm-event-list .cglm-event-card:nth-child(4n + 3) {
  --cglm-card-accent: #287654;
  --cglm-card-soft: #edf9f2;
}

.cglm-event-list .cglm-event-card:nth-child(4n + 4) {
  --cglm-card-accent: #246f9d;
  --cglm-card-soft: #edf7fc;
}

.cglm-event-date {
  padding: 24px;
  background: linear-gradient(145deg, color-mix(in srgb, var(--cglm-card-accent) 88%, #ffffff), var(--cglm-card-accent));
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 10px;
}

.cglm-event-date strong {
  font-size: 18px;
  line-height: 1.55;
}

.cglm-event-date span {
  display: inline-flex;
  align-self: flex-start;
  background: rgba(255, 255, 255, 0.2);
  border: 1px solid rgba(255, 255, 255, 0.46);
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 12px;
  font-weight: 700;
}

.cglm-event-body {
  padding: 24px;
  background: linear-gradient(135deg, #ffffff 0%, var(--cglm-card-soft) 160%);
}

.cglm-event-body h3 {
  margin: 0 0 14px;
  font-size: clamp(20px, 3vw, 27px);
  line-height: 1.45;
}

.cglm-event-body dl {
  margin: 0 0 16px;
  display: grid;
  gap: 8px;
}

.cglm-event-body dl div {
  display: grid;
  grid-template-columns: 4em 1fr;
  gap: 12px;
}

.cglm-event-body dt {
  font-weight: 800;
  color: var(--cglm-card-accent);
}

.cglm-event-body dd {
  margin: 0;
}

.cglm-event-body p {
  line-height: 1.85;
}

.cglm-event-note {
  padding: 12px 14px;
  background: var(--cglm-card-soft);
  border-left: 4px solid var(--cglm-card-accent);
  border-radius: 10px;
  font-size: 0.95em;
}

.cglm-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 10px 20px;
  border: 1px solid var(--cglm-card-accent, var(--cglm-accent));
  border-radius: 999px;
  text-decoration: none !important;
  font-weight: 800;
  color: var(--cglm-card-accent, var(--cglm-accent)) !important;
  background: #fff;
  transition: transform 0.2s, box-shadow 0.2s, background 0.2s;
}

.cglm-button:hover {
  transform: translateY(-1px);
  background: var(--cglm-card-soft, var(--cglm-soft));
  box-shadow: 0 7px 18px rgba(70, 60, 48, 0.13);
}

.cglm-button.primary {
  background: var(--cglm-card-accent, var(--cglm-accent));
  color: #fff !important;
}

.cglm-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 20px;
}

.cglm-handcare-notice {
  margin-top: 20px;
}

.cglm-handcare-notice .cglm-event-card {
  display: block;
  --cglm-card-accent: #c9435d;
  --cglm-card-soft: #fff0f3;
}

.cglm-course-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}

.cglm-course-card {
  border: 1px solid #eadfce;
  border-top: 5px solid #f0a13a;
  border-radius: 15px;
  padding: 18px;
  background: linear-gradient(145deg, #fff 0%, #fffaf1 100%);
}

.cglm-course-card:nth-child(3n + 2) {
  border-top-color: #58ae7b;
}

.cglm-course-card:nth-child(3n + 3) {
  border-top-color: #4aa7d8;
}

.cglm-course-card img {
  width: 100%;
  height: auto;
  border-radius: 10px;
}

.cglm-course-card h3 {
  font-size: 20px;
}

.cglm-text-link {
  font-weight: 800;
  color: #c9435d;
}

.cglm-reservation-summary {
  padding: 18px;
  background: #fff;
  border: 1px solid #efdcc8;
  border-left: 5px solid #f0a13a;
  border-radius: 12px;
  margin: 20px 0;
}

.cglm-reservation-summary p {
  margin: 0.45em 0;
}

.cglm-form-public {
  display: grid;
  gap: 16px;
}

.cglm-form-public label {
  display: grid;
  gap: 7px;
  font-weight: 700;
}

.cglm-form-public label span {
  font-size: 12px;
  color: #b42318;
}

.cglm-form-public input,
.cglm-form-public select,
.cglm-form-public textarea {
  width: 100%;
  padding: 12px;
  border: 1px solid #d8cbb9;
  border-radius: 9px;
  background: #fff;
  font: inherit;
}

.cglm-form-public input:focus,
.cglm-form-public select:focus,
.cglm-form-public textarea:focus {
  outline: 3px solid rgba(74, 167, 216, 0.2);
  border-color: #4aa7d8;
}

.cglm-form-public button {
  border: 0;
  cursor: pointer;
  --cglm-card-accent: #287654;
  --cglm-card-soft: #edf9f2;
}

.cglm-form-message {
  padding: 14px 16px;
  border-radius: 10px;
  background: #edf9f2;
  border: 1px solid #b9ddbf;
  margin: 16px 0;
}

.cglm-hp {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
}

.cglm-reservation-anchor {
  display: block;
  position: relative;
  top: -90px;
  visibility: hidden;
}

.cglm-event-card:target {
  scroll-margin-top: 100px;
}

@media (max-width: 760px) {
  .cglm-event-card {
    grid-template-columns: 1fr;
  }

  .cglm-event-date {
    padding: 18px;
  }

  .cglm-event-body {
    padding: 20px;
  }

  .cglm-course-grid {
    grid-template-columns: 1fr;
  }

  .cglm-upcoming-events,
  .cglm-home-box,
  .cglm-reservation-form {
    border-radius: 14px;
    padding: 22px 16px 20px;
  }

  .cglm-event-body dl div {
    grid-template-columns: 3.5em 1fr;
  }
}
