/* Primary view-switching layout */
#appShell {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 0;
}

#appShell > header.chat-header,
#appShell > .footer-nav {
  flex-shrink: 0;
}

.view-root {
  flex: 1;
  min-height: 0;
  position: relative;
  overflow: hidden;
  background: transparent;
}

.view-panel {
  display: none;
  flex-direction: column;
  height: 100%;
  min-height: 0;
  overflow: hidden;
}

.view-panel.active {
  display: flex;
  --view-primary: var(--jade-gold, #c9a84c);
  --view-accent: var(--jade-accent, #7c3aed);
  background:
    radial-gradient(
      ellipse 110% 72% at 50% -12%,
      color-mix(in srgb, var(--view-primary) 11%, transparent),
      transparent 58%
    ),
    radial-gradient(
      ellipse 88% 58% at 100% 102%,
      color-mix(in srgb, var(--view-accent) 8%, transparent),
      transparent 54%
    ),
    linear-gradient(165deg, #12121f 0%, #0c0c14 44%, #050508 100%);
}

/* Per-tab gradient identity — muted court palette */
#chatView.view-panel.active {
  --view-primary: var(--thread-primary, #c9a84c);
  --view-accent: var(--thread-accent, #7c3aed);
}

#tasksView.view-panel.active {
  --view-primary: #4a8f6a;
  --view-accent: #3d8f82;
}

#gamesView.view-panel.active {
  --view-primary: #b8653a;
  --view-accent: #a85a62;
}

#writingView.view-panel.active {
  --view-primary: #a88938;
  --view-accent: #8f7030;
}

#settingsView.view-panel.active,
#settingsToysView.view-panel.active,
#settingsWardrobeView.view-panel.active,
#settingsEditView.view-panel.active {
  --view-primary: #8578b0;
  --view-accent: #555a94;
}

.view-toolbar {
  flex-shrink: 0;
  display: flex;
  gap: 6px;
  padding: 10px 14px 0;
  border-bottom: 1px solid color-mix(in srgb, var(--view-primary) 10%, transparent);
  background: color-mix(in srgb, var(--view-primary) 4%, rgba(8, 8, 15, 0.55));
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.view-toolbar-btn {
  flex: 1;
  padding: 8px 10px;
  border: none;
  border-radius: 8px 8px 0 0;
  background: transparent;
  color: var(--text-muted, #9898b8);
  font-size: 0.78rem;
  font-weight: 600;
  cursor: pointer;
  border-bottom: 2px solid transparent;
}

.view-toolbar-btn.active {
  color: var(--view-primary, var(--accent, #c9a86c));
  border-bottom-color: var(--view-primary, var(--accent, #c9a86c));
  background: color-mix(in srgb, var(--view-primary, #c9a86c) 7%, transparent);
}

.view-subheader {
  flex-shrink: 0;
  display: none;
  align-items: center;
  gap: 0.75rem;
  padding: 10px 14px;
  border-bottom: 1px solid color-mix(in srgb, var(--view-primary) 10%, transparent);
  background: color-mix(in srgb, var(--view-primary) 4%, rgba(8, 8, 15, 0.62));
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.view-subheader.is-visible {
  display: flex;
}

.view-back {
  border: none;
  background: transparent;
  color: var(--view-primary, var(--accent, #c9a86c));
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  padding: 6px 0;
  white-space: nowrap;
}

.view-subheader-title {
  font-family: "Playfair Display", Georgia, serif;
  font-size: 1rem;
  font-weight: 600;
  color: var(--text, #e8e8f0);
  margin: 0;
}

.view-scroll {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 12px 16px calc(16px + var(--safe-bottom, 0px));
}

.view-scroll .drawer-empty,
.view-panel .drawer-empty {
  color: var(--text-muted, #9898b8);
  font-size: 0.85rem;
  text-align: center;
  padding: 24px 12px;
}

.chat-thread-panel {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
}

.chat-thread-panel.hidden {
  display: none;
}

body.coach-mode #chatRosterPanel {
  display: none !important;
}

body.coach-mode #chatThreadPanel {
  display: flex !important;
}

.chat-roster-panel {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 16px 16px calc(20px + var(--safe-bottom, 0px));
  background: transparent;
}

.chat-roster-panel.hidden {
  display: none;
}

.chat-roster-intro {
  margin-bottom: 1rem;
}

.chat-roster-title {
  font-family: "Playfair Display", Georgia, serif;
  font-size: 1.35rem;
  font-weight: 600;
  color: var(--view-primary, var(--text, #e8e8f0));
  margin: 0 0 0.25rem;
}

.chat-roster-subtitle {
  margin: 0;
  color: var(--text-muted, #9898b8);
  font-size: 0.85rem;
}

.chat-roster-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

@media (min-width: 520px) {
  .chat-roster-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.roster-card {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  text-align: left;
  padding: 14px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--roster-primary, #888) 18%, transparent);
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--roster-primary, #888) 8%, transparent),
    rgba(255, 255, 255, 0.02)
  );
  color: var(--text, #e8e8f0);
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s, transform 0.12s;
}

.roster-card:hover,
.roster-card:focus-visible {
  border-color: color-mix(in srgb, var(--roster-accent, #888) 28%, transparent);
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--roster-primary, #888) 10%, transparent),
    rgba(255, 255, 255, 0.025)
  );
  outline: none;
}

.roster-card--queen {
  border-color: color-mix(in srgb, var(--roster-primary, #c9a84c) 35%, transparent);
}

.roster-card--group {
  border-color: rgba(120, 170, 255, 0.35);
  background: linear-gradient(135deg, rgba(40, 70, 140, 0.22), rgba(255, 255, 255, 0.03));
}

.roster-card--current {
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--roster-accent, #888) 40%, transparent);
}

.roster-card-avatar {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid rgba(255, 255, 255, 0.12);
}

.roster-card-avatar--fallback {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  color: var(--accent, #c9a86c);
  background: rgba(255, 255, 255, 0.06);
}

.roster-card-body {
  flex: 1;
  min-width: 0;
}

.roster-card-top {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  margin-bottom: 4px;
}

.roster-card-name {
  font-weight: 600;
  font-size: 0.95rem;
}

.roster-card-badges {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 4px;
}

.roster-card-badge {
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 2px 6px;
  border-radius: 999px;
  border: 1px solid transparent;
}

.roster-card-badge--default {
  color: #f5d78e;
  border-color: rgba(245, 215, 142, 0.45);
  background: rgba(160, 110, 30, 0.25);
}

.roster-card-badge--active {
  color: #d4b8ff;
  border-color: rgba(212, 184, 255, 0.4);
  background: rgba(100, 60, 160, 0.25);
}

.roster-card-badge--group {
  color: #9ec5ff;
  border-color: rgba(158, 197, 255, 0.4);
  background: rgba(50, 90, 160, 0.25);
}

.roster-card-avatar-wrap {
  position: relative;
  flex-shrink: 0;
  width: 48px;
  height: 48px;
}

.roster-card--unread {
  animation: roster-card-pulse 1.35s ease-in-out infinite;
}

.roster-card--unread .roster-card-avatar,
.roster-card--unread .roster-card-avatar--fallback {
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--pulse-color, #c9a84c) 60%, transparent);
}

.roster-card-avatar-wrap--unread .roster-card-avatar,
.roster-card-avatar-wrap--unread .roster-card-avatar--fallback {
  animation: roster-avatar-pulse 1.35s ease-in-out infinite;
}

@keyframes roster-card-pulse {
  0%, 100% {
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--pulse-color, #c9a84c) 35%, transparent);
    background: rgba(255, 255, 255, 0.02);
  }
  50% {
    box-shadow:
      inset 0 0 0 1px color-mix(in srgb, var(--pulse-color, #c9a84c) 75%, transparent),
      0 0 14px 2px color-mix(in srgb, var(--pulse-color, #c9a84c) 45%, transparent);
    background: color-mix(in srgb, var(--pulse-color, #c9a84c) 8%, transparent);
  }
}

@keyframes roster-avatar-pulse {
  0%, 100% {
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--pulse-color, #c9a84c) 45%, transparent);
  }
  50% {
    box-shadow: 0 0 12px 3px color-mix(in srgb, var(--pulse-color, #c9a84c) 65%, transparent);
  }
}

.roster-card--unread-jade { --pulse-color: #c9a84c; }
.roster-card--unread-kate { --pulse-color: #7eb0d4; }
.roster-card--unread-mia { --pulse-color: #e57373; }
.roster-card--unread-sophie { --pulse-color: #a78bfa; }
.roster-card--unread-danielle { --pulse-color: #2dd4bf; }
.roster-card--unread-vera { --pulse-color: #e8a0b4; }

.roster-card-blurb {
  margin: 0;
  font-size: 0.78rem;
  color: var(--text-muted, #9898b8);
  line-height: 1.35;
}

.roster-card-chevron {
  flex-shrink: 0;
  color: var(--roster-primary, var(--text-muted, #9898b8));
  font-size: 1rem;
  opacity: 0.9;
}

.hero-avatar-ring.hero-avatar-ring--group {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #9ec5ff;
  font-size: 1.45rem;
}

#chatView .stats-bar,
#chatView .composer {
  flex-shrink: 0;
}

#chatView .composer.hidden,
#chatView #statsBar.hidden,
#chatView #reliefBar.hidden {
  display: none;
}

#chatView .chat-thread-panel > #dialogue-window {
  flex: 1;
  min-height: 0;
}

.writing-view-mount {
  padding: 0;
  height: 100%;
}

.writing-view-mount .writing-host {
  height: 100%;
  min-height: 0;
}

.writing-idle {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  min-height: 50vh;
  text-align: center;
  color: var(--text-muted, #9898b8);
  padding: 2rem;
}

.writing-idle h2 {
  font-family: "Playfair Display", Georgia, serif;
  color: var(--view-primary, var(--text, #e8e8f0));
  font-size: 1.2rem;
  margin: 0;
}

.games-interface-panel {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.games-interface-panel.hidden {
  display: none;
}

#gamesView.view-panel.active.games-in-play #gamesViewMount {
  display: none;
}

#gamesView.view-panel.active.games-in-play .games-interface-panel {
  display: flex;
  flex: 1;
  min-height: 0;
  flex-direction: column;
  background: transparent;
}

#gamesView.view-panel.active.games-in-play {
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

#tasksView .action-card,
#tasksView .punishment-item {
  border: 1px solid color-mix(in srgb, var(--view-primary) 16%, transparent);
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--view-primary) 7%, transparent),
    rgba(255, 255, 255, 0.02)
  );
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.16);
}

#tasksView .view-toolbar-btn.active {
  color: var(--view-primary);
  border-bottom-color: var(--view-primary);
}

#tasksView .action-cards.day-log-cards {
  padding: 10px 12px 12px;
}

#tasksView .action-card.action-daylog-info .action-type-badge { color: #7dd3fc; }
#tasksView .action-card.action-daylog-summarize .action-type-badge { color: #a78bfa; }
#tasksView .action-card.action-daylog-note .action-type-badge { color: #e8c468; }
#tasksView .action-card.action-daylog-history .action-type-badge { color: #86efac; }

.day-log-scope-list {
  margin: 0 0 10px;
  padding-left: 1.1rem;
  font-size: 0.86rem;
  line-height: 1.5;
  color: var(--text-dim, #b8b8d0);
}

.day-log-scope-list li {
  margin-bottom: 0.45rem;
}

.day-log-scope-list li:last-child {
  margin-bottom: 0;
}

.day-log-scope-details {
  margin-top: 0.35rem;
  font-size: 0.82rem;
  color: var(--text-muted, #9898b8);
}

.day-log-scope-details summary {
  cursor: pointer;
  color: color-mix(in srgb, var(--view-primary) 80%, var(--text-muted));
  font-weight: 600;
}

.day-log-scope-details .action-card-desc {
  margin-top: 0.45rem;
  margin-bottom: 0;
}

.day-log-status {
  margin: 0.55rem 0 0;
  font-size: 0.72rem;
  color: var(--text-muted, #9898b8);
}

.day-log-status.error {
  color: #f87171;
}

.day-log-history {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

.day-log-history-day {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}

.day-log-history-label {
  margin: 0;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted, #9898b8);
}

.day-log-history-item {
  padding: 0.55rem 0.65rem;
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.22);
  border: 1px solid rgba(255, 255, 255, 0.06);
}

.day-log-history-item .action-foundation-pill,
.day-log-history-item .action-protocol-badge {
  margin-left: 0;
  margin-bottom: 0.35rem;
}

.day-log-entry-text,
.day-log-bullets {
  margin: 0;
  font-size: 0.84rem;
  line-height: 1.45;
  color: var(--text, #e8e8f0);
}

.day-log-bullets {
  padding-left: 1rem;
}

.day-log-bullets li {
  margin-bottom: 0.25rem;
}

.day-log-bullets li:last-child {
  margin-bottom: 0;
}

#tasksView .action-submit-btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

#writingView.writing-active .view-scroll {
  padding: 0;
  overflow: hidden;
}

#writingView.writing-active .writing-view-mount {
  height: 100%;
  min-height: 0;
}

.games-list-panel {
  flex: 1;
  min-height: 0;
}

#gamesView .g-modal-embedded {
  flex: 1;
  min-height: 0;
  background: transparent;
}

#gamesView .g-modal-embedded .g-modal {
  background: transparent;
}

/* Footer tab accent matches active view gradient */
.footer-tab.active[data-view="chat"] {
  color: #b89848;
  background: color-mix(in srgb, #b89848 8%, transparent);
}

.footer-tab.active[data-view="tasks"] {
  color: #d4869a;
  background: color-mix(in srgb, #d4869a 8%, transparent);
}

.footer-tab.active[data-view="games"] {
  color: #b8653a;
  background: color-mix(in srgb, #b8653a 8%, transparent);
}

.footer-tab.active[data-view="writing"] {
  color: #a88938;
  background: color-mix(in srgb, #a88938 8%, transparent);
}

.footer-tab.active[data-view="settings"] {
  color: #8578b0;
  background: color-mix(in srgb, #8578b0 8%, transparent);
}
