/* =========================================================
   FUNUP UI Common
   - Shared design tokens
   - BEM-style common UI classes
   - Compatibility aliases for existing MyPage / Entry / Admin markup
========================================================= */

:root {
  --funup-color-primary: #173957;
  --funup-color-primary-hover: #0f2b45;
  --funup-color-accent: #00c853;
  --funup-color-text: #1f2937;
  --funup-color-muted: #64748b;
  --funup-color-border: #d8e2ee;
  --funup-color-border-soft: #e8eef5;
  --funup-color-bg: #f7fafc;
  --funup-color-surface: #ffffff;
  --funup-color-success: #008c62;
  --funup-color-success-bg: #e8fff5;
  --funup-color-error: #b3261e;
  --funup-color-error-bg: #fff1f0;
  --funup-color-warning: #b7791f;
  --funup-color-warning-bg: #fff8e6;
  --funup-radius-sm: 8px;
  --funup-radius-md: 12px;
  --funup-radius-lg: 18px;
  --funup-shadow-sm: 0 2px 8px rgba(15, 23, 42, .06);
  --funup-shadow-md: 0 8px 24px rgba(15, 23, 42, .08);
}

/* ---------------------------------------------------------
   Layout / Utilities
--------------------------------------------------------- */
.funup-container,
.form-wrapper {
  max-width: 960px;
  margin: 0 auto;
  padding: 24px 18px;
}

.funup-stack > * + * { margin-top: 16px; }
.funup-hidden,
.hidden { display: none !important; }

.funup-text-muted { color: var(--funup-color-muted); }
.funup-loading { color: var(--funup-color-muted); }

/* ---------------------------------------------------------
   Cards
--------------------------------------------------------- */
.funup-card,
.funup-card--surface,
.funup-panel,
.funup-mypage-box,
.funup-mypage-section,
.funup-entry-box,
.funup-auth-card,
.funup-entry-section,
.funup-entry-greeting-card,
.funup-participant-card,
.funup-application-card,
.funup-entry-participant,
.funup-history-card,
.funup-form-card,
.funup-admin-detail-box,
.funup-application-summary {
  background: var(--funup-color-surface);
  border: 1px solid var(--funup-color-border);
  border-radius: var(--funup-radius-lg);
  box-shadow: var(--funup-shadow-sm);
}

.funup-card__header,
.funup-card-header {
  padding: 16px 18px;
  border-bottom: 1px solid var(--funup-color-border-soft);
}

.funup-card__body,
.funup-card-body { padding: 18px; }
.funup-card__footer,
.funup-card-footer,
.funup-entry-card-footer {
  padding: 14px 18px;
  border-top: 1px solid var(--funup-color-border-soft);
}

/* ---------------------------------------------------------
   Buttons
--------------------------------------------------------- */
.funup-button,
.funup-button--primary,
.funup-mypage-button,
.funup-auth-button,
.funup-op-button,
.submit-btn,
.funup-entry-auth-button,
.funup-entry-auth-button:link,
.funup-entry-auth-button:visited,
.funup-application-edit-form button,
.funup-admin-submit,
.funup-admin-filter button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .45em;
  min-height: 44px;
  padding: 12px 22px;
  border: 1px solid transparent;
  border-radius: var(--funup-radius-sm);
  background: var(--funup-color-primary);
  color: #fff;
  font-weight: 700;
  line-height: 1.2;
  text-decoration: none;
  cursor: pointer;
  box-sizing: border-box;
}

.funup-button:hover,
.funup-button:focus,
.funup-button--primary:hover,
.funup-button--primary:focus,
.funup-mypage-button:hover,
.funup-mypage-button:focus,
.funup-auth-button:hover,
.funup-auth-button:focus,
.funup-op-button:hover,
.funup-op-button:focus,
.submit-btn:hover,
.submit-btn:focus,
.funup-entry-auth-button:hover,
.funup-entry-auth-button:focus,
.funup-application-edit-form button:hover,
.funup-application-edit-form button:focus,
.funup-admin-submit:hover,
.funup-admin-submit:focus,
.funup-admin-filter button:hover,
.funup-admin-filter button:focus {
  background: var(--funup-color-primary-hover);
  color: #fff;
  text-decoration: none;
}

.funup-button--secondary,
.funup-button-secondary,
.funup-mypage-button-secondary,
.funup-auth-button-email,
.funup-entry-auth-button.is-mail {
  background: #fff;
  border-color: var(--funup-color-primary);
  color: var(--funup-color-primary);
}

.funup-button--secondary:hover,
.funup-button--secondary:focus,
.funup-button-secondary:hover,
.funup-button-secondary:focus,
.funup-mypage-button-secondary:hover,
.funup-mypage-button-secondary:focus,
.funup-auth-button-email:hover,
.funup-auth-button-email:focus,
.funup-entry-auth-button.is-mail:hover,
.funup-entry-auth-button.is-mail:focus {
  background: #eef6ff;
  color: var(--funup-color-primary);
}

.funup-button--line,
.funup-auth-button-line,
.funup-entry-auth-button.is-line {
  background: #06c755;
  color: #fff;
}

.funup-button--line:hover,
.funup-button--line:focus,
.funup-auth-button-line:hover,
.funup-auth-button-line:focus,
.funup-entry-auth-button.is-line:hover,
.funup-entry-auth-button.is-line:focus {
  background: #05b64d;
  color: #fff;
}

.funup-button--danger,
.delete-participant-button { background: #b3261e; color: #fff; }
.funup-button--danger:hover,
.funup-button--danger:focus,
.delete-participant-button:hover,
.delete-participant-button:focus { background: #8f1f18; color: #fff; }

.funup-button--disabled,
.submit-btn:disabled,
button:disabled {
  opacity: .55;
  cursor: not-allowed;
}

/* ---------------------------------------------------------
   Forms
--------------------------------------------------------- */
.funup-form__row,
.funup-form-row,
.funup-admin-form-row { margin: 0 0 18px; }

.funup-label,
.funup-form__label,
.funup-label-line,
.funup-participant-form label,
.funup-entry-mail-auth-form label,
.funup-admin-form-row label,
label {
  display: block;
  margin: 0 0 8px;
  font-weight: 700;
  color: var(--funup-color-text);
}

.funup-input,
.funup-select,
.funup-textarea,
.funup-participant-form input,
.funup-participant-form textarea,
.funup-participant-form select,
.funup-entry-form input,
.funup-entry-form select,
.funup-entry-form textarea,
.funup-entry-mail-auth-form input,
.funup-entry-mail-auth-form select,
.funup-entry-mail-auth-form textarea,
.funup-admin-filter select,
.funup-admin-filter input[type="search"],
.funup-admin-event-table input[type="number"],
.funup-admin-event-table select,
.funup-application-edit-form select,
.funup-application-edit-form textarea,
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="date"],
input[type="number"],
select,
textarea {
  width: 100%;
  max-width: 100%;
  min-height: 44px;
  padding: 10px 12px;
  border: 1px solid #cfd8e3;
  border-radius: var(--funup-radius-sm);
  background: #fff;
  color: var(--funup-color-text);
  box-sizing: border-box;
}

.funup-input:focus,
.funup-select:focus,
.funup-textarea:focus,
.funup-participant-form input:focus,
.funup-participant-form textarea:focus,
.funup-participant-form select:focus,
.funup-entry-form input:focus,
.funup-entry-form select:focus,
.funup-entry-form textarea:focus,
.funup-entry-mail-auth-form input:focus,
.funup-entry-mail-auth-form select:focus,
.funup-entry-mail-auth-form textarea:focus,
.funup-admin-filter select:focus,
.funup-admin-filter input[type="search"]:focus,
.funup-admin-event-table input:focus,
.funup-admin-event-table select:focus,
.funup-application-edit-form select:focus,
.funup-application-edit-form textarea:focus,
input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
input[type="date"]:focus,
input[type="number"]:focus,
select:focus,
textarea:focus {
  outline: none;
  border-color: #38bdf8;
  box-shadow: 0 0 0 3px rgba(56, 189, 248, .18);
}

.funup-form__actions,
.funup-form-actions,
.funup-auth-actions,
.funup-entry-auth-actions,
.funup-entry-mail-auth-actions,
.funup-actions,
.funup-actions-inline {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.funup-required,
.funup-form__required,
.required { color: #d93025; font-weight: 700; }
.funup-optional,
.funup-form__optional { color: var(--funup-color-muted); font-weight: 600; }

.funup-name-pair,
.funup-form__name-pair {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

/* ---------------------------------------------------------
   Notices / Alerts
--------------------------------------------------------- */
.funup-notice,
.funup-alert,
.funup-mypage-notice,
.funup-admin-notice,
.friend-alert,
.funup-existing-application-warning,
.funup-error {
  margin: 16px 0;
  padding: 14px 16px;
  border: 1px solid var(--funup-color-border);
  border-radius: var(--funup-radius-md);
  background: #f8fafc;
  color: var(--funup-color-text);
  font-weight: 700;
}

.funup-notice--success,
.funup-notice.is-success,
.funup-notice-success,
.funup-admin-notice.is-success,
.funup-alert--success {
  border-color: #54d99c;
  background: var(--funup-color-success-bg);
  color: var(--funup-color-success);
}

.funup-notice--error,
.funup-notice.is-error,
.funup-notice-error,
.funup-error,
.funup-admin-notice.is-error,
.funup-alert--error {
  border-color: #ffb4ab;
  background: var(--funup-color-error-bg);
  color: var(--funup-color-error);
}

.funup-notice--warning,
.funup-notice-warning,
.funup-existing-application-warning,
.funup-alert--warning {
  border-color: #f6d98d;
  background: var(--funup-color-warning-bg);
  color: var(--funup-color-warning);
}


/* ---------------------------------------------------------
   Alert component / Phase 4
--------------------------------------------------------- */
.funup-alert {
  display: block;
  position: relative;
}

.funup-alert__title {
  display: block;
  margin: 0 0 4px;
  font-size: 0.95rem;
  font-weight: 800;
}

.funup-alert__body {
  display: block;
  margin: 0;
  font-size: 0.92rem;
  line-height: 1.75;
  font-weight: 600;
}

.funup-alert__body p {
  margin: 0 0 0.45em;
}

.funup-alert__body p:last-child {
  margin-bottom: 0;
}

.funup-alert--info,
.funup-notice--info,
.funup-notice.is-info {
  border-color: #b6dcff;
  background: #eef7ff;
  color: #075985;
}

.funup-alert--compact {
  padding: 10px 12px;
  font-size: 0.9rem;
}

.funup-entry-alert {
  width: 100%;
}

/* ---------------------------------------------------------
   Badges
--------------------------------------------------------- */
.funup-badge,
.funup-status-badge,
.funup-application-status,
.application-status,
.badge,
.funup-participant-badge,
.funup-level-badge,
.funup-seriesline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .25em;
  min-height: 24px;
  padding: 3px 10px;
  border-radius: 999px;
  background: #eef2f7;
  color: #475569;
  font-size: .86em;
  font-weight: 700;
  line-height: 1.2;
  white-space: nowrap;
}

.funup-badge--success,
.funup-status-badge.status-received,
.funup-application-status.status-received,
.application-status.status-received,
.badge-open {
  background: #e6f8ef;
  color: #08784a;
}

.funup-badge--primary,
.funup-status-badge.status-confirmed,
.funup-application-status.status-confirmed,
.application-status.status-confirmed {
  background: #e8f1ff;
  color: #1d4ed8;
}

.funup-badge--info,
.funup-status-badge.status-details_sent,
.funup-status-badge.status-details-sent,
.funup-application-status.status-details_sent,
.funup-application-status.status-details-sent,
.application-status.status-details_sent,
.application-status.status-details-sent {
  background: #ecfeff;
  color: #0e7490;
}

.funup-badge--warning,
.funup-status-badge.status-provisional,
.funup-application-status.status-provisional,
.application-status.status-provisional,
.badge-few,
.badge-wait {
  background: #fff7ed;
  color: #c2410c;
}

.funup-badge--danger,
.funup-status-badge.status-cancelled,
.funup-application-status.status-cancelled,
.application-status.status-cancelled,
.badge-closed {
  background: #fef2f2;
  color: #b91c1c;
}

.funup-status-badge.status-waitlist,
.funup-application-status.status-waitlist,
.application-status.status-waitlist {
  background: #fff7ed;
  color: #c2410c;
}


/* ---------------------------------------------------------
   Badge component / Phase 7
--------------------------------------------------------- */
.funup-badge {
  border: 1px solid transparent;
}

.funup-badge--open,
.funup-badge--success {
  border-color: var(--status-open-border, #b7e4c7);
  background: var(--status-open-bg, #e8f7ed);
  color: var(--status-open-text, #1f7a3d);
}

.funup-badge--few {
  border-color: var(--status-few-border, #ea580c);
  background: var(--status-few-bg, #ea580c);
  color: var(--status-few-text, #ffffff);
}

.funup-badge--wait,
.funup-badge--warning {
  border-color: var(--status-wait-border, #c7d2fe);
  background: var(--status-wait-bg, #eef0ff);
  color: var(--status-wait-text, #4f5fcf);
}

.funup-badge--closed,
.funup-badge--danger {
  border-color: var(--status-closed-border, #d1d5db);
  background: var(--status-closed-bg, #eeeeee);
  color: var(--status-closed-text, #666666);
}

.funup-badge--role {
  border-color: #c7d2fe;
  background: #eef2ff;
  color: #3730a3;
  font-size: 12px;
}

.funup-badge--required {
  min-height: 20px;
  padding: 2px 7px;
  border-color: #fecaca;
  background: #fef2f2;
  color: #b91c1c;
  font-size: 12px;
}

.funup-badge--optional {
  min-height: 20px;
  padding: 2px 7px;
  border-color: #e2e8f0;
  background: #f8fafc;
  color: #64748b;
  font-size: 12px;
}

/* ---------------------------------------------------------
   BEM aliases for future markup
--------------------------------------------------------- */
.funup-button__icon { display: inline-flex; line-height: 1; }
.funup-form__help,
.funup-help { color: var(--funup-color-muted); font-size: .95em; }
.funup-section__title,
.funup-line-section-title {
  margin: 0 0 14px;
  font-weight: 800;
  color: var(--funup-color-text);
}

@media (max-width: 640px) {
  .funup-container,
  .form-wrapper { padding: 18px 12px; }
  .funup-name-pair,
  .funup-form__name-pair { grid-template-columns: 1fr; }
  .funup-button,
  .funup-button--primary,
  .funup-mypage-button,
  .funup-auth-button,
  .funup-op-button,
  .submit-btn,
  .funup-entry-auth-button { width: 100%; }
}

/* =========================================================
   Common Card Component / Phase 1
   - neutral BEM card parts used by entry and mypage
========================================================= */
.funup-card {
  overflow: hidden;
}

.funup-card__header {
  display: block;
  padding: 16px 18px;
  border-bottom: 1px solid var(--funup-color-border-soft);
  background: var(--funup-color-surface);
}

.funup-card__body {
  display: block;
  padding: 18px;
}

.funup-card__footer {
  display: block;
  padding: 14px 18px;
  border-top: 1px solid var(--funup-color-border-soft);
  background: var(--funup-color-surface);
}

.funup-card__title {
  margin: 0;
  color: #0f172a;
  font-size: 1.08rem;
  font-weight: 800;
  line-height: 1.45;
}


/* =========================================================
   UI Phase 2: canonical button component
   - MyPage / Entry share the same button modifiers
   - Existing legacy classes remain as aliases for safety
========================================================= */
.funup-button,
a.funup-button,
button.funup-button {
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .45em;
  min-height: 44px;
  padding: 12px 22px;
  border: 1px solid transparent;
  border-radius: var(--funup-radius-sm, 10px);
  font-weight: 700;
  line-height: 1.2;
  text-decoration: none;
  cursor: pointer;
  box-sizing: border-box;
  transition: background-color .15s ease, border-color .15s ease, color .15s ease, opacity .15s ease, transform .15s ease;
}

.funup-button--primary,
.funup-mypage-button,
.submit-btn {
  background: var(--funup-color-primary, #173a5e);
  border-color: var(--funup-color-primary, #173a5e);
  color: #fff;
}

.funup-button--primary:hover,
.funup-button--primary:focus,
.funup-mypage-button:hover,
.funup-mypage-button:focus,
.submit-btn:hover,
.submit-btn:focus {
  background: var(--funup-color-primary-hover, #0f2f4f);
  border-color: var(--funup-color-primary-hover, #0f2f4f);
  color: #fff;
  text-decoration: none;
}

.funup-button--outline,
.funup-button--secondary,
.funup-button-secondary,
.funup-mypage-button-secondary {
  background: #fff;
  border-color: var(--funup-color-primary, #173a5e);
  color: var(--funup-color-primary, #173a5e);
}

.funup-button--outline:hover,
.funup-button--outline:focus,
.funup-button--secondary:hover,
.funup-button--secondary:focus,
.funup-button-secondary:hover,
.funup-button-secondary:focus,
.funup-mypage-button-secondary:hover,
.funup-mypage-button-secondary:focus {
  background: #eef6ff;
  border-color: var(--funup-color-primary, #173a5e);
  color: var(--funup-color-primary, #173a5e);
  text-decoration: none;
}

.funup-button--line {
  background: #06c755;
  border-color: #06c755;
  color: #fff;
}

.funup-button--line:hover,
.funup-button--line:focus {
  background: #05b64d;
  border-color: #05b64d;
  color: #fff;
  text-decoration: none;
}

.funup-button--link {
  min-height: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: #0000ee;
  box-shadow: none;
  text-decoration: underline;
  text-underline-offset: .18em;
}

.funup-button--link:hover,
.funup-button--link:focus {
  background: transparent;
  color: #0000ee;
  text-decoration: underline;
  opacity: .8;
}

.funup-button--large {
  min-height: 52px;
  padding: 14px 28px;
  border-radius: 10px;
  font-size: 1.02rem;
}

.funup-button--compact {
  min-height: 36px;
  padding: 8px 14px;
  border-radius: 8px;
  font-size: .92rem;
}

.funup-button--full {
  width: 100%;
}

.funup-button-group {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
}

.funup-button-group--form-actions {
  margin-top: 18px;
}

@media (max-width: 767px) {
  .funup-button-group {
    align-items: stretch;
  }
  .funup-button-group > .funup-button {
    width: 100%;
  }
}


/* ---------------------------------------------------------
   Phase 3: shared form components
--------------------------------------------------------- */
.funup-form {
  margin: 0;
}

.funup-form__row {
  margin-bottom: 18px;
}

.funup-form__control {
  font: inherit;
}

.funup-textarea.funup-form__control,
textarea.funup-form__control {
  min-height: 160px;
  resize: vertical;
}

.funup-form__sublabel {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin: 0;
  color: var(--funup-color-muted);
  font-size: 0.92em;
}

.funup-checkbox,
.funup-form__checkbox {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 12px 0;
  font-weight: 700;
  cursor: pointer;
}

.funup-checkbox__input {
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
}

.funup-checkbox__label {
  line-height: 1.5;
}

/* =========================================================
   UI Phase 6: Event card component
   - Shared event card structure for MyPage / Entry
   - Legacy entry classes are kept in HTML while BEM classes become canonical
========================================================= */
.funup-event-card {
  overflow: hidden;
  border: 1px solid var(--funup-color-border, #e5eaf1);
  border-radius: var(--funup-radius-lg, 18px);
  background: #fff;
  box-shadow: var(--funup-shadow-sm, 0 4px 16px rgba(15, 23, 42, .05));
}

.funup-event-card__link {
  display: block;
  color: inherit !important;
  text-decoration: none !important;
}

.funup-event-card__inner {
  display: grid;
  grid-template-columns: minmax(260px, 44%) minmax(0, 1fr);
  gap: 20px;
  align-items: center;
  padding: 18px;
}

.funup-event-card__head {
  display: grid;
  grid-template-columns: 180px minmax(150px, 1fr);
  gap: 16px;
  align-items: center;
  margin: 0;
}

.funup-event-card__thumb img {
  display: block;
  width: 100%;
  height: 116px;
  border-radius: 12px;
  object-fit: cover;
}

.funup-event-card__date {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 100px;
  padding: 14px 16px;
  border-radius: 14px;
  background: #f7f8fb;
}

.funup-event-card__title {
  margin: 0 0 8px;
  color: var(--funup-color-accent, #c084aa);
  font-size: 1.05rem;
  font-weight: 800;
  line-height: 1.55;
}

.funup-event-card__side-row {
  display: flex;
  justify-content: flex-end;
  align-items: flex-end;
  gap: 10px;
  margin-top: 10px;
}

.funup-event-card .funup-date-year {
  color: #c4cbd6;
  font-size: .92rem;
  font-weight: 800;
}

.funup-event-card .funup-date-main {
  font-size: 1.4rem;
  font-weight: 800;
  line-height: 1.25;
}

.funup-event-card .funup-date-sub {
  color: #8b94a3;
  font-size: .9rem;
  font-weight: 800;
}

.funup-event-card .funup-meeting {
  margin-top: 6px;
  font-weight: 700;
}

.funup-event-card .funup-fee {
  font-size: 1.15rem;
  font-weight: 800;
}

@media (max-width: 760px) {
  .funup-event-card__inner {
    display: block;
    padding: 16px;
  }

  .funup-event-card__head {
    grid-template-columns: 42% 1fr;
    gap: 12px;
    margin-bottom: 14px;
  }

  .funup-event-card__thumb img {
    height: 96px;
  }

  .funup-event-card__date {
    min-height: 96px;
    padding: 12px 13px;
  }

  .funup-event-card__side-row {
    justify-content: flex-start;
    align-items: flex-start;
    flex-wrap: wrap;
  }
}

@media (max-width: 420px) {
  .funup-event-card__head {
    grid-template-columns: 1fr;
  }

  .funup-event-card__thumb img {
    height: 150px;
  }
}


/* =========================================================
   UI Phase 8: page / section layout component
   - unify MyPage and Entry spacing/title rhythm without changing behavior
========================================================= */
.funup-page,
.funup-line-entry-page,
.funup-mypage-container {
  box-sizing: border-box;
}

.funup-page__header,
.funup-entry-page-header,
.funup-mypage-page-header {
  margin: 0 0 18px;
}

.funup-page__title,
.funup-line-page-title,
.funup-card__title {
  margin: 0 0 8px;
  color: #0f172a;
  font-size: 1.25rem;
  font-weight: 800;
  line-height: 1.45;
}

.funup-card__title:last-child,
.funup-line-page-title:last-child {
  margin-bottom: 0;
}

.funup-section,
.funup-mypage-section,
.funup-entry-section {
  margin: 0 0 18px;
}

.funup-section__title,
.funup-line-section-title {
  display: block;
  margin: 0 0 12px;
  color: #0f172a;
  font-size: 1.05rem;
  font-weight: 800;
  line-height: 1.45;
}

.funup-section__lead,
.funup-card__lead {
  margin: 0 0 14px;
  color: var(--funup-color-muted);
  font-size: .95rem;
  line-height: 1.75;
}

.funup-flow,
.funup-entry-flow {
  display: grid;
  gap: 18px;
}

.funup-card--compact .funup-card__body { padding: 14px 16px; }
.funup-card--spacious .funup-card__body { padding: 22px; }

@media (max-width: 640px) {
  .funup-page__title,
  .funup-line-page-title,
  .funup-card__title {
    font-size: 1.14rem;
  }

  .funup-section,
  .funup-mypage-section,
  .funup-entry-section {
    margin-bottom: 14px;
  }
}

/* =========================================================
   UI Phase 9: Confirm / Thanks / summary components
   - shared result screens for Entry and MyPage flows
========================================================= */
.funup-summary-list,
.funup-confirm-summary {
  display: grid;
  gap: 12px;
  margin: 0;
}

.funup-summary-item,
.funup-confirm-summary__item {
  display: grid;
/*  grid-template-columns: 9em 1fr; */
  gap: 12px;
  align-items: start;
  padding: 10px 0;
  border-bottom: 1px solid var(--funup-color-border-soft);
}

.funup-summary-item:last-child,
.funup-confirm-summary__item:last-child {
  border-bottom: 0;
}

.funup-summary-term,
.funup-confirm-summary__term {
  margin: 0;
  color: var(--funup-color-muted);
  font-weight: 700;
}

.funup-summary-desc,
.funup-confirm-summary__desc {
  margin: 0;
  color: var(--funup-color-text);
  line-height: 1.75;
}

.funup-action-row,
.funup-form__actions,
.funup-confirm-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  margin-top: 18px;
}

.funup-action-row--center,
.funup-thanks-actions {
  justify-content: center;
}

.funup-thanks-card {
  text-align: center;
}

.funup-thanks-card__body {
  line-height: 1.85;
  font-size: 15px;
}

.funup-thanks-card__title {
  margin: 0 0 10px;
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--funup-color-primary);
}

.funup-friend-add-button,
.funup-thanks-card__line-button {
  display: inline-block;
  margin: 18px 0;
}

.funup-friend-add-button img,
.funup-thanks-card__line-button img {
  max-width: 240px;
  width: 100%;
  height: auto;
}

@media (max-width: 767px) {
  .funup-summary-item,
  .funup-confirm-summary__item {
    grid-template-columns: 1fr;
    gap: 4px;
  }

  .funup-action-row > .funup-button,
  .funup-form__actions > .funup-button,
  .funup-confirm-actions > .funup-button {
    width: 100%;
  }
}

/* =========================================================
   UI Phase 10: Auth / friend / entry action cards
   - keep entry-specific legacy classes, but render them with common card rhythm
========================================================= */
.funup-auth-card,
.funup-card--notice,
.funup-card--entry-greeting {
  border: 1px solid var(--funup-color-border, #dbe5ef);
  border-radius: var(--funup-radius, 14px);
  background: #fff;
  box-shadow: var(--funup-shadow-sm, 0 1px 3px rgba(15, 23, 42, .06));
}

.funup-action-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-top: 18px;
}

.funup-card--notice .funup-card__title {
  color: var(--funup-color-primary, #173a5e);
}

.funup-friend-card__button {
  margin: 14px 0 0;
  text-align: center;
}

.funup-friend-card__button img {
  max-width: 180px;
  height: auto;
}


/* =========================================================
   UI Phase 11: State / modal / divider components
   - Common rendering for loading, empty, error, and modal-like panels
========================================================= */
.funup-state {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 56px;
  padding: 16px;
  border: 1px solid var(--funup-color-border, #d8e2ee);
  border-radius: var(--funup-radius-md, 12px);
  background: #f8fafc;
  color: var(--funup-color-muted, #64748b);
  font-weight: 700;
  line-height: 1.7;
  text-align: center;
}

.funup-state--loading,
.funup-loading.funup-state {
  background: #f8fafc;
  color: #475569;
}

.funup-state--empty,
.funup-empty {
  border-style: dashed;
  background: #fbfdff;
  color: var(--funup-color-muted, #64748b);
}

.funup-state--error,
.funup-error.funup-state {
  border-color: #ffb4ab;
  background: var(--funup-color-error-bg, #fff1f0);
  color: var(--funup-color-error, #b3261e);
}

.funup-spinner {
  width: 1.05em;
  height: 1.05em;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 999px;
  flex: 0 0 auto;
  opacity: .75;
  animation: funup-spin .8s linear infinite;
}

@keyframes funup-spin {
  to { transform: rotate(360deg); }
}

.funup-divider {
  display: block;
  height: 1px;
  margin: 18px 0;
  border: 0;
  background: var(--funup-color-border-soft, #e8eef5);
}

.funup-divider--dashed {
  height: 0;
  border-top: 1px dashed var(--funup-color-border, #d8e2ee);
  background: transparent;
}

.funup-modal {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  background: rgba(15, 23, 42, .44);
}

.funup-modal[hidden],
.funup-modal.is-hidden {
  display: none !important;
}

.funup-modal__dialog {
  width: min(100%, 520px);
  max-height: calc(100vh - 40px);
  overflow: auto;
  border-radius: var(--funup-radius-lg, 18px);
  background: #fff;
  box-shadow: 0 18px 60px rgba(15, 23, 42, .24);
}

.funup-modal__header,
.funup-modal__body,
.funup-modal__footer {
  padding: 18px;
}

.funup-modal__header {
  border-bottom: 1px solid var(--funup-color-border-soft, #e8eef5);
}

.funup-modal__footer {
  border-top: 1px solid var(--funup-color-border-soft, #e8eef5);
}

.funup-modal__title {
  margin: 0;
  color: var(--funup-color-primary, #173957);
  font-size: 1.05rem;
  font-weight: 800;
}


/* ---------------------------------------------------------
   Legacy Entry / MyPage design tokens
   - Moved from entry-form.css in Phase 12
   - Kept as aliases while entry markup is migrated to common UI
--------------------------------------------------------- */
:root {
  --funup-brand-primary: #003087;
  --funup-brand-primary-light: #f5f9ff;
  --funup-brand-primary-border: #d7e8f7;
  --funup-brand-action: #1877f2;
  --funup-header-bg: #18a9e5;
  --funup-border-default: #e5e7eb;
  --funup-text: #111827;
  --funup-subtext: #4b5563;
  --funup-muted: #6b7280;
  --funup-bg: #ffffff;
  --funup-panel: #f8fbff;
  --funup-radius: 12px;
  --funup-radius-sm: 8px;
  --funup-focus-ring: 0 0 0 3px rgba(24, 119, 242, 0.22);
  --funup-danger: #d60000;
  --funup-danger-bg: #fef2f2;
  --funup-danger-border: #fecaca;
  --funup-danger-text: #b91c1c;
  --funup-warning: #92400e;
  --funup-warning-bg: #fffbeb;
  --funup-warning-border: #f59e0b;
  --funup-success-bg: #ecfdf5;
  --funup-success-text: #047857;
  --funup-success-border: #6ee7b7;
  --funup-cta-primary: #16a34a;
  --funup-cta-primary-light: #22c55e;
  --funup-cta-primary-bg: linear-gradient(
    180deg,
    var(--funup-cta-primary-light) 0%,
    var(--funup-cta-primary) 100%
  );
  --status-open-bg: #e8f7ed;
  --status-open-text: #1f7a3d;
  --status-open-border: #b7e4c7;
  --status-few-bg: #ea580c;
  --status-few-text: #ffffff;
  --status-few-border: #ea580c;
  --status-wait-bg: #eef0ff;
  --status-wait-text: #4f5fcf;
  --status-wait-border: #c7d2fe;
  --status-closed-bg: #eeeeee;
  --status-closed-text: #666666;
  --status-closed-border: #d1d5db;
  --series-default-bg: #f8fafc;
  --series-default-text: #475569;
  --series-default-border: #e2e8f0;


  --funup-mp-brand: #1877f2;
  --funup-mp-brand-dark: #0f5ec7;
  --funup-mp-brand-soft: #eff6ff;
  --funup-mp-brand-text: #1d4ed8;
  --funup-mp-header: #00aeea;

  --funup-mp-cta-orange: #f97316;
  --funup-mp-cta-orange-light: #ff8a1f;
  --funup-mp-cta-orange-dark: #ea580c;

  --funup-mp-text: #111827;
  --funup-mp-text-muted: #475569;
  --funup-mp-white: #ffffff;

  --funup-mp-bg: #f8fafc;
  --funup-mp-panel: #ffffff;
  --funup-mp-panel-soft: #f8fbff;
  --funup-mp-border: #e2e8f0;
  --funup-mp-border-blue: #d7e8f7;
  --funup-mp-border-input: #cbd5e1;

  --funup-mp-success-bg: #ecfdf5;
  --funup-mp-success-text: #047857;
  --funup-mp-success-border: #6ee7b7;

  --funup-mp-danger-bg: #fee2e2;
  --funup-mp-danger-text: #b91c1c;
  --funup-mp-danger: #dc2626;
  --funup-mp-danger-border: #ef4444;

  --funup-mp-secondary: #64748b;
  --funup-mp-secondary-border: #94a3b8;

  --funup-mp-radius-sm: 8px;
  --funup-mp-radius: 10px;
  --funup-mp-radius-lg: 12px;
  --funup-mp-radius-xl: 14px;
  --funup-mp-radius-pill: 999px;

  --funup-mp-shadow-button: 0 3px 8px rgba(0, 0, 0, 0.12);
  --funup-mp-shadow-orange: 0 8px 18px rgba(249, 115, 22, 0.28);

  --funup-mp-card-bg: #ffffff;
  --funup-mp-history-bg: #f8fbff;


}


/* =========================================================
   UI Phase 15: BEM completion layer
   - add canonical BEM element classes while keeping legacy classes
   - no legacy selector removal in this phase
========================================================= */
.funup-card--greeting .funup-card__body { text-align: center; }
.funup-greeting__name { margin: 0 0 10px; }
.funup-badge--auth {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 26px;
  padding: 4px 10px;
  border-color: #bbf7d0;
  background: #f0fdf4;
  color: #166534;
  font-weight: 800;
}
.funup-button-group--center {
  justify-content: center;
  margin-top: 12px;
}
.funup-participant-card__selector {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  align-items: start;
  margin: 0;
  cursor: pointer;
}
.funup-participant-card__checkbox {
  width: auto;
  margin: .25em 0 0;
}
.funup-participant-card__main {
  display: grid;
  gap: 6px;
}
.funup-participant-card__name {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  color: var(--funup-color-text);
  font-weight: 800;
}
.funup-participant-card__meta {
  display: grid;
  gap: 6px;
}
.funup-participant-card__detail {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--funup-color-border-soft);
  color: var(--funup-color-muted);
  font-size: .94rem;
  line-height: 1.7;
}
.funup-participant-card__detail-row + .funup-participant-card__detail-row { margin-top: 4px; }
.funup-participant-card__edit-area { margin-top: 14px; }
.funup-participant-card__actions { margin-top: 14px; }
.funup-participant-card--confirm {
  padding: 12px;
  box-shadow: none;
}
.funup-event-card__link {
  display: block;
  color: inherit;
  text-decoration: none;
}
.funup-event-card__link:hover,
.funup-event-card__link:focus { text-decoration: none; }
.funup-event-card__inner { overflow: hidden; }
.funup-event-card__title {
  color: var(--funup-color-text);
  font-weight: 800;
  line-height: 1.55;
}
.funup-form__name-pair {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.funup-form__name-pair label { margin: 0; }
.funup-form__name-pair input { margin-top: 4px; }
@media (max-width: 520px) {
  .funup-form__name-pair { grid-template-columns: 1fr; }
}


/* ---------------------------------------------------------
   Phase 16: MyPage also uses shared BEM components
--------------------------------------------------------- */
.funup-mypage__app { max-width: 640px; }
.funup-mypage__content { margin-top: 18px; }
.funup-card--mypage-greeting .funup-card__body p,
.funup-card--entry-greeting .funup-card__body p { margin: 0 0 10px; }
.funup-auth-card--mypage .funup-auth-actions { margin-top: 18px; }
.funup-mypage-section + .funup-mypage-section,
.funup-card--mypage-greeting + .funup-mypage-section { margin-top: 18px; }
.funup-participant-card--mypage .funup-card__header { display:flex; align-items:center; justify-content:space-between; gap:12px; }
.funup-participant-card--mypage .funup-card__body { padding: 16px 18px; }
.funup-participant-card--mypage + .funup-participant-card--mypage { margin-top: 12px; }
.funup-participant-card__name { font-size: 1.05rem; font-weight: 700; color: var(--funup-color-text); }
.funup-participant-card__actions { display:flex; flex-wrap:wrap; gap:10px; justify-content:flex-end; }
.funup-application-card + .funup-application-card { margin-top: 12px; }
.funup-actions--center { justify-content:center; text-align:center; }
.funup-application-detail-card + .funup-application-detail-card { margin-top: 12px; }



/* ---------------------------------------------------------
   Phase 20
--------------------------------------------------------- */

.funup-event-card {
  display: block;
}

.funup-event-card__header {
  margin-bottom: 12px;
}

.funup-event-card__date {
  display: inline-block;
  margin-bottom: 6px;
  font-size: 13px;
  font-weight: 700;
  color: var(--funup-color-muted, #6b7280);
}

.funup-event-card__title {
  margin: 0;
  font-size: 20px;
  line-height: 1.45;
  font-weight: 700;
  color: var(--funup-color-text, #1f2937);
}

.funup-event-card__body {
  display: grid;
  gap: 10px;
}

.funup-event-card__meta {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: 14px;
  line-height: 1.6;
}

.funup-event-card__meta-label {
  flex: 0 0 auto;
  min-width: 4em;
  color: var(--funup-color-muted, #6b7280);
  font-weight: 700;
}

.funup-event-card__meta-value {
  flex: 1 1 auto;
  color: var(--funup-color-text, #1f2937);
}

.funup-event-card__description {
  margin-top: 4px;
  font-size: 14px;
  line-height: 1.8;
  color: var(--funup-color-text, #1f2937);
}

.funup-event-card__footer {
  margin-top: 16px;
}


