:root {
  --bg: #f4efe7;
  --panel: rgba(255, 250, 244, 0.82);
  --border: rgba(120, 90, 58, 0.1);
  --shadow: 0 22px 60px rgba(84, 53, 33, 0.1);
  --text: #2f241f;
  --muted: #76685f;
  --accent: #d86f42;
  --blue-1: #5f97b8;
  --blue-2: #7eb2cf;
  --radius: 26px;
  --app-scale: 1;
}

* { box-sizing: border-box; }
html, body { min-height: 100%; margin: 0; overflow: hidden; }
body {
  font-family: "DM Sans", sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at top left, rgba(255, 213, 173, 0.88), transparent 26%),
    radial-gradient(circle at top right, rgba(204, 231, 244, 0.92), transparent 26%),
    linear-gradient(135deg, #f6efe5 0%, #fbf8f4 45%, #eef5f8 100%);
}

.is-hidden { display: none !important; }
.card { border: 1px solid var(--border); background: var(--panel); box-shadow: var(--shadow); backdrop-filter: blur(18px); }
.eyebrow, .label { margin: 0 0 0.35rem; font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.14em; color: var(--muted); }
.loading-shell,
.auth-shell,
.display-pair-shell,
.app-shell { min-height: 100vh; padding: 1.2rem; }
.loading-shell {
  display: grid;
  place-items: center;
}
.auth-shell,
.display-pair-shell { display: grid; place-items: center; }
.app-shell {
  width: 1920px;
  height: 1080px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 50%;
  left: 50%;
  min-height: 0;
  transform: translate(-50%, -50%) scale(var(--app-scale));
  transform-origin: center center;
  overflow: hidden;
}
.auth-card { max-width: 42rem; padding: 2rem 2.2rem; border-radius: 32px; }
.auth-card .legal-links {
  margin-top: 1rem;
}
.display-pair-card { width: min(34rem, 92vw); padding: 2rem 2.2rem; border-radius: 32px; }
.auth-form {
  display: grid;
  gap: 0.75rem;
  margin-top: 1rem;
}
.auth-form label {
  display: grid;
  gap: 0.35rem;
}
.auth-form input,
.settings-group textarea {
  width: 100%;
  padding: 0.8rem 0.9rem;
  border-radius: 14px;
  border: 1px solid rgba(120, 90, 58, 0.16);
  background: rgba(255,255,255,0.88);
  font: inherit;
  color: var(--text);
}
.auth-mode-switch {
  display: inline-flex;
  gap: 0.55rem;
  margin-top: 1rem;
}
.text-button {
  border: 0;
  background: transparent;
  color: var(--accent);
  font: inherit;
  padding: 0;
  cursor: pointer;
}
.auth-link {
  justify-self: flex-start;
  margin-top: 0.15rem;
}
.auth-mode-switch .settings-toggle.is-active {
  background: var(--accent);
  color: white;
}
.loading-card {
  width: min(34rem, 92vw);
  padding: 2.2rem 2.3rem;
  border-radius: 32px;
  text-align: center;
}
.auth-card h1, .family-card h1, .hero-date, .panel h2, .settings-header h2, .settings-group h3 { margin: 0; font-family: "Fraunces", serif; letter-spacing: -0.04em; }
.hero-copy, .helper-text, .save-status, .loading-copy { color: var(--muted); }
.legal-links,
.dashboard-footer {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.65rem;
  color: var(--muted);
  font-size: 0.9rem;
}
.legal-links a,
.dashboard-footer a {
  color: inherit;
  text-decoration: none;
}
.legal-links a:hover,
.dashboard-footer a:hover {
  color: var(--text);
}
.loading-copy {
  margin: 0.75rem auto 0;
  max-width: 24rem;
}
.loading-mark {
  display: inline-flex;
  gap: 0.45rem;
  margin-top: 1.2rem;
}
.loading-mark span {
  width: 0.8rem;
  height: 0.8rem;
  border-radius: 999px;
  background: rgba(216, 111, 66, 0.9);
  animation: morning-board-pulse 1.2s ease-in-out infinite;
}
.loading-mark span:nth-child(2) {
  animation-delay: 0.15s;
}
.loading-mark span:nth-child(3) {
  animation-delay: 0.3s;
}
.primary-link, .primary-button, .ghost-link, .ghost-button, .settings-toggle, .close-button, .user-pill, .badge {
  border: 0; text-decoration: none; font: inherit; border-radius: 999px; padding: 0.75rem 1rem;
}
.primary-link, .primary-button { background: var(--accent); color: white; }
.ghost-link, .ghost-button, .settings-toggle, .user-pill, .badge { background: rgba(255,255,255,0.72); color: var(--text); }
.compact-button,
.compact-link {
  padding: 0.55rem 0.8rem;
  font-size: 0.78rem;
}

.top-grid {
  display: grid;
  grid-template-columns: 1.15fr 2.3fr 1.45fr;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
  flex: 0 0 auto;
}

.mobile-control-deck {
  display: none;
}
.mobile-control-head,
.mobile-control-actions,
.mobile-control-buttons {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
  justify-content: space-between;
}
.mobile-control-deck h1,
.mobile-control-card h2,
.account-display-card h4 {
  margin: 0;
  font-family: "Fraunces", serif;
  letter-spacing: -0.04em;
}
.mobile-control-card,
.account-display-card {
  display: grid;
  gap: 0.65rem;
  padding: 0.95rem 1rem;
  border-radius: 18px;
  background: rgba(255,255,255,0.48);
}
.display-code-value {
  margin: 0;
  font-family: "Fraunces", serif;
  font-size: 2rem;
  letter-spacing: 0.08em;
}
.admin-metrics,
.mobile-admin-metrics {
  display: grid;
  gap: 0.3rem;
}
.admin-metrics p,
.mobile-admin-metrics p {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
}

.family-card, .weather-strip, .meta-card { border-radius: 28px; padding: 0.8rem 1rem; min-height: 6.9rem; }
.family-card h1 { font-size: clamp(1.7rem, 3vw, 3rem); }
.hero-time { margin: 0.2rem 0 0; font-family: "Fraunces", serif; font-size: clamp(1.9rem, 3.2vw, 3.2rem); font-weight: 700; }
.hero-date { margin-top: 1rem; text-align: right; font-size: clamp(1.9rem, 3.2vw, 3.1rem); }
.meta-card { display: flex; flex-direction: column; justify-content: space-between; }
.meta-actions { display: flex; justify-content: flex-end; gap: 0.75rem; }
body.is-display-route .meta-actions,
body.is-display-route .mobile-control-deck {
  display: none !important;
}

.weather-strip {
  background: linear-gradient(135deg, rgba(87, 144, 176, 0.96), rgba(134, 186, 211, 0.95));
  color: white;
}
.weather-strip .eyebrow { color: rgba(255,255,255,0.76); }
.weather-outlook { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.75rem; height: 100%; }
.weather-tile h3 { margin: 0; font-size: 1.1rem; font-family: "Fraunces", serif; }
.weather-place, .weather-summary, .weather-small { margin: 0.12rem 0 0; color: rgba(255,255,255,0.92); font-size: 0.83rem; }
.weather-big { margin: 0.2rem 0; font-size: 1.55rem; }
.weather-hi-lo {
  margin: 0.14rem 0 0;
  font-size: 1.05rem;
  font-family: "Fraunces", serif;
  color: rgba(255,255,255,0.96);
}

.content-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 22rem;
  gap: 0.75rem;
  align-items: stretch;
  flex: 1 1 auto;
  min-height: 0;
}
.dashboard-footer {
  margin-top: 0.85rem;
  flex: 0 0 auto;
}
body.layout-no-calendar .content-grid,
body.layout-no-side .content-grid { grid-template-columns: 1fr; }
.calendar-section,
.side-rail { min-width: 0; min-height: 0; }
.calendar-grid { display: grid; }
.merged-calendar-card,
.meal-card { border-radius: 24px; padding: 0.85rem; overflow: hidden; }
.meal-card {
  background: rgba(230, 240, 228, 0.9);
}
.calendar-board-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 0.55rem;
  margin-top: 0.7rem;
}
.calendar-day-column { min-width: 0; }
.calendar-day-column:not(:last-child) {
  border-right: 1px solid rgba(120, 90, 58, 0.22);
  padding-right: 0.45rem;
}
.calendar-day-column:not(:first-child) {
  padding-left: 0.1rem;
}
.calendar-day-header {
  padding: 0 0.15rem 0.45rem;
  border-bottom: 2px solid rgba(120, 90, 58, 0.2);
  margin-bottom: 0.45rem;
}
.calendar-day-header h3,
.calendar-item h4 { margin: 0; font-family: "Fraunces", serif; }
.calendar-day-header h3 { font-size: 1rem; }
.calendar-day-header p { margin: 0.1rem 0 0; color: var(--muted); font-size: 0.78rem; }
.calendar-day-stack,
.meal-stack { display: grid; gap: 0.5rem; }
.calendar-overlap-row {
  --overlap-count: 2;
  display: grid;
  grid-template-columns: repeat(var(--overlap-count), minmax(0, 1fr));
  gap: 0.35rem;
}
.calendar-item,
.meal-row,
.empty-state,
.settings-group {
  border-radius: 18px; background: rgba(255,255,255,0.48);
}
.calendar-item {
  --calendar-accent: rgba(120, 90, 58, 0.16);
  border-left: 6px solid var(--calendar-accent);
  padding: 0.55rem 0.6rem;
  min-height: 4.6rem;
}
.calendar-item.is-now {
  box-shadow: inset 0 0 0 2px rgba(216, 111, 66, 0.18);
}
.calendar-item-time,
.calendar-item-meta,
.calendar-item-location,
.meal-row p { margin: 0.16rem 0 0; color: var(--muted); font-size: 0.78rem; }
.calendar-item-time { margin-top: 0; font-weight: 700; color: var(--text); }
.calendar-item h4,
.meal-row h3 { font-size: 0.96rem; }
.calendar-item-location { line-height: 1.25; }
.merged-calendar-header { align-items: center; }
.calendar-legend {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.4rem;
}
.calendar-legend-item {
  --calendar-accent: rgba(120, 90, 58, 0.16);
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.28rem 0.5rem;
  border-radius: 999px;
  background: rgba(255,255,255,0.6);
  color: var(--text);
  font-size: 0.72rem;
}
.calendar-legend-dot {
  width: 0.65rem;
  height: 0.65rem;
  border-radius: 999px;
  background: var(--calendar-accent);
}

.side-rail {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  min-height: 0;
  height: 100%;
  align-self: stretch;
}
.meal-card.dinner-card {
  width: 100%;
  align-self: stretch;
  flex: 0 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
  padding: 0.72rem;
}
.meal-header h2 { font-size: 1.02rem; }
.meal-stack {
  gap: 0.3rem;
  margin-top: 0.45rem;
}
.meal-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0.45rem;
  padding: 0.34rem 0.42rem;
  align-items: center;
}
.meal-row.no-note {
  grid-template-columns: 1fr;
}
.meal-day { margin: 0; font-size: 0.54rem; text-transform: uppercase; letter-spacing: 0.12em; color: var(--muted); }
.meal-row h3 { font-size: 0.84rem; }
.meal-note {
  text-align: right;
  max-width: 6.2rem;
  font-size: 0.68rem;
}
.photo-card {
  padding: 0.8rem;
  width: 100%;
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
}
.photo-header h2 { font-size: 1.04rem; }
.photo-header-actions {
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.photo-frame {
  flex: 1 1 auto;
  height: auto;
  min-height: 0;
  margin-top: 0.38rem;
  border-radius: 20px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.2), rgba(255,255,255,0.04)),
    linear-gradient(135deg, rgba(170, 200, 182, 0.55), rgba(241, 231, 212, 0.75));
  border: 1px solid rgba(120, 90, 58, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  padding: 0.75rem;
}
.meal-stack {
  gap: 0.42rem;
}
.photo-frame-copy {
  margin: 0;
  color: var(--muted);
  font-size: 0.82rem;
}
.note-frame {
  width: 100%;
  height: 100%;
  padding: 1rem;
  border-radius: 18px;
  background: rgba(255,255,255,0.42);
  overflow: auto;
}
.note-frame p {
  margin: 0;
  color: var(--text);
  font-size: 0.95rem;
  line-height: 1.45;
  white-space: normal;
}
.photo-frame-empty {
  display: grid;
  justify-items: center;
  gap: 0.75rem;
  padding: 1rem;
  text-align: center;
}
.photo-stage {
  width: min(100%, calc((100vh - 320px) * 4 / 3));
  height: min(100%, calc((100vw - 1600px) * 0 + 100%));
  max-width: 100%;
  max-height: 100%;
  aspect-ratio: 4 / 3;
  margin: 0;
  overflow: hidden;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.28);
}
.photo-stage-image {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center center;
}

.panel-header, .settings-header, .settings-actions { display: flex; align-items: flex-start; justify-content: space-between; gap: 0.75rem; }
.badge { font-size: 0.78rem; }
.empty-state { padding: 0.95rem; color: var(--muted); }
.wide-empty { grid-column: 1 / -1; }

.settings-drawer {
  position: fixed; inset: 0; display: flex; justify-content: flex-end;
  background: rgba(21,15,12,0.3); opacity: 0; pointer-events: none; transition: opacity 180ms ease;
}
.settings-drawer.is-open { opacity: 1; pointer-events: auto; }
.connections-drawer {
  position: fixed;
  inset: 0;
  display: flex;
  justify-content: center;
  background: rgba(21, 15, 12, 0.3);
  opacity: 0;
  pointer-events: none;
  transition: opacity 180ms ease;
}
.connections-drawer.is-open {
  opacity: 1;
  pointer-events: auto;
}
.settings-panel { width: min(38rem, 92vw); height: 100vh; border-radius: 0; padding: 1.5rem; overflow: auto; }
.connections-panel {
  width: min(74rem, 96vw);
  height: min(92vh, 64rem);
  margin: auto;
  border-radius: 28px;
  padding: 1.5rem;
  overflow: auto;
}
.settings-form { display: grid; gap: 1rem; }
.settings-group { display: grid; gap: 0.75rem; padding: 1rem; }
.settings-accordion[open] .settings-summary {
  margin-bottom: 0.85rem;
}
.settings-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  list-style: none;
}
.settings-summary::-webkit-details-marker {
  display: none;
}
.settings-summary::after {
  content: "+";
  width: 1.8rem;
  height: 1.8rem;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  background: rgba(255,255,255,0.72);
  color: var(--text);
  font-size: 1.1rem;
}
.settings-accordion[open] .settings-summary::after {
  content: "–";
}
.settings-group-body {
  display: grid;
  gap: 0.75rem;
}
.connections-layout {
  display: grid;
  gap: 1rem;
  margin-top: 1rem;
}
.section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
}
.settings-group label { display: grid; gap: 0.35rem; }
.settings-group input, .settings-group select {
  width: 100%; padding: 0.8rem 0.9rem; border-radius: 14px; border: 1px solid rgba(120,90,58,0.16);
  background: rgba(255,255,255,0.88); font: inherit; color: var(--text);
}
.settings-group input:disabled {
  background: rgba(255,255,255,0.55);
  color: var(--muted);
}
.settings-group input[readonly] {
  background: rgba(255,255,255,0.55);
  color: var(--muted);
}
.calendar-picker-grid,
.calendar-name-grid,
.dinner-plan-grid,
.account-password-grid { display: grid; gap: 0.75rem; }
.calendar-color-picker { margin-top: -0.35rem; }
.calendar-swatch-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}
.calendar-swatch input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.calendar-swatch {
  display: inline-flex;
  align-items: center;
}
.calendar-swatch-dot {
  --swatch-color: rgba(120, 90, 58, 0.16);
  width: 1.1rem;
  height: 1.1rem;
  border-radius: 999px;
  background: var(--swatch-color);
  border: 2px solid transparent;
  box-shadow: 0 0 0 1px rgba(47, 36, 31, 0.08);
  cursor: pointer;
}
.calendar-swatch input:checked + .calendar-swatch-dot {
  border-color: rgba(47, 36, 31, 0.6);
  box-shadow: 0 0 0 2px rgba(255,255,255,0.9), 0 0 0 3px rgba(47, 36, 31, 0.18);
}
.toggle-row {
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.toggle-row input[type="checkbox"] {
  width: 1.1rem;
  height: 1.1rem;
}
.settings-actions.split { justify-content: flex-start; }
.close-button { width: 2.5rem; height: 2.5rem; font-size: 1.5rem; background: rgba(47,36,31,0.08); }
.connection-list,
.available-source-list,
.ical-form {
  display: grid;
  gap: 0.75rem;
}
.connection-card,
.available-source-card {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.9rem 1rem;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.56);
}
.connection-card h3,
.available-source-card h3 {
  margin: 0;
  font-family: "Fraunces", serif;
  font-size: 1.05rem;
}
.display-device-list {
  display: grid;
  gap: 0.7rem;
}
.display-device-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.9rem;
  padding: 0.9rem 1rem;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.56);
}
.display-device-copy {
  display: grid;
  gap: 0.18rem;
  min-width: 0;
}
.display-device-copy h5 {
  margin: 0;
  font-family: "Fraunces", serif;
  font-size: 1rem;
}
.display-device-copy .helper-text {
  word-break: break-word;
}

@media (max-width: 900px) {
  html, body {
    overflow: auto;
  }
  .app-shell {
    width: auto;
    height: auto;
    min-height: 100vh;
    position: relative;
    top: auto;
    left: auto;
    transform: none;
    padding: 1rem;
    overflow: visible;
  }
  .mobile-control-deck {
    display: grid;
    gap: 1rem;
    margin-bottom: 1rem;
    padding: 1.15rem;
    border-radius: 28px;
  }
  .mobile-control-head {
    display: grid;
    gap: 1rem;
    align-items: stretch;
  }
  .mobile-control-head > div:first-child {
    display: grid;
    gap: 0.45rem;
  }
  .mobile-control-head h1 {
    font-size: clamp(2.15rem, 10vw, 3.4rem);
    line-height: 0.92;
    max-width: none;
  }
  .mobile-control-head .helper-text {
    max-width: none;
    font-size: 1rem;
    line-height: 1.45;
  }
  .mobile-control-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
    align-items: stretch;
  }
  .mobile-control-actions .settings-toggle {
    width: 100%;
    justify-content: center;
    text-align: center;
    padding: 0.95rem 1rem;
    font-size: 1.05rem;
  }
  .mobile-control-card {
    padding: 1rem;
  }
  .mobile-control-buttons {
    display: grid;
    grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
    gap: 0.75rem;
    align-items: stretch;
  }
  .mobile-control-buttons .primary-link,
  .mobile-control-buttons .ghost-button {
    width: 100%;
    justify-content: center;
    text-align: center;
    min-height: 4.2rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
  .top-grid,
  .content-grid {
    display: none;
  }
  .settings-drawer,
  .connections-drawer {
    position: static;
    inset: auto;
    display: none;
    justify-content: stretch;
    background: transparent;
    opacity: 1;
    pointer-events: auto;
    transition: none;
    padding: 1rem;
  }
  .settings-drawer.is-open,
  .connections-drawer.is-open {
    display: block;
  }
  .settings-panel,
  .connections-panel {
    width: auto;
    max-width: none;
    height: auto;
    min-height: calc(100vh - 2rem);
    margin: 0;
    border-radius: 28px;
    padding: 1rem;
    overflow: visible;
  }
  .settings-header,
  .panel-header {
    position: sticky;
    top: 0;
    z-index: 2;
    padding-bottom: 0.5rem;
    margin-bottom: 0.25rem;
    background: linear-gradient(180deg, rgba(245, 239, 231, 0.98), rgba(245, 239, 231, 0.9));
    backdrop-filter: blur(10px);
  }
  .settings-actions {
    position: sticky;
    bottom: 0;
    z-index: 2;
    padding-top: 0.85rem;
    margin-top: 0.25rem;
    background: linear-gradient(180deg, rgba(245, 239, 231, 0), rgba(245, 239, 231, 0.96) 30%);
  }
  .settings-actions .primary-button,
  .settings-actions .ghost-button {
    width: 100%;
    justify-content: center;
  }
  .settings-actions.split {
    display: grid;
    grid-template-columns: 1fr;
  }
  .connections-layout {
    gap: 0.85rem;
    margin-top: 0.75rem;
  }
  .connections-panel .section-head {
    display: grid;
    gap: 0.85rem;
  }
  .connections-panel .section-head .primary-link {
    width: 100%;
    justify-content: center;
    text-align: center;
    display: inline-flex;
    align-items: center;
  }
  .connection-list,
  .available-source-list,
  .ical-form {
    gap: 0.65rem;
  }
  .connection-card,
  .available-source-card,
  .display-device-card {
    display: grid;
    gap: 0.75rem;
    padding: 1rem;
  }
  .connection-card h3,
  .available-source-card h3 {
    font-size: 0.96rem;
    line-height: 1.05;
  }
  .connection-card .helper-text,
  .available-source-card .helper-text {
    word-break: break-word;
  }
  .connection-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem;
    width: 100%;
  }
  .connection-actions .ghost-button {
    width: 100%;
    justify-content: center;
    text-align: center;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
  .display-device-card .ghost-button {
    width: 100%;
    justify-content: center;
    text-align: center;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
  .available-source-card .badge {
    justify-self: start;
  }
  .connections-panel .settings-group label {
    gap: 0.45rem;
  }
  .connections-panel .settings-group input {
    font-size: 1rem;
  }
  .connections-panel .settings-actions.split {
    gap: 0.6rem;
  }
  .connections-panel .settings-actions.split .save-status {
    order: 2;
  }
  .connections-panel .settings-actions.split .primary-button {
    order: 1;
    width: 100%;
    justify-content: center;
  }
  body.is-mobile-subpage {
    background:
      radial-gradient(circle at top left, rgba(255, 214, 171, 0.55), transparent 28%),
      radial-gradient(circle at top right, rgba(194, 222, 255, 0.48), transparent 32%),
      linear-gradient(180deg, #f6f1e9 0%, #f2ede6 100%);
  }
  body.is-display-route .top-grid,
  body.is-display-route .content-grid {
    display: grid;
  }
  body.is-display-route .app-shell {
    width: 1920px;
    height: 1080px;
    position: fixed;
    top: 50%;
    left: 50%;
    padding: 24px;
    min-height: 0;
    transform: translate(-50%, -50%) scale(var(--app-scale));
    overflow: hidden;
  }
}
.connection-actions {
  display: flex;
  gap: 0.45rem;
}
.connection-status {
  margin: 0.25rem 0 0;
  color: var(--muted);
  font-size: 0.78rem;
}
.available-source-copy {
  display: grid;
  gap: 0.22rem;
}

@keyframes morning-board-pulse {
  0%, 80%, 100% {
    transform: translateY(0);
    opacity: 0.35;
  }
  40% {
    transform: translateY(-0.2rem);
    opacity: 1;
  }
}
