
.auth-page {
  width: 100%;
  max-width: 26rem;
  margin: 0 auto;
}

.auth-card {
  background: #fff;
  border-radius: 0.75rem;
  border: 1px solid #e2e8f0;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06), 0 8px 24px rgba(15, 23, 42, 0.08);
  padding: 2rem 1.75rem 1.75rem;
  box-sizing: border-box;
}

.auth-card__brand {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1.25rem;
}

.auth-card__emblem {
  width: 2.75rem;
  height: 2.75rem;
  object-fit: contain;
  flex-shrink: 0;
  display: block;
}

.auth-card__app-name {
  font-size: 1rem;
  font-weight: 700;
  color: #0f172a;
  letter-spacing: -0.02em;
  line-height: 1.25;
}

.auth-card__title {
  margin: 0 0 0.5rem;
  font-size: 1.375rem;
  font-weight: 700;
  color: #0f172a;
  letter-spacing: -0.02em;
  line-height: 1.25;
}

.auth-card__lead {
  margin: 0 0 1.25rem;
  font-size: 0.875rem;
  color: #64748b;
  line-height: 1.6;
}

.auth-oauth {
  margin-bottom: 1rem;
}

.auth-oauth__google {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  width: 100%;
  padding: 0.6rem 1rem;
  border: 1px solid #dadce0;
  border-radius: 0.375rem;
  background: #fff;
  font-size: 0.9375rem;
  font-weight: 600;
  color: #3c4043;
  cursor: pointer;
  text-decoration: none;
  box-sizing: border-box;
  transition: background 0.15s, border-color 0.15s, box-shadow 0.15s;
}
.auth-oauth__google:hover {
  background: #f8f9fa;
  border-color: #d2d4d7;
  box-shadow: 0 1px 2px rgba(60, 64, 67, 0.12);
}
.auth-oauth__google--disabled, .auth-oauth__google:disabled {
  cursor: not-allowed;
  opacity: 0.55;
  background: #f1f5f9;
  color: #64748b;
}
.auth-oauth__google--disabled:hover, .auth-oauth__google:disabled:hover {
  background: #f1f5f9;
  border-color: #dadce0;
  box-shadow: none;
}

.auth-oauth__hint {
  margin: 0.5rem 0 0;
  font-size: 0.75rem;
  line-height: 1.5;
  color: #64748b;
}
.auth-oauth__hint code {
  font-size: 0.7rem;
  padding: 0.1rem 0.25rem;
  border-radius: 0.2rem;
  background: #f1f5f9;
  color: #475569;
}

.auth-oauth__google-icon {
  flex-shrink: 0;
}

.auth-card__divider {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin: 0 0 1.1rem;
  font-size: 0.8125rem;
  color: #94a3b8;
  text-align: center;
}
.auth-card__divider--below-form {
  margin-top: 1.35rem;
  margin-bottom: 1rem;
}
.auth-card__divider::before, .auth-card__divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: #e2e8f0;
}
.auth-card__divider span {
  flex-shrink: 0;
}

.auth-form .field {
  margin-bottom: 1rem;
}
.auth-form .field > p {
  margin: 0;
}
.auth-form .field label {
  display: block;
  margin-bottom: 0.35rem;
  font-weight: 500;
  font-size: 0.875rem;
  color: #334155;
}
.auth-form .field .field__hint {
  display: block;
  margin: -0.15rem 0 0.35rem;
  font-size: 0.8125rem;
  color: #64748b;
}
.auth-form .field input[type=email],
.auth-form .field input[type=password],
.auth-form .field input[type=text] {
  width: 100%;
  padding: 0.6rem 0.75rem;
  border: 1px solid #cbd5e1;
  border-radius: 0.375rem;
  font-size: 1rem;
  background: #fff;
  box-sizing: border-box;
}
.auth-form .field input[type=email]:focus,
.auth-form .field input[type=password]:focus,
.auth-form .field input[type=text]:focus {
  outline: none;
  border-color: #2563eb;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.15);
}
.auth-form .auth-form__remember {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-bottom: 0.25rem;
}
.auth-form .auth-form__remember input[type=checkbox] {
  width: 1rem;
  height: 1rem;
  accent-color: #2563eb;
}
.auth-form .auth-form__remember label {
  margin: 0;
  font-weight: 400;
  font-size: 0.875rem;
  color: #475569;
  cursor: pointer;
}
.auth-form .actions {
  margin-top: 1.35rem;
}
.auth-form .actions input[type=submit],
.auth-form .actions button[type=submit] {
  width: 100%;
  padding: 0.65rem 1rem;
  border-radius: 0.375rem;
  font-size: 0.9375rem;
  font-weight: 600;
  cursor: pointer;
  border: 1px solid #1d4ed8;
  background: #2563eb;
  color: #fff;
  transition: background 0.15s, border-color 0.15s;
}
.auth-form .actions input[type=submit]:hover,
.auth-form .actions button[type=submit]:hover {
  background: #1d4ed8;
  border-color: #1e40af;
}

.auth-card #error_explanation {
  margin-bottom: 1rem;
  padding: 0.75rem 1rem;
  background: #fef2f2;
  border: 1px solid #fecaca;
  border-radius: 0.375rem;
  color: #991b1b;
  font-size: 0.8125rem;
  line-height: 1.5;
}
.auth-card #error_explanation h2 {
  margin: 0 0 0.5rem;
  font-size: 0.8125rem;
  font-weight: 600;
}
.auth-card #error_explanation ul {
  margin: 0;
  padding-left: 1.15rem;
}
.auth-card #error_explanation li + li {
  margin-top: 0.25rem;
}

.auth-card__links {
  margin-top: 1.5rem;
  padding-top: 1.25rem;
  border-top: 1px solid #e2e8f0;
}
.auth-card__links p {
  margin: 0.65rem 0 0;
  font-size: 0.875rem;
}
.auth-card__links p:first-child {
  margin-top: 0;
}
.auth-card__links a {
  color: #334155;
  font-weight: 500;
  text-decoration: none;
}
.auth-card__links a:hover {
  color: #0f172a;
  text-decoration: underline;
}

html {
  max-width: 100%;
  overflow-x: hidden;
  box-sizing: border-box;
}

*,
*::before,
*::after {
  box-sizing: inherit;
}

body {
  margin: 0 !important;
  max-width: 100%;
  overflow-x: hidden;
}

img,
video {
  max-width: 100%;
  height: auto;
}

pre {
  max-width: 100%;
  overflow-x: auto;
}

.app-wrap {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  max-width: 100%;
  overflow-x: hidden;
}

.app-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  width: 100%;
  max-width: 100%;
  min-height: 3rem;
  padding: 0 1.5rem;
  box-sizing: border-box;
  background: #f8fafc;
  color: #0f172a;
  flex-shrink: 0;
  border-bottom: 1px solid #e2e8f0;
}
.app-header .app-header__brand {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex: 1 1 0;
  min-width: 0;
}
.app-header .app-header__titles {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 0.35rem 0.65rem;
  min-width: 0;
}
.app-header .app-header__school {
  font-size: 0.9375rem;
  font-weight: 600;
  color: #64748b;
  letter-spacing: -0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: min(20rem, 50vw);
}
.app-header .app-header__school::before {
  content: "";
  display: inline-block;
  width: 0.25rem;
  height: 0.25rem;
  margin-right: 0.55rem;
  vertical-align: 0.2em;
  border-radius: 50%;
  background: #cbd5e1;
}
.app-header .app-header__emblem {
  height: 2.25rem;
  width: auto;
  flex-shrink: 0;
  display: block;
  object-fit: contain;
}
.app-header .app-header__title {
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1.2;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}
.app-header .app-header__actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.75rem;
  flex: 0 0 auto;
  min-width: 0;
  max-width: 100%;
}
.app-header {
  /* 教育委員会 Web Push 登録（報告書通知用） */
}
.app-header .app-web-push-setup {
  margin: 0.75rem 1rem 0;
  padding: 0.75rem 1rem;
  max-width: 52rem;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 0.375rem;
  font-size: 0.875rem;
}
.app-header .app-web-push-setup__text {
  margin: 0 0 0.5rem;
  color: #334155;
  line-height: 1.45;
}
.app-header .app-web-push-setup__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
}
.app-header .app-header__user-menu {
  position: relative;
  flex: 0 0 auto;
}
.app-header .app-header__user-details {
  position: relative;
}
.app-header .app-header__user-summary {
  list-style: none;
  cursor: pointer;
  border-radius: 999px;
  outline: none;
}
.app-header .app-header__user-summary::-webkit-details-marker {
  display: none;
}
.app-header .app-header__user-summary::marker {
  content: "";
}
.app-header .app-header__user-summary:focus-visible .app-header__user-avatar {
  box-shadow: 0 0 0 2px #fff, 0 0 0 4px #3b82f6;
}
.app-header .app-header__user-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.375rem;
  height: 2.375rem;
  border-radius: 50%;
  background: #e2e8f0;
  color: #1e293b;
  font-size: 0.8125rem;
  font-weight: 600;
  line-height: 1;
  letter-spacing: -0.03em;
  user-select: none;
  border: 1px solid #cbd5e1;
  box-sizing: border-box;
  transition: background 0.15s ease, border-color 0.15s ease;
}
.app-header .app-header__user-summary:hover .app-header__user-avatar {
  background: #cbd5e1;
  border-color: #94a3b8;
}
.app-header .app-header__user-details[open] .app-header__user-avatar {
  background: #cbd5e1;
  border-color: #64748b;
}
.app-header .app-header__user-panel {
  position: absolute;
  right: 0;
  top: calc(100% + 0.35rem);
  z-index: 80;
  min-width: 14rem;
  max-width: min(18rem, 85vw);
  padding: 0.75rem;
  background: #fff;
  color: #0f172a;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.12);
  box-sizing: border-box;
}
.app-header .app-header__user-panel-meta {
  margin-bottom: 0.65rem;
  padding-bottom: 0.65rem;
  border-bottom: 1px solid #e2e8f0;
}
.app-header .app-header__user-panel-name {
  display: block;
  font-size: 0.875rem;
  font-weight: 600;
  color: #0f172a;
  line-height: 1.35;
  word-break: break-word;
}
.app-header .app-header__user-panel-email {
  display: block;
  margin-top: 0.2rem;
  font-size: 0.75rem;
  color: #64748b;
  line-height: 1.35;
  word-break: break-all;
}
.app-header .app-header__user-panel-stop-impersonation {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  width: 100%;
  margin: 0 0 0.5rem;
  padding: 0.45rem 0.65rem;
  background: #fffbeb;
  color: #92400e;
  border: 1px solid #fcd34d;
  border-radius: 0.375rem;
  text-decoration: none;
  font-size: 0.875rem;
  font-weight: 500;
  box-sizing: border-box;
}
.app-header .app-header__user-panel-stop-impersonation i {
  font-size: 1.05rem;
  opacity: 0.9;
}
.app-header .app-header__user-panel-stop-impersonation:hover {
  background: #fef3c7;
  border-color: #f59e0b;
  color: #78350f;
}
.app-header .app-header__user-panel-logout {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  width: 100%;
  margin: 0;
  padding: 0.45rem 0.65rem;
  background: transparent;
  color: #0f172a;
  border: 1px solid #94a3b8;
  border-radius: 0.375rem;
  text-decoration: none;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  box-sizing: border-box;
}
.app-header .app-header__user-panel-logout i {
  font-size: 1.05rem;
  opacity: 0.85;
}
.app-header .app-header__user-panel-logout:hover {
  background: #f1f5f9;
  border-color: #64748b;
}

.app-body {
  display: flex;
  flex: 1;
  min-height: 0;
  min-width: 0;
  max-width: 100%;
}

.app-main__footer-link {
  margin-top: 2rem;
  padding-top: 1rem;
  border-top: 1px solid #e2e8f0;
  font-size: 0.8125rem;
}

.app-main__footer-link-a {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  color: #334155;
  text-decoration: none;
}
.app-main__footer-link-a i {
  font-size: 1rem;
  opacity: 0.9;
}
.app-main__footer-link-a:hover {
  text-decoration: underline;
}

.app-sidebar {
  width: 20%;
  min-width: 12rem;
  max-width: 16rem;
  background: #f8fafc;
  color: #334155;
  padding: 1.5rem 0;
  flex-shrink: 0;
  overflow-x: hidden;
  overflow-y: auto;
  border-right: 1px solid #e2e8f0;
}
.app-sidebar .app-sidebar__nav {
  list-style: none;
  margin: 0;
  padding: 0;
}
.app-sidebar .app-sidebar__item {
  margin: 0;
}
.app-sidebar .app-sidebar__link-inner {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
  box-sizing: border-box;
}
.app-sidebar .app-sidebar__link-inner > i {
  flex-shrink: 0;
  width: 1.35rem;
  text-align: center;
  font-size: 1.125rem;
  opacity: 0.88;
}
.app-sidebar .app-sidebar__link-inner > span:not(.app-sidebar__badge) {
  min-width: 0;
}
.app-sidebar .app-sidebar__link-inner .app-sidebar__link-text {
  flex: 1;
  min-width: 0;
}
.app-sidebar .app-sidebar__badge {
  margin-left: auto;
  flex-shrink: 0;
  min-width: 1.35rem;
  padding: 0.1rem 0.42rem;
  font-size: 0.6875rem;
  font-weight: 800;
  line-height: 1.25;
  text-align: center;
  border-radius: 999px;
  background: #dc2626;
  color: #fff;
}
.app-sidebar .app-sidebar__link {
  display: block;
  padding: 0.625rem 1.5rem;
  color: #334155;
  text-decoration: none;
  font-size: 0.9375rem;
}
.app-sidebar .app-sidebar__link:hover {
  background: #e2e8f0;
}
.app-sidebar .app-sidebar__link.active {
  background: #e2e8f0;
  font-weight: 600;
  color: #0f172a;
}
.app-sidebar .app-sidebar__link.active .app-sidebar__link-inner > i {
  opacity: 1;
  color: #0f172a;
}
.app-sidebar .app-sidebar__link--child {
  padding-left: 1rem;
  font-size: 0.875rem;
}
.app-sidebar .app-sidebar__details {
  margin: 0;
}
.app-sidebar .app-sidebar__summary {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.625rem 1.5rem;
  color: #334155;
  font-size: 0.9375rem;
  cursor: pointer;
  list-style: none;
  user-select: none;
}
.app-sidebar .app-sidebar__summary::-webkit-details-marker {
  display: none;
}
.app-sidebar .app-sidebar__summary::before {
  content: "▶";
  display: inline-block;
  flex-shrink: 0;
  margin-right: 0.125rem;
  font-size: 0.5rem;
  vertical-align: 0.15em;
  transition: transform 0.15s ease;
}
.app-sidebar__details[open] .app-sidebar .app-sidebar__summary::before {
  transform: rotate(90deg);
}
.app-sidebar .app-sidebar__summary:hover {
  background: #e2e8f0;
}
.app-sidebar .app-sidebar__summary-main {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  min-width: 0;
  flex: 1;
  width: 100%;
  box-sizing: border-box;
}
.app-sidebar .app-sidebar__summary-main--text-only {
  padding-left: 0.15rem;
}
.app-sidebar .app-sidebar__summary-icon {
  font-size: 1.125rem;
  opacity: 0.88;
  width: 1.35rem;
  flex-shrink: 0;
  text-align: center;
}
.app-sidebar .app-sidebar__subnav {
  list-style: none;
  margin: 0;
  padding: 0;
  padding-left: 32px;
}
.app-sidebar .app-sidebar__subitem {
  margin: 0;
}

.app-main {
  flex: 1;
  min-width: 0;
  max-width: 100%;
  padding: 1.5rem;
  background: white;
  overflow-x: auto;
  overflow-y: auto;
  box-sizing: border-box;
}

.app-main:has(.ec-dash--admin),
.app-main:has(.page-users--admin-wide),
.app-main:has(.page-users--esd-company-show),
.app-main:has(.page-users--esd-program-show) {
  padding-left: 1rem;
  padding-right: 1rem;
}
@media (min-width: 900px) {
  .app-main:has(.ec-dash--admin),
  .app-main:has(.page-users--admin-wide),
  .app-main:has(.page-users--esd-company-show),
  .app-main:has(.page-users--esd-program-show) {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }
}

.notice, .alert {
  padding: 0.75rem 1.5rem;
  margin-bottom: 1rem;
  border-radius: 0.25rem;
}

.notice {
  background: #dcfce7;
  color: #166534;
}

.alert {
  background: #fee2e2;
  color: #991b1b;
}

.monthly-attendance__toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 0.75rem;
  margin-bottom: 0.75rem;
}

.monthly-attendance__form {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 0.75rem;
}

.monthly-attendance__form select,
.monthly-attendance__form input[type=month] {
  min-height: 2.25rem;
  padding: 0.375rem 0.65rem;
  border: 1px solid #cbd5e1;
  border-radius: 0.4rem;
  background: #fff;
  font-size: 0.95rem;
  line-height: 1.2;
}

.monthly-attendance__form select {
  min-width: 8.5rem;
}

.monthly-attendance__form input[type=month] {
  min-width: 9.5rem;
}

.monthly-attendance__toolbar--school-guard-shifts {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 0.75rem;
}

.monthly-attendance__school-guard-nav-links {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  gap: 0.5rem;
}

.monthly-attendance__school-guard-nav-inner {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  white-space: nowrap;
}

.monthly-attendance__school-guard-nav-links .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

@media (max-width: 639.98px) {
  .monthly-attendance__form:not(.monthly-attendance__form--school-guard-month) {
    width: 100%;
    flex-direction: column;
    align-items: stretch;
  }
  .monthly-attendance__form:not(.monthly-attendance__form--school-guard-month) select,
  .monthly-attendance__form:not(.monthly-attendance__form--school-guard-month) input[type=month] {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
  }
}
.monthly-attendance__label {
  font-size: 0.875rem;
  color: #64748b;
}

.monthly-attendance__intro {
  font-size: 0.875rem;
  color: #64748b;
  line-height: 1.55;
  margin-bottom: 1rem;
}

.monthly-attendance__table-wrap {
  overflow-x: auto;
  margin-bottom: 1rem;
}

.monthly-attendance__totals {
  font-weight: 700;
  background: #f8fafc;
}

.monthly-attendance__date-cell {
  display: flex;
  align-items: baseline;
  gap: 0.35rem;
  flex-wrap: nowrap;
  white-space: nowrap;
}

.monthly-attendance__wday {
  color: #64748b;
  font-size: 0.9375rem;
}

/* スクールガード月次: colgroup + fixed で列幅を揃え、校名は折り返し（省略なし） */
.monthly-attendance__table--guard-split {
  table-layout: fixed;
  width: 100%;
  border-collapse: collapse;
}
.monthly-attendance__table--guard-split col.monthly-attendance__col-day {
  width: 4.5rem;
}
.monthly-attendance__table--guard-split col.monthly-attendance__col-report {
  width: 3rem;
}
.monthly-attendance__table--guard-split col.monthly-attendance__col-school {
  width: 14%;
}
.monthly-attendance__table--guard-split col.monthly-attendance__col-time {
  width: 3.25rem;
}
.monthly-attendance__table--guard-split col.monthly-attendance__col-stat {
  width: 4.25rem;
}
.monthly-attendance__table--guard-split col.monthly-attendance__col-ops {
  width: 4.25rem;
}
.monthly-attendance__table--guard-split th,
.monthly-attendance__table--guard-split td {
  padding: 0.68rem 0.45rem;
  vertical-align: middle;
  box-sizing: border-box;
}

.monthly-attendance__th--day,
.monthly-attendance__td--day {
  text-align: left;
}

.monthly-attendance__th--stat,
.monthly-attendance__td--duration {
  text-align: right;
  font-size: 0.8125rem;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

.monthly-attendance__th--clock-col {
  font-size: 0.6875rem;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -0.02em;
  text-align: center;
  white-space: nowrap;
}

.monthly-attendance__td--time {
  font-size: 0.8125rem;
  text-align: center;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

.monthly-attendance__td--actual-clock {
  vertical-align: top;
  white-space: normal;
}

.monthly-attendance__clock-stack {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.15rem;
  line-height: 1.25;
  min-width: 0;
}

.monthly-attendance__clock-time {
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

.monthly-attendance__geo {
  font-size: 0.625rem;
  color: #64748b;
  line-height: 1.25;
  max-width: 10rem;
  text-align: center;
  word-break: break-word;
}

.monthly-attendance__geo-line {
  display: block;
}

.monthly-attendance__geo--muted {
  display: block;
  font-style: italic;
  color: #94a3b8;
}

.monthly-attendance__th--report,
.monthly-attendance__td--report {
  text-align: center;
  vertical-align: middle;
}

.monthly-attendance__th--ops,
.monthly-attendance__td--ops {
  text-align: center;
  vertical-align: middle;
}

.monthly-attendance__td--span-blank {
  text-align: center;
  color: #94a3b8;
}

.monthly-attendance__report-icon-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #475569;
  font-size: 1.5rem;
  line-height: 1;
  padding: 0.2rem;
  text-decoration: none;
  border-radius: 0.35rem;
}
.monthly-attendance__report-icon-link:hover {
  color: #0f172a;
  background: #f1f5f9;
}
.monthly-attendance__report-icon-link .las {
  pointer-events: none;
}

.monthly-attendance__th--duty-school,
.monthly-attendance__th--scheduled-school {
  font-size: 0.75rem;
  line-height: 1.25;
  text-align: left;
  vertical-align: bottom;
}

.monthly-attendance__th-duty-note,
.monthly-attendance__th-scheduled-note {
  display: block;
  font-weight: 400;
  font-size: 0.65rem;
  color: #64748b;
}

.monthly-attendance__td--duty-school,
.monthly-attendance__td--scheduled-school {
  min-width: 0;
  font-size: 0.8125rem;
  line-height: 1.4;
  text-align: left;
  white-space: normal;
  word-break: break-word;
  overflow-wrap: anywhere;
}

.esd-cover {
  position: relative;
  width: 100%;
  max-width: var(--esd-cover-w, 100%);
  height: var(--esd-cover-h, 200px);
  overflow: hidden;
  background: #e2e8f0;
  border-radius: 0.375rem;
}
.esd-cover--lp-program {
  position: absolute;
  inset: 0;
  width: 100%;
  max-width: none;
  height: 100%;
  border-radius: 0;
  background: #cbd5e1;
}
.esd-cover--lp-tile {
  height: 200px;
  border-radius: 0.5rem 0.5rem 0 0;
  margin: -1.1rem -1.2rem 0.75rem;
  width: calc(100% + 2.4rem);
  max-width: none;
}
.esd-cover--detail-hero {
  max-width: none;
  width: 100%;
  height: min(36vw, 280px);
  min-height: 180px;
  border-radius: 0.5rem;
  margin-bottom: 1.25rem;
}
.esd-cover--partner-hero {
  max-width: none;
  width: 100%;
  height: 100%;
  min-height: 0;
  border-radius: 0;
  margin: 0;
}
.esd-cover--partner-program-card {
  position: absolute;
  inset: 0;
  width: 100%;
  max-width: none;
  height: 100%;
  border-radius: 0;
  background: #cbd5e1;
}
.esd-cover--detail-inline {
  max-width: 320px;
  height: 180px;
  margin-bottom: 1rem;
}
.esd-cover--program-detail-hero {
  display: block;
  max-width: none;
  width: 100%;
  height: 100%;
  min-height: 0;
  border-radius: 0;
  margin: 0;
  background: #cbd5e1;
}
.esd-cover--school-table {
  width: 120px;
  height: 72px;
  max-width: 120px;
  border-radius: 0.35rem;
}
.esd-cover--school-show {
  max-width: 560px;
  width: 100%;
  height: 280px;
  border-radius: 0.5rem;
  margin-bottom: 1rem;
}
.esd-cover--preview {
  margin-top: 0.5rem;
}
.esd-cover--mypage-program {
  width: 100%;
  max-width: none;
  height: 54px;
  border-radius: 0.35rem;
}

.esd-cover__img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.esd-cover__placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  min-height: 100%;
  background: #94a3b8;
  box-sizing: border-box;
}

.esd-cover__placeholder-label {
  padding: 0.35rem 0.65rem;
  background: rgba(15, 23, 42, 0.55);
  color: #f8fafc;
  font-size: 0.8125rem;
  font-weight: 700;
  font-family: ui-monospace, monospace;
  border-radius: 0.25rem;
  letter-spacing: 0.02em;
}

.esd-cover__placeholder--empty {
  background: #e2e8f0;
  min-height: 100%;
}

.esd-lp-v2-program-card__visual-shade {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(180deg, transparent 30%, rgba(15, 23, 42, 0.45) 100%);
}

.page-dashboard .page-dashboard__title {
  margin: 0 0 0.5rem;
  font-size: 1.25rem;
  font-weight: 700;
}
.page-dashboard .page-dashboard__email {
  margin: 0 0 1rem;
  color: #475569;
  font-size: 0.9375rem;
}

.ec-dash .ec-dash__hero {
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  padding: 1.5rem 1.5rem 1.25rem;
  margin-bottom: 1.5rem;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}
.ec-dash .ec-dash__kicker {
  margin: 0 0 0.25rem;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #64748b;
}
.ec-dash .ec-dash__heading {
  margin: 0 0 0.5rem;
  font-size: 1.5rem;
  font-weight: 700;
  color: #0f172a;
  line-height: 1.3;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.ec-dash .ec-dash__heading-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.5rem;
  background: #eff6ff;
  color: #2563eb;
  font-size: 1.35rem;
  flex-shrink: 0;
}
.ec-dash .ec-dash__heading-text {
  min-width: 0;
}
.ec-dash .ec-dash__lead {
  margin: 0 0 1.25rem;
  font-size: 0.9375rem;
  color: #475569;
  line-height: 1.55;
  max-width: 40rem;
}
.ec-dash .ec-dash__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.75rem;
  margin-bottom: 1.5rem;
}
@media (max-width: 640px) {
  .ec-dash .ec-dash__stats {
    grid-template-columns: 1fr;
  }
}
.ec-dash .ec-dash__stat {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  padding: 1rem 1.125rem;
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: auto auto;
  column-gap: 0.75rem;
  row-gap: 0.125rem;
  align-items: start;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}
.ec-dash .ec-dash__stat-icon {
  grid-row: 1/-1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  margin-top: 0.125rem;
  border-radius: 0.5rem;
  background: #f1f5f9;
  color: #64748b;
  font-size: 1.25rem;
}
.ec-dash .ec-dash__stat-value {
  grid-column: 2;
  font-size: 1.75rem;
  font-weight: 700;
  color: #2563eb;
  line-height: 1.1;
  font-variant-numeric: tabular-nums;
}
.ec-dash .ec-dash__stat-label {
  grid-column: 2;
  font-size: 0.8125rem;
  font-weight: 500;
  color: #475569;
  line-height: 1.35;
}
.ec-dash .ec-dash__stat-hint {
  font-weight: 400;
  font-size: 0.75rem;
  color: #94a3b8;
}
.ec-dash .ec-dash__menu {
  margin-bottom: 2rem;
}
.ec-dash .ec-dash__inbox-preview {
  margin: 0 0 1.25rem;
  padding: 0 0 1.25rem;
  border-bottom: 1px solid #e2e8f0;
}
.ec-dash .ec-dash__inbox-preview-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem 1rem;
  margin-bottom: 0.65rem;
}
.ec-dash .ec-dash__section-title--inbox {
  margin: 0;
}
.ec-dash .ec-dash__inbox-preview-more {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: #334155;
  text-decoration: none;
  white-space: nowrap;
}
.ec-dash .ec-dash__inbox-preview-more:hover {
  color: #0f172a;
  text-decoration: underline;
}
.ec-dash .ec-dash__inbox-preview-more .las {
  font-size: 1rem;
  opacity: 0.85;
}
.ec-dash .ec-dash__inbox-preview-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.ec-dash .ec-dash__inbox-preview-item {
  margin: 0 0 0.4rem;
}
.ec-dash .ec-dash__inbox-preview-item:last-child {
  margin-bottom: 0;
}
.ec-dash .ec-dash__inbox-preview-row {
  display: grid;
  grid-template-columns: minmax(7.5rem, 9.5rem) minmax(0, 1fr) minmax(6.5rem, 11rem);
  gap: 0.5rem 1rem;
  align-items: center;
  padding: 0.55rem 0.65rem;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 0.375rem;
  text-decoration: none;
  color: inherit;
  transition: border-color 0.15s, background 0.15s, box-shadow 0.15s;
}
.ec-dash .ec-dash__inbox-preview-row:hover {
  border-color: #cbd5e1;
  background: #fff;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.06);
}
.ec-dash .ec-dash__inbox-preview-row:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
}
@media (max-width: 640px) {
  .ec-dash .ec-dash__inbox-preview-row {
    grid-template-columns: 1fr;
    gap: 0.25rem 0;
  }
}
.ec-dash .ec-dash__inbox-preview-date {
  font-size: 0.75rem;
  font-weight: 600;
  color: #64748b;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.ec-dash .ec-dash__inbox-preview-subject {
  font-size: 0.875rem;
  font-weight: 600;
  color: #0f172a;
  line-height: 1.35;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
@media (max-width: 640px) {
  .ec-dash .ec-dash__inbox-preview-subject {
    white-space: normal;
  }
}
.ec-dash .ec-dash__inbox-preview-from {
  font-size: 0.8125rem;
  color: #475569;
  line-height: 1.35;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
@media (max-width: 640px) {
  .ec-dash .ec-dash__inbox-preview-from {
    white-space: normal;
  }
}
.ec-dash .ec-dash__inbox-preview-empty {
  margin: 0;
  font-size: 0.875rem;
  color: #64748b;
}
.ec-dash .ec-dash__esd-banner {
  position: relative;
  margin: 0 0 1rem;
  min-height: 6.5rem;
  border-radius: 0.5rem;
  overflow: hidden;
  background-color: #14532d;
  background-image: url(/assets/esd_lp/top-17d8ce18ae30609eb4abd7622873be9ec92610ba67ff8b6e11cd874fc348fae7.jpg);
  background-size: cover;
  background-position: right center;
}
.ec-dash .ec-dash__esd-banner::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(15, 23, 42, 0.82) 0%, rgba(15, 23, 42, 0.42) 45%, transparent 75%);
  pointer-events: none;
}
.ec-dash .ec-dash__esd-banner-content {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  padding: 1.1rem 1.25rem;
  max-width: min(100%, 17rem);
}
.ec-dash .ec-dash__esd-banner-title {
  margin: 0;
  font-size: 1.375rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  color: #fff;
  line-height: 1.2;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.35);
}
.ec-dash .ec-dash__esd-banner-sub {
  margin: 0;
  font-size: 0.75rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.93);
  line-height: 1.4;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.28);
}
.ec-dash .row.ec-dash__split {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 0 1rem;
  margin: 0 -0.25rem;
}
.ec-dash .row.ec-dash__split > .col-6 {
  flex: 1 1 calc(50% - 0.5rem);
  min-width: min(100%, 17rem);
  max-width: 100%;
  padding: 0 0.25rem;
  box-sizing: border-box;
}
@media (min-width: 768px) {
  .ec-dash .row.ec-dash__split > .col-6 {
    flex: 1 1 calc(50% - 0.5rem);
    max-width: calc(50% - 0.5rem);
  }
}
.ec-dash .row.ec-dash__menu-tiles-grid {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -0.35rem;
}
.ec-dash .row.ec-dash__menu-tiles-grid > .col-4 {
  flex: 0 0 33.333333%;
  max-width: 33.333333%;
  padding: 0 0.35rem;
  margin-bottom: 0.65rem;
  box-sizing: border-box;
  display: flex;
}
.ec-dash .row.ec-dash__menu-tiles-grid > .col-4 > .ec-tile {
  width: 100%;
  min-height: 7.75rem;
  justify-content: center;
}
@media (max-width: 640px) {
  .ec-dash .row.ec-dash__menu-tiles-grid > .col-4 {
    flex: 0 0 50%;
    max-width: 50%;
  }
}
.ec-dash .ec-dash__pending-block {
  margin: 0 0 1.5rem;
  padding: 0 0 1.25rem;
  border-bottom: 1px solid #e2e8f0;
}
.ec-dash .ec-dash__split .ec-dash__pending-block {
  margin: 0;
  padding: 0;
  border-bottom: none;
}
.ec-dash .ec-dash__esd-partner-footer {
  margin-top: 0.75rem;
}
.ec-dash .ec-dash__esd-partner-footer .ec-tile.ec-tile--box {
  width: 100%;
  box-sizing: border-box;
}
.ec-dash .ec-dash__split .ec-dash__pending-list--grid {
  grid-template-columns: 1fr;
}
.ec-dash .ec-dash__pending-panel {
  padding: 0.25rem 0 0;
}
.ec-dash .ec-dash__pending-lead {
  margin: 0 0 0.75rem;
  font-size: 0.8125rem;
  color: #64748b;
  line-height: 1.45;
}
.ec-dash .ec-dash__pending-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.ec-dash .ec-dash__pending-list--grid {
  display: grid;
  gap: 0.5rem;
}
@media (min-width: 768px) {
  .ec-dash .ec-dash__pending-list--grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
.ec-dash .ec-dash__pending-list--grid .ec-dash__pending-item {
  margin: 0;
}
.ec-dash .ec-dash__pending-item {
  margin: 0 0 0.5rem;
}
.ec-dash .ec-dash__pending-item:last-child {
  margin-bottom: 0;
}
.ec-dash .ec-dash__pending-link {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.2rem;
  padding: 1rem 0.75rem;
  border-bottom: 1px solid #e2e8f0;
  text-decoration: none;
  color: inherit;
  transition: border-color 0.15s, background 0.15s, box-shadow 0.15s;
}
.ec-dash .ec-dash__pending-link:hover {
  border-color: #cbd5e1;
  background: #fff;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.06);
}
.ec-dash .ec-dash__pending-link:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
}
.ec-dash .ec-dash__pending-time {
  font-size: 0.75rem;
  font-weight: 500;
  color: #64748b;
  font-variant-numeric: tabular-nums;
}
.ec-dash .ec-dash__pending-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: #0f172a;
  line-height: 1.35;
  word-break: break-word;
}
.ec-dash .ec-dash__pending-foot {
  margin: 0.85rem 0 0;
  font-size: 0.8125rem;
}
.ec-dash .ec-dash__pending-empty {
  margin: 0;
  font-size: 0.875rem;
  color: #64748b;
  line-height: 1.5;
}
.ec-dash .ec-dash__section-title {
  margin: 0 0 0.75rem;
  font-size: 0.8125rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #64748b;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.ec-dash .ec-dash__section-title i {
  font-size: 1.125rem;
  color: #94a3b8;
}
.ec-dash .ec-dash__section-title--pending {
  margin: 0 0 0.65rem;
}
.ec-dash .ec-dash__section-title--page {
  margin: 0 0 1rem;
  font-size: 1.25rem;
  font-weight: 800;
  text-transform: none;
  letter-spacing: -0.02em;
  color: #0f172a;
}
.ec-dash .ec-dash__section-title--page i {
  font-size: 1.35rem;
  color: #64748b;
}
.ec-dash .ec-dash__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(15.5rem, 1fr));
  gap: 0.75rem;
}
.ec-dash .ec-dash__grid--tiles {
  grid-template-columns: repeat(auto-fill, minmax(6.75rem, 1fr));
  gap: 0.65rem;
}
.ec-dash .ec-dash__menu-tiles-wrap {
  min-width: 0;
}
.ec-dash .ec-dash__menu-group {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  min-width: 0;
}
.ec-dash .ec-dash__menu-subheading {
  margin: 0;
  font-size: 0.8125rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #64748b;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.ec-dash .ec-dash__menu-subheading i {
  font-size: 1.125rem;
  color: #94a3b8;
}
.ec-dash .ec-dash__menu-rows {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}
.ec-dash .ec-dash__menu-rows .ec-tile {
  box-sizing: border-box;
  min-height: 7.75rem;
  justify-content: center;
  align-self: stretch;
}
.ec-dash .ec-dash__menu-rows .ec-tile__icon {
  width: 3.25rem;
  height: 3.25rem;
  font-size: 1.75rem;
  flex-shrink: 0;
}
.ec-dash .ec-dash__menu-rows .ec-tile__label {
  font-size: 0.6875rem;
  line-height: 1.25;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.ec-dash .ec-dash__menu-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.65rem;
  min-width: 0;
  align-items: stretch;
}
@media (max-width: 640px) {
  .ec-dash .ec-dash__menu-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
.ec-dash .ec-tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 0.55rem;
  min-height: 6.75rem;
  padding: 1rem 0.5rem 0.85rem;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  text-decoration: none;
  color: inherit;
  text-align: center;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
  transition: border-color 0.15s, box-shadow 0.15s, transform 0.12s;
}
.ec-dash .ec-tile:hover {
  border-color: #cbd5e1;
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.07);
  transform: translateY(-1px);
}
.ec-dash .ec-tile:hover .ec-tile__icon {
  background: #eff6ff;
  color: #2563eb;
}
.ec-dash .ec-tile:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
}
.ec-dash .ec-tile--accent .ec-tile__icon {
  background: #fffbeb;
  color: #d97706;
}
.ec-dash .ec-tile--accent:hover .ec-tile__icon {
  background: #fef3c7;
  color: #b45309;
}
.ec-dash .ec-tile.ec-tile--box {
  grid-column: 1/-1;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  gap: 0.85rem;
  min-height: unset;
  padding: 0.85rem 1rem;
  text-align: left;
}
.ec-dash .ec-tile.ec-tile--box:hover .ec-tile__icon {
  background: #ecfdf5;
  color: #059669;
}
.ec-dash .ec-tile.ec-tile--box .ec-tile__label {
  flex: 1;
  min-width: 0;
  font-size: 0.9375rem;
  text-align: left;
}
.ec-dash .ec-tile__box-go {
  flex-shrink: 0;
  color: #94a3b8;
  font-size: 1.125rem;
  line-height: 1;
}
.ec-dash .ec-tile__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.75rem;
  height: 3.75rem;
  border-radius: 0.65rem;
  background: #f1f5f9;
  color: #64748b;
  font-size: 2rem;
  line-height: 1;
  flex-shrink: 0;
  transition: background 0.15s, color 0.15s;
}
.ec-dash .ec-tile__label {
  font-size: 0.75rem;
  font-weight: 700;
  color: #0f172a;
  line-height: 1.3;
  word-break: break-word;
  hyphens: auto;
}
.ec-dash .ec-tile.ec-tile--box .ec-tile__icon {
  width: 2.75rem;
  height: 2.75rem;
  font-size: 1.5rem;
  border-radius: 0.5rem;
  background: #f0fdf4;
  color: #047857;
}
.ec-dash .ec-card {
  position: relative;
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 1rem 2.25rem 1rem 1rem;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  text-decoration: none;
  color: inherit;
  transition: border-color 0.15s, box-shadow 0.15s;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
  min-height: 5.5rem;
}
.ec-dash .ec-card:hover {
  border-color: #cbd5e1;
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.06);
}
.ec-dash .ec-card:hover .ec-card__icon {
  background: #eff6ff;
  color: #2563eb;
}
.ec-dash .ec-card:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
}
.ec-dash .ec-card--accent .ec-card__icon {
  background: #fffbeb;
  color: #d97706;
}
.ec-dash .ec-card--accent:hover .ec-card__icon {
  background: #fef3c7;
  color: #b45309;
}
.ec-dash .ec-card__icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  margin-top: 0.0625rem;
  border-radius: 0.5rem;
  background: #f1f5f9;
  color: #64748b;
  font-size: 1.25rem;
  transition: background 0.15s, color 0.15s;
}
.ec-dash .ec-card__body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}
.ec-dash .ec-card__title {
  font-size: 0.9375rem;
  font-weight: 700;
  color: #0f172a;
}
.ec-dash .ec-card__desc {
  font-size: 0.8125rem;
  color: #64748b;
  line-height: 1.45;
}
.ec-dash .ec-card__go {
  position: absolute;
  right: 0.65rem;
  top: 50%;
  transform: translateY(-50%);
  opacity: 0.4;
  font-size: 1.25rem;
  color: #64748b;
  line-height: 1;
  transition: opacity 0.15s, transform 0.15s, color 0.15s;
  pointer-events: none;
}
.ec-dash .ec-card__go i {
  display: block;
}
.ec-dash .ec-card:hover .ec-card__go {
  opacity: 0.95;
  color: #2563eb;
  transform: translateY(-50%) translateX(2px);
}
.ec-dash.ec-dash--facility-tile-grid {
  max-width: 100%;
  margin: 1rem 0 0;
  padding: 0;
}
.ec-dash.ec-dash--facility-tile-grid .row.ec-childcare-staff-shift-facilities-grid {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -0.375rem;
}
.ec-dash.ec-dash--facility-tile-grid .row.ec-childcare-staff-shift-facilities-grid > .col-3.ec-childcare-staff-shift-facilities-grid__col {
  flex: 0 0 25%;
  max-width: 25%;
  padding: 0 0.375rem;
  margin-bottom: 0.75rem;
  box-sizing: border-box;
  display: flex;
}
.ec-dash.ec-dash--facility-tile-grid .row.ec-childcare-staff-shift-facilities-grid > .col-3.ec-childcare-staff-shift-facilities-grid__col > .ec-tile {
  width: 100%;
  min-height: 8.25rem;
  justify-content: center;
}
.ec-dash.ec-dash--facility-tile-grid .ec-tile__meta {
  font-size: 0.6875rem;
  font-weight: 600;
  color: #64748b;
  line-height: 1.3;
}
@media (max-width: 900px) {
  .ec-dash.ec-dash--facility-tile-grid .row.ec-childcare-staff-shift-facilities-grid > .col-3.ec-childcare-staff-shift-facilities-grid__col {
    flex: 0 0 33.3333%;
    max-width: 33.3333%;
  }
}
@media (max-width: 640px) {
  .ec-dash.ec-dash--facility-tile-grid .row.ec-childcare-staff-shift-facilities-grid > .col-3.ec-childcare-staff-shift-facilities-grid__col {
    flex: 0 0 50%;
    max-width: 50%;
  }
}

.ec-dash.ec-dash--admin {
  max-width: 100%;
  width: 100%;
  margin: 0;
  box-sizing: border-box;
  padding: 0;
  border-radius: 0;
  background: transparent;
}
.ec-dash.ec-dash--admin .ec-dash__lead {
  max-width: none;
}
.ec-dash.ec-dash--admin .ec-dash__stats {
  gap: 1rem;
}
@media (min-width: 1100px) {
  .ec-dash.ec-dash--admin .ec-dash__stats {
    gap: 1.25rem;
  }
}
@media (min-width: 1100px) {
  .ec-dash.ec-dash--admin .ec-dash__stat {
    padding: 1.125rem 1.35rem;
  }
}
.ec-dash.ec-dash--admin .ec-dash__grid {
  grid-template-columns: repeat(auto-fill, minmax(13.5rem, 1fr));
  gap: 1rem;
}
@media (min-width: 1000px) {
  .ec-dash.ec-dash--admin .ec-dash__grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}
@media (min-width: 1400px) {
  .ec-dash.ec-dash--admin .ec-dash__grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
}
@media (min-width: 1800px) {
  .ec-dash.ec-dash--admin .ec-dash__grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }
}
.ec-dash.ec-dash--admin .ec-dash__stats {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  margin-bottom: 1.15rem;
}
@media (max-width: 1200px) {
  .ec-dash.ec-dash--admin .ec-dash__stats {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (max-width: 800px) {
  .ec-dash.ec-dash--admin .ec-dash__stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 640px) {
  .ec-dash.ec-dash--admin .ec-dash__stats {
    grid-template-columns: 1fr;
  }
}
.ec-dash.ec-dash--admin .ec-dash__stat {
  border-radius: 0.75rem;
  border: 1px solid #e2e8f0;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.05);
}
.ec-dash.ec-dash--admin .ec-dash__stat-icon {
  background: #f1f5f9;
  color: #64748b;
}
.ec-dash.ec-dash--admin .ec-dash__stat-value {
  color: #0f172a;
}
.ec-dash.ec-dash--admin .ec-dash__section-title {
  color: #475569;
  font-size: 0.85rem;
}
.ec-dash.ec-dash--admin .ec-card {
  border-radius: 0.75rem;
  border: 1px solid #e2e8f0;
  background: #fff;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.05);
  transition: transform 0.16s ease, box-shadow 0.16s ease, border-color 0.16s ease;
}
.ec-dash.ec-dash--admin .ec-card:hover {
  transform: translateY(-1px);
  border-color: #cbd5e1;
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.08);
}
.ec-dash.ec-dash--admin .ec-card__icon {
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  color: #64748b;
}
.ec-dash.ec-dash--admin .ec-card:hover .ec-card__icon {
  background: #f1f5f9;
  color: #475569;
  border-color: #e2e8f0;
}
.ec-dash.ec-dash--admin .ec-card:hover .ec-card__go {
  color: #64748b;
}

.ec-dash.ec-dash--admin .ec-dash__menu--charts {
  margin-bottom: 1.25rem;
}

.ec-dash.ec-dash--admin .ec-dash__menu--top-summary {
  margin-bottom: 0.6rem;
}

.ec-dash.ec-dash--admin .ec-dash__charts {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.8rem 1rem;
}
@media (max-width: 900px) {
  .ec-dash.ec-dash--admin .ec-dash__charts {
    grid-template-columns: 1fr;
  }
}

.ec-dash.ec-dash--admin .ec-chart-row {
  border: 1px solid #e2e8f0;
  border-radius: 0.75rem;
  background: #fff;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.05);
  padding: 0.75rem 0.85rem;
  transition: transform 0.16s ease, box-shadow 0.16s ease;
}

.ec-dash.ec-dash--admin .ec-chart-row:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.07);
}

.ec-dash.ec-dash--admin .ec-chart-row__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.45rem;
}

.ec-dash.ec-dash--admin .ec-chart-row__label {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  color: #334155;
  font-size: 0.86rem;
  font-weight: 700;
}

.ec-dash.ec-dash--admin .ec-chart-row__label i {
  color: #64748b;
}

.ec-dash.ec-dash--admin .ec-chart-row__value {
  color: #0f172a;
  font-size: 0.92rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}

.ec-dash.ec-dash--admin .ec-chart-row__track {
  position: relative;
  width: 100%;
  height: 0.56rem;
  border-radius: 999px;
  background: #e2e8f0;
  overflow: hidden;
}

.ec-dash.ec-dash--admin .ec-chart-row__bar {
  display: block;
  height: 100%;
  width: var(--chart-ratio, 10%);
  border-radius: 999px;
  background: #2563eb;
  transform-origin: left center;
  animation: ecChartGrow 900ms cubic-bezier(0.18, 0.89, 0.32, 1.28) both;
}

@keyframes ecChartGrow {
  from {
    width: 0;
    opacity: 0.4;
  }
  to {
    width: var(--chart-ratio, 10%);
    opacity: 1;
  }
}
.ec-dash.ec-dash--admin .admin-esd-banner {
  position: relative;
  display: block;
  width: 100%;
  min-height: 11rem;
  border-radius: 0.9rem;
  overflow: hidden;
  text-decoration: none;
  background-size: cover;
  background-position: center;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.18);
  transition: transform 0.16s ease, box-shadow 0.16s ease;
}

.ec-dash.ec-dash--admin .admin-esd-banner:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 30px rgba(15, 23, 42, 0.24);
}

.ec-dash.ec-dash--admin .admin-esd-banner__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, rgba(15, 23, 42, 0.66), rgba(15, 23, 42, 0.2));
}

.ec-dash.ec-dash--admin .admin-esd-banner__content {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  justify-content: flex-end;
  min-height: 11rem;
  padding: 1rem 1rem 1.1rem;
  color: #fff;
}

.ec-dash.ec-dash--admin .admin-esd-banner__kicker {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.09em;
  opacity: 0.9;
}

.ec-dash.ec-dash--admin .admin-esd-banner__title {
  font-size: 1.2rem;
  font-weight: 800;
  line-height: 1.2;
}

.ec-dash.ec-dash--admin .admin-esd-banner__desc {
  font-size: 0.8rem;
  font-weight: 500;
  opacity: 0.95;
}

.ec-dash.ec-dash--admin .admin-esd-top-grid {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
  gap: 1rem;
}
@media (max-width: 900px) {
  .ec-dash.ec-dash--admin .admin-esd-top-grid {
    grid-template-columns: 1fr;
  }
}

.ec-dash.ec-dash--admin .admin-esd-visibility-card {
  height: 100%;
  min-height: 11rem;
  border: 1px solid #e2e8f0;
  border-radius: 0.75rem;
  background: #fff;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.05);
  padding: 0.95rem;
}

.ec-dash.ec-dash--admin .admin-esd-visibility-card__title {
  margin: 0 0 0.65rem;
  font-size: 0.95rem;
  font-weight: 800;
  color: #1e293b;
  display: flex;
  align-items: center;
  gap: 0.35rem;
}

.ec-dash.ec-dash--admin .admin-esd-visibility-card__title i {
  color: #64748b;
}

.ec-dash.ec-dash--admin .admin-esd-visibility-card__status {
  margin: 0 0 0.75rem;
  color: #334155;
  font-size: 0.85rem;
}

.ec-dash.ec-dash--admin .admin-esd-visibility-card__status strong {
  color: #0f172a;
  font-size: 0.95rem;
}

.ec-dash.ec-dash--admin .admin-esd-visibility-card__actions {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.ec-dash.ec-dash--admin .admin-esd-toggle-form {
  margin: 0;
}

.ec-dash.ec-dash--admin .admin-esd-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  cursor: pointer;
  user-select: none;
}

.ec-dash.ec-dash--admin .admin-esd-toggle__input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.ec-dash.ec-dash--admin .admin-esd-toggle__slider {
  position: relative;
  width: 2.9rem;
  height: 1.65rem;
  border-radius: 999px;
  background: #cbd5e1;
  transition: background-color 0.2s ease;
}

.ec-dash.ec-dash--admin .admin-esd-toggle__slider::after {
  content: "";
  position: absolute;
  top: 0.15rem;
  left: 0.15rem;
  width: 1.35rem;
  height: 1.35rem;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 4px rgba(15, 23, 42, 0.25);
  transition: transform 0.2s ease;
}

.ec-dash.ec-dash--admin .admin-esd-toggle__input:checked + .admin-esd-toggle__slider {
  background: #15803d;
}

.ec-dash.ec-dash--admin .admin-esd-toggle__input:checked + .admin-esd-toggle__slider::after {
  transform: translateX(1.25rem);
}

.ec-dash.ec-dash--admin .admin-esd-toggle__input:focus-visible + .admin-esd-toggle__slider {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
}

.ec-dash.ec-dash--admin .admin-esd-toggle__text {
  font-size: 0.86rem;
  font-weight: 700;
  color: #1e293b;
}

.ec-dash.ec-dash--admin .admin-esd-popular-list {
  display: grid;
  gap: 0.55rem;
}

.ec-dash.ec-dash--admin .admin-esd-analytics-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}
@media (max-width: 900px) {
  .ec-dash.ec-dash--admin .admin-esd-analytics-grid {
    grid-template-columns: 1fr;
  }
}

.ec-dash.ec-dash--admin .admin-esd-metric-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}
@media (max-width: 700px) {
  .ec-dash.ec-dash--admin .admin-esd-metric-grid {
    grid-template-columns: 1fr;
  }
}

.ec-dash.ec-dash--admin .admin-esd-analytics-grid__sub-title {
  margin: 0 0 0.65rem;
  font-size: 0.92rem;
  font-weight: 800;
  color: #334155;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}

.ec-dash.ec-dash--admin .admin-esd-popular-item {
  display: grid;
  grid-template-columns: 2rem 1fr auto;
  align-items: center;
  gap: 0.65rem;
  padding: 0.6rem 0.75rem;
  border: 1px solid #e2e8f0;
  border-radius: 0.65rem;
  background: #fff;
}

.ec-dash.ec-dash--admin .admin-esd-popular-item__rank {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.8rem;
  height: 1.8rem;
  border-radius: 999px;
  background: #f1f5f9;
  color: #475569;
  font-size: 0.82rem;
  font-weight: 800;
}

.ec-dash.ec-dash--admin .admin-esd-popular-item__main {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
}

.ec-dash.ec-dash--admin .admin-esd-popular-item__title {
  color: #0f172a;
  font-size: 0.9rem;
  font-weight: 700;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ec-dash.ec-dash--admin .admin-esd-popular-item__company {
  color: #64748b;
  font-size: 0.78rem;
}

.ec-dash.ec-dash--admin .admin-esd-popular-item__count {
  color: #1e293b;
  font-size: 0.84rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}

.ec-dash .ec-dash__nav-back {
  margin: 0 0 1rem;
}

.ec-dash .ec-dash__nav-back-link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: #2563eb;
  text-decoration: none;
}
.ec-dash .ec-dash__nav-back-link:hover {
  text-decoration: underline;
}
.ec-dash .ec-dash__nav-back-link:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
  border-radius: 0.25rem;
}
.ec-dash .ec-dash__nav-back-link i {
  font-size: 1rem;
  opacity: 0.85;
}

.ec-dash .ec-admin-school-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(16rem, 1fr));
  gap: 0.75rem;
}

.ec-dash.ec-dash--admin .ec-admin-school-grid {
  grid-template-columns: repeat(auto-fill, minmax(13rem, 1fr));
  gap: 1rem;
}
@media (min-width: 1000px) {
  .ec-dash.ec-dash--admin .ec-admin-school-grid {
    grid-template-columns: repeat(auto-fill, minmax(15rem, 1fr));
  }
}
@media (min-width: 1400px) {
  .ec-dash.ec-dash--admin .ec-admin-school-grid {
    grid-template-columns: repeat(auto-fill, minmax(14rem, 1fr));
  }
}

.ec-dash .ec-admin-school-card {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  padding: 1rem 1.125rem;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.ec-dash .ec-admin-school-card__name {
  font-size: 0.9375rem;
  font-weight: 700;
  color: #0f172a;
  line-height: 1.35;
}

.ec-dash .ec-admin-school-card__action {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  align-self: flex-start;
  margin-top: auto;
  padding: 0.4rem 0.65rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: #2563eb;
  text-decoration: none;
  border-radius: 0.375rem;
  border: 1px solid #e2e8f0;
  background: #f8fafc;
  transition: background 0.15s, border-color 0.15s;
}
.ec-dash .ec-admin-school-card__action .las.la-angle-right {
  margin-left: 0.15rem;
  font-size: 0.875rem;
  opacity: 0.6;
}
.ec-dash .ec-admin-school-card__action:hover {
  background: #eff6ff;
  border-color: #bfdbfe;
}
.ec-dash .ec-admin-school-card__action:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
}

.ec-dash .ec-admin-empty {
  margin: 0;
  padding: 1.25rem 1rem;
  font-size: 0.9375rem;
  color: #64748b;
  line-height: 1.55;
  background: #f8fafc;
  border: 1px dashed #cbd5e1;
  border-radius: 0.5rem;
}

.ec-dash .ec-admin-hint {
  margin: 1rem 0 0;
  padding: 0.875rem 1rem;
  font-size: 0.8125rem;
  line-height: 1.55;
  color: #475569;
  background: #fffbeb;
  border: 1px solid #fde68a;
  border-radius: 0.5rem;
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
}
.ec-dash .ec-admin-hint > i:first-child {
  flex-shrink: 0;
  margin-top: 0.1rem;
  color: #d97706;
  font-size: 1.125rem;
}

.school-dash {
  --sd-accent: #059669;
  --sd-soft: #ecfdf5;
  --sd-mid: #d1fae5;
  --sd-glow: rgba(5, 150, 105, 0.08);
  box-sizing: border-box;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  margin: 0 auto;
}
.school-dash .school-dash__hero {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.75rem;
  padding: 1.5rem 1.5rem 1.25rem;
  margin-bottom: 1.5rem;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.05);
}
.school-dash .school-dash__hero--title-only {
  padding: 1.25rem 1.5rem;
}
.school-dash .school-dash__kicker {
  margin: 0 0 0.25rem;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #64748b;
}
.school-dash .school-dash__heading {
  margin: 0 0 0.5rem;
  font-size: 1.5rem;
  font-weight: 700;
  color: #0f172a;
  line-height: 1.3;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.school-dash .school-dash__heading--plain {
  margin: 0;
  display: block;
}
.school-dash .school-dash__heading-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.5rem;
  background: var(--sd-soft);
  color: var(--sd-accent);
  font-size: 1.35rem;
  flex-shrink: 0;
}
.school-dash .school-dash__heading-text {
  min-width: 0;
}
.school-dash .school-dash__role-chip {
  display: inline-block;
  margin-left: 0.5rem;
  padding: 0.15rem 0.45rem;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  vertical-align: middle;
  border-radius: 0.25rem;
  background: var(--sd-soft);
  color: var(--sd-accent);
  border: 1px solid var(--sd-mid);
}
.school-dash .school-dash__lead {
  margin: 0 0 1.25rem;
  font-size: 0.9375rem;
  color: #475569;
  line-height: 1.55;
  max-width: 40rem;
}
.school-dash .school-dash__account {
  margin: 0;
  padding: 1rem 0 0;
  border-top: 1px solid #e2e8f0;
  display: grid;
  gap: 0.5rem 1.5rem;
  grid-template-columns: repeat(auto-fill, minmax(12rem, 1fr));
}
.school-dash .school-dash__account-row {
  margin: 0;
  display: grid;
  gap: 0.125rem;
}
.school-dash .school-dash__account-row dt {
  margin: 0;
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: #94a3b8;
}
.school-dash .school-dash__account-row .school-dash__account-dt-inner {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}
.school-dash .school-dash__account-row .school-dash__account-dt-inner i {
  font-size: 0.875rem;
  color: #cbd5e1;
}
.school-dash .school-dash__account-row dd {
  margin: 0;
  font-size: 0.875rem;
  color: #334155;
  word-break: break-all;
}
.school-dash .school-dash__stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
  margin-bottom: 1.5rem;
}
@media (max-width: 520px) {
  .school-dash .school-dash__stats {
    grid-template-columns: 1fr;
  }
}
.school-dash .school-dash__stats--single {
  grid-template-columns: 1fr;
  max-width: 22rem;
}
.school-dash .school-dash__stat {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.65rem;
  padding: 1rem 1.125rem;
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: auto auto;
  column-gap: 0.75rem;
  row-gap: 0.125rem;
  align-items: start;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}
.school-dash .school-dash__stat-icon {
  grid-row: 1/-1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  margin-top: 0.125rem;
  border-radius: 0.5rem;
  background: var(--sd-mid);
  color: var(--sd-accent);
  font-size: 1.25rem;
}
.school-dash .school-dash__stat-value {
  grid-column: 2;
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--sd-accent);
  line-height: 1.1;
  font-variant-numeric: tabular-nums;
}
.school-dash .school-dash__stat-label {
  grid-column: 2;
  font-size: 0.8125rem;
  font-weight: 500;
  color: #475569;
  line-height: 1.35;
}
.school-dash .school-dash__stat-hint {
  font-weight: 400;
  font-size: 0.75rem;
  color: #94a3b8;
}
.school-dash .school-dash__menu {
  margin-bottom: 2rem;
}
.school-dash .school-dash__section-title {
  margin: 0 0 0.75rem;
  font-size: 0.8125rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #64748b;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.school-dash .school-dash__section-title i {
  font-size: 1.125rem;
  color: #94a3b8;
}
.school-dash .school-dash__section-title--inline {
  margin-bottom: 0;
}
.school-dash .school-dash__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(15.5rem, 1fr));
  gap: 0.75rem;
}
.school-dash .school-card {
  position: relative;
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 1rem 2.25rem 1rem 1rem;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.65rem;
  text-decoration: none;
  color: inherit;
  transition: border-color 0.15s, box-shadow 0.15s;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
  min-height: 5.5rem;
}
.school-dash .school-card:hover {
  border-color: var(--sd-mid);
  box-shadow: 0 4px 14px var(--sd-glow);
}
.school-dash .school-card:hover .school-card__icon {
  background: var(--sd-soft);
  color: var(--sd-accent);
}
.school-dash .school-card:focus-visible {
  outline: 2px solid var(--sd-accent);
  outline-offset: 2px;
}
.school-dash .school-card--accent .school-card__icon {
  background: #fffbeb;
  color: #d97706;
}
.school-dash .school-card--accent:hover .school-card__icon {
  background: #fef3c7;
  color: #b45309;
}
.school-dash .school-card__icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  margin-top: 0.0625rem;
  border-radius: 0.5rem;
  background: #f1f5f9;
  color: #64748b;
  font-size: 1.25rem;
  transition: background 0.15s, color 0.15s;
}
.school-dash .school-card__body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}
.school-dash .school-card__title {
  font-size: 0.9375rem;
  font-weight: 700;
  color: #0f172a;
}
.school-dash .school-card__desc {
  font-size: 0.8125rem;
  color: #64748b;
  line-height: 1.45;
}
.school-dash .school-card__go {
  position: absolute;
  right: 0.65rem;
  top: 50%;
  transform: translateY(-50%);
  opacity: 0.4;
  font-size: 1.25rem;
  color: #64748b;
  line-height: 1;
  transition: opacity 0.15s, transform 0.15s, color 0.15s;
  pointer-events: none;
}
.school-dash .school-card__go i {
  display: block;
}
.school-dash .school-card:hover .school-card__go {
  opacity: 0.95;
  color: var(--sd-accent);
  transform: translateY(-50%) translateX(2px);
}
.school-dash .school-dash__recent {
  margin-bottom: 1rem;
}
.school-dash .school-dash__recent-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem 1rem;
  margin-bottom: 0.65rem;
}
.school-dash .school-dash__recent-all {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--sd-accent);
  text-decoration: none;
}
.school-dash .school-dash__recent-all:hover {
  text-decoration: underline;
}
.school-dash .school-dash__recent-list {
  list-style: none;
  margin: 0;
  padding: 0;
  border: 1px solid #e2e8f0;
  border-radius: 0.65rem;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}
.school-dash .school-dash__recent-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.85rem 1rem;
  text-decoration: none;
  color: inherit;
  border-bottom: 1px solid #f1f5f9;
  transition: background 0.12s;
}
.school-dash .school-dash__recent-item:last-child {
  border-bottom: none;
}
.school-dash .school-dash__recent-item:hover {
  background: #f8fafc;
}
.school-dash .school-dash__recent-item:focus-visible {
  outline: 2px solid var(--sd-accent);
  outline-offset: -2px;
}
.school-dash .school-dash__recent-main {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  min-width: 0;
}
.school-dash .school-dash__recent-org {
  font-size: 0.9375rem;
  font-weight: 600;
  color: #0f172a;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.school-dash .school-dash__recent-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.8125rem;
  color: #64748b;
}
.school-dash .school-dash__recent-badge {
  display: inline-block;
  padding: 0.12rem 0.4rem;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--sd-accent);
  background: var(--sd-soft);
  border-radius: 0.25rem;
}
.school-dash .school-dash__recent-go {
  flex-shrink: 0;
  opacity: 0.45;
  color: #64748b;
  font-size: 1.15rem;
}
.school-dash .school-dash__recent-item:hover .school-dash__recent-go {
  opacity: 0.9;
  color: var(--sd-accent);
}
.school-dash .school-dash__sched {
  margin-bottom: 1.75rem;
}
.school-dash .school-dash__sched-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem 1rem;
  margin-bottom: 0.75rem;
}
.school-dash .school-dash__sched-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.75rem;
}
.school-dash .school-dash__sched-link {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--sd-accent);
  text-decoration: none;
  padding: 0.25rem 0.5rem;
  border-radius: 0.35rem;
  border: 1px solid var(--sd-mid);
  background: #fff;
  transition: border-color 0.12s, background 0.12s;
}
.school-dash .school-dash__sched-link:hover {
  text-decoration: none;
  background: var(--sd-soft);
  border-color: var(--sd-accent);
}
.school-dash .school-dash__sched-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem 1.25rem;
}
@media (max-width: 640px) {
  .school-dash .school-dash__sched-grid {
    grid-template-columns: 1fr;
  }
}
.school-dash .school-dash__sched-col {
  min-width: 0;
  padding: 1rem 1.1rem;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.65rem;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}
.school-dash .school-dash__sched-subhead {
  margin: 0 0 0.65rem;
  font-size: 0.8125rem;
  font-weight: 700;
  color: #334155;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.school-dash .school-dash__sched-subhead i {
  font-size: 1.05rem;
  color: var(--sd-accent);
}
.school-dash .school-dash__sched-day {
  margin-bottom: 0.85rem;
}
.school-dash .school-dash__sched-day:last-child {
  margin-bottom: 0;
}
.school-dash .school-dash__sched-day-label {
  margin: 0 0 0.35rem;
  font-size: 0.75rem;
  font-weight: 700;
  color: #64748b;
  letter-spacing: 0.02em;
}
.school-dash .school-dash__sched-day-label time {
  font-variant-numeric: tabular-nums;
}
.school-dash .school-dash__sched-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.school-dash .school-dash__sched-list--nested {
  margin-left: 0;
  padding-left: 0;
}
.school-dash .school-dash__sched-item {
  padding: 0.45rem 0;
  border-bottom: 1px solid #f1f5f9;
  font-size: 0.875rem;
  line-height: 1.45;
  color: #0f172a;
}
.school-dash .school-dash__sched-item:last-child {
  border-bottom: none;
}
.school-dash .school-dash__sched-item-title {
  font-weight: 600;
}
.school-dash .school-dash__sched-empty {
  margin: 0;
  font-size: 0.8125rem;
  color: #94a3b8;
  line-height: 1.5;
}
.school-dash .school-dash__notice,
.school-dash .school-dash__panel {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.65rem;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}
.school-dash .school-dash__notice {
  margin-bottom: 1rem;
  padding: 1rem 1.1rem;
}
.school-dash .school-dash__notice-head,
.school-dash .school-dash__panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.65rem;
}
.school-dash .school-dash__notice-all,
.school-dash .school-dash__panel-link {
  color: var(--sd-accent);
  font-size: 0.8125rem;
  font-weight: 600;
  text-decoration: none;
}
.school-dash .school-dash__notice-all:hover,
.school-dash .school-dash__panel-link:hover {
  text-decoration: underline;
}
.school-dash .school-dash__panel-links {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
}
.school-dash .school-dash__notice-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.5rem;
}
.school-dash .school-dash__notice-item {
  display: block;
  padding: 0.55rem 0.65rem;
  border: 1px solid #e2e8f0;
  border-radius: 0.45rem;
  text-decoration: none;
  color: inherit;
  background: #fff;
}
.school-dash .school-dash__notice-title {
  display: block;
  font-size: 0.875rem;
  font-weight: 600;
  color: #0f172a;
  margin-bottom: 0.2rem;
}
.school-dash .school-dash__notice-meta {
  display: flex;
  justify-content: space-between;
  gap: 0.5rem;
  font-size: 0.75rem;
  color: #64748b;
}
.school-dash .school-dash__notice-empty,
.school-dash .school-dash__panel-empty {
  margin: 0;
  font-size: 0.85rem;
  color: #94a3b8;
}
.school-dash .school-dash__row {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -0.4rem;
}
.school-dash .school-dash__col {
  flex: 0 0 50%;
  max-width: 50%;
  padding: 0 0.4rem;
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
  margin-bottom: 0.8rem;
}
@media (max-width: 900px) {
  .school-dash .school-dash__col {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
.school-dash .school-dash__panel {
  padding: 1rem 1.1rem;
}
.school-dash .school-dash__simple-list {
  margin: 0;
  padding-left: 1.15rem;
  display: grid;
  gap: 0.25rem;
  font-size: 0.875rem;
  color: #0f172a;
}
.school-dash .school-dash__simple-list--nested {
  font-size: 0.8125rem;
  margin-top: 0.2rem;
}
.school-dash .school-dash__month-list {
  max-height: 36rem;
  overflow: auto;
  padding-right: 0.3rem;
  display: grid;
  gap: 0.4rem;
}
.school-dash .school-dash__month-row {
  display: grid;
  grid-template-columns: 6.2rem 1fr;
  align-items: start;
  gap: 0.6rem;
  padding: 0.45rem 0.6rem;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  background: #fff;
}
.school-dash .school-dash__month-date {
  margin: 0;
  font-size: 0.78rem;
  font-weight: 700;
  color: #334155;
  line-height: 1.4;
}
.school-dash .school-dash__month-date--placeholder {
  visibility: hidden;
}
.school-dash .school-dash__month-date-main {
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
}
.school-dash .school-dash__month-date-sub {
  color: #64748b;
  font-size: 0.74rem;
  margin-left: 0.15rem;
}
.school-dash .school-dash__month-title {
  margin: 0;
  font-size: 0.82rem;
  color: #0f172a;
  line-height: 1.45;
  word-break: break-word;
}
.school-dash .school-dash__menu-grid {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -0.35rem;
}
.school-dash .school-dash__menu-grid > .col-3 {
  flex: 0 0 25%;
  max-width: 25%;
  padding: 0.35rem;
}
@media (max-width: 900px) {
  .school-dash .school-dash__menu-grid > .col-3 {
    flex: 0 0 33.3333%;
    max-width: 33.3333%;
  }
}
@media (max-width: 640px) {
  .school-dash .school-dash__menu-grid > .col-3 {
    flex: 0 0 50%;
    max-width: 50%;
  }
}
.school-dash .school-dash__menu-tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  min-height: 5.2rem;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  text-decoration: none;
  color: #334155;
  background: #fff;
  text-align: center;
  padding: 0.4rem;
}
.school-dash .school-dash__menu-tile i {
  font-size: 1.7rem;
  color: var(--sd-accent);
}
.school-dash .school-dash__menu-tile span {
  font-size: 0.72rem;
  font-weight: 700;
  line-height: 1.3;
}
.school-dash .school-dash__esd-banner {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 0.25rem;
  min-height: 8.2rem;
  border-radius: 0.65rem;
  overflow: hidden;
  padding: 1rem 1rem 0.95rem;
  text-decoration: none;
  color: #fff;
  background-size: cover;
  background-position: center;
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.18);
}
.school-dash .school-dash__esd-banner-title {
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  line-height: 1.2;
}
.school-dash .school-dash__esd-banner-sub {
  font-size: 0.78rem;
  line-height: 1.4;
  opacity: 0.96;
}

.school-portal.school-portal--vice .school-dash {
  --sd-accent: #4f46e5;
  --sd-soft: #eef2ff;
  --sd-mid: #e0e7ff;
  --sd-glow: rgba(79, 70, 229, 0.12);
}

.school-portal.school-portal--temp .school-dash {
  --sd-accent: #c2410c;
  --sd-soft: #fff7ed;
  --sd-mid: #ffedd5;
  --sd-glow: rgba(194, 65, 12, 0.12);
}

.school-portal {
  --portal-accent: #059669;
  --portal-accent-hover: #047857;
  --portal-accent-heading: #047857;
  --portal-soft: #ecfdf5;
  --portal-mid: #d1fae5;
  --portal-badge-border: #a7f3d0;
  --portal-focus-ring: rgba(5, 150, 105, 0.18);
  box-sizing: border-box;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  margin: 0 auto;
  padding-bottom: 1.5rem;
}
.school-portal--dashboard {
  max-width: none;
  width: 100%;
  padding-bottom: 0;
}
.school-portal--dashboard .school-dash {
  width: 100%;
  min-width: 0;
  max-width: 100%;
  margin: 0 auto;
}
.school-portal .school-portal__masthead {
  margin-bottom: 1.35rem;
}
.school-portal .school-portal__back {
  margin: 0 0 0.5rem;
}
.school-portal .school-portal__back-link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--portal-accent);
  text-decoration: none;
}
.school-portal .school-portal__back-link i {
  font-size: 1.1rem;
  opacity: 0.9;
}
.school-portal .school-portal__back-link:hover {
  color: var(--portal-accent-hover);
  text-decoration: underline;
}
.school-portal .school-portal__title {
  margin: 0 0 0.35rem;
  font-size: clamp(1.2rem, 2.5vw, 1.45rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #0f172a;
  line-height: 1.3;
}
.school-portal .school-portal__lead {
  margin: 0;
  font-size: 0.9375rem;
  color: #64748b;
  line-height: 1.55;
  max-width: 42rem;
}
.school-portal .school-portal__toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem 1rem;
  margin-bottom: 1rem;
}
.school-portal .school-portal__panel {
  padding: 1.15rem 1.25rem 1.25rem;
  margin-bottom: 1.25rem;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.04);
}
.school-portal .school-portal__section-title {
  margin: 0 0 0.65rem;
  font-size: 1rem;
  font-weight: 700;
  color: #0f172a;
  display: flex;
  align-items: center;
  gap: 0.4rem;
  flex-wrap: wrap;
}
.school-portal .school-portal__section-title i {
  color: var(--portal-accent);
  font-size: 1.15rem;
}
.school-portal .school-portal__section-title--spaced {
  margin-top: 1.5rem;
}
.school-portal .school-portal__muted {
  margin: 0;
  font-size: 0.875rem;
  color: #64748b;
  line-height: 1.55;
}
.school-portal .school-portal__table-wrap {
  overflow-x: auto;
  margin-bottom: 0.25rem;
  border-radius: 0.65rem;
  border: 1px solid #e2e8f0;
  background: #fff;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.04);
}
.school-portal .school-portal__table {
  width: 100%;
  min-width: 36rem;
  border-collapse: collapse;
  font-size: 0.875rem;
}
.school-portal .school-portal__table--fit {
  min-width: 0;
}
.school-portal .school-portal__table th,
.school-portal .school-portal__table td {
  padding: 0.75rem 1rem;
  text-align: left;
  border-bottom: 1px solid #f1f5f9;
  vertical-align: middle;
}
.school-portal .school-portal__table th {
  background: var(--portal-soft);
  font-weight: 700;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--portal-accent-heading);
}
.school-portal .school-portal__table tbody tr:last-child td {
  border-bottom: none;
}
.school-portal .school-portal__table tbody tr:hover td {
  background: #f8fafc;
}
.school-portal .school-portal__cell-tags {
  max-width: 14rem;
  vertical-align: middle;
}
.school-portal .esd-program-tags--compact .esd-program-tags__pill {
  font-size: 0.62rem;
  padding: 0.08rem 0.32rem 0.08rem 0.26rem;
}
.school-portal .esd-program-tags--compact .esd-program-tags__icon {
  font-size: 0.72rem;
}
.school-portal .school-portal__thumb {
  width: 1%;
  white-space: nowrap;
}
.school-portal .school-portal__thumb .esd-cover {
  border-radius: 0.375rem;
}
.school-portal .school-portal__cell-title {
  font-weight: 600;
  color: #0f172a;
}
.school-portal .school-portal__cell-muted {
  color: #64748b;
  font-size: 0.8125rem;
  line-height: 1.45;
  max-width: 22rem;
}
.school-portal .school-portal__row-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 0.75rem;
}
.school-portal .school-portal__btn-compact {
  padding: 0.35rem 0.65rem !important;
  font-size: 0.8125rem !important;
}
.school-portal .school-portal__cell-empty {
  padding: 1.5rem 1rem !important;
  text-align: center;
  color: #64748b;
  font-size: 0.9375rem;
  line-height: 1.5;
  background: #fafafa;
}
.school-portal .school-portal__link {
  font-weight: 600;
  color: var(--portal-accent);
  text-decoration: none;
  font-size: 0.875rem;
}
.school-portal .school-portal__link:hover {
  color: var(--portal-accent-hover);
  text-decoration: underline;
}
.school-portal .school-portal__link--image {
  display: inline-block;
  line-height: 0;
  text-decoration: none;
}
.school-portal .school-portal__link--image:hover {
  text-decoration: none;
}
.school-portal .school-portal__link--image .esd-cover {
  transition: opacity 0.15s ease, box-shadow 0.15s ease;
}
.school-portal .school-portal__link--image:hover .esd-cover {
  opacity: 0.92;
  box-shadow: 0 0 0 2px var(--portal-accent);
}
.school-portal .school-portal__empty {
  margin: 0;
  padding: 1.25rem 1rem;
  text-align: center;
  color: #64748b;
  font-size: 0.9375rem;
  background: #f8fafc;
  border-radius: 0.5rem;
  border: 1px dashed #cbd5e1;
}
.school-portal .btn--primary {
  background: var(--portal-accent);
  border-color: var(--portal-accent-hover);
  color: #fff;
}
.school-portal .btn--primary:hover {
  background: var(--portal-accent-hover);
}
.school-portal .btn--secondary {
  border-color: #94a3b8;
}
.school-portal .btn--secondary:hover {
  border-color: #64748b;
}
.school-portal .school-portal__form {
  max-width: 36rem;
}
.school-portal .school-portal__form.school-portal__form--wide {
  max-width: 42rem;
}
.school-portal .page-user-form {
  max-width: 42rem;
}
.school-portal .school-portal__form .field,
.school-portal .page-user-form .field {
  margin-bottom: 1rem;
}
.school-portal .school-portal__form .field label,
.school-portal .page-user-form .field label {
  display: block;
  margin-bottom: 0.35rem;
  font-weight: 600;
  font-size: 0.8125rem;
  color: #334155;
}
.school-portal .school-portal__form .field input[type=email],
.school-portal .school-portal__form .field input[type=text],
.school-portal .school-portal__form .field input[type=tel],
.school-portal .school-portal__form .field textarea,
.school-portal .school-portal__form .field select,
.school-portal .page-user-form .field input[type=email],
.school-portal .page-user-form .field input[type=text],
.school-portal .page-user-form .field input[type=tel],
.school-portal .page-user-form .field textarea,
.school-portal .page-user-form .field select {
  width: 100%;
  padding: 0.55rem 0.75rem;
  border: 1px solid #cbd5e1;
  border-radius: 0.5rem;
  font-size: 0.9375rem;
  background: #fff;
  box-sizing: border-box;
}
.school-portal .school-portal__form .field input[type=email]:focus,
.school-portal .school-portal__form .field input[type=text]:focus,
.school-portal .school-portal__form .field input[type=tel]:focus,
.school-portal .school-portal__form .field textarea:focus,
.school-portal .school-portal__form .field select:focus,
.school-portal .page-user-form .field input[type=email]:focus,
.school-portal .page-user-form .field input[type=text]:focus,
.school-portal .page-user-form .field input[type=tel]:focus,
.school-portal .page-user-form .field textarea:focus,
.school-portal .page-user-form .field select:focus {
  outline: none;
  border-color: var(--portal-accent);
  box-shadow: 0 0 0 3px var(--portal-focus-ring);
}
.school-portal .school-portal__form .field textarea,
.school-portal .page-user-form .field textarea {
  resize: vertical;
  min-height: 7rem;
  line-height: 1.55;
}
.school-portal .school-portal__form .actions,
.school-portal .page-user-form .actions {
  margin-top: 1.25rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  align-items: center;
}
.school-portal .file-drop-zone.is-dragover {
  border-color: var(--portal-accent);
  background: var(--portal-soft);
}
.school-portal .school-portal__cover {
  margin-bottom: 1.25rem;
  border-radius: 0.65rem;
  overflow: hidden;
  border: 1px solid #e2e8f0;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.06);
}
.school-portal .school-portal__cover .esd-cover--school-show {
  max-width: none;
  width: 100%;
  height: min(40vw, 280px);
  min-height: 160px;
  margin: 0;
  border-radius: 0;
}
.school-portal .school-portal__cover .esd-cover__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.school-portal .school-portal__body-text {
  margin: 0;
  font-size: 0.9375rem;
  color: #334155;
  line-height: 1.65;
}
.school-portal .school-portal__body-text p {
  margin: 0 0 0.65rem;
}
.school-portal .school-portal__body-text p:last-child {
  margin-bottom: 0;
}
.school-portal .school-portal__contact-sep {
  color: #cbd5e1;
  font-weight: 400;
}
.school-portal .school-portal__contact-line {
  margin: 1rem 0 0;
  padding-top: 1rem;
  border-top: 1px solid #f1f5f9;
  font-size: 0.875rem;
  color: #475569;
  line-height: 1.6;
}
.school-portal .school-portal__contact-line--block {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.5rem;
}
.school-portal .school-portal__contact-line__row {
  display: block;
  width: 100%;
}
.school-portal .school-portal__program-cards {
  display: flex;
  flex-wrap: wrap;
  margin-top: 0.35rem;
}
.school-portal .school-portal__program-cards.row > .col-3 {
  flex: 0 0 100%;
  max-width: 100%;
  padding-left: 0.75rem;
  padding-right: 0.75rem;
  margin-bottom: 1rem;
  box-sizing: border-box;
  display: flex;
}
@media (min-width: 640px) {
  .school-portal .school-portal__program-cards.row > .col-3 {
    flex: 0 0 50%;
    max-width: 50%;
  }
}
@media (min-width: 992px) {
  .school-portal .school-portal__program-cards.row > .col-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
}
.school-portal .school-portal__program-card {
  margin: 0;
  width: 100%;
}
.school-portal .school-portal__program-card-org {
  margin: 0;
  display: flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.75rem;
  font-weight: 600;
  color: #64748b;
  line-height: 1.3;
}
.school-portal .school-portal__program-card-org i {
  font-size: 1rem;
  color: #94a3b8;
}
.school-portal .school-portal__program-card-org-link {
  font-weight: 600;
}
.school-portal .school-portal__program-card-title-link {
  color: inherit;
  font: inherit;
  text-decoration: none;
  letter-spacing: inherit;
}
.school-portal .school-portal__program-card-title-link:hover {
  color: var(--portal-accent);
  text-decoration: underline;
}
.school-portal .school-portal__program-card-title-link:focus-visible {
  outline: 2px solid var(--portal-accent);
  outline-offset: 2px;
  border-radius: 2px;
}
.school-portal .school-portal__program-card-cta {
  margin-top: auto;
  padding-top: 0.65rem;
  border-top: 1px solid #e2e8f0;
}
.school-portal .school-portal__program-card-cta .school-portal__link--cta {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.875rem;
}
.school-portal .school-program-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}
.school-portal .school-program-card {
  border: 1px solid #e2e8f0;
  border-radius: 0.65rem;
  padding: 1.15rem 1.25rem 1.2rem;
  background: #fff;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
}
.school-portal .school-program-card__head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.35rem 0.5rem;
  margin-bottom: 0;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid #f1f5f9;
}
.school-portal .school-program-card__title {
  margin: 0;
  font-size: 1.0625rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #0f172a;
  line-height: 1.35;
}
.school-portal .school-program-card__tag {
  display: inline-block;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  background: #e0f2fe;
  color: #0369a1;
  padding: 0.2rem 0.45rem;
  border-radius: 0.25rem;
}
.school-portal .school-program-card__tag--empty {
  color: #94a3b8;
  background: #f1f5f9;
  font-weight: 600;
  letter-spacing: normal;
  text-transform: none;
}
.school-portal .school-program-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem;
  align-items: center;
}
.school-portal .school-program-card__block {
  margin-top: 1rem;
}
.school-portal .school-program-card__head + .school-portal .school-program-card__block {
  margin-top: 0.85rem;
}
.school-portal .school-program-card__block-label {
  margin: 0 0 0.4rem;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #64748b;
}
.school-portal .school-program-card__sum {
  margin: 0;
  font-size: 0.9375rem;
  color: #334155;
  line-height: 1.6;
}
.school-portal .school-program-card__body {
  margin: 0;
  font-size: 0.875rem;
  color: #334155;
  line-height: 1.65;
}
.school-portal .school-program-card__body p {
  margin: 0 0 0.5rem;
  font-size: inherit;
}
.school-portal .school-program-card__body p:last-child {
  margin-bottom: 0;
}
.school-portal .school-program-card__logistics {
  margin: 1rem 0 0;
  padding: 0.85rem 1rem;
  background: #f8fafc;
  border: 1px solid #e8edf3;
  border-radius: 0.5rem;
}
.school-portal .school-program-card__logistics-title {
  margin: 0 0 0.65rem;
  font-size: 0.8125rem;
  font-weight: 700;
  color: #0f172a;
  letter-spacing: 0.02em;
  text-transform: none;
}
.school-portal .school-program-card__logistics-dl {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.school-portal .school-program-card__logistics-pair {
  display: grid;
  grid-template-columns: minmax(0, max-content) minmax(0, 1fr);
  column-gap: 1rem;
  row-gap: 0.15rem;
  padding: 0.5rem 0;
  border-bottom: 1px solid #eef2f7;
  font-size: 0.8125rem;
  color: #334155;
  align-items: start;
}
.school-portal .school-program-card__logistics-pair:last-child {
  border-bottom: none;
  padding-bottom: 0;
}
.school-portal .school-program-card__logistics-pair:first-child {
  padding-top: 0;
}
.school-portal .school-program-card__logistics-dt {
  margin: 0;
  font-weight: 600;
  color: #475569;
  font-size: 0.8125rem;
}
.school-portal .school-program-card__logistics-dd {
  margin: 0;
  line-height: 1.55;
  word-break: break-word;
  color: #1e293b;
}
.school-portal .school-program-card__logistics-dd p {
  margin: 0 0 0.35em;
  font-size: inherit;
}
.school-portal .school-program-card__logistics-dd p:last-child {
  margin-bottom: 0;
}
.school-portal .school-program-card__logistics-dd .esd-program-logistics__dash {
  color: #94a3b8;
  font-weight: 600;
}
.school-portal .school-portal__dash {
  margin: 0;
  color: #94a3b8;
  font-weight: 600;
}
.school-portal .school-msg-thread {
  list-style: none;
  margin: 0 0 1.25rem;
  padding: 0;
  border: 1px solid #e2e8f0;
  border-radius: 0.65rem;
  overflow: hidden;
  background: #fff;
  max-height: min(55vh, 28rem);
  overflow-y: auto;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.04);
}
.school-portal .school-msg-thread__item {
  padding: 0.85rem 1rem;
  border-bottom: 1px solid #f1f5f9;
}
.school-portal .school-msg-thread__item:last-child {
  border-bottom: none;
}
.school-portal .school-msg-thread__meta {
  font-size: 0.75rem;
  font-weight: 600;
  color: #64748b;
  margin-bottom: 0.35rem;
}
.school-portal .school-msg-thread__body {
  font-size: 0.9375rem;
  color: #1e293b;
  line-height: 1.6;
  white-space: pre-wrap;
}
.school-portal .school-portal__status-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem 1rem;
  margin-bottom: 1rem;
}
.school-portal .school-portal__badge {
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.55rem;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  border-radius: 0.35rem;
  background: var(--portal-soft);
  color: var(--portal-accent-hover);
  border: 1px solid var(--portal-badge-border);
}
.school-portal .school-portal__esd-unread-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.35rem;
  padding: 0.15rem 0.45rem;
  font-size: 0.6875rem;
  font-weight: 800;
  line-height: 1.25;
  border-radius: 999px;
  background: #dc2626;
  color: #fff;
}
.school-portal .school-portal__hint {
  margin: 0.5rem 0 0;
  font-size: 0.8125rem;
  color: #64748b;
}
.school-portal .school-portal__link-row {
  margin: 0 0 1rem;
}
.school-portal .school-portal__spaced-below {
  margin-bottom: 1rem;
}
.school-portal .school-portal__inline-form {
  display: inline-block;
  margin: 0;
}
.school-portal .school-portal__inline-form .btn {
  margin: 0;
}
.school-portal--esd-company-show .school-portal__cover {
  margin-bottom: 1.25rem;
}
.school-portal--esd-company-show .school-portal__panel--esd-co-intro {
  background: transparent;
  border: none;
  border-radius: 0;
  box-shadow: none;
}
.school-portal--esd-company-show .school-portal__panel--esd-co-programs {
  background: transparent;
  border: none;
  border-radius: 0;
  box-shadow: none;
}
.school-portal--esd-company-show .school-portal__section-title--spaced {
  margin-top: 1.75rem;
  margin-bottom: 0.85rem;
}
.school-portal--esd-company-show .school-portal__inquiry-cta {
  margin-top: 1.25rem;
  margin-bottom: 0.5rem;
  text-align: center;
}
.school-portal--esd-company-show .school-portal__inquiry-cta-form {
  display: inline-block;
  margin: 0;
  vertical-align: middle;
}
.school-portal--esd-company-show .school-portal__inquiry-cta-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: min(100%, 18rem);
  padding: 0.65rem 1.35rem;
  font-size: 0.9375rem;
  font-weight: 700;
}
.school-portal--esd-company-show .school-portal__inquiry-cta-inner {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
}
.school-portal--esd-program-show .school-portal__cover--program-photo {
  margin-bottom: 1rem;
}
.school-portal--esd-program-show .school-portal__section-title--compact {
  font-size: 1.0625rem;
  margin-bottom: 0.55rem;
}
.school-portal--esd-program-show .school-portal__section-title--compact i {
  font-size: 1.15rem;
}
.school-portal--esd-program-show .school-portal__body-text--tight-top {
  margin-top: 0.75rem;
}
.school-portal--esd-program-show .school-portal__program-extra-photos {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-bottom: 1.25rem;
}
.school-portal--esd-program-show .school-portal__program-extra-photo {
  margin: 0;
  border-radius: 0.65rem;
  overflow: hidden;
  border: 1px solid #e2e8f0;
  background: #fff;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.04);
}
.school-portal--esd-program-show .school-portal__program-extra-photo__img {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: middle;
}
.school-portal--esd-program-show .school-portal__meta-dd-link {
  font-size: inherit;
  font-weight: 700;
}
.school-portal--esd-program-show .school-portal__panel--surface-none {
  background: transparent;
  border: none;
  box-shadow: none;
}
.school-portal--esd-program-show .school-portal__panel--program-logistics {
  padding-top: 1rem;
  padding-bottom: 1rem;
}
.school-portal--esd-program-show .school-portal__panel--program-logistics .school-portal__table-wrap--program-logistics {
  margin-bottom: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}
.school-portal--esd-program-show .school-portal__table--program-logistics {
  min-width: 0;
}
.school-portal--esd-program-show .school-portal__table--program-logistics th {
  width: 20%;
  box-sizing: border-box;
  background: transparent;
  font-weight: 700;
  font-size: 0.8125rem;
  text-transform: none;
  letter-spacing: normal;
  color: #475569;
  vertical-align: top;
}
.school-portal--esd-program-show .school-portal__table--program-logistics td {
  width: 80%;
  box-sizing: border-box;
  vertical-align: top;
}
.school-portal--esd-program-show .school-portal__table--program-logistics tbody tr:hover td {
  background: transparent;
}
.school-portal--esd-program-show .school-portal__table--program-logistics tbody tr:last-child th,
.school-portal--esd-program-show .school-portal__table--program-logistics tbody tr:last-child td {
  border-bottom: none;
}
.school-portal--esd-program-show .school-portal__program-footer-links {
  margin: 0 0 1.25rem;
  font-size: 0.875rem;
  color: #64748b;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
}
.school-portal--esd-program-show .school-portal__program-inquiry-form {
  display: inline;
  margin: 0;
}
.school-portal--esd-program-show .school-portal__program-inquiry-submit {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0;
  border: none;
  background: none;
  font: inherit;
  cursor: pointer;
  color: var(--portal-accent);
  font-weight: 600;
  font-size: 0.875rem;
  text-decoration: none;
}
.school-portal--esd-program-show .school-portal__program-inquiry-submit:hover {
  color: var(--portal-accent-hover);
  text-decoration: underline;
}
.school-portal--esd-program-show .school-portal__program-inquiry-submit:focus-visible {
  outline: 2px solid var(--portal-accent);
  outline-offset: 2px;
  border-radius: 2px;
}
.school-portal--esd-program-show .school-portal__program-footer-links__sep {
  color: #cbd5e1;
  user-select: none;
}
.school-portal--esd-program-show .school-portal__link--with-icon {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}
.school-portal--esd-program-show .esd-program-sdg-badges--detail {
  flex-wrap: wrap;
}
.school-portal--esd-msg-show .school-esd-msg-layout.row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 0 1rem;
  margin: 0 -0.25rem 1rem;
}
.school-portal--esd-msg-show .school-esd-msg-layout.row > .col-8 {
  flex: 1 1 calc(66.666% - 0.5rem);
  min-width: min(100%, 17rem);
  max-width: 100%;
  padding: 0 0.25rem;
  box-sizing: border-box;
}
.school-portal--esd-msg-show .school-esd-msg-layout.row > .col-4 {
  flex: 1 1 calc(33.333% - 0.5rem);
  min-width: min(100%, 14rem);
  max-width: 100%;
  padding: 0 0.25rem;
  box-sizing: border-box;
}
@media (max-width: 767px) {
  .school-portal--esd-msg-show .school-esd-msg-layout.row > .col-8,
  .school-portal--esd-msg-show .school-esd-msg-layout.row > .col-4 {
    flex: 1 1 100%;
    max-width: 100%;
  }
}
.school-portal--esd-msg-show .school-esd-msg-layout__main {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  min-width: 0;
}
.school-portal--esd-msg-show .school-esd-msg-stream {
  border: 1px solid #e2e8f0;
  border-radius: 0.65rem;
  background: #f8fafc;
  padding: 0.85rem 0.75rem;
  max-height: min(58vh, 30rem);
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}
.school-portal--esd-msg-show .school-esd-msg-daysep {
  display: flex;
  justify-content: center;
  width: 100%;
  margin: 0.45rem 0 0.35rem;
  flex-shrink: 0;
}
.school-portal--esd-msg-show .school-esd-msg-daysep__text {
  display: inline-block;
  padding: 0.2rem 0.65rem;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: #64748b;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 999px;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}
.school-portal--esd-msg-show .school-esd-msg-bubble-wrap {
  display: flex;
  width: 100%;
}
.school-portal--esd-msg-show .school-esd-msg-bubble-wrap.is-mine {
  justify-content: flex-end;
}
.school-portal--esd-msg-show .school-esd-msg-bubble-wrap.is-theirs {
  justify-content: flex-start;
}
.school-portal--esd-msg-show .school-esd-msg-stack {
  display: flex;
  flex-direction: column;
  gap: 0.28rem;
  max-width: min(100%, 26rem);
  min-width: 0;
}
.school-portal--esd-msg-show .is-mine .school-esd-msg-stack {
  align-items: flex-end;
}
.school-portal--esd-msg-show .is-theirs .school-esd-msg-stack {
  align-items: flex-start;
}
.school-portal--esd-msg-show .school-esd-msg-bubble {
  width: 100%;
  max-width: min(100%, 26rem);
  border-radius: 1rem;
  padding: 0.55rem 0.75rem 0.45rem;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
}
.school-portal--esd-msg-show .is-theirs .school-esd-msg-bubble {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-bottom-left-radius: 0.25rem;
}
.school-portal--esd-msg-show .is-mine .school-esd-msg-bubble {
  background: var(--portal-mid);
  border: 1px solid var(--portal-badge-border);
  border-bottom-right-radius: 0.25rem;
}
.school-portal--esd-msg-show .school-esd-msg-bubble__body {
  margin: 0;
  font-size: 0.9375rem;
  line-height: 1.55;
  color: #0f172a;
  white-space: pre-wrap;
  word-break: break-word;
}
.school-portal--esd-msg-show .school-esd-msg-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.35rem;
  padding: 0 0.2rem;
  max-width: min(100%, 26rem);
}
.school-portal--esd-msg-show .is-mine .school-esd-msg-meta {
  justify-content: flex-end;
}
.school-portal--esd-msg-show .is-theirs .school-esd-msg-meta {
  justify-content: flex-start;
}
.school-portal--esd-msg-show .school-esd-msg-meta__time {
  font-size: 0.6875rem;
  color: #64748b;
  font-weight: 600;
}
.school-portal--esd-msg-show .school-esd-msg-meta__read {
  font-size: 0.6875rem;
  font-weight: 700;
  color: var(--portal-accent-heading);
}
.school-portal--esd-msg-show .school-esd-msg-compose {
  margin-bottom: 0;
}
.school-portal--esd-msg-show .school-esd-msg-compose__input {
  min-height: 5rem;
}
.school-portal--esd-msg-show .school-esd-msg-layout__aside {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  min-width: 0;
}
.school-portal--esd-msg-show .school-esd-msg-aside-block {
  margin-bottom: 0;
}
.school-portal--esd-msg-show .school-esd-msg-aside-block--muted {
  background: #fafafa;
}
.school-portal--esd-msg-show .school-esd-msg-aside__muted-only {
  margin: 0;
  font-size: 0.8125rem;
  line-height: 1.55;
}
.school-portal--esd-msg-show .school-esd-msg-aside__name {
  margin: 0 0 0.35rem;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.4;
}
.school-portal--esd-msg-show .school-esd-msg-aside__program-title {
  margin: 0 0 0.5rem;
  font-size: 0.9375rem;
  font-weight: 700;
  line-height: 1.45;
}
.school-portal--esd-msg-show .school-esd-msg-aside__dl {
  margin: 0;
  display: grid;
  grid-template-columns: max-content minmax(0, 1fr);
  gap: 0.35rem 0.65rem;
  font-size: 0.8125rem;
  align-items: baseline;
}
.school-portal--esd-msg-show .school-esd-msg-aside__dl dt {
  margin: 0;
  font-weight: 600;
  color: #64748b;
}
.school-portal--esd-msg-show .school-esd-msg-aside__dl dd {
  margin: 0;
  color: #1e293b;
  word-break: break-word;
}
.school-portal--esd-msg-show .school-esd-msg-aside__contract-form {
  margin: 0;
  width: 100%;
}
.school-portal--esd-msg-show .school-esd-msg-aside__contract-btn {
  width: 100%;
  justify-content: center;
}
.school-portal--esd-msg-show .school-esd-sched-modal {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  margin: 0;
  border: none;
  padding: 0;
  width: min(26rem, 100vw - 2rem);
  max-height: calc(100vh - 2rem);
  overflow: auto;
  background: transparent;
}
.school-portal--esd-msg-show .school-esd-sched-modal::backdrop {
  background: rgba(15, 23, 42, 0.45);
}
.school-portal--esd-msg-show .school-esd-sched-modal__card {
  position: relative;
  padding: 1.25rem 1.35rem 1.2rem;
  border-radius: 0.65rem;
  background: #fff;
  border: 1px solid #e2e8f0;
  box-shadow: 0 18px 48px rgba(15, 23, 42, 0.18);
}
.school-portal--esd-msg-show .school-esd-sched-modal__close {
  position: absolute;
  top: 0.45rem;
  right: 0.5rem;
  width: 2rem;
  height: 2rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: none;
  border-radius: 0.35rem;
  background: transparent;
  color: #64748b;
  font-size: 1.35rem;
  line-height: 1;
  cursor: pointer;
}
.school-portal--esd-msg-show .school-esd-sched-modal__close:hover {
  color: #0f172a;
  background: #f1f5f9;
}
.school-portal--esd-msg-show .school-esd-sched-modal__lead {
  margin: 0 0 1rem;
  font-size: 0.875rem;
  color: #334155;
  line-height: 1.5;
  padding-right: 1.75rem;
}
.school-portal--esd-msg-show .school-esd-sched-modal__form {
  margin: 0;
}
.school-portal--esd-msg-show .school-esd-sched-modal__date-row {
  margin-bottom: 0.85rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 0.75rem;
}
.school-portal--esd-msg-show .school-esd-sched-modal__date-label {
  font-size: 0.8125rem;
  font-weight: 600;
  color: #64748b;
}
.school-portal--esd-msg-show .school-esd-sched-modal__date-input {
  font-size: 0.875rem;
  padding: 0.35rem 0.5rem;
  border: 1px solid #cbd5e1;
  border-radius: 0.35rem;
}
.school-portal--esd-msg-show .school-esd-sched-modal__row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.65rem 1rem;
}
.school-portal--esd-msg-show .school-esd-sched-modal__later {
  flex-shrink: 0;
}
.school-portal--esd-msg-show .school-esd-sched-modal__submit {
  flex-shrink: 0;
}
.school-portal .school-portal__meta-dl {
  margin: 1rem 0 0;
  padding: 0.85rem 1rem;
  background: #f8fafc;
  border: 1px solid #e8edf3;
  border-radius: 0.5rem;
  display: grid;
  grid-template-columns: max-content minmax(0, 1fr);
  gap: 0.45rem 1rem;
  font-size: 0.875rem;
  align-items: baseline;
}
.school-portal .school-portal__meta-dt {
  margin: 0;
  font-weight: 600;
  color: #64748b;
  font-size: 0.8125rem;
}
.school-portal .school-portal__meta-dd {
  margin: 0;
  color: #0f172a;
  line-height: 1.45;
  word-break: break-word;
}
.school-portal.school-portal--esd-program-show .school-portal__panel--surface-none .school-portal__meta-dl--program-org {
  margin-top: 0.35rem;
  padding: 0;
  background: transparent;
  border: none;
  border-radius: 0;
  gap: 0.5rem 1rem;
}

.school-portal.school-portal--vice {
  --portal-accent: #4f46e5;
  --portal-accent-hover: #4338ca;
  --portal-accent-heading: #3730a3;
  --portal-soft: #eef2ff;
  --portal-mid: #e0e7ff;
  --portal-badge-border: #c7d2fe;
  --portal-focus-ring: rgba(79, 70, 229, 0.22);
}

.school-portal.school-portal--temp {
  --portal-accent: #c2410c;
  --portal-accent-hover: #9a3412;
  --portal-accent-heading: #9a3412;
  --portal-soft: #fff7ed;
  --portal-mid: #ffedd5;
  --portal-badge-border: #fdba74;
  --portal-focus-ring: rgba(194, 65, 12, 0.22);
}

.school-portal.school-portal--ec {
  --portal-accent: #2563eb;
  --portal-accent-hover: #1d4ed8;
  --portal-accent-heading: #1e40af;
  --portal-soft: #eff6ff;
  --portal-mid: #dbeafe;
  --portal-badge-border: #93c5fd;
  --portal-focus-ring: rgba(37, 99, 235, 0.22);
}

.school-sched .school-sched__crumb {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
  margin: 0 0 1rem;
  font-size: 0.9rem;
  font-weight: 600;
  color: #475569;
}
.school-sched .school-sched__crumb-link {
  color: var(--portal-accent, #059669);
  text-decoration: none;
}
.school-sched .school-sched__crumb-link:hover {
  text-decoration: underline;
}
.school-sched .school-sched__crumb-sep {
  color: #94a3b8;
  font-weight: 500;
}
.school-sched .school-sched__crumb-current {
  color: #0f172a;
}
.school-sched .school-sched__toolbar {
  margin-bottom: 1rem;
}
.school-sched .school-sched__toolbar--compact {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
}
.school-sched .school-sched__table-block {
  display: flex;
  flex-direction: column;
  align-items: stretch;
}
.school-sched .school-sched__table-block-head {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 0.35rem;
}
.school-sched .school-sched__memo-panel {
  margin-bottom: 1.25rem;
}
.school-sched .school-sched__textarea {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  padding: 0.65rem 0.75rem;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  font-size: 0.9375rem;
  line-height: 1.5;
  resize: vertical;
  margin-top: 0.5rem;
}
.school-sched .school-sched__textarea--compact {
  min-height: 3.5rem;
}
.school-sched .school-sched__memo-body {
  margin-top: 0.5rem;
  font-size: 0.9375rem;
  line-height: 1.6;
  color: #334155;
}
.school-sched .school-sched__form-actions {
  margin-top: 0.65rem;
}
.school-sched .school-sched__year-panel {
  margin-bottom: 1.25rem;
}
.school-sched .school-sched__year-3col {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 1rem;
  align-items: stretch;
}
@media (max-width: 52rem) {
  .school-sched .school-sched__year-3col {
    grid-template-columns: 1fr;
  }
}
.school-sched .school-sched__month-col {
  border: 1px solid #e2e8f0;
  border-radius: 0.55rem;
  background: #fff;
  min-width: 0;
  display: flex;
  flex-direction: column;
}
.school-sched .school-sched__month-col-title {
  margin: 0;
  padding: 0.65rem 0.75rem;
  font-size: 1rem;
  font-weight: 800;
  border-bottom: 1px solid #f1f5f9;
  background: var(--portal-soft, #ecfdf5);
  flex-shrink: 0;
}
.school-sched .school-sched__month-col-title-link {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  max-width: 100%;
  color: var(--portal-accent-heading, #047857);
  text-decoration: none;
}
.school-sched .school-sched__month-col-title-link:hover {
  text-decoration: underline;
}
.school-sched .school-sched__month-col-title-link:hover .school-sched__month-col-title-link-icon {
  opacity: 1;
}
.school-sched .school-sched__month-col-title-link-icon {
  font-size: 0.95rem;
  opacity: 0.8;
  flex-shrink: 0;
  color: var(--portal-accent, #059669);
}
.school-sched .school-sched__month-col-title-link-text {
  min-width: 0;
}
.school-sched .school-sched__month-col-body {
  padding: 0.4rem 0.55rem 0.6rem;
  overflow: visible;
}
.school-sched .school-sched__day-stack {
  padding-bottom: 0.45rem;
  margin-bottom: 0.45rem;
  border-bottom: 1px solid #f1f5f9;
}
.school-sched .school-sched__day-stack:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: none;
}
.school-sched .school-sched__day-stack-hd {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.25rem 0.5rem;
  margin-bottom: 0.35rem;
  font-size: 0.8125rem;
  font-weight: 700;
  color: #0f172a;
}
.school-sched .school-sched__day-stack-line {
  font-variant-numeric: tabular-nums;
  color: #0f172a;
}
.school-sched .school-sched__day-stack--sat .school-sched__day-stack-line {
  color: #1d4ed8;
}
.school-sched .school-sched__day-stack--sun .school-sched__day-stack-line {
  color: #b91c1c;
}
.school-sched .school-sched__day-stack-link {
  margin-left: auto;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--portal-accent, #059669);
  text-decoration: none;
}
.school-sched .school-sched__day-stack-link:hover {
  text-decoration: underline;
}
.school-sched .school-sched__day-stack-list {
  margin: 0;
  padding: 0 0 0 1.1rem;
  font-size: 0.8125rem;
  line-height: 1.45;
  color: #334155;
}
.school-sched .school-sched__day-stack-title {
  font-weight: 600;
}
.school-sched .school-sched__day-stack-empty {
  margin: 0;
  font-size: 0.8125rem;
  color: #94a3b8;
}
.school-sched .school-sched__quarter {
  margin-bottom: 1.25rem;
}
.school-sched .school-sched__subhead {
  margin: 0.75rem 0 0.4rem;
  font-size: 0.9375rem;
  font-weight: 700;
  color: #334155;
}
.school-sched .school-sched__subhead--spaced {
  margin-top: 1.25rem;
}
.school-sched .school-sched__th-date {
  width: 1%;
  white-space: nowrap;
}
.school-sched .school-sched__datecell {
  width: 1%;
  white-space: nowrap;
  vertical-align: top;
  font-variant-numeric: tabular-nums;
  font-weight: 700;
  color: #0f172a;
}
.school-sched .school-sched__datecell--sat {
  color: #1d4ed8;
}
.school-sched .school-sched__datecell--sun {
  color: #b91c1c;
}
.school-sched .school-sched__month-day-toolbar {
  display: flex;
  justify-content: flex-end;
  margin: 0 0 0.35rem;
}
.school-sched .school-sched__icon-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.2rem;
  color: var(--portal-accent, #059669);
  text-decoration: none;
  border: none;
  background: transparent;
  border-radius: 0.35rem;
}
.school-sched .school-sched__icon-link:hover {
  color: #047857;
  background: rgba(5, 150, 105, 0.08);
}
.school-sched .school-sched__icon-link:focus-visible {
  outline: 2px solid var(--portal-accent, #059669);
  outline-offset: 2px;
}
.school-sched .school-sched__week-icon-link .las {
  font-size: 1.2rem;
  line-height: 1;
}
.school-sched .school-sched__icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.1rem;
  min-height: 2.1rem;
  padding: 0.2rem;
  border: none;
  background: transparent;
  color: #64748b;
  cursor: pointer;
  border-radius: 0.35rem;
}
.school-sched .school-sched__icon-btn:hover {
  background: #f1f5f9;
  color: #0f172a;
}
.school-sched .school-sched__icon-btn:focus-visible {
  outline: 2px solid #94a3b8;
  outline-offset: 1px;
}
.school-sched .school-sched__icon-btn .las {
  font-size: 1.1rem;
  line-height: 1;
}
.school-sched .school-sched__icon-btn--danger:hover {
  color: #b91c1c;
  background: #fef2f2;
}
.school-sched .school-sched__text-link {
  color: var(--portal-accent, #059669);
  font-weight: 600;
  text-decoration: none;
}
.school-sched .school-sched__text-link:hover {
  text-decoration: underline;
}
.school-sched .school-sched__cell-notes {
  font-size: 0.875rem;
  line-height: 1.5;
  color: #334155;
  vertical-align: top;
}
.school-sched .school-sched__cell-day-block {
  vertical-align: top;
  padding-top: 0.4rem;
  padding-bottom: 0.4rem;
}
.school-sched .school-sched__day-stack-list--tools {
  list-style: none;
  margin: 0;
  padding: 0;
}
.school-sched .school-sched__day-stack-list--tools > li {
  margin: 0 0 0.4rem;
}
.school-sched .school-sched__day-stack-list--tools > li:last-child {
  margin-bottom: 0;
}
.school-sched .school-sched__day-item-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.35rem 0.5rem;
}
.school-sched .school-sched__day-item-row .school-sched__day-stack-title {
  flex: 1 1 auto;
  min-width: 0;
}
.school-sched .school-sched__day-item-tools {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.25rem;
  flex-shrink: 0;
}
.school-sched .school-sched__trash-form {
  display: inline-flex;
  flex: 0 0 auto;
  margin: 0;
}
.school-sched .school-sched__btn-add {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.35rem;
  min-height: 2.35rem;
  padding: 0.35rem;
}
.school-sched .school-sched__btn-add .las {
  font-size: 1.35rem;
  line-height: 1;
}
.school-sched .school-sched__dialog {
  max-width: min(22rem, 100vw - 2rem);
  padding: 0;
  border: 1px solid #e2e8f0;
  border-radius: 0.65rem;
  box-shadow: 0 12px 40px rgba(15, 23, 42, 0.12);
}
.school-sched .school-sched__dialog::backdrop {
  background: rgba(15, 23, 42, 0.35);
}
.school-sched .school-sched__dialog-panel {
  padding: 1.25rem 1.35rem;
}
.school-sched .school-sched__dialog-title {
  margin: 0 0 1rem;
  font-size: 1.05rem;
  font-weight: 700;
  color: #0f172a;
}
.school-sched .school-sched__modal-form {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}
.school-sched .school-sched__modal-field {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}
.school-sched .school-sched__modal-label {
  font-size: 0.8125rem;
  font-weight: 600;
  color: #475569;
}
.school-sched .school-sched__dialog-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.25rem;
}
.school-sched .school-sched__modal-hint {
  margin: -0.35rem 0 0;
  font-size: 0.8125rem;
  line-height: 1.45;
}
.school-sched .school-sched__input {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  padding: 0.45rem 0.55rem;
  border: 1px solid #e2e8f0;
  border-radius: 0.4rem;
  font-size: 0.875rem;
}
.school-sched .btn--small {
  font-size: 0.8125rem;
  padding: 0.35rem 0.6rem;
}
.school-sched .school-portal__table-wrap {
  overflow-x: visible;
  overflow-y: visible;
}

.app-main:has(.school-portal.school-sched) {
  overflow-x: visible;
  overflow-y: visible;
}

html.attend-html {
  overflow-x: visible;
  max-width: 100%;
  font-family: system-ui, -apple-system, "Segoe UI", sans-serif;
  line-height: 1.5;
  color: #0f172a;
  -webkit-font-smoothing: antialiased;
}
html.attend-html body.attend-body {
  overflow-x: visible;
  max-width: 100%;
  font-family: inherit;
  line-height: inherit;
  color: inherit;
}

.attend-page--shifts .school-guard-shift-cal {
  min-width: 0;
}

.attend-page--shifts .school-guard-shift-cal__scroll {
  -webkit-overflow-scrolling: touch;
}

.attend-shifts-layout {
  min-height: 100vh;
  box-sizing: border-box;
}

.attend-header--school-guard {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  width: 100%;
  margin: 0;
  padding: 0.65rem 1rem;
  padding-left: max(1rem, env(safe-area-inset-left, 0px));
  padding-right: max(1rem, env(safe-area-inset-right, 0px));
  box-sizing: border-box;
  background: #f8fafc;
  border-bottom: 1px solid #e2e8f0;
  flex-shrink: 0;
}

.attend-header__brand {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  min-width: 0;
  flex: 1 1 auto;
}

.attend-header__actions {
  flex-shrink: 0;
  display: flex;
  align-items: center;
}

.attend-below-header-bar {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  padding: 0.45rem max(1rem, env(safe-area-inset-right, 0px)) 0.5rem max(1rem, env(safe-area-inset-left, 0px));
  box-sizing: border-box;
  flex-shrink: 0;
}

.attend-below-header-bar__shifts-link {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  min-width: 3.75rem;
  min-height: 3.75rem;
  padding: 0.25rem;
  border-radius: 12px;
  background: transparent;
  color: #2563eb;
  text-decoration: none;
  line-height: 1;
  -webkit-tap-highlight-color: transparent;
  box-sizing: border-box;
  transition: transform 0.12s ease, background 0.15s ease, color 0.15s ease;
}
.attend-below-header-bar__shifts-link:hover {
  background: #eff6ff;
  color: #1d4ed8;
}
.attend-below-header-bar__shifts-link:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
}
.attend-below-header-bar__shifts-link:active {
  transform: scale(0.96);
}

.attend-below-header-bar__shifts-icon {
  font-size: clamp(2.5rem, 8vw, 3.25rem);
  display: block;
}

.attend-header__menu-wrap {
  position: relative;
}

.attend-header__menu-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  min-width: 2.75rem;
  min-height: 2.75rem;
  padding: 0.2rem;
  border: none;
  border-radius: 10px;
  background: transparent;
  color: #475569;
  cursor: pointer;
  line-height: 1;
  -webkit-tap-highlight-color: transparent;
}
.attend-header__menu-btn:hover {
  background: #e2e8f0;
  color: #0f172a;
}
.attend-header__menu-btn:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
}

.attend-header__menu-icon {
  font-size: 2.25rem;
  display: block;
}

.attend-header__dropdown {
  position: absolute;
  top: calc(100% + 0.35rem);
  right: 0;
  min-width: 14rem;
  max-width: min(18rem, 100vw - 2rem);
  padding: 0.85rem 1rem 1rem;
  text-align: left;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  box-sizing: border-box;
  z-index: 200;
}

.attend-header__dropdown-name {
  margin: 0 0 0.75rem;
  padding-bottom: 0.65rem;
  border-bottom: 1px solid #e2e8f0;
  font-size: 0.95rem;
  font-weight: 600;
  color: #0f172a;
  line-height: 1.4;
  word-break: break-word;
}

.attend-header__logout-form {
  margin: 0;
  padding: 0;
}

.attend-header__logout-btn {
  display: block;
  width: 100%;
  margin: 0;
  padding: 0.55rem 0.75rem;
  font-size: 0.9rem;
  font-weight: 600;
  color: #fff;
  background: #475569;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  box-sizing: border-box;
}
.attend-header__logout-btn:hover {
  background: #334155;
}

.attend-header__emblem {
  flex-shrink: 0;
  display: block;
  width: 2.25rem;
  height: 2.25rem;
  object-fit: contain;
}

.attend-header__org {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 700;
  color: #0f172a;
  letter-spacing: -0.02em;
  line-height: 1.25;
}

.attend-shifts-layout > .attend-page {
  margin-top: 0.75rem;
}

.attend-page__title--shifts {
  text-align: center;
  margin: 0 0 0.5rem;
}

.attend-page__shift-upcoming-box {
  margin: 0 0 3rem;
  padding: 1rem 1.15rem 1.15rem;
  text-align: center;
  background: #f8fafc;
  border: 2px solid #cbd5e1;
  border-radius: 12px;
  box-sizing: border-box;
}
.attend-page__shift-upcoming-box--empty {
  border-color: #e2e8f0;
  background: #fff;
}

.attend-page__shift-upcoming-heading {
  margin: 0 0 0.75rem;
  font-size: 1rem;
  font-weight: 700;
  color: #334155;
  letter-spacing: 0.02em;
  line-height: 1.3;
}

.attend-page__shift-upcoming-date {
  margin: 0 0 0.6rem;
  font-size: clamp(1.35rem, 5vw, 1.85rem);
  font-weight: 800;
  color: #0f172a;
  line-height: 1.35;
  letter-spacing: 0.01em;
}

.attend-page__shift-upcoming-school {
  margin: 0;
  font-size: clamp(1.2rem, 4.2vw, 1.6rem);
  font-weight: 700;
  color: #1e40af;
  line-height: 1.4;
  word-break: break-word;
}

.attend-page__shift-upcoming-msg {
  margin: 0;
  font-size: clamp(1.1rem, 3.8vw, 1.35rem);
  font-weight: 600;
  color: #64748b;
  line-height: 1.5;
}

.attend-page__shift-empty-block {
  margin: 0.5rem 0 0.75rem;
  text-align: center;
}

.attend-page {
  max-width: 36rem;
  width: 100%;
  margin: clamp(1rem, 4vw, 2rem) auto;
  padding: clamp(0.75rem, 3vw, 1rem) max(0.75rem, env(safe-area-inset-left, 0px)) clamp(1rem, 3vw, 1.25rem) max(0.75rem, env(safe-area-inset-right, 0px));
  text-align: center;
  box-sizing: border-box;
}
.attend-page--shifts {
  max-width: min(52rem, 100%);
  text-align: left;
}

.attend-page__action-bar {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.65rem;
  width: 100%;
  max-width: 24rem;
  margin: 0.35rem auto 0.5rem;
  box-sizing: border-box;
}
.attend-page__action-bar__link {
  text-align: center;
  border-radius: 10px;
}
.attend-page__action-bar .attend-page__btn--panel-toggle {
  width: 100%;
  max-width: 22rem;
  margin: 0 auto;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  gap: 0.75rem;
  padding: 0.85rem 1.1rem;
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1.35;
  text-align: left;
  border-radius: 12px;
  box-sizing: border-box;
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease, transform 0.12s ease;
}
.attend-page__action-bar .attend-page__btn--panel-toggle:active {
  transform: scale(0.99);
}

.attend-page__action-bar__icon-wrap {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 10px;
  font-size: 1.35rem;
}
.attend-page__action-bar__icon-wrap--report {
  background: linear-gradient(145deg, #ede9fe 0%, #ddd6fe 100%);
  color: #5b21b6;
}

.attend-page__btn--panel-report {
  color: #4c1d95;
  background: #faf5ff;
  border: 2px solid #a78bfa;
}
.attend-page__btn--panel-report:hover {
  background: #f3e8ff;
  border-color: #8b5cf6;
  color: #3b0764;
}
.attend-page__btn--panel-report[aria-expanded=true] {
  background: #ede9fe;
  border-color: #7c3aed;
  color: #4c1d95;
  outline: 2px solid rgba(124, 58, 237, 0.45);
  outline-offset: 2px;
}

.attend-page__btn-label {
  flex: 1 1 auto;
  text-align: left;
  min-width: 0;
}

.attend-page__btn--panel-toggle:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
}

.attend-page__panel-section:not([hidden]) {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid #e2e8f0;
}
.attend-page__panel-section:not([hidden]) .attend-page__report {
  margin-top: 0;
  padding-top: 0.5rem;
  border-top: none;
}

.attend-page__geo-hint {
  margin: 0 auto 0.65rem;
  max-width: 24rem;
  padding: 0.55rem 0.75rem;
  font-size: 0.78rem;
  line-height: 1.55;
  color: #64748b;
  background: #f8fafc;
  border-radius: 10px;
  border: 1px solid #e2e8f0;
  box-sizing: border-box;
}

.attend-page__duration-quick-actions {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: stretch;
  justify-content: center;
  gap: 0.65rem;
  width: 100%;
  max-width: 24rem;
  margin: 0.35rem auto 80px;
  box-sizing: border-box;
}
.attend-page__duration-quick-actions .attend-page__btn {
  flex: 1 1 0;
  min-width: 0;
}

.attend-page__btn--clock-punch {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  min-height: 4.5rem;
  padding: 0.65rem 0.5rem 0.75rem;
  font-weight: 800;
  font-size: 1.1rem;
  letter-spacing: 0.06em;
  border-radius: 14px;
  border: none;
  transition: transform 0.12s ease, filter 0.15s ease;
}
.attend-page__btn--clock-punch:active {
  transform: scale(0.98);
}

.attend-page__btn--clock-punch__icon {
  font-size: 1.65rem;
  line-height: 1;
  opacity: 0.95;
}

.attend-page__btn--clock-punch__label {
  font-size: 1.05rem;
  letter-spacing: 0.12em;
}

.attend-page__btn--duration-start.attend-page__btn--clock-punch {
  background: linear-gradient(160deg, #22c55e 0%, #16a34a 45%, #15803d 100%);
  color: #fff;
}
.attend-page__btn--duration-start.attend-page__btn--clock-punch:hover {
  filter: brightness(1.05);
}

.attend-page__btn--duration-finish.attend-page__btn--clock-punch {
  background: linear-gradient(160deg, #f87171 0%, #ef4444 45%, #dc2626 100%);
  color: #fff;
}
.attend-page__btn--duration-finish.attend-page__btn--clock-punch:hover {
  filter: brightness(1.05);
}

.attend-page__work-duration-form--wrap {
  margin: 0;
  padding: 0;
  border: none;
  background: transparent;
}

.attend-page__shift-back {
  margin: 1.25rem 0 0.5rem;
  text-align: center;
  clear: both;
}

.attend-page__link-back {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 22rem;
  margin: 0 auto;
  padding: 0.75rem 1rem;
  font-size: 0.95rem;
  font-weight: 600;
  line-height: 1.35;
  color: #1e40af;
  text-decoration: none;
  box-sizing: border-box;
  background: #fff;
  border: 2px solid #3b82f6;
  border-radius: 10px;
  transition: background 0.15s ease, border-color 0.15s ease;
}
.attend-page__link-back:hover {
  background: #eff6ff;
  border-color: #2563eb;
  color: #1e3a8a;
}
.attend-page__link-back:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
}

.attend-page__shift-toolbar {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.65rem;
  margin: 1rem 0;
  justify-content: center;
}

.attend-page__school-guard-nav-links {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  gap: 0.5rem;
}

.attend-page__school-guard-nav-inner {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  white-space: nowrap;
}

.attend-page__btn--shift-nav {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #f1f5f9;
  color: #334155;
  border: 1px solid #cbd5e1;
  text-decoration: none;
  padding: 0.5rem 1rem;
  font-size: 0.9rem;
  flex: 0 0 auto;
  text-align: center;
  box-sizing: border-box;
}
.attend-page__btn--shift-nav:hover {
  background: #e2e8f0;
}

.attend-page__shift-month-form {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  flex: 1 1 auto;
  min-width: 0;
  justify-content: center;
}
.attend-page__shift-month-form input[type=month] {
  padding: 0.45rem 0.5rem;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  font-size: 0.95rem;
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
}

.attend-page__shift-month-label {
  font-size: 0.85rem;
  color: #334155;
  margin: 0;
}

.attend-page__shift-empty {
  font-size: 0.85rem;
  color: #64748b;
  margin: 0.5rem 0 0;
  text-align: center;
}

@media (max-width: 480px) {
  .attend-page__shift-toolbar {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
  }
  .attend-page__shift-month-form input[type=month] {
    max-width: 100%;
  }
}
.attend-page__title {
  font-size: 1.25rem;
  margin: 1.5rem 0;
}

.attend-page__user {
  color: #666;
  font-size: 0.9rem;
}

.attend-page__date {
  font-size: 1rem;
  margin-bottom: 1rem;
}

.attend-page__buttons {
  display: flex;
  gap: 0.75rem;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 1.5rem;
}

.attend-page__btn {
  padding: 0.75rem 1.5rem;
  border: none;
  border-radius: 8px;
  font-size: 1rem;
  cursor: pointer;
}
.attend-page__btn--start {
  background: #22c55e;
  color: white;
}
.attend-page__btn--end {
  background: #ef4444;
  color: white;
}
.attend-page__btn--login {
  background: #2563eb;
  color: #fff;
  width: 100%;
}
.attend-page__btn--logout {
  background: #475569;
  color: #fff;
}

.attend-page__logout {
  margin-top: 1rem;
}

.attend-page__lead {
  margin: 1rem 0 0.75rem;
  color: #334155;
}

.attend-page__help {
  margin-top: 0.75rem;
  color: #64748b;
  font-size: 0.8rem;
  line-height: 1.5;
}

.attend-page__login-form {
  margin-top: 0.5rem;
  text-align: left;
}

.attend-page__field {
  margin-bottom: 0.75rem;
}
.attend-page__field label {
  display: block;
  margin-bottom: 0.25rem;
  font-size: 0.85rem;
  color: #334155;
}
.attend-page__field input {
  width: 100%;
  box-sizing: border-box;
  padding: 0.625rem 0.75rem;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  font-size: 1rem;
}

.attend-page__notice {
  color: #16a34a;
  margin: 0.5rem 0;
}

.attend-page__alert {
  color: #dc2626;
  margin: 0.5rem 0;
}

.attend-page__report {
  margin-top: 1.75rem;
  text-align: left;
  border-top: 1px solid #e2e8f0;
  padding-top: 1.25rem;
}

.attend-page__report-title {
  font-size: 1rem;
  text-align: center;
  margin: 0 0 0.5rem;
}

.attend-page__report-lead {
  font-size: 0.8rem;
  color: #64748b;
  margin: 0 0 1rem;
  line-height: 1.5;
}

.attend-page__report-errors {
  color: #b91c1c;
  font-size: 0.85rem;
  margin: 0 0 1rem;
  padding-left: 1.25rem;
}

.attend-page__report-form {
  margin: 0;
}

.attend-page__report-row {
  margin-bottom: 0.75rem;
}
.attend-page__report-row label {
  display: block;
  margin-bottom: 0.25rem;
  font-size: 0.85rem;
  color: #334155;
}
.attend-page__report-row input[type=text],
.attend-page__report-row textarea {
  width: 100%;
  box-sizing: border-box;
  padding: 0.5rem 0.65rem;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  font-size: 1rem;
}
.attend-page__report-row textarea {
  resize: vertical;
  min-height: 4rem;
}

.attend-page__report-fieldset {
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  padding: 0.75rem;
  margin: 0 0 0.75rem;
}
.attend-page__report-fieldset legend {
  font-size: 0.85rem;
  color: #334155;
  padding: 0 0.35rem;
}

.attend-page__report-check {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin: 0.35rem 0;
  font-size: 0.9rem;
}
.attend-page__report-check input {
  width: auto;
}

.attend-page__btn--save-report {
  width: 100%;
  margin-top: 0.5rem;
  background: #2563eb;
  color: #fff;
}

.attend-page__report-row--school {
  margin-bottom: 1rem;
}
.attend-page__report-row--school label {
  font-weight: 600;
  color: #0f172a;
  letter-spacing: 0.02em;
}

select.attend-page__report-select--school {
  display: block;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  margin-top: 0.35rem;
  padding: 0.65rem 2.5rem 0.65rem 0.85rem;
  font-size: 1rem;
  line-height: 1.45;
  color: #0f172a;
  background-color: #fff;
  border: 1px solid #cbd5e1;
  border-radius: 0.5rem;
  cursor: pointer;
  min-height: 2.75rem;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.65rem center;
  background-size: 1rem 1rem;
  transition: border-color 0.15s ease;
}
select.attend-page__report-select--school:hover {
  border-color: #94a3b8;
}
select.attend-page__report-select--school:focus {
  border-color: #2563eb;
  outline: 2px solid rgba(37, 99, 235, 0.35);
  outline-offset: 2px;
}

.esd-partner-body {
  margin: 0;
  min-height: 100vh;
  color: #0f172a;
  font-family: system-ui, -apple-system, "Segoe UI", sans-serif;
  line-height: 1.55;
  background-color: white;
  background-image: linear-gradient(rgba(148, 163, 184, 0.05) 1px, transparent 1px), linear-gradient(90deg, rgba(148, 163, 184, 0.05) 1px, transparent 1px);
  background-size: 22px 22px;
}

.esd-partner-topbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  position: relative;
  top: auto;
  left: auto;
  right: auto;
  width: 100%;
  z-index: 100;
  background: rgba(255, 254, 252, 0.92);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(232, 228, 222, 0.95);
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.04);
}

.esd-partner-body--lp-hero-topbar .esd-partner-topbar {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  background: transparent;
  border-bottom: none;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.esd-partner-topbar__brand {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  text-decoration: none;
  color: inherit;
  min-width: 0;
  padding: 1rem;
}

.esd-partner-topbar__brand-mark {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.625rem;
  background: linear-gradient(145deg, #ecfdf5 0%, #ccfbf1 55%, #d1fae5 100%);
  color: #047857;
  font-size: 1.35rem;
  flex-shrink: 0;
  box-shadow: 0 1px 2px rgba(4, 120, 87, 0.12);
}

.esd-partner-topbar__brand-text {
  min-width: 0;
}

.esd-partner-topbar__title {
  display: block;
  font-weight: 700;
  font-size: 1.0625rem;
  line-height: 1.25;
  color: #0f172a;
}

.esd-partner-topbar__sub {
  display: block;
  font-size: 0.6875rem;
  color: #64748b;
  line-height: 1.4;
  margin-top: 0.15rem;
}

.esd-partner-body--lp-hero-topbar .esd-partner-topbar__title {
  color: #fff;
}

.esd-partner-body--lp-hero-topbar .esd-partner-topbar__sub {
  color: rgba(255, 255, 255, 0.92);
}

.esd-partner-topbar__nav {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

.esd-partner-topbar__link {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.5rem 0.9rem;
  min-height: 2.75rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: white;
  text-decoration: none;
  border-radius: 0.5rem;
  border: 1px solid transparent;
  transition: background 0.12s, border-color 0.12s, box-shadow 0.12s;
}
.esd-partner-topbar__link i {
  font-size: 1.15rem;
}
.esd-partner-topbar__link:hover {
  background: rgba(37, 99, 235, 0.08);
  text-decoration: none;
}
.esd-partner-topbar__link:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
}
.esd-partner-topbar__link.is-active {
  background: #eff6ff;
  border-color: #bfdbfe;
  color: #1d4ed8;
}

.esd-partner-topbar--company-sign-in {
  flex-wrap: nowrap;
  align-items: center;
}
.esd-partner-topbar--company-sign-in .esd-partner-topbar__brand {
  min-width: 0;
  flex: 1 1 auto;
  max-width: calc(100% - 3.75rem);
  overflow: hidden;
}
.esd-partner-topbar--company-sign-in .esd-partner-topbar__brand-text {
  min-width: 0;
  overflow: hidden;
}
.esd-partner-topbar--company-sign-in .esd-partner-topbar__title {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.esd-partner-topbar--company-sign-in .esd-partner-topbar__sub {
  display: none;
}
.esd-partner-topbar--company-sign-in .esd-partner-topbar__nav {
  flex: 0 0 auto;
  margin-left: auto;
}

@media (max-width: 767px) {
  .esd-partner-topbar--company-sign-in {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    column-gap: 0.2rem;
    width: 100%;
  }
  .esd-partner-topbar--company-sign-in .esd-partner-topbar__brand {
    flex: unset;
    max-width: none;
    min-width: 0;
    padding: 0.65rem 0.45rem 0.65rem 0.75rem;
    justify-self: start;
  }
  .esd-partner-topbar--company-sign-in .esd-partner-topbar__nav {
    margin-left: 0;
    justify-self: end;
    align-self: center;
  }
  .esd-partner-topbar--company-sign-in .esd-partner-topbar-auth-menu {
    width: auto;
    max-width: 3rem;
  }
  .esd-partner-topbar--company-sign-in .esd-partner-topbar-auth-menu__trigger {
    margin-right: 0.4rem;
  }
}
.esd-partner-topbar-auth-menu {
  position: relative;
}

.esd-partner-topbar-auth-menu__trigger {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.75rem;
  height: 2.75rem;
  margin: 0.35rem 0.75rem 0.35rem 0;
  padding: 0;
  list-style: none;
  cursor: pointer;
  color: #0f172a;
  border-radius: 0.5rem;
  border: 1px solid transparent;
  background: transparent;
  transition: background 0.12s, border-color 0.12s;
}
.esd-partner-topbar-auth-menu__trigger::-webkit-details-marker {
  display: none;
}
.esd-partner-topbar-auth-menu__trigger:hover {
  background: rgba(15, 23, 42, 0.06);
}
.esd-partner-topbar-auth-menu__trigger:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
}

.esd-partner-topbar-auth-menu__icon i {
  font-size: 1.4rem;
  line-height: 1;
}

.esd-partner-topbar-auth-menu__panel {
  position: absolute;
  top: calc(100% + 0.25rem);
  right: 0;
  min-width: 12rem;
  padding: 0.35rem;
  background: #fff;
  border: 1px solid #e8e4de;
  border-radius: 0.75rem;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04), 0 6px 20px rgba(15, 23, 42, 0.06);
  z-index: 220;
}

.esd-partner-topbar-auth-menu__item {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.55rem 0.65rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: #2563eb;
  text-decoration: none;
  border-radius: 0.4rem;
  transition: background 0.12s;
}
.esd-partner-topbar-auth-menu__item i {
  font-size: 1.1rem;
  flex-shrink: 0;
  opacity: 0.9;
}
.esd-partner-topbar-auth-menu__item:hover {
  background: rgba(37, 99, 235, 0.08);
  text-decoration: none;
}

.esd-partner-sb-state {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
  opacity: 0;
  pointer-events: none;
}

.esd-partner-shell {
  --esd-partner-masthead-h: 3.65rem;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  align-items: stretch;
}

.esd-partner-app-body {
  display: flex;
  flex: 1;
  min-height: 0;
  width: 100%;
  align-items: stretch;
}

.esd-partner-scrim {
  display: none;
}

.esd-partner-side {
  flex: 0 0 16.5rem;
  width: 16.5rem;
  min-width: 16.5rem;
  display: flex;
  flex-direction: column;
  background: linear-gradient(180deg, #fffefb 0%, #faf8f5 100%);
  border-right: 1px solid #e8e4de;
  box-shadow: 4px 0 24px rgba(15, 23, 42, 0.03);
  align-self: stretch;
  min-height: 0;
  overflow-y: auto;
  z-index: 1;
  box-sizing: border-box;
}

.esd-partner-side__nav {
  flex: 1;
  padding: 0.85rem 0 1rem;
}

.esd-partner-side__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.esd-partner-side__list li {
  margin: 0;
}

.esd-partner-side__link {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.6rem 1rem;
  min-height: 2.75rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: #334155;
  text-decoration: none;
  border-left: 3px solid transparent;
  transition: background 0.12s, color 0.12s, border-color 0.12s;
}
.esd-partner-side__link i {
  font-size: 1.15rem;
  color: #64748b;
  width: 1.3rem;
  text-align: center;
  flex-shrink: 0;
}
.esd-partner-side__link .esd-partner-side__label {
  flex: 1;
  min-width: 0;
}
.esd-partner-side__link .esd-partner-side__badge {
  margin-left: auto;
  flex-shrink: 0;
  min-width: 1.35rem;
  padding: 0.1rem 0.42rem;
  font-size: 0.6875rem;
  font-weight: 800;
  line-height: 1.25;
  text-align: center;
  border-radius: 999px;
  background: #0d9488;
  color: #fff;
}
.esd-partner-side__link:hover {
  background: rgba(13, 148, 136, 0.06);
  color: #0f172a;
}
.esd-partner-side__link:hover i {
  color: #0d9488;
}
.esd-partner-side__link:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: -2px;
}
.esd-partner-side__link.is-active {
  background: linear-gradient(90deg, rgba(37, 99, 235, 0.08) 0%, rgba(37, 99, 235, 0.02) 100%);
  color: #1e40af;
  border-left-color: #0d9488;
  font-weight: 600;
}
.esd-partner-side__link.is-active i {
  color: #0d9488;
}
.esd-partner-side__link--quiet {
  font-size: 0.8125rem;
  color: #64748b;
}
.esd-partner-side__link--quiet i {
  font-size: 1.05rem;
}
.esd-partner-side__link--quiet:hover {
  color: #334155;
}

.esd-partner-side__form {
  margin: 0;
  padding: 0;
  display: block;
  width: 100%;
}

.esd-partner-side__logout {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
  padding: 0.55rem 1rem;
  margin: 0.35rem 0 0;
  background: transparent;
  border: none;
  text-decoration: none;
  box-sizing: border-box;
  border-left: 3px solid transparent;
  font-size: 0.8125rem;
  font-weight: 500;
  color: #64748b;
  cursor: pointer;
  text-align: left;
  font-family: inherit;
}
.esd-partner-side__logout i {
  font-size: 1.1rem;
  width: 1.3rem;
  text-align: center;
}
.esd-partner-side__logout:hover {
  background: #fef2f2;
  color: #b91c1c;
}

.esd-partner-side__footer {
  margin-top: auto;
  padding: 0.75rem 0.5rem 1.15rem;
  border-top: 1px solid #f1f5f9;
  flex-shrink: 0;
}

.esd-partner-column {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  background: white;
  min-height: 0;
}

.esd-partner-masthead {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.6rem 1rem;
  min-height: 3.35rem;
  background: #fff;
  border-bottom: 1px solid #e8e4de;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.04);
  position: sticky;
  top: 0;
  z-index: 210;
  flex-shrink: 0;
  box-sizing: border-box;
  width: 100%;
}

.esd-partner-masthead__start {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  min-width: 0;
}

.esd-partner-masthead__brand {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  text-decoration: none;
  color: inherit;
  min-width: 0;
  border-radius: 0.375rem;
  padding: 0.15rem 0.25rem;
  margin: -0.15rem -0.25rem;
}
.esd-partner-masthead__brand:hover {
  background: rgba(15, 23, 42, 0.04);
}

.esd-partner-masthead__brand-mark {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.35rem;
  height: 2.35rem;
  border-radius: 0.55rem;
  background: linear-gradient(145deg, #ecfdf5 0%, #ccfbf1 55%, #d1fae5 100%);
  color: #047857;
  font-size: 1.2rem;
  flex-shrink: 0;
  box-shadow: 0 1px 2px rgba(4, 120, 87, 0.1);
}

.esd-partner-masthead__brand-text {
  min-width: 0;
}

.esd-partner-masthead__brand-title {
  display: block;
  font-weight: 700;
  font-size: 0.95rem;
  line-height: 1.2;
  color: #0f172a;
}

.esd-partner-masthead__brand-sub {
  display: block;
  font-size: 0.65rem;
  color: #64748b;
  margin-top: 0.1rem;
}

.esd-partner-masthead__end {
  flex-shrink: 0;
}

.esd-partner-masthead__user-menu {
  position: relative;
}

.esd-partner-masthead__user-summary {
  list-style: none;
  cursor: pointer;
  padding: 0.2rem;
  border-radius: 9999px;
}
.esd-partner-masthead__user-summary::-webkit-details-marker {
  display: none;
}
.esd-partner-masthead__user-summary:hover {
  background: #f1f5f9;
}

.esd-partner-masthead__user-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.35rem;
  height: 2.35rem;
  border-radius: 9999px;
  background: linear-gradient(145deg, #e0f2fe 0%, #dbeafe 100%);
  color: #0369a1;
  font-weight: 700;
  font-size: 0.8rem;
  line-height: 1;
}

.esd-partner-masthead__user-panel {
  position: absolute;
  right: 0;
  top: calc(100% + 0.4rem);
  min-width: 13rem;
  padding: 0.65rem 0.75rem;
  background: #fff;
  border: 1px solid #e8e4de;
  border-radius: 0.5rem;
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.14);
  z-index: 320;
}

.esd-partner-masthead__user-meta {
  padding: 0.25rem 0.35rem 0.5rem;
  border-bottom: 1px solid #f1f5f9;
  margin-bottom: 0.35rem;
}

.esd-partner-masthead__user-name {
  display: block;
  font-size: 0.8125rem;
  font-weight: 600;
  color: #0f172a;
  word-break: break-word;
}

.esd-partner-masthead__user-logout {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.45rem 0.35rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: #b91c1c;
  text-decoration: none;
  border-radius: 0.35rem;
}
.esd-partner-masthead__user-logout:hover {
  background: #fef2f2;
}
.esd-partner-masthead__user-logout i {
  font-size: 1.1rem;
}

.esd-partner-burger {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.35rem 0.5rem;
  margin: -0.35rem -0.25rem -0.35rem -0.5rem;
  border-radius: 0.375rem;
  cursor: pointer;
  color: #334155;
  font-size: 0.875rem;
  font-weight: 600;
  user-select: none;
}
.esd-partner-burger:hover {
  background: #f1f5f9;
}

.esd-partner-burger__icon i {
  font-size: 1.35rem;
}

@media (min-width: 900px) {
  .esd-partner-masthead__burger {
    display: none;
  }
}
@media (max-width: 899px) {
  .esd-partner-app-body {
    display: block;
    flex: 1;
    min-height: 0;
  }
  .esd-partner-side {
    position: fixed;
    left: 0;
    top: var(--esd-partner-masthead-h);
    bottom: 0;
    transform: translateX(-100%);
    transition: transform 0.22s ease;
    box-shadow: none;
    height: auto;
    max-height: calc(100dvh - var(--esd-partner-masthead-h));
    z-index: 220;
  }
  #esd-partner-sidebar-toggle:checked ~ .esd-partner-shell .esd-partner-side {
    transform: translateX(0);
    box-shadow: 8px 0 32px rgba(15, 23, 42, 0.18);
  }
  .esd-partner-scrim {
    display: block;
    position: fixed;
    left: 0;
    right: 0;
    top: var(--esd-partner-masthead-h);
    bottom: 0;
    z-index: 215;
    background: rgba(15, 23, 42, 0.45);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease;
  }
  #esd-partner-sidebar-toggle:checked ~ .esd-partner-shell .esd-partner-scrim {
    opacity: 1;
    pointer-events: auto;
  }
  .esd-partner-column {
    width: 100%;
  }
}
@media (min-width: 900px) {
  .esd-partner-scrim {
    display: none !important;
  }
}
.esd-partner-main {
  max-width: 960px;
  margin: 0 auto;
  padding: 1.75rem 1.35rem 3rem;
  box-sizing: border-box;
}

.esd-partner-shell .esd-partner-main {
  flex: 1;
  width: 95%;
  max-width: none;
  margin-left: auto;
  margin-right: auto;
}

#esd-mypage-programs {
  scroll-margin-top: calc(var(--esd-partner-masthead-h, 3.65rem) + 0.75rem);
}

#esd-cover-image {
  scroll-margin-top: 5rem;
}
@media (min-width: 900px) {
  #esd-cover-image {
    scroll-margin-top: 1.5rem;
  }
}

.esd-partner-flash {
  margin: 0 0 1rem;
  padding: 0.8rem 1rem 0.8rem 1.1rem;
  border-radius: 0.75rem;
  font-size: 0.875rem;
  border: 1px solid transparent;
}

.esd-partner-flash.notice {
  background: #ecfdf5;
  color: #065f46;
  border-color: #a7f3d0;
  border-left: 4px solid #059669;
}

.esd-partner-flash.alert {
  background: #fef2f2;
  color: #991b1b;
  border-color: #fecaca;
  border-left: 4px solid #dc2626;
}

.page-users__logout-form {
  display: inline-block;
  margin: 0;
}

.esd-lp-hero {
  background: #fff;
  border: 1px solid #e8e4de;
  border-radius: 0.75rem;
  border-left: 4px solid #0d9488;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04), 0 6px 20px rgba(15, 23, 42, 0.06);
  padding: 2rem 1.5rem;
  margin-bottom: 1.5rem;
}

.esd-lp-hero h1 {
  margin: 0 0 0.75rem;
  font-size: 1.5rem;
}

.esd-lp-hero p {
  margin: 0 0 1rem;
  color: #475569;
  line-height: 1.6;
}

.esd-lp-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.esd-lp-card, .esd-panel {
  background: #fff;
  border-radius: 0.75rem;
  padding: 1.35rem 1.4rem;
  margin-bottom: 1.15rem;
}

.esd-lp-card h2, .esd-panel h2 {
  margin: 0 0 0.5rem;
  font-size: 1rem;
}

.esd-panel__title {
  margin: 0 0 0.65rem;
  font-size: 1.1875rem;
  font-weight: 700;
  color: #0f172a;
  letter-spacing: -0.02em;
}
.esd-panel__title:has(> .las:first-child) {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}
.esd-panel__title > .las:first-child {
  flex-shrink: 0;
  font-size: 1.1rem;
  color: #0d9488;
}

.esd-panel__actions {
  margin-bottom: 0.85rem;
}

.esd-panel__muted {
  margin: 0;
  font-size: 0.8125rem;
  color: #64748b;
  line-height: 1.5;
}

.esd-section-title + .esd-panel__muted--below-title,
.esd-panel__muted--below-title {
  margin-bottom: 0.75rem;
}

.esd-panel__muted--tight {
  margin-top: 0.65rem;
  margin-bottom: 0;
}

.esd-panel__section {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(232, 228, 222, 0.85);
}

.esd-panel__label {
  margin: 0 0 0.35rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: #475569;
}

.esd-panel__lead {
  margin: 0.5rem 0 0;
  font-size: 1.125rem;
  font-weight: 700;
  color: #0f172a;
  line-height: 1.35;
}

.esd-section-title--first {
  margin-top: 0;
}

.esd-callout {
  margin: 0 0 1rem;
  padding: 0.85rem 1rem 0.85rem 1.05rem;
  border-radius: 0.75rem;
  font-size: 0.875rem;
  line-height: 1.55;
  border: 1px solid transparent;
}

.esd-callout--warning {
  background: #fffbeb;
  border-color: #fde68a;
  border-left: 4px solid #d97706;
  color: #78350f;
}

.esd-callout--info {
  background: #f1f5f9;
  border-color: #e2e8f0;
  border-left: 4px solid #64748b;
  color: #334155;
}

.esd-callout .page-users__link {
  margin-top: 0.35rem;
  display: inline-block;
}

.esd-partner-notices {
  margin: 0 0 1.5rem;
  padding: 1rem 1.1rem;
  border-radius: 0.75rem;
  background: #fff;
}

.esd-partner-notices__head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem 1rem;
  margin-bottom: 0.35rem;
}

.esd-partner-notices__title {
  margin: 0;
  font-size: 1.1875rem;
  font-weight: 800;
  color: #0f172a;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.esd-partner-notices__list-link {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: #0d9488;
  text-decoration: none;
  white-space: nowrap;
}
.esd-partner-notices__list-link:hover {
  text-decoration: underline;
}
.esd-partner-notices__list-link .las {
  font-size: 0.95rem;
  opacity: 0.9;
}

.esd-mypage-lp-banner {
  display: block;
  margin: 0 0 1.5rem;
  min-height: 9.5rem;
  border-radius: 0.75rem;
  overflow: hidden;
  text-decoration: none;
  color: #fff;
  background-color: #1a3d2e;
  background-size: cover;
  background-position: center;
  position: relative;
  box-shadow: 0 4px 22px rgba(15, 23, 42, 0.12);
}
.esd-mypage-lp-banner::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg, rgba(15, 23, 42, 0.78) 0%, rgba(15, 23, 42, 0.38) 50%, rgba(15, 23, 42, 0.22) 100%);
  pointer-events: none;
}
.esd-mypage-lp-banner:hover {
  box-shadow: 0 6px 28px rgba(15, 23, 42, 0.16);
}
.esd-mypage-lp-banner:hover .esd-mypage-lp-banner__title {
  text-decoration: underline;
}

.esd-mypage-lp-banner--last {
  margin: 1.5rem 0 0;
}

.esd-mypage-lp-banner__inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 0.35rem;
  min-height: 9.5rem;
  padding: 1.4rem 1.5rem;
  max-width: 26rem;
  box-sizing: border-box;
}

.esd-mypage-lp-banner__title {
  font-size: 1.2rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.25);
}

.esd-mypage-lp-banner__sub {
  font-size: 0.8125rem;
  font-weight: 500;
  line-height: 1.45;
  opacity: 0.95;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}

.esd-mypage-lp-banner__cta {
  margin-top: 0.35rem;
  font-size: 1.35rem;
  opacity: 0.95;
}

.page-users .row.esd-mypage-split {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 0 1rem;
  margin: 0 -0.25rem 1.5rem;
}

.page-users .row.esd-mypage-split > .col-6 {
  flex: 1 1 calc(50% - 0.5rem);
  min-width: min(100%, 17rem);
  max-width: 100%;
  padding: 0 0.25rem;
  box-sizing: border-box;
  display: flex;
}

.page-users .row.esd-mypage-split > .col-6 > .esd-panel--mypage-split {
  flex: 1 1 auto;
  width: 100%;
}

@media (min-width: 768px) {
  .page-users .row.esd-mypage-split > .col-6 {
    flex: 1 1 calc(50% - 0.5rem);
    max-width: calc(50% - 0.5rem);
  }
}
.esd-panel__head-row {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5rem 1rem;
  margin-bottom: 0.65rem;
}

.esd-panel__head-row--valign-center {
  align-items: center;
}

.esd-panel__head-row-end {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.5rem 0.75rem;
}

.esd-panel__head-row .esd-panel__title {
  margin: 0;
}

.esd-mypage-program-add-btn {
  flex-shrink: 0;
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0.2rem;
  min-width: 2rem;
  min-height: 2rem;
  border: none;
  background: transparent;
  color: #0d9488;
  line-height: 1;
  text-decoration: none;
  vertical-align: middle;
  border-radius: 0.35rem;
  cursor: pointer;
}
.esd-mypage-program-add-btn:hover {
  color: rgb(9.7055900621, 110.4944099379, 101.5354037267);
}
.esd-mypage-program-add-btn:focus {
  outline: none;
}
.esd-mypage-program-add-btn:focus-visible {
  outline: 2px solid rgba(13, 148, 136, 0.45);
  outline-offset: 2px;
}
.esd-mypage-program-add-btn .esd-mypage-program-add-btn__icon {
  font-size: 1.45rem;
  line-height: 1;
  display: block;
  margin: 0;
}

.esd-panel__head-link {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: #0d9488;
  text-decoration: none;
}
.esd-panel__head-link:hover {
  text-decoration: underline;
}

.esd-mypage-message-preview-list {
  list-style: none;
  margin: 0;
  padding: 0;
  border: 1px solid #e8e4de;
  border-radius: 0.65rem;
  overflow: hidden;
  background: #fff;
}

.esd-mypage-message-preview-list__item {
  margin: 0;
  border-top: 1px solid #f1f5f9;
}
.esd-mypage-message-preview-list__item:first-child {
  border-top: none;
}

.esd-mypage-message-preview-list__link {
  display: grid;
  grid-template-columns: minmax(5rem, 9rem) 1fr;
  gap: 0.35rem 1rem;
  padding: 0.85rem 1rem;
  text-decoration: none;
  color: inherit;
}
@media (max-width: 640px) {
  .esd-mypage-message-preview-list__link {
    grid-template-columns: 1fr;
  }
}
.esd-mypage-message-preview-list__link:hover {
  background: #f8fafc;
}

.esd-mypage-message-preview-list__school {
  font-weight: 700;
  font-size: 0.9rem;
  color: #0f172a;
  grid-column: 1;
}

.esd-mypage-message-preview-list__program {
  font-size: 0.8125rem;
  font-weight: 600;
  color: #0d9488;
  grid-column: 2;
}
@media (max-width: 640px) {
  .esd-mypage-message-preview-list__program {
    grid-column: 1;
  }
}

.esd-mypage-message-preview-list__excerpt {
  grid-column: 1/-1;
  font-size: 0.8125rem;
  color: #64748b;
  line-height: 1.45;
}

.esd-mypage-message-preview-list__meta {
  grid-column: 1/-1;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 0.75rem;
  font-size: 0.75rem;
  color: #64748b;
}

.esd-mypage-message-preview-list__badge {
  display: inline-block;
  padding: 0.1rem 0.4rem;
  border-radius: 0.25rem;
  font-size: 0.6875rem;
  font-weight: 700;
  background: #ecfdf5;
  color: #047857;
}

.esd-back-link__sep {
  margin: 0 0.35rem;
  color: #94a3b8;
}

.esd-partner-notices__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.esd-partner-notices__item {
  margin: 0;
  padding: 0.75rem 0;
  border-top: 1px solid #e8e4de;
}
.esd-partner-notices__item:first-of-type {
  border-top: none;
  padding-top: 0;
}

.esd-partner-notices__item-head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.35rem 0.75rem;
  margin-bottom: 0.35rem;
}

.esd-partner-notices__item-title {
  margin: 0;
  font-size: 0.9375rem;
  font-weight: 700;
  color: #0f172a;
}

.esd-partner-notices__item-meta {
  margin: 0;
  font-size: 0.75rem;
  color: #64748b;
  white-space: nowrap;
  flex: 0 0 auto;
  min-width: 6.5rem;
}

.esd-partner-notices__item-link {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.35rem 1rem;
  text-decoration: none;
  color: inherit;
  padding: 0.5rem 0;
  border-bottom: 1px dashed #e8e4de;
}
.esd-partner-notices__item-link:hover .esd-partner-notices__item-title, .esd-partner-notices__item-link:focus-visible .esd-partner-notices__item-title {
  color: #0d9488;
  text-decoration: underline;
}
.esd-partner-notices__item-link:focus-visible {
  outline: 2px solid rgba(13, 148, 136, 0.45);
  outline-offset: 2px;
  border-radius: 0.25rem;
}
.esd-partner-notices__item-link .esd-partner-notices__item-title {
  flex: 1 1 12rem;
  min-width: 0;
}

.esd-recruit-grid {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -0.4rem;
}

.esd-recruit-grid__col {
  flex: 0 0 25%;
  max-width: 25%;
  padding: 0.4rem;
}

.page-users .row.esd-mypage-approved-grid {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -0.4rem;
}

.page-users .row.esd-mypage-approved-grid > .col-3.esd-mypage-approved-grid__col {
  box-sizing: border-box;
  padding: 0.4rem;
  flex: 1 1 100%;
  max-width: 100%;
  min-width: 0;
  display: flex;
}

@media (min-width: 560px) {
  .page-users .row.esd-mypage-approved-grid > .col-3.esd-mypage-approved-grid__col {
    flex: 0 0 50%;
    max-width: 50%;
  }
}
@media (min-width: 960px) {
  .page-users .row.esd-mypage-approved-grid > .col-3.esd-mypage-approved-grid__col {
    flex: 0 0 25%;
    max-width: 25%;
  }
}
.esd-recruit-card {
  height: 100%;
  border: 1px solid #e2e8f0;
  border-radius: 0.7rem;
  padding: 0.75rem;
  background: #fff;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.05);
}

.esd-recruit-card__school {
  margin: 0 0 0.35rem;
  color: #0369a1;
  font-size: 0.75rem;
  font-weight: 700;
}

.esd-recruit-card__title {
  margin: 0 0 0.4rem;
  font-size: 0.9rem;
  font-weight: 700;
  line-height: 1.35;
}

.esd-recruit-card__body {
  margin: 0;
  color: #475569;
  font-size: 0.79rem;
  line-height: 1.5;
  white-space: pre-line;
}

.esd-recruit-card__date {
  margin: 0.45rem 0 0;
  color: #94a3b8;
  font-size: 0.72rem;
}

.esd-partner-notice-detail {
  margin: 0 0 1.5rem;
  padding: 1.15rem 1.25rem 1.35rem;
  border-radius: 0.75rem;
  background: #fff;
}

.esd-partner-notice-detail__head {
  margin-bottom: 1rem;
  padding-bottom: 0.85rem;
  border-bottom: 1px solid #e8e4de;
}

.esd-partner-notice-detail__date {
  margin: 0 0 0.45rem;
  font-size: 0.8125rem;
  color: #64748b;
}

.esd-partner-notice-detail__title {
  margin: 0;
  font-size: 1.2rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #0f172a;
  line-height: 1.35;
}

.esd-partner-notice-detail__body {
  font-size: 0.9375rem;
  line-height: 1.65;
  color: #334155;
}
.esd-partner-notice-detail__body p {
  margin: 0 0 0.65rem;
}
.esd-partner-notice-detail__body p:last-child {
  margin-bottom: 0;
}

.esd-partner-notices__item-body {
  margin: 0;
  font-size: 0.875rem;
  line-height: 1.6;
  color: #334155;
  white-space: pre-wrap;
}

.esd-partner-notices__badge {
  display: inline-block;
  margin-right: 0.35rem;
  padding: 0.1rem 0.4rem;
  border-radius: 0.25rem;
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  vertical-align: 0.08em;
}

.esd-partner-notices__badge--rejection {
  background: #fef2f2;
  color: #b91c1c;
  border: 1px solid #fecaca;
}

.esd-partner-notices__badge--approval {
  background: #ecfdf5;
  color: #047857;
  border: 1px solid #a7f3d0;
}

.esd-partner-notices__badge--suspension {
  background: #fffbeb;
  color: #b45309;
  border: 1px solid #fde68a;
}

.esd-page-head {
  margin-bottom: 1.5rem;
}

.esd-page-head__title {
  margin: 0 0 0.35rem;
  font-size: 1.6875rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #0f172a;
  line-height: 1.25;
}

.esd-page-head__meta {
  margin: 0;
  font-size: 0.875rem;
  color: #64748b;
}

.esd-page-head__meta--row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 0.75rem;
}

.esd-page-head__hint-block {
  display: block;
  margin-top: 0.35rem;
}

.esd-back-link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  margin: 0 0 1rem;
  font-size: 0.875rem;
}

.esd-back-link--spaced {
  margin-top: 1.5rem;
}

.esd-status {
  display: inline-block;
  font-weight: 700;
  font-size: 0.875rem;
}

.esd-status--pending {
  color: #b45309;
}

.esd-status--ok {
  color: #047857;
}

.esd-status--bad {
  color: #b91c1c;
}

.esd-status-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.2rem 0.55rem;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 700;
  margin-left: 0.35rem;
  vertical-align: middle;
}

.esd-status-pill--ok {
  background: #d1fae5;
  color: #065f46;
}

.esd-status-pill--contract {
  background: #d1fae5;
  color: #065f46;
}

.esd-program-list__group {
  margin-top: 1.35rem;
}
.esd-program-list__group:first-of-type {
  margin-top: 0;
}

.esd-program-list__group-title {
  margin: 0 0 0.55rem;
  font-size: 1.0625rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #0f172a;
  display: flex;
  align-items: center;
  gap: 0.35rem;
}
.esd-program-list__group-title i {
  font-size: 1.05rem;
  color: #0d9488;
}

.esd-program-cards {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

@media (min-width: 520px) {
  .esd-program-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (min-width: 900px) {
  .esd-program-cards {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
.esd-program-cards__cell {
  margin: 0;
  min-width: 0;
  display: flex;
}

.esd-mypage-program-card {
  display: flex;
  flex-direction: column;
  width: 100%;
  min-height: 100%;
  background: #fff;
  border: 1px solid #e8e4de;
  border-radius: 0.65rem;
  overflow: hidden;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04), 0 6px 20px rgba(15, 23, 42, 0.06);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.esd-mypage-program-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(15, 23, 42, 0.08);
}

.esd-mypage-program-card__visual {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  overflow: hidden;
  background: #e2e8f0;
  flex-shrink: 0;
}

.esd-mypage-program-card__visual-actions {
  position: absolute;
  top: 0.35rem;
  right: 0.35rem;
  z-index: 2;
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0.3rem;
  pointer-events: none;
}
.esd-mypage-program-card__visual-actions > * {
  pointer-events: auto;
}

.esd-mypage-program-card__icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 0.4rem;
  background: rgba(15, 23, 42, 0.52);
  color: #fff;
  text-decoration: none;
  line-height: 1;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
  transition: background 0.15s ease, color 0.15s ease, transform 0.12s ease;
  cursor: pointer;
}
.esd-mypage-program-card__icon-btn .las {
  font-size: 1rem;
}
.esd-mypage-program-card__icon-btn:hover {
  background: rgba(15, 23, 42, 0.72);
  color: #fff;
  transform: scale(1.04);
}
.esd-mypage-program-card__icon-btn:focus {
  outline: none;
}
.esd-mypage-program-card__icon-btn:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 2px;
}

.esd-mypage-program-card__icon-btn--delete:hover {
  background: rgba(185, 28, 28, 0.88);
}

.esd-cover--mypage-program-card {
  position: absolute;
  inset: 0;
  width: 100%;
  max-width: none;
  height: 100%;
  border-radius: 0;
  margin: 0;
  background: #cbd5e1;
}

.esd-mypage-program-card__body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  padding: 0.85rem 1rem 1rem;
  min-height: 0;
}

.esd-mypage-program-card__title {
  margin: 0;
  font-size: 0.9375rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #0f172a;
  line-height: 1.35;
}

.esd-mypage-program-card__badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  align-items: center;
  min-height: 1.15rem;
}

.esd-mypage-program-card__tags {
  margin: 0;
}
.esd-mypage-program-card__tags .esd-program-tags {
  flex-wrap: wrap;
}

.esd-mypage-program-card__sum {
  margin: 0;
  font-size: 0.8125rem;
  color: #64748b;
  line-height: 1.5;
  flex: 1;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  overflow: hidden;
}

.esd-program-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.esd-program-list__lp-badge {
  display: inline-block;
  margin-left: 0;
  padding: 0.1rem 0.4rem;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  vertical-align: middle;
  color: #1d4ed8;
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  border-radius: 0.25rem;
}

.esd-program-list__scope-badge {
  display: inline-block;
  margin-left: 0;
  padding: 0.1rem 0.4rem;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  vertical-align: middle;
  color: #92400e;
  background: #fffbeb;
  border: 1px solid #fde68a;
  border-radius: 0.25rem;
}

.esd-program-list__status-pill {
  display: inline-block;
  margin-left: 0;
  padding: 0.1rem 0.4rem;
  font-size: 0.65rem;
  font-weight: 700;
  vertical-align: middle;
  color: #64748b;
  background: #f1f5f9;
  border: 1px solid #e2e8f0;
  border-radius: 0.25rem;
}

.esd-program-list__meta {
  margin: 0.2rem 0 0;
  font-size: 0.8125rem;
  color: #64748b;
  line-height: 1.45;
}

.esd-program-list__actions {
  margin-top: 0.35rem;
}

.esd-prose {
  margin: 0.75rem 0 0;
  white-space: pre-wrap;
  font-size: 0.875rem;
  color: #334155;
  line-height: 1.6;
}

.esd-partner-body .page-users .page-users__table {
  border-radius: 0.75rem;
  border-color: #e8e4de;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04), 0 6px 20px rgba(15, 23, 42, 0.06);
  overflow: hidden;
}

.esd-section-title {
  margin: 1.75rem 0 0.65rem;
  font-size: 1.0625rem;
  font-weight: 700;
  color: #0f172a;
  letter-spacing: -0.02em;
}

.esd-partner-body .page-user-form .esd-section-title {
  padding-bottom: 0.4rem;
  margin-top: 1.5rem;
  margin-bottom: 0.45rem;
  border-bottom: 1px solid rgba(226, 232, 240, 0.95);
}

.esd-section-title--tight {
  margin-top: 1.25rem;
}

.page-users--company-signup {
  padding-top: 3rem;
}

.esd-partner-body .page-user-form,
.page-users--company-signup .page-user-form {
  max-width: 960px;
}

.page-users--company-signup .page-user-form {
  padding: 1.25rem 1.35rem 1.35rem;
  border-radius: 0.75rem;
  border: 1px solid #e8e4de;
  background: #fff;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04), 0 6px 20px rgba(15, 23, 42, 0.06);
}

.esd-partner-body .page-user-form .field {
  margin-bottom: 1.2rem;
}
.esd-partner-body .page-user-form .field label {
  display: block;
  margin-bottom: 0.35rem;
  font-weight: 600;
  font-size: 0.875rem;
  color: #0f172a;
  letter-spacing: 0.01em;
}
.esd-partner-body .page-user-form .field .field__hint {
  display: block;
  margin: -0.1rem 0 0.5rem;
  font-size: 0.78125rem;
  line-height: 1.45;
  color: #64748b;
}
.esd-partner-body .page-user-form .field input[type=email],
.esd-partner-body .page-user-form .field input[type=password],
.esd-partner-body .page-user-form .field input[type=tel],
.esd-partner-body .page-user-form .field input[type=text],
.esd-partner-body .page-user-form .field input[type=url],
.esd-partner-body .page-user-form .field input[type=number],
.esd-partner-body .page-user-form .field input[type=date],
.esd-partner-body .page-user-form .field input[type=datetime-local],
.esd-partner-body .page-user-form .field select,
.esd-partner-body .page-user-form .field textarea {
  width: 100%;
  box-sizing: border-box;
  padding: 0.55rem 0.85rem;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  font-size: 0.9375rem;
  line-height: 1.45;
  color: #0f172a;
  background: #fff;
  transition: border-color 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}
.esd-partner-body .page-user-form .field input[type=email]::placeholder,
.esd-partner-body .page-user-form .field input[type=password]::placeholder,
.esd-partner-body .page-user-form .field input[type=tel]::placeholder,
.esd-partner-body .page-user-form .field input[type=text]::placeholder,
.esd-partner-body .page-user-form .field input[type=url]::placeholder,
.esd-partner-body .page-user-form .field input[type=number]::placeholder,
.esd-partner-body .page-user-form .field input[type=date]::placeholder,
.esd-partner-body .page-user-form .field input[type=datetime-local]::placeholder,
.esd-partner-body .page-user-form .field select::placeholder,
.esd-partner-body .page-user-form .field textarea::placeholder {
  color: #94a3b8;
}
.esd-partner-body .page-user-form .field input[type=email]:hover:not(:disabled),
.esd-partner-body .page-user-form .field input[type=password]:hover:not(:disabled),
.esd-partner-body .page-user-form .field input[type=tel]:hover:not(:disabled),
.esd-partner-body .page-user-form .field input[type=text]:hover:not(:disabled),
.esd-partner-body .page-user-form .field input[type=url]:hover:not(:disabled),
.esd-partner-body .page-user-form .field input[type=number]:hover:not(:disabled),
.esd-partner-body .page-user-form .field input[type=date]:hover:not(:disabled),
.esd-partner-body .page-user-form .field input[type=datetime-local]:hover:not(:disabled),
.esd-partner-body .page-user-form .field select:hover:not(:disabled),
.esd-partner-body .page-user-form .field textarea:hover:not(:disabled) {
  border-color: #cbd5e1;
}
.esd-partner-body .page-user-form .field input[type=email]:focus,
.esd-partner-body .page-user-form .field input[type=password]:focus,
.esd-partner-body .page-user-form .field input[type=tel]:focus,
.esd-partner-body .page-user-form .field input[type=text]:focus,
.esd-partner-body .page-user-form .field input[type=url]:focus,
.esd-partner-body .page-user-form .field input[type=number]:focus,
.esd-partner-body .page-user-form .field input[type=date]:focus,
.esd-partner-body .page-user-form .field input[type=datetime-local]:focus,
.esd-partner-body .page-user-form .field select:focus,
.esd-partner-body .page-user-form .field textarea:focus {
  outline: none;
  border-color: #0d9488;
  box-shadow: 0 0 0 3px rgba(13, 148, 136, 0.14);
}
.esd-partner-body .page-user-form .field input[type=email]:disabled,
.esd-partner-body .page-user-form .field input[type=password]:disabled,
.esd-partner-body .page-user-form .field input[type=tel]:disabled,
.esd-partner-body .page-user-form .field input[type=text]:disabled,
.esd-partner-body .page-user-form .field input[type=url]:disabled,
.esd-partner-body .page-user-form .field input[type=number]:disabled,
.esd-partner-body .page-user-form .field input[type=date]:disabled,
.esd-partner-body .page-user-form .field input[type=datetime-local]:disabled,
.esd-partner-body .page-user-form .field select:disabled,
.esd-partner-body .page-user-form .field textarea:disabled {
  opacity: 0.65;
  cursor: not-allowed;
  background: #f8fafc;
}
.esd-partner-body .page-user-form .field textarea {
  resize: vertical;
  min-height: 5.5rem;
}
.esd-partner-body .page-user-form .field input[type=file] {
  width: 100%;
  max-width: 100%;
  padding: 0.5rem 0.65rem;
  font-size: 0.8125rem;
  border: 1px dashed #cbd5e1;
  border-radius: 0.5rem;
  background: #f8fafc;
  cursor: pointer;
}
.esd-partner-body .page-user-form .field input[type=file]:hover {
  border-color: #94a3b8;
  background: #f1f5f9;
}
.esd-partner-body .page-user-form .actions,
.esd-partner-body .page-user-form .esd-signup-actions {
  margin-top: 1.35rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(232, 228, 222, 0.9);
}

.esd-form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: center;
  margin-top: 1.5rem;
}

.esd-checkbox-label {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 0.75rem;
  font-size: 0.875rem;
  cursor: pointer;
}

.esd-checkbox-label--block {
  align-items: flex-start;
}
.esd-checkbox-label--block input[type=checkbox] {
  margin-top: 0.2rem;
}
.esd-checkbox-label--block span {
  line-height: 1.45;
}

.esd-program-content-previews {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(11rem, 1fr));
  gap: 1rem;
  margin-bottom: 1rem;
}

.esd-program-content-preview {
  border: 1px solid #e8e4de;
  border-radius: 0.75rem;
  padding: 0.5rem;
  background: #fff;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04), 0 6px 20px rgba(15, 23, 42, 0.06);
}

.esd-program-content-preview__img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 4/3;
  object-fit: cover;
  border-radius: 0.35rem;
  background: #f1f5f9;
}

.esd-program-content-preview__remove {
  margin-top: 0.5rem;
  font-size: 0.8125rem;
}

.esd-btn--danger-outline {
  color: #b91c1c !important;
  border-color: #fecaca !important;
}
.esd-btn--danger-outline:hover {
  background: #fef2f2 !important;
  border-color: #f87171 !important;
}

.esd-error-list {
  margin: 0 0 1rem;
  padding: 0.65rem 0.85rem 0.65rem 1.15rem;
  border-radius: 0.5rem;
  border: 1px solid #fecaca;
  background: #fef2f2;
  color: #991b1b;
  font-size: 0.875rem;
  line-height: 1.45;
}

.esd-partner-body .page-user-form > .esd-error-list:first-child {
  margin-top: 0;
}

.esd-error-list li {
  margin: 0.2rem 0;
  text-decoration: none;
  list-style: none;
}

.esd-msg-thread {
  margin-bottom: 1.15rem;
}

.esd-msg-list li:first-child {
  padding-top: 0;
}

.esd-msg-list li:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.esd-msg-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.esd-msg-list li {
  padding: 0.75rem 0;
  border-bottom: 1px solid #e2e8f0;
}

.esd-msg-meta {
  font-size: 0.75rem;
  color: #64748b;
  margin-bottom: 0.25rem;
}

.esd-msg-body {
  font-size: 0.9375rem;
  white-space: pre-wrap;
}

.esd-partner-msg-page .esd-partner-msg-layout.row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 0 1rem;
  margin: 0 -0.25rem 1rem;
}
.esd-partner-msg-page .esd-partner-msg-layout.row > .col-8 {
  flex: 1 1 calc(66.666% - 0.5rem);
  min-width: min(100%, 17rem);
  max-width: 100%;
  padding: 0 0.25rem;
  box-sizing: border-box;
}
.esd-partner-msg-page .esd-partner-msg-layout.row > .col-4 {
  flex: 1 1 calc(33.333% - 0.5rem);
  min-width: min(100%, 14rem);
  max-width: 100%;
  padding: 0 0.25rem;
  box-sizing: border-box;
}
@media (max-width: 767px) {
  .esd-partner-msg-page .esd-partner-msg-layout.row > .col-8,
  .esd-partner-msg-page .esd-partner-msg-layout.row > .col-4 {
    flex: 1 1 100%;
    max-width: 100%;
  }
}
.esd-partner-msg-page .esd-partner-msg-layout__main {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  min-width: 0;
}
.esd-partner-msg-page .esd-partner-msg-stream__empty {
  margin: 0;
  font-size: 0.8125rem;
  color: #64748b;
  line-height: 1.55;
}
.esd-partner-msg-page .esd-partner-msg-stream {
  border: 1px solid #e2e8f0;
  border-radius: 0.65rem;
  background: #f8fafc;
  padding: 0.85rem 0.75rem;
  max-height: min(58vh, 30rem);
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  margin-bottom: 0;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}
.esd-partner-msg-page .esd-partner-msg-bubble-wrap {
  display: flex;
  width: 100%;
}
.esd-partner-msg-page .esd-partner-msg-bubble-wrap.is-mine {
  justify-content: flex-end;
}
.esd-partner-msg-page .esd-partner-msg-bubble-wrap.is-theirs {
  justify-content: flex-start;
}
.esd-partner-msg-page .esd-partner-msg-bubble {
  max-width: min(100%, 26rem);
  border-radius: 1rem;
  padding: 0.55rem 0.75rem 0.45rem;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
}
.esd-partner-msg-page .is-theirs .esd-partner-msg-bubble {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-bottom-left-radius: 0.25rem;
}
.esd-partner-msg-page .is-mine .esd-partner-msg-bubble {
  background: #ecfdf5;
  border: 1px solid #a7f3d0;
  border-bottom-right-radius: 0.25rem;
}
.esd-partner-msg-page .esd-partner-msg-bubble__body {
  margin: 0;
  font-size: 0.9375rem;
  line-height: 1.55;
  color: #0f172a;
  white-space: pre-wrap;
  word-break: break-word;
}
.esd-partner-msg-page .esd-partner-msg-bubble__foot {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.45rem;
  margin-top: 0.35rem;
  flex-wrap: wrap;
}
.esd-partner-msg-page .esd-partner-msg-bubble__time {
  font-size: 0.6875rem;
  color: #64748b;
  font-weight: 600;
}
.esd-partner-msg-page .esd-partner-msg-bubble__read {
  font-size: 0.6875rem;
  font-weight: 700;
  color: #047857;
}
.esd-partner-msg-page .esd-partner-msg-compose {
  margin-bottom: 0;
}
.esd-partner-msg-page .esd-partner-msg-layout__aside {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  min-width: 0;
}
.esd-partner-msg-page .esd-partner-msg-aside-block {
  padding: 1rem 1.1rem;
  margin-bottom: 0;
}
.esd-partner-msg-page .esd-partner-msg-aside-block--muted {
  background: #fafafa;
}
.esd-partner-msg-page .esd-partner-msg-aside__h {
  margin: 0 0 0.45rem;
  font-size: 0.8125rem;
  font-weight: 700;
  color: #64748b;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.esd-partner-msg-page .esd-partner-msg-aside__lead {
  margin: 0;
  font-size: 1rem;
  font-weight: 700;
  color: #0f172a;
  line-height: 1.4;
}
.esd-partner-msg-page .esd-partner-msg-aside__program-title {
  margin: 0 0 0.5rem;
  font-size: 0.9375rem;
  font-weight: 700;
  color: #0f172a;
  line-height: 1.45;
}
.esd-partner-msg-page .esd-partner-msg-aside__dl {
  margin: 0;
  display: grid;
  grid-template-columns: max-content minmax(0, 1fr);
  gap: 0.35rem 0.65rem;
  font-size: 0.8125rem;
  align-items: baseline;
}
.esd-partner-msg-page .esd-partner-msg-aside__dl dt {
  margin: 0;
  font-weight: 600;
  color: #64748b;
}
.esd-partner-msg-page .esd-partner-msg-aside__dl dd {
  margin: 0;
  color: #1e293b;
  word-break: break-word;
}
.esd-partner-msg-page .esd-partner-msg-aside__muted {
  margin: 0;
  font-size: 0.8125rem;
  color: #64748b;
  line-height: 1.55;
}

.page-users--company-signup {
  max-width: 960px;
  padding-top: 0.35rem;
}
.page-users--company-signup > h1.page-users__title.esd-signup-page-title {
  color: #272727;
}

.esd-signup-page-title {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  margin-top: 0.35rem;
  color: #272727;
}

.esd-signup-page-title__icon {
  flex-shrink: 0;
  margin-top: 0.12rem;
  font-size: 1.65rem;
  color: #272727;
  line-height: 1;
}

.esd-signup-page-title__text {
  flex: 1;
  min-width: 0;
}

.esd-signup-section-hdg {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem 0.6rem;
  margin-top: 1.35rem !important;
  margin-bottom: 0.35rem;
  padding: 0;
  border: none;
  background: transparent;
  font-size: 1rem !important;
  color: #272727;
}

.esd-signup-section-hdg:has(.esd-signup-heading__badge) {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: auto auto;
  align-items: start;
  column-gap: 0.45rem;
  row-gap: 0.35rem;
}

.esd-signup-section-hdg:has(.esd-signup-heading__badge) .esd-signup-heading__badge {
  grid-column: 1/-1;
  grid-row: 1;
  justify-self: start;
}

.esd-signup-section-hdg:has(.esd-signup-heading__badge) .esd-signup-heading__icon {
  grid-column: 1;
  grid-row: 2;
}

.esd-signup-section-hdg:has(.esd-signup-heading__badge) .esd-signup-heading__text {
  grid-column: 2;
  grid-row: 2;
  min-width: 0;
}

.esd-signup-section-hdg--sub {
  margin-top: 1.05rem !important;
  margin-bottom: 0.35rem;
  padding: 0;
  border: none;
  background: transparent;
}
.esd-signup-section-hdg--sub .esd-signup-heading__icon {
  font-size: 1.1rem;
  color: #272727;
}
.esd-signup-section-hdg--sub .esd-signup-heading__text {
  font-weight: 600;
  font-size: 0.9375rem;
  color: #272727;
}

.esd-signup-heading__badge {
  display: inline-flex;
  align-items: center;
  padding: 1rem 0 0.5rem;
  border-radius: 0.3rem;
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #272727;
  background: transparent;
}

.esd-signup-heading__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  color: #272727;
  line-height: 1;
}

.esd-signup-heading__text {
  font-weight: 700;
  letter-spacing: -0.02em;
}

.esd-signup-steps {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 0.55rem;
  margin: 1.35rem 0 1.75rem;
  padding: 0;
  list-style: none;
  border: none;
  background: transparent;
}

.esd-signup-steps__item {
  flex: 1 1 6.5rem;
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: auto auto;
  align-items: start;
  column-gap: 0.4rem;
  row-gap: 0.25rem;
  padding: 0.35rem 0;
  border-radius: 0;
  border: none;
  border-bottom: 1px solid #e2e8f0;
  background: transparent;
  color: #64748b;
  font-size: 0.78rem;
  font-weight: 600;
}

.esd-signup-steps__item .esd-signup-steps__badge {
  grid-column: 1/-1;
  grid-row: 1;
  justify-self: start;
}

.esd-signup-steps__item .esd-signup-steps__icon {
  grid-column: 1;
  grid-row: 2;
}

.esd-signup-steps__item .esd-signup-steps__label {
  grid-column: 2;
  grid-row: 2;
  min-width: 0;
}

.esd-signup-steps__item--done {
  color: #272727;
}
.esd-signup-steps__item--done .esd-signup-steps__badge {
  color: #272727;
  border-color: #272727;
  background: transparent;
}
.esd-signup-steps__item--done .esd-signup-steps__icon {
  color: #272727;
}

.esd-signup-steps__item--current {
  color: #272727;
  border-bottom-color: #ccc;
}
.esd-signup-steps__item--current .esd-signup-steps__badge {
  color: #272727;
  border-color: #ccc;
  background: transparent;
}
.esd-signup-steps__item--current .esd-signup-steps__icon {
  color: #272727;
}

.esd-signup-steps__badge {
  display: inline-flex;
  align-items: center;
  padding: 0.1rem 0;
  border-radius: 0.25rem;
  font-size: 0.58rem;
  font-weight: 800;
  letter-spacing: 0.05em;
  color: #64748b;
  background: transparent;
  flex-shrink: 0;
}

.esd-signup-steps__icon {
  flex-shrink: 0;
  font-size: 1.1rem;
  color: #64748b;
  line-height: 1;
}

.esd-signup-steps__label {
  line-height: 1.35;
  min-width: 0;
}

@media (max-width: 767px) {
  .esd-signup-steps {
    flex-direction: column;
    flex-wrap: nowrap;
    gap: 0;
    align-items: stretch;
  }
  .esd-signup-steps__item {
    flex: none;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    padding: 0.55rem 0;
  }
  .esd-signup-steps__item .esd-signup-steps__label {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}
.esd-signup-lead {
  margin-top: 0.65rem;
  padding: 1rem 0;
  border: none;
  background: transparent;
  line-height: 1.65;
}

.esd-signup-account-lead {
  margin-top: -0.35rem;
  margin-bottom: 0.65rem;
}

.esd-signup-step3-password-note {
  margin-bottom: 1rem;
}

.esd-dropzone-list {
  display: grid;
  gap: 0.65rem;
}

.esd-dropzone {
  position: relative;
  display: block;
  border: 1px dashed #cbd5e1;
  border-radius: 0.5rem;
  background: #f8fafc;
  padding: 0.8rem 0.9rem;
  cursor: pointer;
}

.esd-dropzone__title {
  display: block;
  font-size: 0.875rem;
  font-weight: 700;
  color: #334155;
}

.esd-dropzone__sub {
  display: block;
  margin-top: 0.15rem;
  font-size: 0.78rem;
  color: #64748b;
}

.esd-dropzone__input {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
}

.esd-signup-actions {
  margin-top: 1.25rem;
}

.esd-signup-back {
  margin: 0 0 0.75rem;
}

.esd-signup-actions--row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.65rem 0.85rem;
}
.esd-signup-actions--row .esd-signup-actions__back-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  margin-right: auto;
  text-align: center;
}
.esd-signup-actions--row .esd-signup-actions__next,
.esd-signup-actions--row input[type=submit].btn--primary {
  flex-shrink: 0;
}

.esd-signup-summary {
  margin: 0 0 1.5rem;
  padding: 0;
  border: none;
  background: transparent;
  color: #0f172a;
}
.esd-signup-summary .esd-signup-section-hdg,
.esd-signup-summary .page-users__title {
  color: #272727;
}

.esd-signup-summary__dl {
  margin: 0;
  display: grid;
  grid-template-columns: minmax(6.5rem, 28%) 1fr;
  gap: 0.35rem 0.75rem;
  font-size: 0.875rem;
  color: #0f172a;
}

.esd-signup-summary__dl dt {
  margin: 0;
  font-weight: 700;
  color: #64748b;
  font-size: 0.78rem;
}

.esd-signup-summary__dl dd {
  margin: 0;
  line-height: 1.5;
}

.esd-signup-summary__pre {
  white-space: pre-wrap;
  word-break: break-word;
}

.esd-signup-footer-link {
  margin-top: 1.25rem;
}

.esd-program-tags {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  align-items: center;
}

.esd-program-tags__pill {
  display: inline-flex;
  align-items: center;
  gap: 0.2rem;
  padding: 0.12rem 0.45rem 0.12rem 0.35rem;
  border-radius: 999px;
  font-size: 0.6875rem;
  font-weight: 700;
  line-height: 1.25;
  color: #0369a1;
  background: #e0f2fe;
  border: 1px solid #bae6fd;
}

.esd-program-tags__icon {
  font-size: 0.8rem;
  opacity: 0.92;
  line-height: 1;
}

.esd-program-tags__text {
  line-height: 1.2;
}

.esd-program-tags--empty {
  color: #94a3b8;
  font-size: 0.8125rem;
  font-weight: 600;
}

.esd-program-tags--list .esd-program-tags__pill {
  font-size: 0.7rem;
}

.esd-tag-picker {
  border: 0;
  margin: 0 0 1.35rem;
  padding: 1rem 1.05rem 1.15rem;
  border-radius: 0.75rem;
  border: 1px solid rgba(13, 148, 136, 0.18);
  background: linear-gradient(165deg, #f0fdf9 0%, #fff 42%, #fafaf9 100%);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04), inset 0 1px 0 rgba(255, 255, 255, 0.85);
}

.esd-tag-picker__legend {
  font-weight: 700;
  font-size: 0.9375rem;
  padding: 0;
  margin: 0 0 0.4rem;
  color: #0f172a;
  letter-spacing: -0.01em;
}

.esd-tag-picker__hint {
  margin: 0 0 0.85rem;
  font-size: 0.78125rem;
  line-height: 1.5;
  color: #64748b;
}

.esd-tag-picker__section-title {
  margin: 0.5rem 0 0.45rem;
  font-size: 0.875rem;
  font-weight: 700;
  color: #0f172a;
}

.esd-tag-picker__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(10.5rem, 1fr));
  gap: 0.5rem;
}
@media (min-width: 520px) {
  .esd-tag-picker__grid {
    grid-template-columns: repeat(auto-fill, minmax(11.25rem, 1fr));
  }
}

.esd-tag-chip {
  position: relative;
  cursor: pointer;
  user-select: none;
  min-width: 0;
}

.esd-tag-chip__input {
  position: absolute;
  opacity: 0;
  width: 1px;
  height: 1px;
  margin: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.esd-tag-chip__face {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  min-height: 2.5rem;
  padding: 0.45rem 0.7rem 0.45rem 0.55rem;
  border-radius: 999px;
  border: 1px solid #e2e8f0;
  background: #fff;
  font-size: 0.8125rem;
  font-weight: 600;
  color: #0f172a;
  line-height: 1.25;
  transition: border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease, transform 0.1s ease, color 0.15s ease;
  box-shadow: 0 1px 1px rgba(15, 23, 42, 0.03);
}

.esd-tag-chip:hover .esd-tag-chip__face {
  border-color: #99f6e4;
  background: #f0fdfa;
}

.esd-tag-chip:active .esd-tag-chip__face {
  transform: scale(0.98);
}

.esd-tag-chip__input:focus-visible + .esd-tag-chip__face {
  outline: 2px solid #0d9488;
  outline-offset: 2px;
}

.esd-tag-chip__input:checked + .esd-tag-chip__face {
  border-color: #2dd4bf;
  background: linear-gradient(155deg, #ecfdf5 0%, #ccfbf1 55%, #99f6e4 160%);
  color: #0f766e;
  box-shadow: 0 1px 4px rgba(13, 148, 136, 0.15), inset 0 1px 0 rgba(255, 255, 255, 0.5);
}

.esd-tag-chip__input:checked:focus-visible + .esd-tag-chip__face {
  outline-color: #0f766e;
}

.esd-tag-chip__icon {
  flex-shrink: 0;
  font-size: 1.05rem;
  color: #14b8a6;
  line-height: 1;
  opacity: 0.92;
}

.esd-tag-chip__input:checked + .esd-tag-chip__face .esd-tag-chip__icon {
  color: #0d9488;
}

.esd-tag-chip__label {
  flex: 1;
  min-width: 0;
  line-height: 1.3;
  hyphens: auto;
}

.esd-sdg-picker {
  margin: 1rem 0 1.25rem;
}

.esd-sdg-picker__legend {
  font-size: 0.95rem;
  font-weight: 700;
  color: #334155;
  margin-bottom: 0.35rem;
}

.esd-sdg-picker__hint {
  margin-bottom: 0.6rem;
}

.esd-sdg-picker__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(11rem, 1fr));
  gap: 0.55rem;
}

.esd-sdg-chip {
  position: relative;
  cursor: pointer;
  user-select: none;
}

.esd-sdg-chip__input {
  position: absolute;
  opacity: 0;
  width: 1px;
  height: 1px;
  margin: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.esd-sdg-chip__face {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  min-height: 2.65rem;
  padding: 0.35rem 0.45rem;
  border: 1px solid #e2e8f0;
  border-radius: 0.55rem;
  background: #fff;
  transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.1s ease;
}

.esd-sdg-chip__img {
  width: 2rem;
  height: 2rem;
  object-fit: cover;
  border-radius: 0.35rem;
  flex-shrink: 0;
}

.esd-sdg-chip__label {
  font-size: 0.78rem;
  font-weight: 600;
  color: #334155;
  line-height: 1.3;
}

.esd-sdg-chip:hover .esd-sdg-chip__face {
  border-color: #93c5fd;
}

.esd-sdg-chip:active .esd-sdg-chip__face {
  transform: scale(0.99);
}

.esd-sdg-chip__input:focus-visible + .esd-sdg-chip__face {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
}

.esd-sdg-chip__input:checked + .esd-sdg-chip__face {
  border-color: #2563eb;
  box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.14) inset;
}

.esd-program-sdg-badges--overlay {
  position: absolute;
  top: 0.45rem;
  left: 0.45rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
  z-index: 3;
  max-width: calc(100% - 1rem);
}

.esd-program-sdg-badge {
  display: inline-flex;
  width: 1.8rem;
  height: 1.8rem;
  border-radius: 0.35rem;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.9);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.25);
  background: #fff;
}

.esd-program-sdg-badge img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.esd-program-sdg-badges--detail {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.7rem;
}

.esd-program-sdg-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.24rem 0.45rem 0.24rem 0.24rem;
  border-radius: 999px;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  color: #334155;
  font-size: 0.78rem;
  font-weight: 600;
}

.esd-program-sdg-chip img {
  width: 1.2rem;
  height: 1.2rem;
  border-radius: 0.2rem;
  object-fit: cover;
}

.esd-partner-main--lp {
  max-width: none;
  margin: 0;
  padding: 0;
}

.esd-lp-v2 {
  color: #0f172a;
  font-family: system-ui, -apple-system, "Segoe UI", sans-serif;
}
.esd-lp-v2 * {
  box-sizing: border-box;
}

.esd-lp-v2-hero {
  position: relative;
  min-height: min(100vh, 800px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 3rem 1.5rem 4rem;
  background-image: url(/assets/esd_lp/top-17d8ce18ae30609eb4abd7622873be9ec92610ba67ff8b6e11cd874fc348fae7.jpg);
  background-size: cover;
}
.esd-lp-v2-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: rgba(0, 0, 0, 0.3);
}

.esd-lp-v2-hero__inner {
  position: relative;
  z-index: 1;
  max-width: 56rem;
  margin: 0 16px;
  color: white;
}

.esd-lp-v2-kicker {
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: white;
  margin: 0 0 0.5rem;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.esd-lp-v2-kicker > i {
  font-size: 1rem;
  letter-spacing: 0;
  text-transform: none;
  color: #0369a1;
  opacity: 0.9;
}

.esd-lp-v2-title {
  margin: 0 0 1rem;
  font-size: clamp(1.75rem, 4vw, 2.35rem);
  font-weight: 800;
  line-height: 1.25;
  letter-spacing: -0.02em;
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
}

.esd-lp-v2-title__icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.75rem;
  height: 2.75rem;
  margin-top: 0.15rem;
  border-radius: 0.5rem;
  background: rgba(255, 255, 255, 0.85);
  color: #0369a1;
  font-size: 1.5rem;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.08);
}

.esd-lp-v2-title__text {
  flex: 1;
  min-width: 0;
}

.esd-lp-v2-lead {
  margin: 0 0 1.75rem;
  font-size: 0.98rem;
  line-height: 1.75;
  color: white;
  max-width: 40rem;
  white-space: pre-line;
}

.esd-lp-v2-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.esd-lp-v2-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  padding: 0.65rem 1.35rem;
  font-size: 0.875rem;
  font-weight: 600;
  text-decoration: none;
  border-radius: 9999px;
  border: none;
  cursor: pointer;
  transition: transform 0.12s, box-shadow 0.12s;
}
.esd-lp-v2-btn i {
  font-size: 1.15rem;
  flex-shrink: 0;
}
.esd-lp-v2-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(15, 23, 42, 0.12);
}
.esd-lp-v2-btn--primary {
  background: #0369a1;
  color: #fff;
}
.esd-lp-v2-btn--ghost {
  background: #fff;
  color: #0f172a;
  border: 1px solid #cbd5e1;
}
.esd-lp-v2-btn--programs {
  background: #0369a1;
  color: #fff;
  border-color: #0369a1;
}

.esd-lp-v2-section {
  padding: 3rem 1.5rem;
  max-width: 72rem;
  margin: calc(80px + 2rem) auto;
}

.esd-lp-v2-section__head {
  margin-bottom: 1.5rem;
}

.esd-lp-v2-section__en {
  display: block;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  color: #94a3b8;
  margin-bottom: 0.25rem;
  text-align: left;
}
.esd-lp-v2-section__en > i {
  font-size: 1rem;
  letter-spacing: 0;
  color: #64748b;
}

.esd-lp-v2-section__ja {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 700;
}

.esd-lp-v2-section__head--focus {
  text-align: center;
}

.esd-lp-v2-section__head--focus .esd-lp-v2-section__en {
  justify-content: center;
  font-size: 0.8rem;
  margin-bottom: 1rem;
  text-align: center;
}

.esd-lp-v2-section__ja--focus {
  font-size: 1.7rem;
}

.esd-lp-v2-section__head--sub {
  margin-top: 1.4rem;
  text-align: center;
}

.esd-lp-v2-section__head--sub > .esd-lp-v2-section__en {
  text-align: center;
}

.esd-lp-v2-section__ja--sub {
  font-size: 1.7rem;
  display: inline-block;
}

.esd-lp-v2-section__ja--focus-item {
  font-size: 1.25rem;
  color: #333;
  font-weight: 600;
  margin-bottom: 0rem;
}

.esd-lp-v2-focus-block {
  margin: 80px 0;
}

.esd-lp-v2-recruit-grid {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -0.4rem;
}

.esd-lp-v2-recruit-col {
  flex: 0 0 25%;
  max-width: 25%;
  padding: 0.4rem;
}

.esd-lp-v2-recruit-card {
  height: 100%;
  border: 1px solid #e2e8f0;
  border-radius: 0.7rem;
  padding: 0.75rem;
  background: #fff;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
}

.esd-lp-v2-recruit-card__school {
  margin: 0 0 0.35rem;
  color: #0369a1;
  font-size: 0.75rem;
  font-weight: 700;
}

.esd-lp-v2-recruit-card__title {
  margin: 0 0 0.4rem;
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1.35;
}

.esd-lp-v2-recruit-card__body {
  margin: 0;
  font-size: 0.8rem;
  line-height: 1.55;
  color: #475569;
  white-space: pre-line;
}

.esd-lp-v2-recruit-card__date {
  margin: 0.5rem 0 0;
  font-size: 0.72rem;
  color: #94a3b8;
}

.esd-lp-v2-focus-item__icon {
  display: block;
  width: fit-content;
  margin: 0 auto 0.4rem;
  color: #2563eb;
}
.esd-lp-v2-focus-item__icon i {
  font-size: 1.45rem;
  line-height: 1;
}

.esd-lp-v2-section__lead {
  margin: 0.65rem auto 2rem;
  max-width: 52rem;
  font-size: 0.95rem;
  line-height: 1.75;
  color: #475569;
  white-space: pre-line;
}

.esd-lp-v2-rights-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.85rem;
  margin-bottom: 3rem;
}

.esd-lp-v2-rights-grid > .esd-lp-v2-rights-col {
  width: auto;
  max-width: none;
  float: none;
  padding: 0;
}

.esd-lp-v2-rights-card {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
}

.esd-lp-v2-rights-card__img {
  display: block;
  width: 100%;
  height: auto;
}

.esd-lp-v2-learning-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.85rem;
}

.esd-lp-v2-learning-grid > .esd-lp-v2-learning-col {
  width: auto;
  max-width: none;
  float: none;
  padding: 0;
}

.esd-lp-v2-sdgs-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 0.75rem;
  margin-top: 0.85rem;
}

.esd-lp-v2-sdgs-grid > .esd-lp-v2-sdgs-col {
  width: auto;
  max-width: none;
  float: none;
  padding: 0;
}

@media (max-width: 1023px) {
  .esd-lp-v2-rights-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .esd-lp-v2-learning-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .esd-lp-v2-sdgs-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}
@media (max-width: 767px) {
  .esd-lp-v2-rights-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .esd-lp-v2-learning-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .esd-lp-v2-sdgs-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
.esd-lp-v2-learning-card {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  min-height: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  padding: 0.6rem;
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
}

.esd-lp-v2-learning-card__img {
  width: auto;
  height: 100px;
  object-fit: contain;
  display: block;
  margin: 2rem auto;
}

.esd-lp-v2-learning-card__body {
  width: 100%;
}

.esd-lp-v2-learning-card__title {
  margin: 0 0 0.45rem;
  font-size: 0.95rem;
  line-height: 1.4;
  text-align: center;
}

.esd-lp-v2-learning-card__body p {
  margin: 0;
  font-size: 0.82rem;
  line-height: 1.6;
  color: #334155;
}

.esd-lp-v2-sdgs-card {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
}

.esd-lp-v2-sdgs-card__img {
  display: block;
  width: 100%;
  height: auto;
}

.esd-lp-v2-section.esd-lp-v2-section--programs {
  position: relative;
  max-width: none;
  width: 100%;
  margin: calc(80px + 2rem) 0;
  padding: calc(80px + 2rem) 0;
  box-sizing: border-box;
  overflow-x: visible;
  overflow-y: visible;
  background-image: url(/assets/esd_lp/slidebg-2de334bc43bf24ad96ef6bc05b1e3d54da3ab37ba1bdd0ebb415efd20c5108ca.jpg);
  background-size: cover;
}
.esd-lp-v2-section.esd-lp-v2-section--programs::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(248, 250, 252, 0.55);
  pointer-events: none;
}
.esd-lp-v2-section.esd-lp-v2-section--programs .esd-lp-v2-section__head {
  margin-bottom: 1.5rem;
  text-align: left;
}
.esd-lp-v2-section.esd-lp-v2-section--programs .esd-lp-v2-section__en {
  color: #64748b;
  justify-content: flex-start;
  text-align: left;
}
.esd-lp-v2-section.esd-lp-v2-section--programs .esd-lp-v2-section__ja {
  color: #0f172a;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.6);
  text-align: left;
  margin: 0 0 3rem;
}

.esd-lp-v2-section--programs__inner {
  position: relative;
  z-index: 1;
  max-width: 72rem;
  margin: 0 auto;
  padding: 0 1.5rem;
  box-sizing: border-box;
  text-align: left;
}

.esd-lp-v2-section--programs__carousel-breakout {
  position: relative;
  z-index: 1;
  width: 100%;
  padding-left: max(1.5rem, calc((100% - 72rem) / 2 + 1.5rem));
  padding-right: 0;
  box-sizing: border-box;
}

.esd-lp-v2-section--programs__carousel-row {
  display: flex;
  justify-content: flex-end;
  width: 100%;
}

.esd-lp-v2-section--programs .esd-lp-v2-carousel-outer {
  flex: 1 1 auto;
  width: 100%;
  min-width: 0;
  max-width: none;
}

.esd-lp-v2-section--programs .esd-lp-v2-carousel__dots {
  justify-content: flex-start;
}

@media (max-width: 639px) {
  .esd-lp-v2-section--programs__carousel-row {
    justify-content: stretch;
  }
  .esd-lp-v2-section--programs .esd-lp-v2-carousel__dots {
    justify-content: flex-start;
  }
}
.esd-lp-v2-section--programs__empty {
  margin: 0;
  color: #475569;
  font-size: 0.875rem;
  line-height: 1.6;
}

.esd-lp-v2-section--programs__notice {
  margin: 0.75rem 0 0;
  color: #334155;
  font-size: 0.875rem;
  line-height: 1.6;
}

.esd-lp-v2-section--programs__inner--actions {
  margin-top: 1rem;
}

.esd-lp-v2-programs-list__lead {
  margin: 0.65rem 0 0;
  color: #475569;
  font-size: 0.95rem;
  line-height: 1.7;
}

.esd-lp-v2-programs-list {
  margin-top: 1rem;
}

.esd-lp-v2-programs-list .esd-lp-v2-program-card {
  flex: initial;
}

.esd-lp-v2-program-map {
  width: 100%;
  height: 420px;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  overflow: hidden;
  margin-top: 1rem;
}

.esd-lp-v2-program-map__info {
  min-width: 180px;
  line-height: 1.55;
  color: #1e293b;
}
.esd-lp-v2-program-map__info strong {
  color: #0f172a;
}

.esd-lp-v2-program-map__sdg {
  display: inline-block;
  margin-top: 0.2rem;
  font-weight: 600;
  color: #334155;
}

.esd-lp-v2-section--event-banners {
  margin-top: calc(80px + 1rem);
}

.esd-lp-v2-event-banners {
  margin-top: 0.5rem;
}

.esd-lp-v2-event-banners__col {
  margin-bottom: 1rem;
}

.esd-lp-v2-event-banner {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.08);
}

.esd-lp-v2-event-banner__link {
  display: block;
  text-decoration: none;
}
.esd-lp-v2-event-banner__link:hover .esd-lp-v2-event-banner__cta {
  background: #f1f5f9;
  color: #0f172a;
}

.esd-lp-v2-event-banner__img {
  display: block;
  width: 100%;
  height: auto;
}

.esd-lp-v2-event-banner__cta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  padding: 0.5rem 0.75rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: #334155;
  background: #f8fafc;
  border-top: 1px solid #e2e8f0;
}
.esd-lp-v2-event-banner__cta > .las {
  font-size: 1rem;
  opacity: 0.88;
  flex-shrink: 0;
}

.esd-lp-v2-footer {
  margin-top: calc(80px + 1rem);
  padding: 2.4rem 1.2rem;
  background: #0f172a;
  color: #e2e8f0;
}

.esd-lp-v2-footer__inner {
  max-width: 72rem;
  margin: 0 auto;
  text-align: center;
}

.esd-lp-v2-footer__title {
  margin: 0 0 0.5rem;
  color: #fff;
  font-size: 1.05rem;
  font-weight: 700;
}

.esd-lp-v2-footer__text {
  margin: 0;
  color: #cbd5e1;
  line-height: 1.7;
  font-size: 0.9rem;
}

.esd-lp-v2-footer__nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.45rem 1rem;
  margin-top: 1rem;
}

.esd-lp-v2-footer__link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  color: #cbd5e1;
  text-decoration: none;
  font-size: 0.84rem;
  border-bottom: 1px solid transparent;
}
.esd-lp-v2-footer__link .las {
  font-size: 1rem;
  opacity: 0.88;
  flex-shrink: 0;
}
.esd-lp-v2-footer__link:hover {
  color: #fff;
  border-bottom-color: rgba(255, 255, 255, 0.6);
}
.esd-lp-v2-footer__link:hover .las {
  opacity: 1;
}

.esd-lp-v2-footer__copy {
  margin: 0.75rem 0 0;
  color: #94a3b8;
  font-size: 0.78rem;
}

.esd-lp-v2-terms {
  max-width: 58rem;
  margin: 0 auto;
  color: #1f2937;
  line-height: 1.8;
}
.esd-lp-v2-terms h2 {
  margin: 1.4rem 0 0.35rem;
  font-size: 1.05rem;
  color: #0f172a;
}
.esd-lp-v2-terms p {
  margin: 0;
}

.esd-lp-v2-terms__updated {
  margin-top: 1.3rem !important;
  color: #64748b;
  font-size: 0.85rem;
}

.esd-lp-v2-news {
  padding: 3rem 1rem;
  margin: calc(80px + 2rem) auto;
}

.esd-lp-v2-news__list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.esd-lp-v2-news__item {
  display: grid;
  grid-template-columns: 6.5rem 1fr;
  gap: 1rem;
  padding: 1rem 0;
  border-bottom: 1px solid #f1f5f9;
  font-size: 0.875rem;
}
.esd-lp-v2-news__item:last-child {
  border-bottom: none;
}

.esd-lp-v2-news__date {
  color: #94a3b8;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}
.esd-lp-v2-news__date > i {
  font-size: 1rem;
  color: #cbd5e1;
}

.esd-lp-v2-news__content {
  min-width: 0;
}

.esd-lp-v2-news__title-line {
  display: block;
  margin-bottom: 0.35rem;
  color: #0f172a;
}

.esd-lp-v2-news__body {
  margin-top: 0.25rem;
  color: #475569;
  line-height: 1.6;
}
.esd-lp-v2-news__body p {
  margin: 0 0 0.5rem;
}
.esd-lp-v2-news__body p:last-child {
  margin-bottom: 0;
}

.esd-lp-v2-news__item--static {
  opacity: 0.95;
}

.esd-lp-v2-carousel-outer {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0;
  margin: 0;
}
.esd-lp-v2-carousel-outer.has-dots {
  gap: 1rem;
}

.esd-lp-v2-carousel__dots {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 0.5rem;
  padding: 0.15rem 0 0.25rem;
  list-style: none;
  margin: 0;
}

.esd-lp-v2-carousel__dot {
  flex-shrink: 0;
  width: 0.5rem;
  height: 0.5rem;
  padding: 0;
  border: none;
  border-radius: 9999px;
  background: #cbd5e1;
  cursor: pointer;
  transition: background 0.2s, transform 0.2s, box-shadow 0.2s;
}
.esd-lp-v2-carousel__dot:hover {
  background: #94a3b8;
  transform: scale(1.15);
}
.esd-lp-v2-carousel__dot:focus-visible {
  outline: 2px solid #0ea5e9;
  outline-offset: 3px;
}
.esd-lp-v2-carousel__dot.is-active {
  background: #0369a1;
  transform: scale(1.35);
  box-shadow: 0 0 0 2px rgba(3, 105, 161, 0.25);
}

.esd-lp-v2-carousel-wrap {
  flex: 1;
  min-width: 0;
  width: 100%;
  overflow: hidden;
  margin: 0;
  padding: 0 0 0.5rem;
}

.esd-lp-v2-carousel {
  display: flex;
  gap: 1rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-bottom: 0.5rem;
  scrollbar-width: thin;
  scroll-behavior: smooth;
}
.esd-lp-v2-carousel::-webkit-scrollbar {
  height: 6px;
}
.esd-lp-v2-carousel::-webkit-scrollbar-thumb {
  background: #cbd5e1;
  border-radius: 3px;
}

.esd-lp-v2-program-card {
  flex: 0 0 min(300px, 85vw);
  scroll-snap-align: start;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
  display: flex;
  flex-direction: column;
}

.esd-lp-v2-program-card--link {
  text-decoration: none;
  color: inherit;
  transition: border-color 0.15s, box-shadow 0.15s, transform 0.12s;
}
.esd-lp-v2-program-card--link:hover {
  border-color: #cbd5e1;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.1);
  transform: translateY(-2px);
}
.esd-lp-v2-program-card--link:focus-visible {
  outline: 2px solid #0ea5e9;
  outline-offset: 2px;
}

.esd-lp-v2-program-card__more {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  margin-top: 0.75rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: #0369a1;
}
.esd-lp-v2-program-card__more i {
  font-size: 0.9rem;
}

.esd-lp-v2-program-card__visual {
  position: relative;
  height: 200px;
  overflow: hidden;
  background: #cbd5e1;
}

.esd-lp-v2-program-card__visual-icon {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  font-size: 3rem;
  color: rgba(255, 255, 255, 0.45);
  pointer-events: none;
}

.esd-lp-v2-program-card__tags {
  position: absolute;
  bottom: 0.5rem;
  left: 0.5rem;
  right: 0.5rem;
  z-index: 3;
  display: flex;
  flex-wrap: wrap;
  gap: 0.2rem;
  pointer-events: none;
}

.esd-program-tags--lp-strip .esd-program-tags__pill {
  background: #facc15;
  color: #422006;
  border: 1px solid rgba(245, 158, 11, 0.55);
  font-size: 0.625rem;
  font-weight: 700;
  padding: 0.1rem 0.38rem 0.1rem 0.28rem;
  letter-spacing: 0.01em;
}
.esd-program-tags--lp-strip .esd-program-tags__icon {
  color: #92400e;
  font-size: 0.72rem;
}

.esd-program-tags--tile .esd-program-tags__pill {
  font-size: 0.65rem;
}

.esd-lp-v2-company-tile__tags {
  margin-top: 0.45rem;
}

.esd-lp-v2-company-tile__visual {
  position: relative;
  margin-bottom: 0.45rem;
}

.esd-lp-v2-program-card__body {
  padding: 1rem 1.1rem 1.15rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.esd-lp-v2-program-card__name {
  margin: 0 0 0.35rem;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.35;
}

.esd-lp-v2-program-card__sum {
  margin: 0;
  font-size: 0.8125rem;
  color: #64748b;
  line-height: 1.55;
  flex: 1;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  overflow: hidden;
}

.esd-lp-v2-program-card__org {
  margin: 0 0 0.35rem;
  font-size: 0.75rem;
  font-weight: 600;
  color: #64748b;
  letter-spacing: 0.02em;
}

.esd-lp-v2-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(10rem, 1fr));
  gap: 0.75rem;
}

@media (min-width: 768px) {
  .esd-lp-v2-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.esd-lp-v2-focus-card {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  padding: 3rem 1rem;
  text-align: center;
  font-size: 0.8125rem;
  line-height: 1.5;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}
.esd-lp-v2-focus-card p {
  white-space: pre-line;
}
.esd-lp-v2-focus-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 0.5rem;
  width: 4.5rem;
  height: 4.5rem;
  border-radius: 9999px;
  background: #f0f9ff;
  color: #0369a1;
  font-size: 4rem;
}
.esd-lp-v2-focus-card strong {
  display: block;
  font-size: 0.9375rem;
  margin: 1rem 0;
  color: #0f172a;
}

.esd-lp-v2-grid-companies {
  display: grid;
  gap: 1rem;
  grid-template-columns: 1fr;
}
@media (min-width: 640px) {
  .esd-lp-v2-grid-companies {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1024px) {
  .esd-lp-v2-grid-companies {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media (max-width: 767px) {
  .esd-lp-v2-grid-companies {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.esd-lp-v2-company-tile {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  padding: 1.1rem 1.2rem;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
  overflow: hidden;
}

.esd-lp-v2-company-tile--link {
  display: block;
  text-decoration: none;
  color: inherit;
  transition: border-color 0.15s, box-shadow 0.15s, transform 0.12s;
}
.esd-lp-v2-company-tile--link:hover {
  border-color: #cbd5e1;
  box-shadow: 0 6px 20px rgba(15, 23, 42, 0.08);
  transform: translateY(-2px);
}
.esd-lp-v2-company-tile--link:focus-visible {
  outline: 2px solid #0ea5e9;
  outline-offset: 2px;
}

.esd-lp-v2-company-tile__more {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  margin-top: 0.85rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: #0369a1;
}
.esd-lp-v2-company-tile__more i {
  font-size: 0.9rem;
}

.esd-lp-v2-company-tile__tag {
  display: inline-block;
  font-size: 0.6875rem;
  font-weight: 700;
  background: #e0f2fe;
  color: #0369a1;
  padding: 0.15rem 0.45rem;
  border-radius: 0.25rem;
  margin-bottom: 0.5rem;
}

.esd-lp-v2-company-tile__name {
  margin: 0 0 0.4rem;
  font-size: 1rem;
  font-weight: 700;
  display: flex;
  align-items: flex-start;
  gap: 0.4rem;
}
.esd-lp-v2-company-tile__name > i {
  flex-shrink: 0;
  margin-top: 0.1rem;
  font-size: 1.1rem;
  color: #64748b;
}

.esd-lp-v2-company-tile__sum {
  margin: 0;
  font-size: 0.8125rem;
  color: #64748b;
  line-height: 1.55;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  overflow: hidden;
}

@media (max-width: 767px) {
  .esd-cover--lp-tile {
    height: 130px;
  }
  .esd-lp-v2-company-tile__tags {
    position: absolute;
    bottom: 0.4rem;
    left: 0.45rem;
    right: 0.45rem;
    margin: 0;
    z-index: 3;
    pointer-events: none;
  }
  .esd-lp-v2-company-tile__tag {
    position: absolute;
    bottom: 0.4rem;
    left: 0.45rem;
    margin: 0;
    z-index: 3;
    pointer-events: none;
  }
}
.esd-lp-v2-cta {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: 2.5rem clamp(1rem, 4vw, 3rem);
  min-height: min(52vh, 520px);
  text-align: left;
  color: #fff;
  background-image: url(/assets/esd_lp/contact_image-2878675fa16ec2b3d8f0bc8ac5ed1c302d4d4f39f5811d6267605d660de6388a.jpg);
  background-size: cover;
  background-position: center;
  margin: calc(80px + 2rem) auto;
}
.esd-lp-v2-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.3);
}

.esd-lp-v2-cta__inner {
  position: relative;
  z-index: 1;
  flex: 0 1 50%;
  max-width: 50rem;
  width: 1368px;
  margin: 0 0 0 auto;
  padding-left: 0.5rem;
  box-sizing: border-box;
}

.esd-lp-v2-cta__title {
  margin: 0 0 0.75rem;
  font-size: clamp(1.1rem, 2.8vw, 1.35rem);
  font-weight: 800;
  line-height: 1.35;
}

.esd-lp-v2-cta__text {
  margin: 0 0 1.25rem;
  font-size: 0.9rem;
  line-height: 1.65;
  opacity: 0.95;
}

@media (max-width: 639px) {
  .esd-lp-v2-cta {
    justify-content: center;
    text-align: center;
    min-height: min(70vh, 560px);
    padding-top: 3rem;
    padding-bottom: 3rem;
  }
  .esd-lp-v2-cta__inner {
    flex-basis: 100%;
    max-width: 36rem;
    padding-left: 0;
  }
  .esd-lp-v2-cta__title {
    text-align: center;
  }
  .esd-lp-v2-cta__text {
    text-align: center;
  }
}
.esd-lp-v2-footnote {
  font-size: 0.75rem;
  color: #64748b;
  max-width: 48rem;
  margin: 0 auto;
  padding: 2rem 1.5rem 3rem;
  line-height: 1.6;
}

@media (max-width: 520px) {
  .esd-lp-v2-br {
    display: none;
  }
}
.esd-lp-v2-detail {
  max-width: 48rem;
  margin: 0 auto;
  padding: 1.5rem 1.25rem 3rem;
}

.esd-lp-v2-detail--partner {
  max-width: none;
  width: 100%;
  margin: 0;
  padding: 0;
}

.esd-lp-v2-detail--program {
  max-width: none;
  width: 100%;
  margin: 0;
  padding: 0;
  background: #f1f5f9;
}

.esd-lp-v2-detail__program-hero {
  position: relative;
  width: 100%;
  height: min(44vw, 460px);
  min-height: 200px;
  max-height: 560px;
  overflow: hidden;
  background: #e2e8f0;
}
.esd-lp-v2-detail__program-hero .esd-cover--program-detail-hero {
  height: 100%;
}
.esd-lp-v2-detail__program-hero .esd-cover__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.esd-lp-v2-detail__program-hero .esd-cover__placeholder,
.esd-lp-v2-detail__program-hero .esd-cover__placeholder--empty {
  min-height: 100%;
  height: 100%;
}

.esd-lp-v2-detail__program-hero-shade {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(180deg, transparent 40%, rgba(15, 23, 42, 0.25) 100%);
}

.esd-lp-v2-detail__program-inner {
  max-width: 87.5rem;
  margin: 0 auto;
  padding: 0 clamp(1rem, 3vw, 1.5rem) 3rem;
  box-sizing: border-box;
}

.esd-lp-v2-detail__program-sheet {
  position: relative;
  z-index: 2;
  margin-top: -2.25rem;
  padding: 1.35rem clamp(1rem, 2.5vw, 1.5rem) 2.25rem;
  background: #fff;
  border-radius: 1rem;
  box-shadow: 0 4px 28px rgba(15, 23, 42, 0.1);
  border: 1px solid rgba(226, 232, 240, 0.95);
}

.esd-lp-v2-detail__breadcrumb--program {
  margin-bottom: 1.35rem;
}

.esd-lp-v2-detail__article--program {
  max-width: 100%;
  margin: 0 auto;
  padding: 0;
  background: transparent;
}

.esd-lp-v2-detail__program-header {
  margin-bottom: 0.25rem;
  padding-bottom: 1.25rem;
}

.esd-lp-v2-detail__program-kicker {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  margin: 0 0 0.5rem;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #64748b;
}
.esd-lp-v2-detail__program-kicker i {
  font-size: 1rem;
  letter-spacing: 0;
  text-transform: none;
  color: #0369a1;
}

.esd-lp-v2-detail__name--program-page {
  margin: 0 0 1rem;
  font-size: clamp(1.45rem, 3.8vw, 2rem);
  font-weight: 800;
  line-height: 1.28;
  letter-spacing: -0.025em;
  color: #0f172a;
}

.esd-lp-v2-detail__program-meta-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.65rem 1rem;
}

.esd-lp-v2-detail__program-provider {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.35rem 0.5rem;
  font-size: 0.9375rem;
  color: #475569;
}

.esd-lp-v2-detail__program-provider-label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #94a3b8;
}

.esd-lp-v2-detail__program-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.28rem 0.65rem;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: #0369a1;
  background: #e0f2fe;
  border-radius: 9999px;
}
.esd-lp-v2-detail__program-pill--empty {
  color: #94a3b8;
  background: #f1f5f9;
  font-weight: 600;
  letter-spacing: normal;
  text-transform: none;
}

.esd-lp-v2-detail__program-meta-tags {
  flex: 1;
  min-width: 0;
  display: flex;
  justify-content: flex-end;
}

.esd-program-tags--detail {
  justify-content: flex-end;
}
.esd-program-tags--detail .esd-program-tags__pill {
  font-size: 0.72rem;
  padding: 0.14rem 0.5rem 0.14rem 0.38rem;
}

@media (max-width: 767px) {
  .esd-lp-v2-detail__program-meta-row {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.75rem;
  }
  .esd-lp-v2-detail__program-meta-tags {
    flex: none;
    width: 100%;
    min-width: 0;
    justify-content: flex-start;
  }
  .esd-program-tags--detail {
    justify-content: flex-start;
    max-width: 100%;
    flex-wrap: wrap;
  }
  .esd-program-tags--detail .esd-program-tags__pill {
    white-space: nowrap;
    writing-mode: horizontal-tb;
  }
}
.esd-lp-v2-detail__lead--empty {
  color: #94a3b8;
  font-weight: 600;
}

.esd-lp-v2-detail__empty-dash {
  margin: 0;
  color: #94a3b8;
  font-weight: 600;
}

.esd-program-logistics__dash {
  color: #94a3b8;
  font-weight: 600;
}

.esd-lp-v2-detail__program-dl {
  margin: 0.5rem 0 0;
  display: grid;
  grid-template-columns: minmax(6.5rem, 28%) 1fr;
  gap: 0.35rem 0.75rem;
  align-items: start;
  font-size: 0.9375rem;
  color: #334155;
}

.esd-lp-v2-detail__program-dt {
  margin: 0;
  font-weight: 700;
  color: #64748b;
  font-size: 0.8125rem;
}

.esd-lp-v2-detail__program-dd {
  margin: 0;
  line-height: 1.55;
  word-break: break-word;
}
.esd-lp-v2-detail__program-dd p {
  margin: 0 0 0.5em;
}
.esd-lp-v2-detail__program-dd p:last-child {
  margin-bottom: 0;
}

.esd-program-logistics__link {
  word-break: break-all;
}

.esd-lp-v2-detail--program .esd-lp-v2-detail__block--program {
  margin-top: 1.15rem;
  padding: 1.2rem 1.25rem 1.35rem;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.05);
}
.esd-lp-v2-detail--program .esd-lp-v2-detail__block--program:first-of-type {
  margin-top: 1.35rem;
  padding-top: 1.2rem;
}

.esd-lp-v2-detail--program .esd-lp-v2-detail__block--program-muted {
  margin-left: 0;
  margin-right: 0;
  padding: 1.2rem 1.25rem 1.35rem;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 0.65rem;
}

.esd-lp-v2-detail__gallery--program {
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 220px), 1fr));
  gap: 1rem;
}

.esd-lp-v2-detail__program-related {
  width: 100%;
  margin-top: 2rem;
  padding-top: 1.5rem;
  border-top: 1px solid #e2e8f0;
}
.esd-lp-v2-detail__program-related .esd-lp-v2-detail__h {
  margin-bottom: 1rem;
}
.esd-lp-v2-detail__program-related .esd-partner-program-grid.row {
  margin-top: 0;
  margin-bottom: 0;
}

.esd-lp-v2-detail__program-article-footer {
  max-width: 50rem;
  margin: 0 auto;
  width: 100%;
  padding-top: 1.75rem;
  box-sizing: border-box;
}
.esd-lp-v2-detail__program-article-footer > .esd-lp-v2-detail__block--program:first-child {
  margin-top: 0;
}

.esd-lp-v2-detail__program-footer-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1.75rem;
  padding-top: 1.5rem;
  border-top: 1px solid #f1f5f9;
}

.esd-lp-v2-detail__program-footer-btn {
  flex: 1 1 auto;
  min-width: min(100%, 14rem);
  justify-content: center;
}

@media (max-width: 520px) {
  .esd-lp-v2-detail__program-sheet {
    margin-top: -1.25rem;
    border-radius: 0.75rem;
  }
  .esd-lp-v2-detail__program-hero {
    height: min(52vw, 240px);
    min-height: 160px;
  }
}
.esd-lp-v2-detail__partner-hero {
  width: 100%;
  height: 50vh;
  min-height: 200px;
  max-height: 720px;
  overflow: hidden;
  background: #e2e8f0;
}
.esd-lp-v2-detail__partner-hero .esd-cover--partner-hero {
  display: block;
  height: 100%;
}
.esd-lp-v2-detail__partner-hero .esd-cover__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.esd-lp-v2-detail__partner-hero .esd-cover__placeholder,
.esd-lp-v2-detail__partner-hero .esd-cover__placeholder--empty {
  min-height: 100%;
  height: 100%;
}

.esd-lp-v2-detail__partner-inner {
  max-width: 87.5rem;
  margin: 0 auto;
  padding: 1.25rem clamp(1rem, 3vw, 1.5rem) 3rem;
  box-sizing: border-box;
}

.esd-lp-v2-detail__breadcrumb {
  margin: 0 0 1rem;
}

.esd-lp-v2-detail__breadcrumb-list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
  margin: 0;
  padding: 0;
  list-style: none;
  font-size: 0.8125rem;
  color: #64748b;
}

.esd-lp-v2-detail__breadcrumb-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.esd-lp-v2-detail__breadcrumb-item:not(:last-child)::after {
  content: "/";
  color: #cbd5e1;
  font-weight: 400;
  pointer-events: none;
}
.esd-lp-v2-detail__breadcrumb-item--current {
  color: #0f172a;
  font-weight: 600;
}

.esd-lp-v2-detail__breadcrumb-link {
  color: #0369a1;
  text-decoration: none;
  font-weight: 600;
}
.esd-lp-v2-detail__breadcrumb-link:hover {
  text-decoration: underline;
}

.esd-lp-v2-detail__article--partner {
  margin-top: 0.25rem;
}

.esd-lp-v2-detail__name--partner {
  margin-bottom: 1rem;
}

.esd-lp-v2-detail__partner-intro {
  margin-bottom: 1.5rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid #f1f5f9;
}
.esd-lp-v2-detail__partner-intro .esd-lp-v2-detail__body {
  margin: 0;
}
.esd-lp-v2-detail__partner-intro .esd-lp-v2-detail__lead {
  margin: 0;
}

.esd-lp-v2-detail__partner-address {
  margin: 0 0 1rem;
  font-size: 0.9375rem;
  line-height: 1.55;
  color: #334155;
}

.esd-lp-v2-detail__partner-address-label {
  display: block;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #94a3b8;
  margin-bottom: 0.25rem;
}

.esd-lp-v2-detail__partner-address-value {
  display: block;
  white-space: pre-wrap;
  word-break: break-word;
}

.esd-lp-v2-detail__partner-intro + .esd-lp-v2-detail__block {
  margin-top: 0;
  padding-top: 0;
  border-top: none;
}

.esd-lp-v2-detail__programs-lead {
  margin: 0 0 1rem;
}

.esd-lp-v2-detail__partner-foot {
  margin-top: 1.5rem;
}

.esd-lp-v2-detail__partner-foot-icon {
  margin-right: 0.25rem;
  color: #94a3b8;
}

.esd-partner-program-grid.row {
  display: flex;
  flex-wrap: wrap;
  margin: 2rem auto;
}

.esd-partner-program-grid.row > .col-3 {
  flex: 0 0 100%;
  max-width: 100%;
  padding-left: 0.75rem;
  padding-right: 0.75rem;
  margin-bottom: 1.25rem;
  box-sizing: border-box;
}

@media (min-width: 640px) {
  .esd-partner-program-grid.row > .col-3 {
    flex: 0 0 50%;
    max-width: 50%;
  }
}
@media (min-width: 992px) {
  .esd-partner-program-grid.row > .col-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
}
.esd-partner-program-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 100%;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.65rem;
  overflow: hidden;
  text-decoration: none;
  color: #0f172a;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.esd-partner-program-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.1);
  color: #0f172a;
  text-decoration: none;
}
.esd-partner-program-card:focus-visible {
  outline: 2px solid #0369a1;
  outline-offset: 2px;
}

.esd-partner-program-card__visual {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  overflow: hidden;
  background: #e2e8f0;
  flex-shrink: 0;
}

.esd-partner-program-card__placeholder-icon {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  color: rgba(255, 255, 255, 0.95);
  font-size: 2.5rem;
  text-shadow: 0 1px 8px rgba(15, 23, 42, 0.35);
  background: linear-gradient(145deg, rgba(100, 116, 139, 0.35) 0%, rgba(51, 65, 85, 0.45) 100%);
}

.esd-partner-program-card__body {
  padding: 1rem 1.1rem 1.2rem;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.esd-partner-program-card__title {
  margin: 0;
  font-size: 1.0625rem;
  font-weight: 800;
  line-height: 1.35;
  letter-spacing: -0.02em;
}

.esd-partner-program-card__tags {
  align-self: flex-start;
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem;
}

.esd-program-tags--card-body .esd-program-tags__pill {
  font-size: 0.65rem;
  padding: 0.1rem 0.42rem 0.1rem 0.32rem;
}

.esd-partner-program-card__sum {
  margin: 0;
  font-size: 0.8125rem;
  line-height: 1.55;
  color: #64748b;
  flex: 1;
}

.esd-partner-program-card__more {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  margin-top: 0.35rem;
  font-size: 0.8125rem;
  font-weight: 700;
  color: #0369a1;
}
.esd-partner-program-card__more i {
  font-size: 1rem;
}

.esd-lp-v2-detail__bar {
  margin-bottom: 1.25rem;
}

.esd-lp-v2-detail__back {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: #0369a1;
  text-decoration: none;
}
.esd-lp-v2-detail__back i {
  font-size: 1.1rem;
}
.esd-lp-v2-detail__back:hover {
  text-decoration: underline;
}

.esd-lp-v2-detail__article {
  background: #fff;
  padding: 1.5rem 1.35rem 2rem;
}

.esd-lp-v2-detail__name {
  margin: 0 0 1rem;
  font-size: clamp(1.35rem, 3.5vw, 1.75rem);
  font-weight: 800;
  line-height: 1.3;
  letter-spacing: -0.02em;
}

.esd-lp-v2-detail__switch {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
  margin: 0 0 1.25rem;
  font-size: 0.8125rem;
}
.esd-lp-v2-detail__switch a {
  color: #0369a1;
  text-decoration: none;
  font-weight: 600;
}
.esd-lp-v2-detail__switch a:hover {
  text-decoration: underline;
}
.esd-lp-v2-detail__switch a.is-active {
  color: #0f172a;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.esd-lp-v2-detail__switch-sep {
  color: #cbd5e1;
  user-select: none;
}

.esd-lp-v2-detail__tag-wrap {
  margin: 0 0 1rem;
}

.esd-lp-v2-detail__block {
  margin-top: 1.35rem;
  padding-top: 1.25rem;
  border-top: 1px solid #f1f5f9;
}
.esd-lp-v2-detail__block:first-of-type {
  margin-top: 0;
  padding-top: 0;
  border-top: none;
}
.esd-lp-v2-detail__block--muted {
  background: #f8fafc;
  margin-left: -1.35rem;
  margin-right: -1.35rem;
  padding: 1.25rem 1.35rem;
  border-top: 1px solid #e2e8f0;
  border-radius: 0 0 0.5rem 0.5rem;
}

.esd-lp-v2-detail__h {
  margin: 0 0 0.5rem;
  font-size: 0.9375rem;
  font-weight: 700;
  color: #334155;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.esd-lp-v2-detail__h > i {
  font-size: 1.05rem;
  color: #64748b;
  flex-shrink: 0;
}

.esd-lp-v2-detail__lead {
  margin: 0;
  font-size: 0.9375rem;
  line-height: 1.7;
  color: #475569;
}

.esd-lp-v2-detail__body {
  font-size: 0.9375rem;
  line-height: 1.75;
  color: #334155;
}
.esd-lp-v2-detail__body p {
  margin: 0 0 0.65rem;
}
.esd-lp-v2-detail__body p:last-child {
  margin-bottom: 0;
}

.esd-lp-v2-detail__gallery {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 200px), 1fr));
  gap: 0.85rem;
  margin-top: 0.35rem;
}

.esd-lp-v2-detail__gallery-img {
  width: 100%;
  height: auto;
  border-radius: 0.5rem;
  object-fit: cover;
  aspect-ratio: 4/3;
  background: #f1f5f9;
  border: 1px solid #e2e8f0;
}

.esd-lp-v2-detail__small {
  margin: 0;
  font-size: 0.8125rem;
  line-height: 1.65;
  color: #64748b;
}

.esd-lp-v2-detail__meta {
  margin: 0 0 1rem;
  font-size: 0.875rem;
  color: #475569;
}

.esd-lp-v2-detail__meta-link {
  font-weight: 600;
  color: #0369a1;
  text-decoration: none;
}
.esd-lp-v2-detail__meta-link:hover {
  text-decoration: underline;
}

.esd-lp-v2-program-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.esd-lp-v2-program-list--compact .esd-lp-v2-program-list__item {
  margin-bottom: 0.5rem;
}

.esd-lp-v2-program-list__item {
  margin-bottom: 0.75rem;
}

.esd-lp-v2-program-list__link {
  display: block;
  padding: 0.85rem 1rem;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  background: #f8fafc;
  text-decoration: none;
  color: inherit;
  transition: border-color 0.15s, background 0.15s;
}
.esd-lp-v2-program-list__link:hover {
  border-color: #cbd5e1;
  background: #fff;
}
.esd-lp-v2-program-list__link:focus-visible {
  outline: 2px solid #0ea5e9;
  outline-offset: 2px;
}

.esd-lp-v2-program-list__title {
  display: block;
  font-size: 1rem;
  font-weight: 700;
  color: #0f172a;
  margin-bottom: 0.25rem;
}

.esd-lp-v2-program-list__tag {
  margin-right: 0.35rem;
  margin-bottom: 0.35rem;
  vertical-align: middle;
}

.esd-lp-v2-program-list__sum {
  display: block;
  font-size: 0.8125rem;
  color: #64748b;
  line-height: 1.55;
  margin-top: 0.35rem;
}

.esd-lp-v2-program-list__more {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  margin-top: 0.5rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: #0369a1;
}
.esd-lp-v2-program-list__more i {
  font-size: 0.9rem;
}

.field__hint {
  margin-top: 0.25rem;
  font-size: 0.8125rem;
  color: #64748b;
}

.form-errors {
  margin: 0 0 1rem;
  padding-left: 1.25rem;
  color: #dc2626;
  font-size: 0.875rem;
}

a {
  text-decoration: none;
  color: #272727;
}

.btn {
  padding: 0.5rem 1rem;
  border-radius: 0.375rem;
  font-size: 0.9375rem;
  font-weight: 500;
  cursor: pointer;
  text-decoration: none;
  display: inline-block;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.btn--primary {
  background: #2563eb;
  color: #fff;
  border: 1px solid #1d4ed8;
}
.btn--primary:hover {
  background: #1d4ed8;
}
.btn--secondary {
  background: #fff;
  color: #334155;
  border: 1px solid #94a3b8;
}
.btn--secondary:hover {
  background: #f1f5f9;
  border-color: #64748b;
}

.broadcast-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 0.75rem 1rem;
  margin: 0 0 1.25rem;
}

.broadcast-toolbar__compose.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 2.75rem;
  height: 2.75rem;
  min-width: 2.75rem;
  min-height: 2.75rem;
  padding: 0;
  box-sizing: border-box;
  border-radius: 0.5rem;
}
.broadcast-toolbar__compose.btn .las {
  font-size: 1.35rem;
  line-height: 1;
}

.broadcast-tabs {
  display: flex;
  flex: 1 1 auto;
  min-width: min(100%, 12rem);
  gap: 0.125rem;
  border-bottom: 2px solid #e2e8f0;
}

.broadcast-tabs__tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  margin-bottom: -2px;
  padding: 0.5rem 0.85rem 0.65rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: #64748b;
  text-decoration: none;
  border: none;
  border-bottom: 2px solid transparent;
  border-radius: 0.375rem 0.375rem 0 0;
  transition: color 0.15s, background 0.15s, border-color 0.15s;
}
.broadcast-tabs__tab:hover {
  color: #334155;
  background: #f8fafc;
}
.broadcast-tabs__tab.is-active {
  color: #1d4ed8;
  font-weight: 600;
  border-bottom-color: #2563eb;
  background: #fff;
}

.broadcast-tabs__icon {
  font-size: 1.1rem;
  line-height: 1;
  opacity: 0.9;
}

.school-portal .broadcast-tabs__tab.is-active {
  color: var(--portal-accent);
  border-bottom-color: var(--portal-accent);
}

.school-broadcast-targets {
  margin: 0 0 1.25rem;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  padding: 1rem 1rem 0.9rem;
}
.school-broadcast-targets__hint {
  margin: 0.65rem 0 0.4rem;
  font-size: 0.8125rem;
}
.school-broadcast-targets__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(13.5rem, 1fr));
  gap: 0.4rem 0.85rem;
  align-items: start;
  margin-top: 0.25rem;
}
.school-broadcast-targets__item {
  display: flex;
  align-items: flex-start;
  gap: 0.45rem;
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.4;
  cursor: pointer;
}
.school-broadcast-targets__item input[type=checkbox] {
  margin-top: 0.2rem;
  flex-shrink: 0;
}
.school-broadcast-targets__item--block {
  display: flex;
  margin-bottom: 0.35rem;
}

.school-broadcast-form {
  box-sizing: border-box;
  width: 100%;
}
.school-broadcast-form > .alert {
  margin: 0 0 1rem;
}
.school-broadcast-form.page-users__panel {
  padding: 1.25rem 1.5rem;
}
.school-broadcast-form__field {
  margin: 0 0 1.125rem;
  max-width: 42rem;
}
.school-broadcast-form__field--wide {
  max-width: 52rem;
}
.school-broadcast-form__label {
  display: block;
  margin: 0 0 0.4rem;
  font-weight: 600;
  font-size: 0.875rem;
  color: #334155;
}
.school-broadcast-form__legend {
  font-weight: 600;
  font-size: 0.875rem;
  color: #334155;
  padding: 0 0.25rem;
}
.school-broadcast-form__input, .school-broadcast-form__textarea {
  display: block;
  width: 100%;
  padding: 0.55rem 0.85rem;
  border: 1px solid #cbd5e1;
  border-radius: 0.5rem;
  font-size: 0.9375rem;
  line-height: 1.45;
  font-family: inherit;
  background: #fff;
  color: #0f172a;
  box-sizing: border-box;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.school-broadcast-form__input:focus, .school-broadcast-form__textarea:focus {
  outline: none;
  border-color: #2563eb;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.16);
}
.school-broadcast-form__input::placeholder, .school-broadcast-form__textarea::placeholder {
  color: #94a3b8;
}
.school-broadcast-form__textarea {
  min-height: 14rem;
  resize: vertical;
  line-height: 1.55;
}

.school-portal .school-broadcast-form__input:focus,
.school-portal .school-broadcast-form__textarea:focus {
  border-color: var(--portal-accent);
  box-shadow: 0 0 0 3px var(--portal-focus-ring);
}

.page-users.page-users--esd-company-show,
.page-users.page-users--esd-program-show {
  max-width: none;
  width: 100%;
  box-sizing: border-box;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-shell,
.page-users.page-users--esd-program-show .page-users__esd-ec-shell {
  max-width: min(56rem, 100%);
  margin: 0 auto;
  padding: 0 0.15rem 2.25rem;
  box-sizing: border-box;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-nav,
.page-users.page-users--esd-program-show .page-users__esd-ec-nav {
  margin: 0 0 0.25rem;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-back,
.page-users.page-users--esd-program-show .page-users__esd-ec-back {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: #334155;
  text-decoration: none;
  padding: 0.4rem 0.55rem;
  margin-left: -0.35rem;
  border-radius: 0.375rem;
  transition: color 0.15s ease, background 0.15s ease;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-back:hover,
.page-users.page-users--esd-program-show .page-users__esd-ec-back:hover {
  color: #1d4ed8;
  background: #f1f5f9;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-back .las,
.page-users.page-users--esd-program-show .page-users__esd-ec-back .las {
  font-size: 1.15rem;
  opacity: 0.85;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-page-head,
.page-users.page-users--esd-program-show .page-users__esd-ec-page-head {
  margin-bottom: 1.15rem;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-page-head-row,
.page-users.page-users--esd-program-show .page-users__esd-ec-page-head-row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.65rem 1rem;
  margin-bottom: 0.45rem;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-page-title,
.page-users.page-users--esd-program-show .page-users__esd-ec-page-title {
  flex: 1 1 14rem;
  margin: 0;
  line-height: 1.22;
  font-size: clamp(1.28rem, 2.4vw, 1.72rem);
  letter-spacing: -0.02em;
  color: #0f172a;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-lead,
.page-users.page-users--esd-program-show .page-users__esd-ec-lead {
  margin: 0;
  max-width: 40rem;
  font-size: 0.875rem;
  line-height: 1.55;
  color: #64748b;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-provider,
.page-users.page-users--esd-program-show .page-users__esd-ec-provider {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.45rem 0.75rem;
  margin: 0.5rem 0 0;
  font-size: 0.9375rem;
  color: #475569;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-provider-label,
.page-users.page-users--esd-program-show .page-users__esd-ec-provider-label {
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: #94a3b8;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-provider-link,
.page-users.page-users--esd-program-show .page-users__esd-ec-provider-link {
  font-weight: 600;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-hero-card,
.page-users.page-users--esd-program-show .page-users__esd-ec-hero-card {
  position: relative;
  border-radius: 0.7rem;
  overflow: hidden;
  margin-bottom: 1.2rem;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-hero-card .esd-cover.esd-cover--school-show,
.page-users.page-users--esd-program-show .page-users__esd-ec-hero-card .esd-cover.esd-cover--school-show {
  max-width: 100%;
  width: 100%;
  height: auto;
  aspect-ratio: 2/1;
  min-height: 10rem;
  max-height: min(22rem, 42vw);
}
.page-users.page-users--esd-company-show .page-users__esd-ec-card,
.page-users.page-users--esd-program-show .page-users__esd-ec-card {
  background: #fff;
  border-radius: 0.7rem;
  padding: 1.05rem 1.2rem 1.2rem;
  margin-bottom: 1.1rem;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-card-title,
.page-users.page-users--esd-program-show .page-users__esd-ec-card-title {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  margin: 0 0 0.65rem;
  font-size: 1rem;
  font-weight: 700;
  color: #0f172a;
  letter-spacing: -0.01em;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-card-title .las,
.page-users.page-users--esd-program-show .page-users__esd-ec-card-title .las {
  font-size: 1.2rem;
  color: #3b82f6;
  opacity: 0.9;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-hint,
.page-users.page-users--esd-program-show .page-users__esd-ec-hint {
  margin: 0 0 0.75rem;
  padding: 0.55rem 0.65rem;
  font-size: 0.8125rem;
  line-height: 1.5;
  color: #475569;
  background: #f8fafc;
  border-radius: 0.45rem;
  border: 1px solid #f1f5f9;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-muted,
.page-users.page-users--esd-program-show .page-users__esd-ec-muted {
  margin: 0.35rem 0 0;
  font-size: 0.8125rem;
  line-height: 1.45;
  color: #64748b;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-empty,
.page-users.page-users--esd-program-show .page-users__esd-ec-empty {
  margin: 0.35rem 0 0;
  color: #64748b;
  font-size: 0.875rem;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-pre,
.page-users.page-users--esd-program-show .page-users__esd-ec-pre {
  white-space: pre-wrap;
  word-break: break-word;
  line-height: 1.55;
  color: #334155;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-pill-row,
.page-users.page-users--esd-program-show .page-users__esd-ec-pill-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 0.65rem;
  margin: 0 0 1rem;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-pill-row--tags,
.page-users.page-users--esd-program-show .page-users__esd-ec-pill-row--tags {
  align-items: flex-start;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-pill-tags,
.page-users.page-users--esd-program-show .page-users__esd-ec-pill-tags {
  flex: 1;
  min-width: 0;
}
.page-users.page-users--esd-company-show .page-users .esd-program-tags--ec .esd-program-tags__pill,
.page-users.page-users--esd-program-show .page-users .esd-program-tags--ec .esd-program-tags__pill {
  font-size: 0.78rem;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-pill-label,
.page-users.page-users--esd-program-show .page-users__esd-ec-pill-label {
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #94a3b8;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-pill,
.page-users.page-users--esd-program-show .page-users__esd-ec-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.65rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: #1e40af;
  background: #eff6ff;
  border-radius: 9999px;
  border: 1px solid #dbeafe;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-pill--empty,
.page-users.page-users--esd-program-show .page-users__esd-ec-pill--empty {
  color: #94a3b8;
  font-weight: 700;
  background: #f8fafc;
  border-color: #e2e8f0;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-dash-only,
.page-users.page-users--esd-program-show .page-users__esd-ec-dash-only {
  margin: 0;
  color: #94a3b8;
  font-weight: 600;
  font-size: 0.9375rem;
}
.page-users.page-users--esd-company-show .esd-program-logistics__dash,
.page-users.page-users--esd-program-show .esd-program-logistics__dash {
  color: #94a3b8;
  font-weight: 600;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-status,
.page-users.page-users--esd-program-show .page-users__esd-ec-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.2rem 0.62rem;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  border-radius: 9999px;
  white-space: nowrap;
  line-height: 1.3;
  border: 1px solid transparent;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-status--pending,
.page-users.page-users--esd-program-show .page-users__esd-ec-status--pending {
  background: #fef3c7;
  color: #b45309;
  border-color: #fde68a;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-status--approved,
.page-users.page-users--esd-program-show .page-users__esd-ec-status--approved {
  background: #d1fae5;
  color: #047857;
  border-color: #a7f3d0;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-status--rejected,
.page-users.page-users--esd-program-show .page-users__esd-ec-status--rejected {
  background: #fee2e2;
  color: #b91c1c;
  border-color: #fecaca;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-status--suspended,
.page-users.page-users--esd-program-show .page-users__esd-ec-status--suspended {
  background: #f1f5f9;
  color: #475569;
  border-color: #e2e8f0;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-status--table,
.page-users.page-users--esd-program-show .page-users__esd-ec-status--table {
  text-decoration: none;
  transition: box-shadow 0.12s ease, transform 0.12s ease;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-status--table:hover,
.page-users.page-users--esd-program-show .page-users__esd-ec-status--table:hover {
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.08);
  transform: translateY(-1px);
}
.page-users.page-users--esd-company-show .page-users__esd-ec-status--lg,
.page-users.page-users--esd-program-show .page-users__esd-ec-status--lg {
  font-size: 0.875rem;
  padding: 0.38rem 0.88rem;
}
.page-users.page-users--esd-company-show a.page-users__esd-ec-status.page-users__esd-ec-status--table.page-users__esd-ec-status--pending,
.page-users.page-users--esd-program-show a.page-users__esd-ec-status.page-users__esd-ec-status--table.page-users__esd-ec-status--pending {
  color: #b45309;
}
.page-users.page-users--esd-company-show a.page-users__esd-ec-status.page-users__esd-ec-status--table.page-users__esd-ec-status--approved,
.page-users.page-users--esd-program-show a.page-users__esd-ec-status.page-users__esd-ec-status--table.page-users__esd-ec-status--approved {
  color: #047857;
}
.page-users.page-users--esd-company-show a.page-users__esd-ec-status.page-users__esd-ec-status--table.page-users__esd-ec-status--rejected,
.page-users.page-users--esd-program-show a.page-users__esd-ec-status.page-users__esd-ec-status--table.page-users__esd-ec-status--rejected {
  color: #b91c1c;
}
.page-users.page-users--esd-company-show a.page-users__esd-ec-status.page-users__esd-ec-status--table.page-users__esd-ec-status--suspended,
.page-users.page-users--esd-program-show a.page-users__esd-ec-status.page-users__esd-ec-status--table.page-users__esd-ec-status--suspended {
  color: #475569;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-prose,
.page-users.page-users--esd-program-show .page-users__esd-ec-prose {
  margin: 0;
  font-size: 0.9375rem;
  line-height: 1.65;
  color: #334155;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-prose p,
.page-users.page-users--esd-program-show .page-users__esd-ec-prose p {
  margin: 0 0 0.65em;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-prose p:last-child,
.page-users.page-users--esd-program-show .page-users__esd-ec-prose p:last-child {
  margin-bottom: 0;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-prose--rich p,
.page-users.page-users--esd-program-show .page-users__esd-ec-prose--rich p {
  margin-bottom: 0.65em;
}
.page-users.page-users--esd-company-show .page-users__table--ec-esd-ec,
.page-users.page-users--esd-program-show .page-users__table--ec-esd-ec {
  width: 100%;
}
.page-users.page-users--esd-company-show .page-users__table--ec-esd-ec th,
.page-users.page-users--esd-program-show .page-users__table--ec-esd-ec th {
  width: 10.5rem;
  max-width: 34%;
  vertical-align: top;
  white-space: normal;
  font-size: 0.8125rem;
  background: #f8fafc;
}
.page-users.page-users--esd-company-show .page-users__table--ec-esd-ec td,
.page-users.page-users--esd-program-show .page-users__table--ec-esd-ec td {
  font-size: 0.875rem;
  line-height: 1.5;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-table-wrap,
.page-users.page-users--esd-program-show .page-users__esd-ec-table-wrap {
  margin-top: 0.35rem;
  border-radius: 0.5rem;
  border: 1px solid #e2e8f0;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-table-wrap .page-users__table--ec-esd-company-programs,
.page-users.page-users--esd-program-show .page-users__esd-ec-table-wrap .page-users__table--ec-esd-company-programs {
  min-width: 36rem;
}
.page-users.page-users--esd-company-show .page-users__table--ec-esd-company-programs .page-users__esd-ec-th-num,
.page-users.page-users--esd-company-show .page-users__table--ec-esd-company-programs .page-users__esd-ec-td-num,
.page-users.page-users--esd-program-show .page-users__table--ec-esd-company-programs .page-users__esd-ec-th-num,
.page-users.page-users--esd-program-show .page-users__table--ec-esd-company-programs .page-users__esd-ec-td-num {
  width: 2rem;
  min-width: 1.75rem;
  max-width: 2.75rem;
  box-sizing: border-box;
  padding-left: 0.4rem !important;
  padding-right: 0.4rem !important;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
}
.page-users.page-users--esd-company-show .page-users__table--ec-esd-company-programs .page-users__esd-ec-th-status,
.page-users.page-users--esd-company-show .page-users__table--ec-esd-company-programs .page-users__esd-ec-td-status,
.page-users.page-users--esd-program-show .page-users__table--ec-esd-company-programs .page-users__esd-ec-th-status,
.page-users.page-users--esd-program-show .page-users__table--ec-esd-company-programs .page-users__esd-ec-td-status {
  width: 5.25rem;
  min-width: 4.5rem;
  max-width: 7rem;
  box-sizing: border-box;
  padding-left: 0.45rem !important;
  padding-right: 0.45rem !important;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-td-num,
.page-users.page-users--esd-program-show .page-users__esd-ec-td-num {
  font-variant-numeric: tabular-nums;
  color: #64748b;
  font-weight: 600;
  font-size: 0.8125rem;
}
.page-users.page-users--esd-company-show .page-users__esd-program-table-title,
.page-users.page-users--esd-program-show .page-users__esd-program-table-title {
  display: inline-block;
  font-size: 0.875rem;
  text-decoration: none;
}
.page-users.page-users--esd-company-show .page-users__esd-program-table-title strong,
.page-users.page-users--esd-program-show .page-users__esd-program-table-title strong {
  font-weight: 600;
}
.page-users.page-users--esd-company-show .page-users__esd-program-table-category,
.page-users.page-users--esd-program-show .page-users__esd-program-table-category {
  display: block;
  margin-top: 0.2rem;
  font-size: 0.75rem;
  color: #64748b;
  font-weight: 400;
}
.page-users.page-users--esd-company-show .page-users__esd-program-table-category--empty,
.page-users.page-users--esd-program-show .page-users__esd-program-table-category--empty {
  color: #94a3b8;
  font-weight: 600;
}
.page-users.page-users--esd-company-show .page-users__esd-program-table-tags,
.page-users.page-users--esd-program-show .page-users__esd-program-table-tags {
  display: block;
  margin-top: 0.25rem;
}
.page-users.page-users--esd-company-show .page-users .esd-program-tags--ec-table .esd-program-tags__pill,
.page-users.page-users--esd-program-show .page-users .esd-program-tags--ec-table .esd-program-tags__pill {
  font-size: 0.65rem;
  padding: 0.06rem 0.38rem 0.06rem 0.28rem;
}
.page-users.page-users--esd-company-show .page-users__esd-program-table-summary,
.page-users.page-users--esd-program-show .page-users__esd-program-table-summary {
  display: block;
  font-size: 0.875rem;
  color: #334155;
}
.page-users.page-users--esd-company-show .page-users__esd-program-cards,
.page-users.page-users--esd-program-show .page-users__esd-program-cards {
  display: flex;
  flex-wrap: wrap;
  margin-top: 0.35rem;
}
.page-users.page-users--esd-company-show .page-users__esd-program-cards.row > .col-4,
.page-users.page-users--esd-program-show .page-users__esd-program-cards.row > .col-4 {
  flex: 0 0 100%;
  max-width: 100%;
  padding-left: 0.75rem;
  padding-right: 0.75rem;
  margin-bottom: 1rem;
  box-sizing: border-box;
}
@media (min-width: 640px) {
  .page-users.page-users--esd-company-show .page-users__esd-program-cards.row > .col-4,
  .page-users.page-users--esd-program-show .page-users__esd-program-cards.row > .col-4 {
    flex: 0 0 50%;
    max-width: 50%;
  }
}
@media (min-width: 992px) {
  .page-users.page-users--esd-company-show .page-users__esd-program-cards.row > .col-4,
  .page-users.page-users--esd-program-show .page-users__esd-program-cards.row > .col-4 {
    flex: 0 0 33.333333%;
    max-width: 33.333333%;
  }
}
.page-users.page-users--esd-company-show .page-users__esd-program-card,
.page-users.page-users--esd-program-show .page-users__esd-program-card {
  height: 100%;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  padding: 0.85rem;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
}
.page-users.page-users--esd-company-show .page-users__esd-program-card__num,
.page-users.page-users--esd-program-show .page-users__esd-program-card__num {
  margin: 0 0 0.35rem;
  font-size: 0.78rem;
  color: #64748b;
  font-weight: 600;
}
.page-users.page-users--esd-company-show .page-users__esd-program-card__title,
.page-users.page-users--esd-program-show .page-users__esd-program-card__title {
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.4;
}
.page-users.page-users--esd-company-show .page-users__esd-program-card__tags,
.page-users.page-users--esd-program-show .page-users__esd-program-card__tags {
  margin-top: 0.4rem;
}
.page-users.page-users--esd-company-show .page-users__esd-program-card__summary,
.page-users.page-users--esd-program-show .page-users__esd-program-card__summary {
  margin: 0.5rem 0 0;
  font-size: 0.84rem;
  line-height: 1.55;
  color: #334155;
}
.page-users.page-users--esd-company-show .page-users__esd-program-card__status,
.page-users.page-users--esd-program-show .page-users__esd-program-card__status {
  margin-top: 0.65rem;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-foot,
.page-users.page-users--esd-program-show .page-users__esd-ec-foot {
  margin-top: 1.75rem;
  padding-top: 1.35rem;
  border-top: 1px solid #e2e8f0;
}
.page-users.page-users--esd-company-show .page-users__esd-ec-card--siblings,
.page-users.page-users--esd-program-show .page-users__esd-ec-card--siblings {
  background: linear-gradient(180deg, #f8fafc 0%, #fff 100%);
  border-style: solid;
  border-color: #e2e8f0;
}
.page-users.page-users--esd-company-show .page-users__esd-program-gallery,
.page-users.page-users--esd-program-show .page-users__esd-program-gallery {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin: 0.25rem 0 0;
}
.page-users.page-users--esd-company-show .page-users__esd-program-gallery-img,
.page-users.page-users--esd-program-show .page-users__esd-program-gallery-img {
  max-width: 100%;
  width: auto;
  height: auto;
  max-height: 28rem;
  border-radius: 0.45rem;
  border: 1px solid #e2e8f0;
}
.page-users.page-users--esd-company-show .page-users__esd-program-siblings,
.page-users.page-users--esd-program-show .page-users__esd-program-siblings {
  list-style: none;
  padding: 0;
  margin: 0.35rem 0 0;
}
.page-users.page-users--esd-company-show .page-users__esd-program-siblings li,
.page-users.page-users--esd-program-show .page-users__esd-program-siblings li {
  margin: 0;
  padding: 0.5rem 0;
  border-bottom: 1px solid #f1f5f9;
}
.page-users.page-users--esd-company-show .page-users__esd-program-siblings li:last-child,
.page-users.page-users--esd-program-show .page-users__esd-program-siblings li:last-child {
  border-bottom: none;
  padding-bottom: 0;
}
.page-users.page-users--esd-company-show .page-users__esd-program-siblings-tag,
.page-users.page-users--esd-program-show .page-users__esd-program-siblings-tag {
  margin-left: 0.35rem;
  font-weight: 400;
}
.page-users.page-users--esd-company-show .page-users__table--ec-esd-program-logistics,
.page-users.page-users--esd-program-show .page-users__table--ec-esd-program-logistics {
  max-width: 100%;
  margin: 0.35rem 0 0;
}

.page-users.page-users--esd-program-show .page-users__esd-ec-shell {
  max-width: min(960px, 100%);
}
.page-users.page-users--esd-program-show .page-users__esd-ec-card--review .page-users__esd-ec-hint {
  background: #eff6ff;
  border-color: #dbeafe;
  color: #1e3a8a;
}

.esd-company-status-form {
  width: 100%;
  max-width: 26rem;
}
.esd-company-status-form__row {
  margin-bottom: 0.65rem;
}
.esd-company-status-form__label {
  display: block;
  font-size: 0.8125rem;
  font-weight: 600;
  color: #475569;
  margin-bottom: 0.3rem;
}
.esd-company-status-form__select {
  max-width: 100%;
}
.esd-company-status-form__reason {
  max-width: 100%;
  min-height: 5rem;
}
.esd-company-status-form--ec-program {
  max-width: none;
}
.esd-company-status-form__select--standalone {
  max-width: min(22rem, 100%);
  font-weight: 600;
}

.ec-monthly-upload__toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.65rem;
  margin-bottom: 1rem;
  padding: 0 0.15rem;
}
.ec-monthly-upload__fy-label {
  font-size: 0.875rem;
  font-weight: 600;
  color: #334155;
}
.ec-monthly-upload__th-school {
  min-width: 7.5rem;
}
.ec-monthly-upload__th-month {
  text-align: center;
  vertical-align: bottom;
  white-space: nowrap;
  min-width: 3.35rem;
  padding-left: 0.3rem;
  padding-right: 0.3rem;
}
.ec-monthly-upload__th-m {
  display: block;
  font-size: 0.72rem;
  line-height: 1.2;
  font-weight: 600;
}
.ec-monthly-upload__th-y {
  display: block;
  font-size: 0.65rem;
  line-height: 1.2;
  font-weight: 500;
  color: #64748b;
}
.ec-monthly-upload__td-school {
  white-space: nowrap;
  max-width: 14rem;
  text-overflow: ellipsis;
  overflow: hidden;
}
.ec-monthly-upload__cell {
  text-align: center;
  vertical-align: middle;
  font-variant-numeric: tabular-nums;
  padding-top: 0.45rem;
  padding-bottom: 0.45rem;
}
.ec-monthly-upload__mark {
  display: block;
  font-size: 0.95rem;
  line-height: 1.15;
  color: #0f766e;
}
.ec-monthly-upload__at {
  display: block;
  margin-top: 0.2rem;
  font-size: 0.65rem;
  line-height: 1.25;
  color: #64748b;
  white-space: normal;
  word-break: break-all;
}
.ec-monthly-upload__dash {
  color: #cbd5e1;
  font-size: 0.95rem;
  font-weight: 300;
}

.page-users {
  box-sizing: border-box;
}

.page-users--narrow {
  background: #fff;
  padding: 2rem 1rem;
  border-radius: 12px;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 767px) {
  .page-users--narrow {
    width: 90%;
    max-width: 100%;
  }
}
@media (min-width: 768px) {
  .page-users--narrow {
    width: 100%;
    max-width: 500px;
  }
}

.page-users .page-users__header {
  margin-bottom: 1.25rem;
}
.page-users .page-users__title {
  margin: 0 0 2rem;
  font-size: 1.375rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: #0f172a;
  line-height: 1.3;
}
.page-users .page-users__head-row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 0.75rem;
}
.page-users .page-users__head-row-main {
  flex: 1;
  min-width: min(100%, 16rem);
}
.page-users .page-users__toolbar {
  margin-bottom: 1rem;
  flex-shrink: 0;
}
.page-users__head-row .page-users .page-users__toolbar {
  margin-bottom: 0;
  align-self: center;
}
.page-users .page-users__duty-minutes-field {
  width: 5.5rem;
  max-width: 100%;
  padding: 0.4rem 0.5rem;
  border: 1px solid #cbd5e1;
  border-radius: 6px;
  font-size: 0.9375rem;
  box-sizing: border-box;
}
.page-users .page-users__duty-clock-select {
  min-width: 6.5rem;
  max-width: 100%;
  padding: 0.4rem 0.45rem;
  border: 1px solid #cbd5e1;
  border-radius: 6px;
  font-size: 0.875rem;
  box-sizing: border-box;
}
.page-users .school-guard-shift-form__duty-hint {
  margin: 0.35rem 0 0;
  font-size: 0.8125rem;
  line-height: 1.45;
}
.page-users .page-users__lead {
  margin: 0 0 1rem;
  font-size: 0.875rem;
  color: #64748b;
  line-height: 1.65;
  max-width: 40rem;
}
.page-users .page-users__lead--approver-summary {
  max-width: 48rem;
}
.page-users .page-users__lead--warning-soft {
  color: #475569;
  background: #fffbeb;
  border: 1px solid #fde68a;
  border-radius: 0.5rem;
  padding: 0.75rem 1rem;
  box-sizing: border-box;
}
.page-users .page-users__approver-name {
  color: #0f172a;
}
.page-users .page-users__lead-hint {
  display: block;
  margin-top: 0.35rem;
  font-size: 0.8125rem;
  font-weight: 400;
  color: #64748b;
}
.page-users .page-users__staff-tabs-wrap {
  margin: 0 0 1rem;
  max-width: 48rem;
}
.page-users .page-users__staff-tabs {
  margin-bottom: 0;
}
.page-users .page-users__staff-tabs--many {
  flex-wrap: wrap;
  row-gap: 0.25rem;
}
.page-users .page-users__tab-hint {
  margin: 0.5rem 0 0;
  font-size: 0.8125rem;
  color: #64748b;
  line-height: 1.5;
}
.page-users .page-users__link--table-name {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-weight: 600;
  color: #334155;
}
.page-users .page-users__link--table-name::before {
  display: none;
}
.page-users .page-users__link--table-name:hover {
  color: #0f172a;
}
.page-users .page-users__link--table-name-icon {
  font-size: 1rem;
  line-height: 1;
  opacity: 0.85;
  flex-shrink: 0;
}
.page-users .page-users__panel--detail {
  padding: 1rem 1.25rem;
  max-width: 40rem;
}
.page-users .page-users__settings-sections {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.page-users .page-users__settings-grid {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  margin: 0 -0.375rem;
}
.page-users .page-users__settings-grid > .col-3 {
  flex: 0 0 33.3333%;
  max-width: 33.3333%;
  padding: 0 0.375rem;
  margin-bottom: 0.75rem;
}
.page-users .page-users__settings-category {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}
.page-users .page-users__settings-category-title {
  margin: 0 0 0.15rem;
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: #64748b;
}
.page-users .page-users__settings-card {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  min-height: 7rem;
  padding: 0.85rem 0.9rem;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  text-decoration: none;
  color: inherit;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
  transition: border-color 0.15s, box-shadow 0.15s, transform 0.12s;
}
.page-users .page-users__settings-card:hover {
  border-color: #cbd5e1;
  box-shadow: 0 4px 10px rgba(15, 23, 42, 0.06);
  transform: translateY(-1px);
}
.page-users .page-users__settings-card-title {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 700;
  color: #0f172a;
}
.page-users .page-users__detail-list {
  margin: 0;
}
.page-users .page-users__detail-row {
  display: grid;
  grid-template-columns: minmax(7rem, 10rem) 1fr;
  gap: 0.35rem 1rem;
  padding: 0.65rem 0;
  border-bottom: 1px solid #e2e8f0;
  font-size: 0.875rem;
}
.page-users .page-users__detail-row:last-child {
  border-bottom: none;
}
.page-users .page-users__detail-row dt {
  margin: 0;
  font-weight: 600;
  color: #64748b;
}
.page-users .page-users__detail-row dd {
  margin: 0;
  color: #0f172a;
  word-break: break-word;
}
.page-users .field__checkbox-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.page-users .field__label-inline {
  font-size: 0.875rem;
  font-weight: 500;
  color: #0f172a;
  margin: 0;
  cursor: pointer;
}
.page-users .page-users__subtitle {
  margin: 1.75rem 0 0;
  font-size: 1.05rem;
  font-weight: 600;
  color: #0f172a;
}
.page-users .page-users__subtitle--reports {
  margin-top: 2rem;
  scroll-margin-top: 4rem;
}
.page-users .page-users__subtitle-hint {
  margin: 0.35rem 0 0;
}
.page-users .page-users__back {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  margin: 0;
  font-size: 0.875rem;
  font-weight: 500;
  color: #334155;
  text-decoration: none;
}
.page-users .page-users__back .las {
  font-size: 1.125rem;
  opacity: 0.9;
}
.page-users .page-users__back:hover {
  color: #0f172a;
  text-decoration: underline;
}
.page-users .page-users__panel {
  overflow: hidden;
}
.page-users .page-users__panel--subtle {
  margin-bottom: 1rem;
  padding: 1rem 1.25rem;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  box-sizing: border-box;
}
.page-users .page-users__subpanel-title {
  margin: 0 0 0.35rem;
  font-size: 1rem;
  font-weight: 600;
  color: #0f172a;
}
.page-users .page-users__subpanel-lead {
  margin: 0 0 1rem;
  font-size: 0.875rem;
  color: #64748b;
  line-height: 1.55;
  max-width: 40rem;
}
.page-users .page-user-form--inline-row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 1rem;
  max-width: 48rem;
}
.page-users .page-user-form--inline-row__field {
  flex: 1 1 14rem;
  min-width: 0;
  margin-bottom: 0;
}
.page-users .page-user-form--inline-row__field select {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}
.page-users .page-user-form--inline-row__actions {
  margin: 0;
  flex-shrink: 0;
}
.page-users .page-users__badge--soft {
  display: inline-block;
  padding: 0.2rem 0.5rem;
  font-size: 0.75rem;
  font-weight: 600;
  color: #047857;
  background: #ecfdf5;
  border-radius: 0.375rem;
  white-space: nowrap;
}
.page-users .page-users__cell-muted {
  color: #64748b;
  font-size: 0.875rem;
}
.page-users .page-users__actions {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.page-users .page-users__link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  color: #334155;
  text-decoration: none !important;
  font-size: 0.875rem;
}
.page-users .page-users__link::before {
  content: "";
  width: 0.28rem;
  height: 0.28rem;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(-45deg);
  opacity: 0.45;
  flex-shrink: 0;
}
.page-users .page-users__link:has(i.las)::before {
  display: none;
}
.page-users .page-users__link:hover {
  color: #0f172a;
  text-decoration: underline;
}
.page-users .page-users__link:hover::before {
  opacity: 0.75;
}
.page-users .page-users__link--danger {
  color: #b91c1c;
}
.page-users .page-users__link--danger:hover {
  color: #991b1b;
}
.page-users .page-users__link--danger::before {
  border-color: currentColor;
}
.page-users .page-users__link--impersonate {
  color: #047857;
  font-weight: 500;
}
.page-users .page-users__link--impersonate:hover {
  text-decoration: underline;
}
.page-users .page-users__link--impersonate::before {
  border-color: currentColor;
}
.page-users .page-users__link--strong {
  font-weight: 600;
  font-size: 0.9375rem;
}
.page-users .page-users__link--strong::before {
  width: 0.32rem;
  height: 0.32rem;
}
.page-users .page-users__filter-hint {
  margin: 0 0 1rem;
  font-size: 0.875rem;
  color: #475569;
  line-height: 1.5;
}
.page-users .page-users__th-actions {
  width: 1%;
  white-space: nowrap;
  text-align: right;
}
.page-users .page-users__form--inline {
  display: inline-flex;
  align-items: center;
  margin: 0;
  padding: 0;
  vertical-align: middle;
}
.page-users .page-users__table td.page-users__icon-actions {
  vertical-align: middle;
}
.page-users .page-users__table td.page-users__icon-actions > form.button_to {
  display: inline-flex;
  align-items: center;
  margin: 0;
  padding: 0;
}
.page-users .page-users__name-action {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  margin: 0;
  padding: 0.35rem 0.6rem 0.35rem 0.45rem;
  border: 1px solid transparent;
  border-radius: 0.5rem;
  background: transparent;
  font: inherit;
  font-weight: 600;
  font-size: 0.9375rem;
  color: #334155;
  cursor: pointer;
  text-align: left;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.page-users .page-users__name-action .las {
  font-size: 1.1rem;
  color: #059669;
  opacity: 0.9;
}
.page-users .page-users__name-action:hover {
  background: #ecfdf5;
  border-color: #a7f3d0;
  color: #0f172a;
}
.page-users .page-users__name-text {
  font-weight: 600;
  font-size: 0.9375rem;
  color: #0f172a;
}
.page-users .page-users__link-row {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-weight: 600;
  font-size: 0.9375rem;
  color: #334155;
  text-decoration: none;
  padding: 0.35rem 0.5rem 0.35rem 0.4rem;
  margin: -0.35rem -0.5rem -0.35rem -0.4rem;
  border-radius: 0.5rem;
  transition: background 0.15s, color 0.15s;
}
.page-users .page-users__link-row::before {
  content: "";
  width: 0.32rem;
  height: 0.32rem;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(-135deg);
  opacity: 0.4;
  flex-shrink: 0;
}
.page-users .page-users__link-row:hover {
  background: #f1f5f9;
  color: #0f172a;
}
.page-users .page-users__link-row:hover .page-users__link-row-chevron {
  transform: translateX(3px);
  opacity: 1;
}
.page-users .page-users__link-row:hover::before {
  opacity: 0.65;
}
.page-users .page-users__link-row--icon-only {
  justify-content: center;
  min-width: 2.25rem;
  min-height: 2.25rem;
  padding: 0.35rem;
  margin: -0.35rem;
}
.page-users .page-users__link-row--icon-only .page-users__link-row-chevron {
  font-size: 1rem;
  opacity: 0.55;
}
.page-users .page-users__link-row-chevron {
  font-size: 0.7rem;
  opacity: 0.45;
  transition: transform 0.15s ease, opacity 0.15s;
}
.page-users .page-users__icon-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.375rem;
}
.page-users .page-users__table td.page-users__icon-actions {
  display: table-cell;
}
.page-users .page-users__icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.375rem;
  height: 2.375rem;
  padding: 0;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  background: #fff;
  color: #475569;
  text-decoration: none;
  cursor: pointer;
  box-shadow: 0 1px 1px rgba(15, 23, 42, 0.04);
  transition: background 0.15s, border-color 0.15s, color 0.15s, box-shadow 0.15s;
}
.page-users .page-users__icon-btn:hover {
  background: #f8fafc;
  border-color: #cbd5e1;
  color: #0f172a;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
}
.page-users .page-users__icon-btn .las {
  font-size: 1.2rem;
  line-height: 1;
}
.page-users .page-users__icon-btn--danger {
  color: #b91c1c;
  border-color: #fecdd3;
  background: #fffafb;
}
.page-users .page-users__icon-btn--danger:hover {
  background: #fff1f2;
  border-color: #fda4af;
  color: #991b1b;
}

.page-user-form__csv-format {
  background: #f1f5f9;
  padding: 0.75rem 1rem;
  border-radius: 0.25rem;
  font-size: 0.8125rem;
  overflow-x: auto;
  margin-bottom: 1rem;
}

.file-drop-zone {
  border: 2px dashed #cbd5e1;
  border-radius: 0.5rem;
  padding: 1.5rem;
  text-align: center;
  background: #fff;
  transition: border-color 0.15s, background 0.15s;
}
.file-drop-zone.is-dragover {
  border-color: #2563eb;
  background: #eff6ff;
}
.file-drop-zone .file-drop-zone__label {
  display: block;
  margin-bottom: 0.5rem;
  font-weight: 500;
  font-size: 0.875rem;
}
.file-drop-zone .file-drop-zone__hint {
  font-size: 0.875rem;
  color: #64748b;
  margin-bottom: 0.75rem;
}
.file-drop-zone .file-drop-zone__filename {
  font-size: 0.8125rem;
  color: #047857;
  margin-top: 0.5rem;
}
.file-drop-zone input[type=file] {
  margin-top: 0.5rem;
  font-size: 0.875rem;
}

.page-user-form {
  max-width: 28rem;
}
.page-user-form .page-user-form__title {
  margin: 0 0 1rem;
  font-size: 1.25rem;
  font-weight: 700;
}
.page-user-form .field {
  margin-bottom: 1rem;
}
.page-user-form .field label {
  display: block;
  margin-bottom: 0.25rem;
  font-weight: 500;
  font-size: 0.875rem;
}
.page-user-form .field input[type=email],
.page-user-form .field input[type=password],
.page-user-form .field input[type=tel],
.page-user-form .field input[type=text],
.page-user-form .field input[type=date],
.page-user-form .field input[type=datetime-local],
.page-user-form .field select,
.page-user-form .field textarea {
  width: 100%;
  padding: 0.5rem 0.75rem;
  border: 1px solid #cbd5e1;
  border-radius: 0.375rem;
  font-size: 1rem;
  background: #fff;
}
.page-user-form .field input[type=email]:focus,
.page-user-form .field input[type=password]:focus,
.page-user-form .field input[type=tel]:focus,
.page-user-form .field input[type=text]:focus,
.page-user-form .field input[type=date]:focus,
.page-user-form .field input[type=datetime-local]:focus,
.page-user-form .field select:focus,
.page-user-form .field textarea:focus {
  outline: none;
  border-color: #2563eb;
  box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.15);
}
.page-user-form .field textarea {
  resize: vertical;
  min-height: 6rem;
}
.page-user-form .field--school-staff-delegations {
  margin-top: 1.25rem;
  padding-top: 1rem;
  border-top: 1px solid #e2e8f0;
}
.page-user-form .field--school-staff-delegations .field__hint {
  margin-bottom: 0.75rem;
  line-height: 1.55;
}
.page-user-form .field--school-staff-delegations .field__delegations-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-top: 0.35rem;
}
.page-user-form .field--school-staff-delegations .field__delegation-row {
  min-width: 0;
}
.page-user-form .field--school-staff-delegations .field__delegation-row input[type=hidden] {
  display: none;
}
.page-user-form .field--school-staff-delegations label.field__delegation-label {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 0.5rem;
  margin: 0;
  width: 100%;
  box-sizing: border-box;
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1.45;
  color: #0f172a;
  cursor: pointer;
}
.page-user-form .field--school-staff-delegations .field__delegation-label input[type=checkbox] {
  flex-shrink: 0;
  width: auto;
  height: auto;
  margin: 0.2rem 0 0;
}
.page-user-form .field--school-staff-delegations .field__delegation-text {
  flex: 1;
  min-width: 0;
}
.page-user-form .field--designated-childcare-approver .field__checkbox-row {
  margin: 0;
}
.page-user-form .field--designated-childcare-approver .field__checkbox-inline-label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  margin: 0;
  cursor: pointer;
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1.35;
  color: #0f172a;
}
.page-user-form .field--designated-childcare-approver .field__checkbox-inline-label input[type=checkbox] {
  flex-shrink: 0;
  width: auto;
  height: auto;
  margin: 0;
}
.page-user-form .field--designated-childcare-approver .field__checkbox-inline-text {
  flex: 1;
  min-width: 0;
}
.page-user-form .field--transport-allowance .field__transport-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr));
  gap: 0.75rem 0.9rem;
}
.page-user-form .field--transport-allowance .field__transport-item {
  min-width: 0;
}
.page-user-form .field--transport-allowance input[type=text] {
  max-width: 12rem;
}
.page-user-form .actions {
  margin-top: 1.25rem;
  display: flex;
  gap: 0.75rem;
}

.page-users.page-users--admin-wide {
  max-width: none;
  width: 100%;
  box-sizing: border-box;
}
.page-users.page-users--admin-wide .admin-dashboard__intro {
  max-width: 52rem;
  line-height: 1.65;
}
.page-users.page-users--admin-wide .admin-dashboard__cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 18rem), 1fr));
  gap: 1.25rem;
  margin-top: 1rem;
  align-items: start;
}
@media (min-width: 1100px) {
  .page-users.page-users--admin-wide .admin-dashboard__cards {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (min-width: 1600px) {
  .page-users.page-users--admin-wide .admin-dashboard__cards {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.5rem;
  }
}
.page-users.page-users--admin-wide .admin-dashboard__cards .esd-lp-card, .page-users.page-users--admin-wide .admin-dashboard__cards .esd-panel {
  max-width: none;
  margin: 0;
}
.page-users.page-users--admin-wide .admin-dashboard__foot {
  margin-top: 1.25rem;
  max-width: 52rem;
  color: #64748b;
  font-size: 0.8125rem;
  line-height: 1.55;
}

.page-users__table-wrap,
.page-users .page-users__table-wrap {
  margin: 0.5rem 0 1.25rem;
  border: 1px solid #e1e7ef;
  border-radius: 0.75rem;
  background: #fff;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.05);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.page-users .page-users__panel > .page-users__table-wrap:first-child {
  margin-top: 0;
}

.page-users__table-wrap--data {
  border-color: #d8e0ea;
}

.page-users__table--data th,
.page-users__table--data td {
  padding: 0.55rem 0.7rem;
  font-size: 0.8125rem;
}

.page-users .page-users__table,
.page-users__table-wrap .page-users__table {
  width: 100%;
  border-collapse: collapse;
  background: #fff;
  font-size: 0.875rem;
  line-height: 1.45;
  color: #334155;
}

.page-users .page-users__table th,
.page-users .page-users__table td,
.page-users__table-wrap .page-users__table th,
.page-users__table-wrap .page-users__table td {
  padding: 0.7rem 0.9rem;
  text-align: left;
  vertical-align: middle;
  border-bottom: 1px solid #eef2f7;
  border-right: 1px solid #f1f5f9;
}

.page-users .page-users__table th:last-child,
.page-users .page-users__table td:last-child,
.page-users__table-wrap .page-users__table th:last-child,
.page-users__table-wrap .page-users__table td:last-child {
  border-right: none;
  padding-right: 1.1rem;
}

.page-users .page-users__table th:first-child,
.page-users .page-users__table td:first-child,
.page-users__table-wrap .page-users__table th:first-child,
.page-users__table-wrap .page-users__table td:first-child {
  padding-left: 1.1rem;
}

.page-users .page-users__table thead th,
.page-users__table-wrap .page-users__table thead th,
.page-users__th {
  background: #eef2f7;
  font-weight: 600;
  font-size: 0.78rem;
  letter-spacing: 0.02em;
  color: #475569;
  border-bottom: 2px solid #cbd5e1;
  white-space: nowrap;
}

.page-users__th--action {
  width: 1%;
  white-space: nowrap;
  vertical-align: middle;
  text-align: center;
}

.page-users__td--numeric {
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1;
}

.page-users__td--strong {
  font-weight: 600;
  color: #1e293b;
}

.page-users__td--action {
  width: 1%;
  white-space: nowrap;
  text-align: right;
  vertical-align: middle;
}

.page-users__delegation-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  max-width: 22rem;
}

.page-users__delegation-badge {
  display: inline-block;
  padding: 0.2rem 0.5rem;
  font-size: 0.72rem;
  font-weight: 600;
  line-height: 1.35;
  border-radius: 0.3rem;
  white-space: nowrap;
}

.page-users__delegation-badge--login {
  background: #e0f2fe;
  color: #0369a1;
}

.page-users__delegation-badge--leave {
  background: #fef3c7;
  color: #b45309;
}

.page-users__delegation-badge--staff {
  background: #ede9fe;
  color: #5b21b6;
}

.page-users__delegation-none {
  color: #94a3b8;
  font-size: 0.875rem;
}

.page-users .page-users__table tbody tr:nth-child(even) td:not([class*=school-csv-external-work--]),
.page-users__table-wrap .page-users__table tbody tr:nth-child(even) td:not([class*=school-csv-external-work--]) {
  background: #fafbfc;
}

.page-users .page-users__table tbody tr:last-child td,
.page-users__table-wrap .page-users__table tbody tr:last-child td {
  border-bottom: none;
}

.admin-school-unit-cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.9rem;
  margin-top: 0.25rem;
}
@media (max-width: 1100px) {
  .admin-school-unit-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 700px) {
  .admin-school-unit-cards {
    grid-template-columns: 1fr;
  }
}

.admin-school-unit-cards__col {
  min-width: 0;
}

.admin-school-unit-card {
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  padding: 0.95rem;
  border: 1px solid #e2e8f0;
  border-radius: 0.75rem;
  background: #fff;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.05);
}

.admin-school-unit-card__main {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  text-decoration: none;
  text-align: center;
}

.admin-school-unit-card__icon {
  width: 4.2rem;
  height: 4.2rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #475569;
  font-size: 2rem;
  flex-shrink: 0;
}

.admin-school-unit-card__name {
  color: #0f172a;
  font-size: 0.96rem;
  font-weight: 700;
  line-height: 1.35;
}

.admin-school-unit-card__actions {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  margin-top: auto;
}

.page-users .page-users__table tbody tr:hover td,
.page-users__table-wrap .page-users__table tbody tr:hover td {
  background: #f1f5f9;
}

.page-users .page-users__table tbody tr:hover td[class*=school-csv-external-work--],
.page-users__table-wrap .page-users__table tbody tr:hover td[class*=school-csv-external-work--] {
  background: inherit;
}

.page-users__table-wrap .page-users__table td.school-csv-external-work--yellow,
.page-users .page-users__table td.school-csv-external-work--yellow {
  background: #fff9c4;
}

.page-users__table-wrap .page-users__table td.school-csv-external-work--green,
.page-users .page-users__table td.school-csv-external-work--green {
  background: #c8e6c9;
}

.page-users__table-wrap .page-users__table td.school-csv-external-work--red,
.page-users .page-users__table td.school-csv-external-work--red {
  background: #ffcdd2;
}

.page-users__table-wrap .page-users__table tbody tr:hover td.school-csv-external-work--yellow,
.page-users .page-users__table tbody tr:hover td.school-csv-external-work--yellow {
  background: #fff176;
}

.page-users__table-wrap .page-users__table tbody tr:hover td.school-csv-external-work--green,
.page-users .page-users__table tbody tr:hover td.school-csv-external-work--green {
  background: #aed581;
}

.page-users__table-wrap .page-users__table tbody tr:hover td.school-csv-external-work--red,
.page-users .page-users__table tbody tr:hover td.school-csv-external-work--red {
  background: #ef9a9a;
}

.page-users .page-users__table .page-users__empty-cell {
  text-align: center;
  padding: 2.5rem 1.5rem !important;
  color: #64748b;
  font-size: 0.875rem;
  background: #fafafa !important;
}

.school-csv-external-work-legend {
  margin: 0.75rem 0 0;
  padding: 0 0 0.5rem;
  font-size: 0.75rem;
  color: #64748b;
  line-height: 1.5;
}

.school-csv-external-work-legend__label {
  margin-right: 0.35rem;
}

.school-csv-external-work-legend__swatch {
  display: inline-block;
  margin-right: 0.65rem;
  padding: 0.1rem 0.35rem;
  border-radius: 0.25rem;
  border: 1px solid #e2e8f0;
}

.school-csv-external-work-legend__swatch--white {
  background: #fff;
}

.school-csv-external-work-legend__swatch--yellow {
  background: #fff9c4;
}

.school-csv-external-work-legend__swatch--green {
  background: #c8e6c9;
}

.school-csv-external-work-legend__swatch--red {
  background: #ffcdd2;
}

.school-csv-external-work-legend--in-card {
  margin: 0.5rem 0 0;
  padding: 0 0.25rem 0.35rem;
}

.school-csv-sort-th__link {
  color: inherit;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.15rem;
  border-radius: 0.25rem;
  margin: -0.15rem -0.25rem;
  padding: 0.15rem 0.25rem;
}
.school-csv-sort-th__link:hover {
  color: #2563eb;
  text-decoration: underline;
  background: rgba(37, 99, 235, 0.06);
}
.school-csv-sort-th__link.is-active {
  font-weight: 700;
  color: #1d4ed8;
}

.school-csv-sort-th__indicator {
  font-size: 0.65em;
  opacity: 0.85;
}

.page-users__esd-company-cards {
  display: flex;
  flex-wrap: wrap;
  margin-top: 0.75rem;
}

.page-users__esd-company-cards.row > .col-3 {
  flex: 0 0 100%;
  max-width: 100%;
  padding-left: 0.75rem;
  padding-right: 0.75rem;
  margin-bottom: 1rem;
  box-sizing: border-box;
}

@media (min-width: 640px) {
  .page-users__esd-company-cards.row > .col-3 {
    flex: 0 0 50%;
    max-width: 50%;
  }
}
@media (min-width: 992px) {
  .page-users__esd-company-cards.row > .col-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
}
.page-users__esd-company-card {
  height: 100%;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  padding: 0.85rem;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
}

.page-users__esd-company-card__cover {
  margin-bottom: 0.65rem;
}

.page-users__esd-company-card__name {
  margin: 0 0 0.45rem;
  font-size: 1rem;
  line-height: 1.4;
}

.page-users__esd-company-card__meta {
  margin: 0 0 0.35rem;
  font-size: 0.82rem;
  color: #475569;
  line-height: 1.5;
}

.page-users__esd-company-card__actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 0.5rem;
}

.school-guard-shift-cal {
  margin-top: 1rem;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
}
.school-guard-shift-cal__scroll {
  position: relative;
  overflow-x: auto;
  overflow-y: visible;
  -webkit-overflow-scrolling: touch;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
}
.school-guard-shift-cal__scroll-pane {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
}
@media (max-width: 900px) {
  .school-guard-shift-cal__scroll-pane {
    width: max-content;
    min-width: 100%;
  }
}
@media (hover: none) and (pointer: coarse) {
  .school-guard-shift-cal__scroll-pane {
    width: max-content;
    min-width: 100%;
  }
}
.school-guard-shift-cal__grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(5.75rem, 1fr));
  width: 100%;
  min-width: calc(40.25rem + 6px);
  max-width: 52rem;
  margin-left: auto;
  margin-right: auto;
  gap: 1px;
  background: #e2e8f0;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  overflow: hidden;
  box-sizing: border-box;
}
@media (max-width: 900px) {
  .school-guard-shift-cal__grid {
    grid-template-columns: repeat(7, 5.75rem);
    width: calc(40.25rem + 6px);
    min-width: calc(40.25rem + 6px);
    max-width: none;
    margin-left: 0;
    margin-right: 0;
  }
}
@media (hover: none) and (pointer: coarse) {
  .school-guard-shift-cal__grid {
    grid-template-columns: repeat(7, 5.75rem);
    width: calc(40.25rem + 6px);
    min-width: calc(40.25rem + 6px);
    max-width: none;
    margin-left: 0;
    margin-right: 0;
  }
}
@media (max-width: 900px) {
  .school-guard-shift-cal__scroll {
    overflow-x: scroll;
  }
}
@media (hover: none) and (pointer: coarse) {
  .school-guard-shift-cal__scroll {
    overflow-x: scroll;
  }
}
.school-guard-shift-cal__weekday {
  background: #f1f5f9;
  color: #475569;
  font-size: clamp(0.62rem, 1.8vw, 0.75rem);
  font-weight: 600;
  text-align: center;
  padding: clamp(0.3rem, 1.2vw, 0.45rem) clamp(0.1rem, 0.8vw, 0.25rem);
  letter-spacing: 0.02em;
  min-width: 0;
}
.school-guard-shift-cal__day {
  background: #fff;
  min-height: clamp(4rem, 18vw, 5.75rem);
  padding: clamp(0.2rem, 1.2vw, 0.4rem) clamp(0.15rem, 1vw, 0.4rem) clamp(0.3rem, 1.2vw, 0.5rem);
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  box-sizing: border-box;
  min-width: 0;
}
.school-guard-shift-cal__day--outside {
  background: #f8fafc;
  color: #94a3b8;
}
.school-guard-shift-cal__day--outside .school-guard-shift-cal__daynum {
  color: #94a3b8;
}
.school-guard-shift-cal__day--today {
  box-shadow: inset 0 0 0 2px #3b82f6;
}
.school-guard-shift-cal__dayhead {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.15rem;
  flex-shrink: 0;
  min-width: 0;
}
.school-guard-shift-cal__daynum {
  font-size: clamp(0.72rem, 2.4vw, 0.9rem);
  font-weight: 700;
  color: #0f172a;
  line-height: 1.2;
  min-width: 0;
}
.school-guard-shift-cal__add {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 0.25rem;
  color: #2563eb;
  background: rgba(37, 99, 235, 0.08);
  flex-shrink: 0;
  box-sizing: border-box;
}
@media (max-width: 639.98px) {
  .school-guard-shift-cal__add {
    width: 2.75rem;
    height: 2.75rem;
  }
}
.school-guard-shift-cal__add:hover {
  background: rgba(37, 99, 235, 0.16);
  color: #1d4ed8;
}
.school-guard-shift-cal__add .las {
  font-size: 1rem;
}
.school-guard-shift-cal__entries {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: clamp(0.2rem, 1vw, 0.35rem);
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  max-height: clamp(5rem, 28vw, 9rem);
}
.school-guard-shift-cal__entry {
  font-size: clamp(0.58rem, 1.85vw, 0.72rem);
  line-height: 1.35;
  padding: clamp(0.2rem, 1vw, 0.3rem) clamp(0.2rem, 1vw, 0.35rem);
  border-radius: 0.25rem;
  background: #f1f5f9;
  border: 1px solid #e2e8f0;
  color: #334155;
  min-width: 0;
}
.school-guard-shift-cal__entry--interactive {
  cursor: pointer;
}
.school-guard-shift-cal__entry--interactive:hover {
  background: #e8eef5;
  border-color: #cbd5e1;
}
.school-guard-shift-cal__entry--interactive:focus-visible {
  outline: 2px solid #3b82f6;
  outline-offset: 1px;
}
.school-guard-shift-cal__who {
  display: block;
  font-weight: 600;
  color: #0f172a;
  word-break: break-word;
  overflow-wrap: anywhere;
}
.school-guard-shift-cal__school {
  display: block;
  font-weight: 500;
  color: #1e40af;
  word-break: break-word;
  overflow-wrap: anywhere;
}
.school-guard-shift-cal__duty-time {
  display: block;
  margin-top: 0.08rem;
  font-weight: 600;
  color: #0f766e;
  font-size: clamp(0.55rem, 1.65vw, 0.68rem);
  letter-spacing: 0.02em;
}
.school-guard-shift-cal__note {
  display: block;
  margin-top: 0.1rem;
  color: #64748b;
  font-size: clamp(0.55rem, 1.65vw, 0.68rem);
  word-break: break-word;
  overflow-wrap: anywhere;
}
.school-guard-shift-cal__entry-actions {
  display: flex;
  gap: 0.2rem;
  margin-top: 0.2rem;
  justify-content: flex-end;
  flex-wrap: wrap;
}
.school-guard-shift-cal__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.65rem;
  height: 1.65rem;
  border: none;
  border-radius: 0.25rem;
  background: #fff;
  color: #475569;
  cursor: pointer;
  text-decoration: none;
  padding: 0;
  font-size: 0.95rem;
  box-sizing: border-box;
}
@media (max-width: 639.98px) {
  .school-guard-shift-cal__icon {
    width: 2.75rem;
    height: 2.75rem;
  }
}
.school-guard-shift-cal__icon:hover {
  background: #e2e8f0;
  color: #0f172a;
}
.school-guard-shift-cal__icon--danger:hover {
  background: #fee2e2;
  color: #b91c1c;
}
.school-guard-shift-cal__legend {
  margin: 0.75rem 0 0;
  font-size: clamp(0.72rem, 2vw, 0.8125rem);
  color: #64748b;
  line-height: 1.5;
  max-width: 52rem;
  margin-left: auto;
  margin-right: auto;
  padding: 0 0.25rem;
  box-sizing: border-box;
}
.school-guard-shift-cal__legend-sample {
  display: inline-block;
  padding: 0.1rem 0.35rem;
  border-radius: 0.2rem;
  background: #f8fafc;
  color: #94a3b8;
  border: 1px solid #e2e8f0;
  margin-right: 0.25rem;
}

.school-guard-shift-modal {
  position: fixed;
  inset: 0;
  z-index: 4000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  box-sizing: border-box;
}
.school-guard-shift-modal[hidden] {
  display: none !important;
}
.school-guard-shift-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.45);
  cursor: pointer;
}
.school-guard-shift-modal__dialog {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 22rem;
  max-height: min(90vh, 32rem);
  overflow: auto;
  background: #fff;
  border-radius: 0.65rem;
  box-shadow: 0 25px 50px -12px rgba(15, 23, 42, 0.35);
  border: 1px solid #e2e8f0;
  box-sizing: border-box;
}
.school-guard-shift-modal__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 1rem 1rem 0.75rem;
  border-bottom: 1px solid #e2e8f0;
}
.school-guard-shift-modal__title {
  margin: 0;
  font-size: 1.125rem;
  font-weight: 700;
  color: #0f172a;
  line-height: 1.35;
  flex: 1;
  min-width: 0;
}
.school-guard-shift-modal__close {
  flex-shrink: 0;
  width: 2.25rem;
  height: 2.25rem;
  margin: -0.25rem -0.35rem 0 0;
  border: none;
  border-radius: 0.35rem;
  background: transparent;
  color: #64748b;
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
}
.school-guard-shift-modal__close:hover {
  background: #f1f5f9;
  color: #0f172a;
}
.school-guard-shift-modal__body {
  padding: 1rem 1rem 0.75rem;
}
.school-guard-shift-modal__dl {
  margin: 0;
}
.school-guard-shift-modal__row {
  display: grid;
  grid-template-columns: 5.5rem 1fr;
  gap: 0.35rem 0.75rem;
  padding: 0.5rem 0;
  border-bottom: 1px solid #f1f5f9;
  font-size: 0.9375rem;
}
.school-guard-shift-modal__row:last-child {
  border-bottom: none;
}
.school-guard-shift-modal__row dt {
  margin: 0;
  font-weight: 600;
  color: #64748b;
}
.school-guard-shift-modal__row dd {
  margin: 0;
  color: #0f172a;
  word-break: break-word;
  overflow-wrap: anywhere;
}
.school-guard-shift-modal__footer {
  padding: 0.75rem 1rem 1rem;
  border-top: 1px solid #e2e8f0;
}
.school-guard-shift-modal__edit {
  display: inline-block;
  text-decoration: none;
  text-align: center;
}

@supports (-webkit-touch-callout: none) {
  @media (any-hover: none) {
    .school-guard-shift-cal__scroll-pane {
      width: max-content;
      min-width: 100%;
    }
    .school-guard-shift-cal__grid {
      grid-template-columns: repeat(7, 5.75rem);
      width: calc(40.25rem + 6px);
      min-width: calc(40.25rem + 6px);
      max-width: none;
      margin-left: 0;
      margin-right: 0;
    }
    .school-guard-shift-cal__scroll {
      overflow-x: scroll;
      -webkit-overflow-scrolling: touch;
      -webkit-transform: translate3d(0, 0, 0);
    }
  }
}
.body--standalone .app-wrap {
  min-height: 100vh;
  background: linear-gradient(165deg, #f1f5f9 0%, #e2e8f0 45%, #f8fafc 100%);
}
.body--standalone .app-header {
  display: none;
}
.body--standalone .app-body {
  display: block;
  flex: 1;
  min-height: 100vh;
}
.body--standalone .app-sidebar {
  display: none;
}
.body--standalone .app-main {
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
  padding: 2rem 1.25rem 3rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  background: transparent;
  min-height: calc(100vh - 4rem);
}
.body--standalone .notice,
.body--standalone .alert {
  width: 100%;
  max-width: 26rem;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 1rem;
  box-sizing: border-box;
  flex-shrink: 0;
}
