/* ===== 申込サマリーバー ===== */
#app-summary-bar {
  max-width: 900px;
  margin: 0 auto;
  padding: 6px 16px;
}

.app-summary-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--surface-card);
  border: 1.5px solid var(--border-sky);
  border-radius: 999px;
  padding: 7px 14px 7px 16px;
  cursor: pointer;
  user-select: none;
  transition: background 0.15s, box-shadow 0.15s;
  box-shadow: 0 1px 6px rgba(14, 165, 233, 0.08);
  gap: 8px;
}

.app-summary-inner:hover {
  background: var(--sky-50);
  box-shadow: 0 2px 10px rgba(14, 165, 233, 0.14);
}

.app-summary-inner:active {
  transform: scale(0.99);
}

.app-summary-chips {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  flex: 1;
  min-width: 0;
}

.app-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  font-weight: 700;
  border-radius: 999px;
  padding: 3px 8px;
  white-space: nowrap;
}

.app-chip--urgent {
  background: #fef2f2;
  color: #dc2626;
  border: 1px solid #fecaca;
}

.app-chip--open {
  background: #f0fdf4;
  color: #16a34a;
  border: 1px solid #bbf7d0;
}

.app-chip--soon {
  background: #fffbeb;
  color: #d97706;
  border: 1px solid #fde68a;
}

.app-chip--result {
  background: #f5f3ff;
  color: #7c3aed;
  border: 1px solid #ddd6fe;
}

.app-chip--today {
  background: #fdf2f8;
  color: #db2777;
  border: 1px solid #fbcfe8;
}

.app-chip .chip-count {
  font-size: 13px;
  font-weight: 900;
}

.app-summary-arrow {
  font-size: 16px;
  color: var(--sky-400);
  flex-shrink: 0;
  line-height: 1;
}

/* ===== 申込ダッシュボード ドロワー ===== */
#appDashboard {
  display: flex;
  position: fixed;
  inset: 0;
  z-index: 500;
  background: rgba(15, 23, 42, 0.45);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  align-items: flex-end;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.28s;
}

#appDashboard.open {
  opacity: 1;
  pointer-events: auto;
}

.app-dashboard-card {
  background: var(--surface-card);
  border-radius: 24px 24px 0 0;
  width: 100%;
  max-width: 640px;
  max-height: 92vh;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding: 0 0 24px;
  box-shadow: 0 -4px 40px rgba(14, 165, 233, 0.12);
  transform: translateY(100%);
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

#appDashboard.open .app-dashboard-card {
  transform: translateY(0);
}

/* 下スワイプで閉じる: ドラッグ中はトランジションを無効化して指に追従させる */
#appDashboard.dragging,
#appDashboard.dragging .app-dashboard-card {
  transition: none;
}

.app-dashboard-handle {
  width: 40px;
  height: 4px;
  background: var(--sky-200);
  border-radius: 2px;
  margin: 12px auto 16px;
}

.app-dashboard-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 20px 14px;
  border-bottom: 1.5px solid var(--border-sky);
}

.app-dashboard-title {
  font-size: 17px;
  font-weight: 900;
  color: var(--text-main);
}

.app-dashboard-close {
  background: var(--sky-50);
  border: 1.5px solid var(--sky-200);
  border-radius: 50%;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  color: var(--sky-600);
  cursor: pointer;
  transition: background 0.15s;
}

.app-dashboard-close:hover { background: var(--sky-100); }

/* ===== セクション ===== */
.dashboard-section {
  padding: 16px 20px 0;
}

.dashboard-section-header {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.04em;
  margin-bottom: 8px;
}

.section-icon { font-size: 14px; }

.section-label--today  { color: #db2777; }
.section-label--urgent { color: #dc2626; }
.section-label--open   { color: #16a34a; }
.section-label--soon   { color: #d97706; }
.section-label--result { color: #7c3aed; }

/* ===== イベント行 ===== */
.dashboard-event-row {
  display: flex;
  align-items: center;
  gap: 10px;
  background: white;
  border: 1.5px solid var(--border-sky);
  border-radius: 12px;
  padding: 10px 12px;
  margin-bottom: 8px;
  cursor: pointer;
  transition: background 0.15s, box-shadow 0.15s, transform 0.15s;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
  touch-action: manipulation;
  box-shadow: 0 1px 4px rgba(14, 165, 233, 0.12);
}

.dashboard-event-row:hover {
  background: var(--sky-50);
  box-shadow: 0 2px 8px rgba(14, 165, 233, 0.1);
}

.dashboard-event-row:active {
  transform: scale(0.975);
  background: var(--sky-100);
  box-shadow: 0 0 2px rgba(14, 165, 233, 0.08);
  transition: transform 0.08s, background 0.08s, box-shadow 0.08s;
}

.dashboard-event-row.urgent {
  border-color: #fecaca;
  background: #fef9f9;
}

.dashboard-event-row.urgent:hover { background: #fef2f2; }

.dashboard-event-row.urgent:active { background: #fecaca; }

.event-row-body {
  flex: 1;
  min-width: 0;
}

.event-row-step-type {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  padding: 1px 7px;
  border-radius: 4px;
  margin-bottom: 3px;
  letter-spacing: 0.02em;
}
.step-type--apply   { background:#eff6ff; color:#1d4ed8; border:1px solid #bfdbfe; }
.step-type--result  { background:#f5f3ff; color:#6d28d9; border:1px solid #ddd6fe; }
.step-type--payment { background:#fff7ed; color:#c2410c; border:1px solid #fed7aa; }
.step-type--lottery { background:#f0fdfa; color:#0f766e; border:1px solid #99f6e4; }
.step-type--concert,
.step-type--other   { background:#f1f5f9; color:#475569; border:1px solid #cbd5e1; }

.event-row-name {
  font-size: 13px;
  font-weight: 900;
  color: var(--text-main);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.event-row-step-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-sub);
  margin-left: 6px;
}

.event-row-date {
  font-size: 11px;
  color: var(--text-sub);
  margin-top: 2px;
}

.event-row-badge {
  font-size: 10px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 999px;
  white-space: nowrap;
  flex-shrink: 0;
}

.badge--urgent {
  background: #fef2f2;
  color: #dc2626;
  border: 1px solid #fecaca;
}

.badge--open {
  background: #f0fdf4;
  color: #16a34a;
  border: 1px solid #bbf7d0;
}

.badge--soon {
  background: #fffbeb;
  color: #d97706;
  border: 1px solid #fde68a;
}

.badge--result {
  background: #f5f3ff;
  color: #7c3aed;
  border: 1px solid #ddd6fe;
}

.event-row-arrow {
  font-size: 16px;
  font-weight: 700;
  color: var(--sky-500);
  flex-shrink: 0;
}

/* ===== タイムライン詳細ビュー ===== */
#timelineView {
  display: none;
}

#timelineView.open {
  display: block;
}

.timeline-back-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 700;
  color: var(--sky-600);
  background: var(--sky-50);
  border: 1.5px solid var(--sky-200);
  border-radius: 999px;
  padding: 6px 14px;
  cursor: pointer;
  transition: background 0.15s;
  margin: 16px 20px 0;
  width: fit-content;
}

.timeline-back-btn:hover { background: var(--sky-100); }

.timeline-event-header {
  padding: 14px 20px 0;
}

.timeline-event-name {
  font-size: 18px;
  font-weight: 900;
  color: var(--text-main);
}


/* ステッパー横スクロール */
.timeline-stepper-wrap {
  overflow-x: auto;
  padding: 16px 20px 8px;
  scrollbar-width: none;
}

.timeline-stepper-wrap::-webkit-scrollbar { display: none; }

.timeline-stepper {
  display: flex;
  align-items: flex-start;
  gap: 0;
  min-width: max-content;
}

/* グループ括り */
.stepper-group {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.stepper-group--multi {
  border: 1.5px solid var(--sky-200);
  border-radius: 10px;
  padding: 4px 8px 8px;
  background: rgba(14, 165, 233, 0.03);
}

.stepper-group-label {
  font-size: 12px;
  font-weight: 800;
  color: var(--sky-600);
  white-space: nowrap;
  margin-bottom: 6px;
  background: var(--sky-100);
  border-radius: 99px;
  padding: 1px 7px;
}

.stepper-group-dots {
  display: flex;
  align-items: flex-start;
}

/* グループ間の破線セパレーター（ドットの高さに合わせてパディングで位置調整） */
.stepper-group-sep {
  flex-shrink: 0;
  width: 20px;
  align-self: flex-start;
  padding-top: 33px;
}

.stepper-group-sep::after {
  content: '';
  display: block;
  width: 100%;
  height: 2px;
  background: repeating-linear-gradient(
    to right,
    var(--sky-300) 0,
    var(--sky-300) 3px,
    transparent 3px,
    transparent 7px
  );
}

.stepper-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
}

.stepper-connector {
  height: 2px;
  background: var(--sky-200);
  align-self: center;
  flex-shrink: 0;
  width: 40px;
  margin-top: -10px;
}

.stepper-dot-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}

.stepper-dot {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 2.5px solid var(--sky-300);
  background: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 900;
  color: var(--sky-500);
  flex-shrink: 0;
  z-index: 1;
}

.stepper-dot.active {
  background: var(--sky-500);
  border-color: var(--sky-500);
  color: white;
  box-shadow: 0 0 0 4px rgba(14, 165, 233, 0.2);
}

.stepper-dot.done {
  background: var(--sky-200);
  border-color: var(--sky-300);
  color: var(--sky-600);
}

.stepper-dot.upcoming {
  border-color: var(--sky-200);
  color: var(--text-mute);
}

.stepper-label {
  font-size: 12px;
  font-weight: 700;
  color: var(--text-sub);
  text-align: center;
  max-width: 68px;
  white-space: nowrap;
}

.stepper-date-label {
  font-size: 11px;
  color: var(--text-mute);
  text-align: center;
  max-width: 72px;
  white-space: nowrap;
}

.now-indicator {
  font-size: 11px;
  font-weight: 700;
  color: var(--sky-500);
}

/* ステッパーリスト（縦型詳細） */
.timeline-step-list {
  padding: 8px 20px 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.step-list-item {
  display: flex;
  gap: 14px;
  position: relative;
}

.step-list-item:not(:last-child)::after {
  content: '';
  position: absolute;
  left: 9px;
  top: 24px;
  bottom: -4px;
  width: 2px;
  background: var(--sky-100);
}

.step-number {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 2px solid var(--sky-300);
  background: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 900;
  color: var(--sky-500);
  flex-shrink: 0;
  margin-top: 2px;
  z-index: 1;
}

.step-number.active {
  background: var(--sky-500);
  border-color: var(--sky-500);
  color: white;
  box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.18);
}

.step-number.done {
  background: var(--sky-100);
  border-color: var(--sky-200);
  color: var(--sky-500);
}

.step-body {
  flex: 1;
  padding-bottom: 16px;
}

.step-title {
  font-size: 13px;
  font-weight: 900;
  color: var(--text-main);
}

.step-dates {
  font-size: 11px;
  color: var(--text-sub);
  margin-top: 2px;
}

.step-status-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  border-radius: 999px;
  padding: 2px 8px;
  margin-top: 4px;
}

.step-status-badge.open     { background: #f0fdf4; color: #16a34a; border: 1px solid #bbf7d0; }
.step-status-badge.urgent   { background: #fef2f2; color: #dc2626; border: 1px solid #fecaca; }
.step-status-badge.done     { background: #f1f5f9; color: #64748b; border: 1px solid #e2e8f0; }
.step-status-badge.upcoming { background: #f5f3ff; color: #7c3aed; border: 1px solid #ddd6fe; }

.step-url-btn {
  display: inline-block;
  margin-top: 6px;
  font-size: 11px;
  font-weight: 700;
  color: var(--sky-600);
  background: var(--sky-50);
  border: 1.5px solid var(--sky-200);
  border-radius: 999px;
  padding: 4px 12px;
  text-decoration: none;
  transition: background 0.15s;
}

.step-url-btn:hover { background: var(--sky-100); }

/* リスト／タイムライン切り替え */
#dashboardListView.hidden { display: none; }
#timelineView.hidden { display: none; }

/* ===== タイムライン ナビ行・保存ボタン ===== */
.timeline-nav-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px 0;
}

.timeline-nav-row .timeline-back-btn {
  margin: 0;
}

/* 一覧ビューのナビ行（保存ボタンのみ・右寄せ） */
.dashboard-list-nav-row {
  justify-content: flex-end;
  padding-bottom: 4px;
}

.timeline-save-img-btn {
  font-size: 11px;
  font-weight: 700;
  color: var(--sky-600);
  background: var(--sky-50);
  border: 1.5px solid var(--sky-200);
  border-radius: 999px;
  padding: 6px 14px;
  cursor: pointer;
  transition: background 0.15s;
  white-space: nowrap;
}

.timeline-save-img-btn:hover    { background: var(--sky-100); }
.timeline-save-img-btn:disabled { opacity: 0.6; cursor: default; }

/* ===== ステップリスト グループ括り ===== */
.step-list-group {
  margin-bottom: 12px;
}

.step-list-group--labeled {
  border: 1.5px solid var(--sky-200);
  border-radius: 12px;
  padding: 0 12px 4px;
  background: rgba(14, 165, 233, 0.02);
}

.step-list-group-header {
  font-size: 11px;
  font-weight: 900;
  color: var(--sky-600);
  background: var(--sky-100);
  border-radius: 99px;
  padding: 2px 10px;
  margin: 8px 0 8px;
  width: fit-content;
}
