:root {
  --bg: #F5F1EA;
  --bg-soft: #EFE8DD;
  --surface: rgba(255, 255, 255, 0.42);
  --surface-raised: rgba(255, 255, 255, 0.55);
  --surface-muted: rgba(255, 255, 255, 0.30);
  --surface-solid: #FBF7EF;
  --glass-surface: rgba(255, 255, 255, 0.42);
  --glass-elevated: rgba(255, 255, 255, 0.55);
  --glass-strong: rgba(255, 255, 255, 0.68);
  --glass-border: rgba(255, 255, 255, 0.22);
  --glass-border-strong: rgba(255, 255, 255, 0.32);
  --focus-blur: 20px;
  --focus-blur-strong: 28px;
  --focus-shadow: 0 10px 40px rgba(0, 0, 0, 0.08);
  --focus-shadow-elevated: 0 30px 80px rgba(0, 0, 0, 0.14);
  --focus-glow: 0 0 24px color-mix(in srgb, var(--primary) 18%, transparent);
  --motion-fast: 140ms cubic-bezier(.2, .8, .2, 1);
  --motion-standard: 220ms cubic-bezier(.2, .8, .2, 1);
  --motion-smooth: 320ms cubic-bezier(.2, .8, .2, 1);
  --line: rgba(74, 61, 47, 0.11);
  --line-strong: rgba(74, 61, 47, 0.18);
  --text: #2F2A26;
  --muted: #9C9187;
  --muted-strong: #6F655E;
  --user-primary: #5678F5;
  --primary: var(--user-primary);
  --primary-2: color-mix(in srgb, var(--user-primary) 82%, #1e244f);
  --primary-soft: color-mix(in srgb, var(--user-primary) 14%, transparent);
  --reminder: #5678F5;
  --green: #5F9073;
  --red: #D96B5F;
  --yellow: #D89A3D;
  --orange: #C56A4B;
  --ai: #8C7AE6;
  --rose: #C96A87;
  --cyan: #47A7B8;
  --shadow-xs: 0 1px 1px rgba(47, 42, 38, 0.04);
  --shadow-sm: 0 10px 40px rgba(0, 0, 0, 0.08);
  --shadow-md: 0 18px 54px rgba(0, 0, 0, 0.10);
  --shadow-lg: 0 30px 80px rgba(0, 0, 0, 0.14);
  --ring-soft: 0 0 0 4px color-mix(in srgb, var(--primary) 12%, transparent);
  --radius-xs: 8px;
  --radius-sm: 12px;
  --radius-md: 18px;
  --radius-lg: 24px;
  --radius-xl: 32px;
  --sidebar: 280px;
  --app-font-size: 15px;
  --density-pad: 12px;
  --density-gap: 10px;
  --density-panel-pad: 18px;
  --density-section-gap: 16px;
  --density-button-height: 42px;
  --font: Inter, "Geist Sans", "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  --font-display: Inter, "Geist Sans", "Segoe UI", system-ui, sans-serif;
  color-scheme: light;
}

:root[data-theme="contrast"] {
  --bg: #F7F7F5;
  --bg-soft: #ECEDEA;
  --surface: rgba(255, 255, 255, 0.72);
  --surface-raised: rgba(255, 255, 255, 0.82);
  --surface-muted: rgba(247, 247, 245, 0.72);
  --surface-solid: #FDFDFC;
  --glass-surface: rgba(255, 255, 255, 0.72);
  --glass-elevated: rgba(255, 255, 255, 0.82);
  --glass-strong: rgba(255, 255, 255, 0.90);
  --glass-border: rgba(30, 30, 30, 0.10);
  --glass-border-strong: rgba(30, 30, 30, 0.16);
  --line: rgba(30, 30, 30, 0.11);
  --line-strong: rgba(30, 30, 30, 0.17);
  --text: #1E1E1E;
  --muted: #85827B;
  --muted-strong: #575552;
  --primary: #3366FF;
  --primary-2: color-mix(in srgb, #3366FF 82%, #1E1E1E);
  --primary-soft: color-mix(in srgb, #3366FF 12%, transparent);
}

:root[data-theme="warm"] {
  --bg: #F5F1EA;
  --bg-soft: #EFE8DD;
  --surface: rgba(255, 255, 255, 0.42);
  --surface-raised: rgba(255, 255, 255, 0.55);
  --surface-muted: rgba(255, 255, 255, 0.30);
  --surface-solid: #FBF7EF;
  --glass-surface: rgba(255, 255, 255, 0.42);
  --glass-elevated: rgba(255, 255, 255, 0.55);
  --glass-strong: rgba(255, 255, 255, 0.68);
  --glass-border: rgba(255, 255, 255, 0.22);
  --glass-border-strong: rgba(255, 255, 255, 0.32);
  --line: rgba(74, 61, 47, 0.11);
  --line-strong: rgba(74, 61, 47, 0.18);
  --text: #2F2A26;
  --muted: #9C9187;
  --muted-strong: #6F655E;
  --primary: var(--user-primary);
  --primary-2: color-mix(in srgb, var(--user-primary) 82%, #2F2A26);
  --primary-soft: color-mix(in srgb, var(--user-primary) 14%, transparent);
  --green: #5F9073;
  --red: #D96B5F;
  --yellow: #D89A3D;
}

:root[data-theme="dark"] {
  --bg: #131722;
  --bg-soft: #1A2030;
  --surface: rgba(255, 255, 255, 0.06);
  --surface-raised: rgba(255, 255, 255, 0.10);
  --surface-muted: rgba(255, 255, 255, 0.08);
  --surface-solid: #1A2030;
  --glass-surface: rgba(255, 255, 255, 0.06);
  --glass-elevated: rgba(255, 255, 255, 0.10);
  --glass-strong: rgba(255, 255, 255, 0.14);
  --glass-border: rgba(255, 255, 255, 0.08);
  --glass-border-strong: rgba(255, 255, 255, 0.13);
  --line: rgba(255, 255, 255, 0.08);
  --line-strong: rgba(255, 255, 255, 0.13);
  --text: #F2F1EE;
  --muted: #8F96A8;
  --muted-strong: #B7BCC9;
  --primary: #6F8CFF;
  --primary-2: color-mix(in srgb, #6F8CFF 74%, #ffffff);
  --primary-soft: color-mix(in srgb, #6F8CFF 22%, transparent);
  --green: #72B58F;
  --red: #D96B5F;
  --yellow: #D89A3D;
  --focus-glow: 0 0 24px rgba(111, 140, 255, 0.18);
  --shadow-sm: 0 10px 40px rgba(0, 0, 0, 0.28);
  --shadow-md: 0 18px 54px rgba(0, 0, 0, 0.34);
  --shadow-lg: 0 30px 80px rgba(0, 0, 0, 0.46);
  --ring-soft: 0 0 0 4px color-mix(in srgb, var(--primary) 20%, transparent);
  color-scheme: dark;
}

* {
  box-sizing: border-box;
}

html {
  min-width: 320px;
  background: var(--bg);
  font-size: var(--app-font-size);
}

body {
  min-width: 320px;
  min-height: 100vh;
  margin: 0;
  color: var(--text);
  background:
    radial-gradient(circle at 10% -10%, color-mix(in srgb, var(--primary) 12%, transparent), transparent 31rem),
    radial-gradient(circle at 92% 8%, color-mix(in srgb, var(--yellow) 10%, transparent), transparent 28rem),
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 64%, transparent), transparent 34rem),
    var(--bg);
  font-family: var(--font);
  font-size: var(--app-font-size);
  line-height: 1.55;
  letter-spacing: 0;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

:root[data-font-size="compact"] {
  --app-font-size: 13px;
}

:root[data-font-size="large"] {
  --app-font-size: 18px;
}

:root[data-density="compact"] {
  --density-pad: 7px;
  --density-gap: 6px;
  --density-panel-pad: 12px;
  --density-section-gap: 10px;
  --density-button-height: 34px;
}

:root:not([data-density="compact"]),
:root[data-density="comfortable"] {
  --density-pad: 13px;
  --density-gap: 12px;
  --density-panel-pad: 20px;
  --density-section-gap: 18px;
  --density-button-height: 44px;
}

:root.quotes-hidden .quote-ticker {
  display: none;
}

button,
input,
textarea {
  font: inherit;
}

button {
  border: 0;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}

h1,
h2,
h3,
p {
  margin-top: 0;
}

h1,
h2,
h3 {
  color: var(--text);
  font-family: var(--font-display);
  letter-spacing: 0;
}

.is-hidden {
  display: none !important;
}

.auth-screen {
  display: grid;
  min-height: 100vh;
  place-items: center;
  padding: var(--density-panel-pad);
}

.auth-panel {
  width: min(100%, 520px);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  background: var(--surface-raised);
  box-shadow: var(--shadow-lg);
  padding: clamp(24px, 4vw, 40px);
}

.brand-lockup,
.brand,
.panel-title,
.voice-head,
.topbar,
.sheet-head,
.modal-head,
.sidebar-top {
  display: flex;
  align-items: center;
}

.brand-lockup {
  gap: 14px;
  margin-bottom: 28px;
}

.brand-lockup p,
.sheet-head p,
.modal-head p,
.plan-motto,
.legend p {
  margin-bottom: 4px;
  color: var(--muted);
  font-size: 0.86rem;
  font-weight: 650;
}

.brand-lockup h1 {
  margin-bottom: 0;
  font-size: 2.14rem;
  line-height: 2.66rem;
  font-weight: 650;
}

.brand-mark {
  display: grid;
  width: 44px;
  height: 44px;
  flex: 0 0 auto;
  place-items: center;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--line-strong) 70%, transparent);
  border-radius: var(--radius-md);
  background: #fff;
  box-shadow: var(--shadow-sm);
  padding: 0;
}

.brand-mark img {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: var(--radius-sm);
  object-fit: cover;
}

.compact {
  min-width: 0;
  gap: 10px;
}

.compact .brand-mark {
  width: 34px;
  height: 34px;
}

.compact strong {
  overflow: hidden;
  font-size: 1rem;
  font-weight: 650;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.auth-form,
.modal-fields,
.create-fields {
  display: grid;
  gap: 14px;
}

label span,
.field-caption {
  display: block;
  margin: 0 0 6px;
  color: var(--muted-strong);
  font-size: 0.8rem;
  font-weight: 600;
  line-height: 1.06rem;
}

input,
textarea,
select {
  width: 100%;
  min-width: 0;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-md);
  outline: 0;
  color: var(--text);
  background: var(--surface);
  -webkit-appearance: none;
  appearance: none;
}

input,
select {
  min-height: var(--density-button-height);
  padding: 0 12px;
}

select {
  cursor: pointer;
}

textarea {
  min-height: calc(var(--density-button-height) * 2.2);
  padding: var(--density-pad) 12px;
  resize: vertical;
}

input::placeholder,
textarea::placeholder {
  color: color-mix(in srgb, var(--muted) 72%, transparent);
}

[hidden] {
  display: none !important;
}

input:focus,
textarea:focus,
select:focus,
button:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

input:focus,
textarea:focus,
select:focus {
  border-color: var(--primary);
}

.button,
.logout-button,
.side-button,
.icon-button,
.round-control,
.text-link {
  min-height: var(--density-button-height);
  border-radius: var(--radius-md);
  transition:
    background 160ms cubic-bezier(0.2, 0.8, 0.2, 1),
    border-color 160ms cubic-bezier(0.2, 0.8, 0.2, 1),
    color 160ms cubic-bezier(0.2, 0.8, 0.2, 1),
    transform 120ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border: 1px solid transparent;
  padding: 0 14px;
  font-size: 0.94rem;
  font-weight: 650;
}

.button:hover,
.logout-button:hover,
.side-button:hover,
.icon-button:hover,
.round-control:hover,
.text-link:hover {
  transform: translateY(-1px);
}

button:disabled,
button[aria-busy="true"] {
  cursor: wait;
  opacity: 0.58;
  transform: none !important;
}

button[aria-busy="true"] {
  pointer-events: none;
}

.button.primary {
  color: #fff;
  background: linear-gradient(180deg, color-mix(in srgb, var(--primary) 92%, #fff), var(--primary-2));
  box-shadow: var(--shadow-sm), inset 0 1px 0 color-mix(in srgb, #fff 24%, transparent);
}

.button.primary:hover {
  background: linear-gradient(180deg, var(--primary), var(--primary-2));
}

.button.secondary {
  border-color: var(--line);
  color: var(--text);
  background: linear-gradient(180deg, var(--surface-raised), var(--surface));
  box-shadow: var(--shadow-sm);
}

.button.secondary:hover {
  background: var(--surface-muted);
}

.button.ghost {
  border-color: transparent;
  color: var(--muted-strong);
  background: transparent;
}

.button.ghost:hover {
  color: var(--text);
  background: var(--surface-muted);
}

.button.action-image-button {
  width: 46px;
  min-width: 46px;
  height: 46px;
  min-height: 46px;
  overflow: hidden;
  padding: 0;
  border-color: color-mix(in srgb, var(--line) 72%, var(--primary));
  background: color-mix(in srgb, var(--surface-raised) 88%, transparent);
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 10%, transparent);
  color: transparent;
  font-size: 0;
  line-height: 0;
}

.button.action-image-button::before {
  content: "";
  display: block;
  width: 36px;
  height: 36px;
  margin: auto;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  transform: translateX(var(--action-icon-shift-x, 0));
  transition:
    transform 160ms ease,
    filter 160ms ease,
    opacity 160ms ease;
  filter: brightness(1.45) contrast(1.08) drop-shadow(0 8px 14px rgba(0, 0, 0, 0.22));
}

.button.action-image-button:hover {
  border-color: color-mix(in srgb, var(--primary) 44%, var(--line));
  background: color-mix(in srgb, var(--primary-soft) 58%, var(--surface));
  transform: translateY(-1px);
}

.button.action-image-button:hover::before {
  transform: translateX(var(--action-icon-shift-x, 0)) scale(1.08);
  filter: brightness(1.7) contrast(1.12) drop-shadow(0 10px 18px rgba(76, 141, 255, 0.26));
}

.button.action-image-button:disabled {
  opacity: 0.55;
}

.button.back-image-button::before {
  --action-icon: var(--icon-back);
}

.button.save-image-button {
  width: 46px;
  min-width: 46px;
  height: 46px;
  min-height: 46px;
  border-color: color-mix(in srgb, var(--line) 72%, var(--primary));
  background: color-mix(in srgb, var(--surface-raised) 88%, transparent);
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 10%, transparent);
}

.button.save-image-button:hover,
.button.save-image-button:focus-visible {
  background: color-mix(in srgb, var(--primary-soft) 58%, var(--surface));
  filter: none;
}

.button.save-image-button::before {
  display: block;
  --action-icon: var(--icon-save);
}

.button.next-image-button::before {
  --action-icon: var(--icon-next);
}

.button.small {
  min-height: calc(var(--density-button-height) - 8px);
  padding: 0 10px;
  font-size: 0.86rem;
}

.button.full {
  width: 100%;
}

.auth-actions,
.modal-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.modal-actions {
  justify-content: flex-end;
}

.modal[data-action="birthday"] .modal-actions [data-close-entry] {
  display: none;
}

.modal[data-action="reminder"] .modal-actions [data-close-entry] {
  display: none;
}

.modal[data-action="schedule"] .modal-actions [data-close-entry] {
  display: none;
}

.modal[data-action="plan"] .modal-actions [data-close-entry] {
  display: none;
}

.modal[data-action="reminder"] .modal-panel,
.modal[data-action="birthday"][data-mode="create"] .modal-panel,
.modal[data-action="plan"] .modal-panel {
  align-content: start;
  grid-template-columns: minmax(0, 1fr) auto;
  padding: 18px;
}

.modal[data-action="reminder"] .modal-head,
.modal[data-action="reminder"] .modal-fields,
.modal[data-action="birthday"][data-mode="create"] .modal-head,
.modal[data-action="birthday"][data-mode="create"] .modal-fields,
.modal[data-action="plan"] .modal-head,
.modal[data-action="plan"] .modal-fields {
  grid-column: 1 / -1;
}

.modal[data-action="reminder"] .modal-head,
.modal[data-action="birthday"][data-mode="create"] .modal-head,
.modal[data-action="plan"] .modal-head {
  margin-bottom: 10px;
  padding-bottom: 10px;
}

.modal[data-action="reminder"] .modal-fields,
.modal[data-action="birthday"][data-mode="create"] .modal-fields,
.modal[data-action="birthday"][data-mode="create"] .create-fields,
.modal[data-action="plan"] .modal-fields {
  gap: 10px;
}

.modal[data-action="reminder"] .modal-actions,
.modal[data-action="birthday"][data-mode="create"] .modal-actions,
.modal[data-action="plan"] .modal-actions {
  align-self: start;
  grid-column: 2;
  margin-top: 12px;
  padding-top: 0;
}

.modal[data-action="reminder"] .voice-box,
.modal[data-action="birthday"][data-mode="create"] .voice-box,
.modal[data-action="plan"] .voice-box {
  grid-column: 1;
  margin-top: 10px;
}

.modal[data-action="reminder"] .voice-status,
.modal[data-action="reminder"] .form-error,
.modal[data-action="birthday"][data-mode="create"] .voice-status,
.modal[data-action="birthday"][data-mode="create"] .form-error,
.modal[data-action="plan"] .voice-status,
.modal[data-action="plan"] .form-error {
  grid-column: 1 / -1;
}

.modal[data-action="reminder"] .modal-actions .button,
.modal[data-action="birthday"][data-mode="create"] .modal-actions .button,
.modal[data-action="plan"] .modal-actions .button {
  min-height: 34px;
  padding-inline: 14px;
  font-size: 0.9rem;
}

.modal[data-action="reminder"] .modal-actions .button.action-image-button,
.modal[data-action="birthday"][data-mode="create"] .modal-actions .button.action-image-button,
.modal[data-action="plan"] .modal-actions .button.action-image-button,
.modal[data-action="schedule"] .wizard-actions .button.action-image-button {
  width: 46px;
  min-width: 46px;
  height: 46px;
  min-height: 46px;
  padding: 0;
  font-size: 0;
  line-height: 0;
}

.modal[data-action="reminder"] .modal-actions .button.save-image-button,
.modal[data-action="birthday"][data-mode="create"] .modal-actions .button.save-image-button,
.modal[data-action="plan"] .modal-actions .button.save-image-button,
.modal[data-action="schedule"] .wizard-actions .button.save-image-button {
  width: 46px;
  min-width: 46px;
  height: 46px;
  min-height: 46px;
}

.modal[data-action="birthday"][data-mode="create"] .managed-head {
  display: none;
}

.modal[data-action="schedule"][data-mode="create"] .modal-head {
  justify-content: space-between;
}

.modal[data-action="schedule"][data-mode="create"] .modal-head p {
  display: none;
}

.modal[data-action="schedule"][data-mode="create"] .managed-head {
  display: none;
}

.modal[data-action="birthday"][data-mode="list"] .modal-actions {
  display: none;
}

.form-error {
  min-height: 20px;
  margin: 0;
  color: var(--red);
  font-size: 0.94rem;
}

.voice-status {
  display: block;
  min-height: 18px;
  margin: 2px 0 0;
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.35;
}

.form-error:empty,
.voice-status:empty {
  display: none;
  min-height: 0;
}

.toast-region {
  position: fixed;
  right: max(18px, env(safe-area-inset-right));
  bottom: max(18px, env(safe-area-inset-bottom));
  z-index: 80;
  display: grid;
  justify-items: end;
  pointer-events: none;
}

.toast {
  max-width: min(360px, calc(100vw - 32px));
  border: 1px solid color-mix(in srgb, var(--green) 32%, var(--line));
  border-radius: var(--radius-md);
  color: var(--text);
  background: color-mix(in srgb, var(--green) 10%, var(--surface));
  box-shadow: var(--shadow-md);
  font-size: 0.94rem;
  font-weight: 650;
  line-height: 1.35;
  padding: 12px 14px;
}

.toast.error {
  border-color: color-mix(in srgb, var(--red) 36%, var(--line));
  background: color-mix(in srgb, var(--red) 10%, var(--surface));
}

.app-shell {
  display: grid;
  grid-template-columns: var(--sidebar) minmax(0, 1fr) 320px;
  min-height: 100vh;
}

.sidebar {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  height: 100vh;
  flex-direction: column;
  gap: 14px;
  border-right: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 88%, transparent);
  backdrop-filter: blur(18px);
  padding: 16px 12px;
}

.sidebar-top {
  justify-content: space-between;
  gap: 10px;
  min-height: 40px;
  padding: 0 4px;
}

.icon-button,
.round-control {
  display: inline-grid;
  width: 40px;
  height: 40px;
  flex: 0 0 auto;
  place-items: center;
  border: 1px solid var(--line);
  color: var(--muted-strong);
  background: linear-gradient(180deg, var(--surface-raised), var(--surface));
  box-shadow: var(--shadow-sm);
}

[data-tooltip] {
  position: relative;
}

[data-tooltip]::after {
  display: none !important;
}

.floating-tooltip {
  position: fixed;
  z-index: 1000;
  width: max-content;
  max-width: 240px;
  border: 1px solid color-mix(in srgb, var(--line) 82%, var(--primary));
  border-radius: var(--radius-sm);
  color: var(--text);
  background: color-mix(in srgb, var(--surface) 94%, transparent);
  box-shadow: var(--shadow-md), inset 0 1px 0 color-mix(in srgb, #fff 42%, transparent);
  font-family: var(--font);
  font-size: 0.82rem;
  font-weight: 650;
  line-height: 1.25;
  opacity: 0;
  padding: 8px 10px;
  pointer-events: none;
  text-align: center;
  transform: translate(-50%, 4px);
  transition: opacity 140ms ease, transform 140ms ease;
  white-space: nowrap;
}

.floating-tooltip.is-visible {
  opacity: 1;
  transform: translate(-50%, 0);
}

#sidebarToggle .icon.panel {
  width: 26px;
  height: 26px;
  background-image: url("/assets/icons/sidebar-toggle.svg");
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}

#sidebarToggle .icon.panel::before,
#sidebarToggle .icon.panel::after {
  display: none;
}

.round-control {
  border-radius: 50%;
}

.legend {
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--surface);
  box-shadow: var(--shadow-sm);
  padding: var(--density-pad);
}

.legend {
  display: grid;
  gap: var(--density-gap);
  margin: var(--density-section-gap) var(--density-panel-pad) 0;
}

.legend p {
  margin: 0;
}

#markerLegendItems {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 12px;
}

#markerLegendItems span {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--muted-strong);
  font-size: 0.86rem;
  font-weight: 550;
}

.side-actions {
  display: grid;
  gap: calc(var(--density-gap) - 6px);
  margin-top: 2px;
}

.settings-action {
  margin-top: var(--density-gap);
  border-top: 1px solid var(--line);
}

.side-button {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 12px;
  width: 100%;
  min-height: 44px;
  border: 1px solid transparent;
  color: var(--muted-strong);
  background: transparent;
  font-size: 0.94rem;
  font-weight: 600;
  padding: 0 10px;
  text-align: left;
  transition:
    background 160ms ease,
    border-color 160ms ease,
    color 160ms ease,
    transform 120ms ease,
    box-shadow 160ms ease;
}

.side-button:hover,
.side-button.active {
  border-color: color-mix(in srgb, var(--primary) 24%, var(--line));
  color: var(--text);
  background: linear-gradient(90deg, var(--primary-soft), var(--surface-muted));
  box-shadow: inset 3px 0 0 var(--primary), var(--shadow-xs);
}

.logout-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  width: 100%;
  margin-top: auto;
  border: 1px solid var(--line);
  color: var(--muted-strong);
  background: var(--surface);
  font-size: 0.94rem;
  font-weight: 650;
}

.logout-button::before {
  width: 22px;
  height: 22px;
  flex: 0 0 auto;
  background-image: url("/assets/icons/logout-action.svg");
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
}

.mobile-logout {
  display: none;
}

.logout-button:hover {
  color: var(--red);
  background: color-mix(in srgb, var(--red) 8%, var(--surface));
}

.main-surface {
  min-width: 0;
  border-right: 1px solid var(--line);
}

.topbar {
  position: sticky;
  top: 0;
  z-index: 12;
  justify-content: stretch;
  min-height: 56px;
  border-bottom: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg) 86%, transparent);
  backdrop-filter: blur(18px);
  padding: 0 24px;
}

.top-actions {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: var(--density-gap);
  width: 100%;
}

.current-date {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  color: var(--muted-strong);
  background: var(--surface);
  box-shadow: var(--shadow-sm);
  font-size: 0.94rem;
  font-weight: 600;
  padding: 0 12px;
}

.mobile-current-date {
  display: none;
}

.today-board {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--density-gap);
  padding: var(--density-panel-pad) var(--density-panel-pad) 0;
}

.info-panel,
.quote-ticker,
.day-summary,
.calendar-sheet,
.plan-panel,
.modal-panel {
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface-raised) 96%, var(--primary-soft)), var(--surface));
  box-shadow: var(--shadow-sm), inset 0 1px 0 color-mix(in srgb, #fff 38%, transparent);
}

.info-panel,
.quote-ticker,
.day-summary {
  position: relative;
  min-width: 0;
  padding: var(--density-pad);
  overflow: hidden;
}

.info-panel::before,
.quote-ticker::before,
.day-summary::before {
  position: absolute;
  top: 0;
  left: 12px;
  right: 12px;
  height: 3px;
  border-radius: 0 0 999px 999px;
  background: linear-gradient(90deg, var(--primary), color-mix(in srgb, var(--yellow) 80%, var(--primary)));
  content: "";
}

.compact-info {
  max-height: 174px;
  overflow: hidden;
}

.panel-title {
  gap: 9px;
  min-width: 0;
  margin-bottom: var(--density-gap);
}

.panel-title h2,
.panel-title h3 {
  margin: 0;
  color: var(--primary);
  font-size: 1.18rem;
  line-height: 1.32;
  font-weight: 700;
}

.panel-title .icon {
  color: var(--primary);
}

.info-list {
  display: grid;
  gap: var(--density-gap);
  margin: 0;
  padding: 0;
  list-style: none;
}

.scroll-list {
  max-height: 112px;
  overflow: auto;
  padding-right: 4px;
}

.info-list li {
  display: grid;
  gap: 2px;
  border-top: 1px solid var(--line);
  padding-top: var(--density-pad);
}

.info-list li:first-child {
  border-top: 0;
  padding-top: 0;
}

.info-list strong {
  font-size: 0.94rem;
  font-weight: 650;
  line-height: 20px;
}

.info-list small {
  color: var(--muted);
  font-size: 0.82rem;
}

.quote-ticker {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: var(--density-gap);
  min-height: 52px;
  overflow: hidden;
}

.topbar .quote-ticker {
  grid-column: auto;
  min-height: 36px;
  padding: 8px 12px;
}

.day-summary {
  grid-column: 1 / -1;
  display: grid;
  gap: var(--density-gap);
}

.summary-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--density-gap);
}

.summary-item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: start;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: linear-gradient(180deg, var(--surface-raised), var(--surface));
  box-shadow: var(--shadow-xs);
  padding: var(--density-pad);
}

.summary-item i {
  width: 9px;
  height: 9px;
  margin-top: 6px;
  border-radius: 50%;
  background: var(--summary-color, var(--primary));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--summary-color, var(--primary)) 16%, transparent);
}

.summary-item strong {
  display: block;
  color: var(--text);
  font-size: 0.94rem;
  font-weight: 650;
  line-height: 1.3;
}

.summary-item small {
  color: var(--muted);
  font-size: 0.82rem;
}

.quote-ticker strong {
  color: var(--primary);
  font-size: 0.96rem;
  font-weight: 750;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.ticker-window {
  overflow: hidden;
  min-width: 0;
}

.ticker-window p {
  display: flex;
  align-items: center;
  width: max-content;
  margin: 0;
  color: var(--muted-strong);
  font-size: 0.94rem;
  white-space: nowrap;
  animation: ticker 34s linear infinite;
  will-change: transform;
}

.ticker-window p span {
  flex: 0 0 auto;
  padding-right: 64px;
}

@keyframes ticker {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

.calendar-sheet {
  --calendar-month-image: none;
  --calendar-month-fallback-image: none;
  --calendar-season-image: none;
  --calendar-season-gradient: linear-gradient(135deg, #10100f, #24211d 48%, #3a342d);
  --calendar-season-accent: var(--primary);
  --calendar-season-overlay-top: rgba(18, 17, 15, 0.34);
  --calendar-season-overlay-bottom: rgba(12, 11, 10, 0.56);
  --calendar-season-vignette: radial-gradient(circle at 50% 26%, transparent 0 34%, rgba(5, 5, 5, 0.28) 72%, rgba(5, 5, 5, 0.54) 100%);
  --calendar-season-noise: repeating-radial-gradient(circle at 12% 18%, rgba(255, 255, 255, 0.018) 0 1px, transparent 1px 4px);
  position: relative;
  isolation: isolate;
  overflow: hidden;
  margin: var(--density-section-gap) var(--density-panel-pad) var(--density-panel-pad);
  padding: var(--density-panel-pad);
  border-color: rgba(255, 255, 255, 0.08);
  color: #f7f3ec;
  background: #12110f;
  box-shadow: var(--shadow-lg), inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.calendar-sheet::before,
.calendar-sheet::after {
  position: absolute;
  inset: 0;
  pointer-events: none;
  content: "";
}

.calendar-sheet::before {
  z-index: 0;
  background-image: var(--calendar-month-image), var(--calendar-month-fallback-image), var(--calendar-season-image), var(--calendar-season-gradient);
  background-position: center;
  background-size: cover;
  filter: saturate(1.12) contrast(1.03);
  transform: none;
}

.calendar-sheet::after {
  z-index: 1;
  background:
    radial-gradient(circle at 20% 10%, rgba(255, 255, 255, 0.08), transparent 24%),
    repeating-radial-gradient(circle at 12% 18%, rgba(255, 255, 255, 0.018) 0 1px, transparent 1px 4px),
    linear-gradient(180deg, rgba(18, 17, 15, 0.22), rgba(12, 11, 10, 0.38));
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.calendar-sheet > * {
  position: relative;
  z-index: 2;
}

.sheet-head {
  justify-content: space-between;
  gap: var(--density-section-gap);
  border-bottom: 1px solid rgba(255, 255, 255, 0.10);
  padding-bottom: var(--density-section-gap);
}

.sheet-head div {
  min-width: 0;
  text-align: center;
}

.sheet-head h2 {
  margin: 0;
  font-size: 1.62rem;
  line-height: 32px;
  font-weight: 650;
  color: color-mix(in srgb, #ffffff 88%, var(--calendar-season-accent, var(--primary)));
}

.calendar-sheet .sheet-head p,
.calendar-sheet .weekdays {
  color: rgba(255, 255, 255, 0.68);
}

.calendar-sheet .round-control {
  border-color: rgba(255, 255, 255, 0.10);
  color: rgba(255, 255, 255, 0.82);
  background: rgba(18, 17, 15, 0.28);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

.weekdays,
.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(42px, 1fr));
  gap: 8px;
}

.weekdays {
  margin-top: var(--density-section-gap);
  color: var(--muted-strong);
  font-size: 0.78rem;
  font-weight: 650;
  text-align: center;
  text-transform: uppercase;
}

.calendar-grid {
  margin-top: var(--density-gap);
}

.day-cell {
  position: relative;
  display: grid;
  min-height: clamp(52px, calc(7vw + var(--density-pad)), 96px);
  align-content: start;
  gap: calc(var(--density-gap) - 2px);
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: calc(var(--radius-md) + 2px);
  color: rgba(255, 255, 255, 0.92);
  background: rgba(18, 17, 15, 0.18);
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.16), inset 0 1px 0 rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
  padding: var(--density-pad);
  text-align: left;
  transition:
    border-color 160ms ease,
    background 160ms ease,
    box-shadow 160ms ease,
    transform 120ms ease;
}

.day-cell:hover {
  border-color: rgba(255, 255, 255, 0.28);
  background: rgba(255, 255, 255, 0.08);
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.24), inset 0 1px 0 rgba(255, 255, 255, 0.10);
  transform: translateY(-1px);
}

.day-cell.outside {
  color: rgba(255, 255, 255, 0.42);
  background: rgba(18, 17, 15, 0.10);
}

.day-cell.today {
  border-color: color-mix(in srgb, var(--calendar-season-accent, var(--primary)) 84%, #ffffff);
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--calendar-season-accent, var(--primary)) 26%, transparent), transparent 62%),
    rgba(18, 17, 15, 0.24);
  box-shadow:
    0 0 0 4px color-mix(in srgb, var(--calendar-season-accent, var(--primary)) 18%, transparent),
    0 14px 36px rgba(0, 0, 0, 0.25);
}

.day-cell.selected {
  border-color: var(--primary);
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--primary) 30%, transparent), transparent 62%),
    rgba(18, 17, 15, 0.30);
  box-shadow: inset 0 0 0 2px var(--primary), 0 18px 42px rgba(0, 0, 0, 0.32);
}

.day-cell.holiday {
  border-color: color-mix(in srgb, var(--red) 88%, #ffffff);
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--red) 58%, transparent),
    0 8px 24px color-mix(in srgb, var(--red) 18%, transparent),
    0 8px 22px rgba(0, 0, 0, 0.16);
}

.day-cell.holiday > span:last-child {
  color: color-mix(in srgb, var(--red) 82%, #ffffff);
}

.day-cell.holiday.selected {
  border-color: color-mix(in srgb, var(--red) 92%, #ffffff);
  box-shadow:
    inset 0 0 0 2px color-mix(in srgb, var(--red) 78%, #ffffff),
    0 0 0 4px color-mix(in srgb, var(--primary) 18%, transparent),
    0 18px 42px rgba(0, 0, 0, 0.32);
}

.day-cell > span:last-child {
  justify-self: end;
  font-size: 1rem;
  font-weight: 650;
}

.marker-row {
  display: flex;
  min-height: 10px;
  flex-wrap: wrap;
  gap: 4px;
}

.dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  flex: 0 0 auto;
  border-radius: 50%;
  background: currentColor;
  box-shadow: 0 0 0 2px rgba(13, 12, 11, 0.74);
}

.dot.blue { background: var(--reminder); }
.dot.red { background: var(--red); }
.dot.green { background: var(--green); }

.plan-panel {
  position: sticky;
  top: 0;
  display: flex;
  height: 100vh;
  flex-direction: column;
  gap: var(--density-gap);
  border-width: 0 0 0 1px;
  border-radius: 0;
  padding: var(--density-panel-pad);
}

.plan-motto {
  margin: -6px 0 2px;
  color: var(--muted-strong);
  font-size: 0.92rem;
  font-weight: 550;
  line-height: 1.42;
}

.plan-content {
  display: grid;
  gap: var(--density-gap);
  overflow: auto;
  padding-right: 2px;
}

.task-item,
.event-pill,
.plan-content > p,
.diary-entry {
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: linear-gradient(180deg, var(--surface), var(--surface-muted));
  box-shadow: var(--shadow-xs);
  line-height: 1.4;
  padding: var(--density-pad) calc(var(--density-pad) + 4px);
}

.task-item,
.managed-head,
.records-list {
  display: grid;
  gap: var(--density-gap);
}

.task-item {
  position: relative;
  grid-template-columns: minmax(0, 1fr);
  align-items: start;
  border-left: 3px solid color-mix(in srgb, var(--primary) 70%, var(--line));
  overflow: visible;
}

.task-item .item-actions {
  display: inline-flex;
  grid-column: 1;
  grid-row: 2;
  align-self: start;
  justify-self: end;
  gap: 4px;
}

.item-actions {
  display: inline-flex;
  align-items: center;
  justify-self: end;
  gap: 4px;
  overflow: visible;
}

.icon-action {
  position: relative;
  display: inline-grid;
  width: 32px;
  height: 32px;
  flex: 0 0 auto;
  place-items: center;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  color: var(--muted-strong);
  background-color: color-mix(in srgb, var(--surface) 78%, transparent);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 72% 72%;
  overflow: visible;
  transform-origin: center;
  transition:
    background-color 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease,
    transform 140ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

.text-action {
  display: inline-flex;
  min-height: 32px;
  align-items: center;
  justify-content: center;
  border: 1px solid color-mix(in srgb, var(--primary) 22%, var(--line));
  border-radius: var(--radius-sm);
  color: var(--primary);
  background: var(--primary-soft);
  font-size: 0.82rem;
  font-weight: 700;
  padding: 0 10px;
}

.text-action:hover {
  border-color: var(--primary);
  color: var(--primary-2);
  background: color-mix(in srgb, var(--primary-soft) 76%, var(--surface));
}

.icon-action:hover {
  border-color: color-mix(in srgb, var(--primary) 26%, var(--line));
  color: var(--text);
  background-color: var(--surface);
  box-shadow: var(--shadow-xs);
  transform: scale(1.08);
  z-index: 25;
}

.icon-action.delete {
  color: var(--red);
}

.icon-action.edit {
  --micro-icon: var(--icon-edit);
}

.icon-action.delete {
  --micro-icon: var(--icon-delete);
}

.icon-action.move {
  --micro-icon: var(--icon-move);
}

.icon-action::before {
  position: absolute;
  display: none !important;
  content: "";
}

.icon-action.edit::before {
  width: 14px;
  height: 3px;
  border-radius: 2px;
  background: currentColor;
  transform: rotate(-42deg);
}

.icon-action.delete::before {
  width: 13px;
  height: 13px;
  border: 2px solid currentColor;
  border-top: 0;
  border-radius: 0 0 3px 3px;
  transform: translateY(3px);
}

.task-item p,
.diary-entry p {
  margin: 0;
}

.empty-state {
  margin: 0;
  color: var(--muted);
  font-size: 0.94rem;
}

.schedule-wizard {
  display: grid;
  gap: 16px;
}

.schedule-wizard > h3 {
  margin: 0;
  color: var(--primary);
  font-size: 1.14rem;
}

.wizard-topline {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  color: var(--muted);
  font-size: 0.9rem;
  font-weight: 700;
}

.wizard-progress {
  height: 5px;
  overflow: hidden;
  border-radius: 999px;
  background: color-mix(in srgb, var(--line) 70%, transparent);
}

.wizard-progress i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--primary), var(--primary-2));
  transition: width 220ms ease;
}

.wizard-card {
  display: grid;
  gap: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: linear-gradient(180deg, var(--surface), var(--surface-muted));
  box-shadow: var(--shadow-xs);
  padding: 16px;
}

.wizard-card h3 {
  margin: 0;
  color: var(--primary);
  font-size: 1.06rem;
}

.section-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.wizard-subsection {
  display: grid;
  gap: 10px;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--surface-muted) 78%, transparent);
  padding: 12px;
}

.wizard-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}

.schedule-voice-slot {
  grid-column: 1;
  margin-top: 4px;
  margin-bottom: 2px;
}

.schedule-voice-slot .voice-box.compact-voice {
  margin-top: 0;
}

.schedule-voice-slot .voice-box.compact-voice #voiceButton {
  min-height: 34px;
  padding-inline: 10px;
}

.wizard-chip-row,
.wizard-tags,
.wizard-option-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.wizard-option-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.wizard-chip,
.wizard-tag,
.wizard-option {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface-muted);
  color: var(--text);
  font-weight: 700;
  padding: 8px 12px;
}

.wizard-option {
  min-height: 46px;
  border-radius: var(--radius-sm);
  text-align: left;
}

.wizard-option.selected,
.wizard-chip.selected,
.wizard-chip:hover {
  border-color: color-mix(in srgb, var(--primary) 42%, var(--line));
  color: var(--primary);
  background: var(--primary-soft);
}

.wizard-chip.muted {
  opacity: 0.48;
}

.wizard-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.wizard-tag button {
  width: 20px;
  height: 20px;
  border: 0;
  border-radius: 999px;
  color: var(--muted-strong);
  background: color-mix(in srgb, var(--line) 65%, transparent);
}

.wizard-add-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
}

.mentor-group-picker {
  display: grid;
  gap: 12px;
}

.mentor-group-picker-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.mentor-group-kind {
  min-width: 110px;
  justify-content: center;
  text-align: center;
}

.mentor-group-number-row,
.mentor-group-letter-row {
  padding-top: 2px;
}

.mentor-group-choice {
  min-width: 42px;
  justify-content: center;
}

.mentor-group-picker-add {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  border-top: 1px solid var(--line);
  padding-top: 12px;
}

.mentor-group-picker-add span {
  min-width: 120px;
  color: var(--text);
  font-weight: 800;
}

.selected-subjects {
  display: grid;
  gap: 8px;
  border-top: 1px solid var(--line);
  margin-top: 2px;
  padding-top: 12px;
}

.lesson-subject-picker {
  display: grid;
  gap: 8px;
}

.arts-day-subject-list {
  display: grid;
  gap: 8px;
}

.arts-day-subject-row {
  display: grid;
  grid-template-columns: minmax(160px, max-content) minmax(0, 1fr);
  gap: 10px;
  align-items: end;
}

.arts-day-subject {
  width: fit-content;
  justify-self: start;
}

.arts-time-popover {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  align-items: stretch;
  width: fit-content;
  max-width: 250px;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--surface-elevated) 90%, transparent);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(12px);
}

.time-picker {
  position: relative;
  display: grid;
  gap: 6px;
  width: fit-content;
}

.time-picker-trigger {
  width: 132px;
  min-height: 38px;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--surface) 82%, transparent);
  color: var(--text);
  font-size: 1rem;
  font-weight: 800;
}

.time-picker-panel {
  display: none;
  grid-template-columns: repeat(2, 64px);
  gap: 6px;
  width: fit-content;
  max-height: 192px;
  overflow: hidden;
  padding: 5px;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--surface-elevated) 94%, transparent);
  box-shadow: var(--shadow-soft);
}

.time-picker.is-open .time-picker-panel {
  display: grid;
}

.time-picker-column {
  display: grid;
  gap: 4px;
  max-height: 180px;
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-width: thin;
}

.time-picker-column button {
  min-height: 32px;
  border: 1px solid transparent;
  border-radius: 6px;
  background: transparent;
  color: var(--text);
  font-weight: 800;
}

.time-picker-column button:hover,
.time-picker-column button.selected {
  border-color: color-mix(in srgb, var(--primary) 52%, var(--line));
  background: color-mix(in srgb, var(--primary) 32%, transparent);
  color: var(--text);
}

.arts-time-popover .button {
  width: 100%;
  min-height: 38px;
  padding-inline: 14px;
}

.music-practice-builder,
.sport-day-builder {
  display: grid;
  gap: 16px;
}

.practice-day-list,
.sport-day-list {
  display: grid;
  gap: 8px;
}

.practice-day-row,
.sport-day-row {
  display: grid;
  grid-template-columns: minmax(92px, max-content) minmax(0, 1fr);
  gap: 10px;
  align-items: start;
}

.practice-day-button,
.sport-day-button {
  width: 92px;
  height: 50px;
  box-sizing: border-box;
  justify-content: center;
  border-radius: var(--radius-sm);
}

.practice-time-popover,
.sport-time-popover {
  max-width: 250px;
}

.practice-day-sessions,
.sport-day-sessions {
  grid-column: 2;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
}

.practice-day-session {
  padding: 7px 9px;
}

.sport-day-session {
  width: 118px;
  height: 50px;
  min-height: 50px;
  box-sizing: border-box;
  padding: 6px 8px 6px 10px;
}

.sport-day-session strong {
  overflow: visible;
  text-overflow: clip;
  font-size: 0.94rem;
}

.sport-day-session .item-actions {
  flex: 0 0 auto;
}

.sport-add-more {
  display: grid;
  width: 38px;
  height: 50px;
  box-sizing: border-box;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--surface-muted) 76%, transparent);
  color: var(--text);
  font-size: 1.35rem;
  font-weight: 800;
}

.sport-add-more:hover {
  border-color: color-mix(in srgb, var(--primary) 45%, var(--line));
  background: var(--primary-soft);
  color: var(--primary);
}

.wizard-weekdays {
  margin-top: 2px;
}

.wizard-lesson-list {
  display: grid;
  gap: 8px;
}

.wizard-lesson,
.school-preview-day,
.wizard-person-row {
  display: grid;
  gap: 4px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--surface);
  padding: 10px;
}

.wizard-lesson {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.school-day-lesson {
  min-height: 0;
  gap: 8px;
  padding: 8px 10px;
}

.school-day-lesson strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.wizard-lesson .schedule-form-grid {
  grid-column: 1 / -1;
}

.wizard-person-row {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
}

.wizard-lesson .item-actions {
  grid-row: span 2;
}

.school-day-lesson .item-actions {
  grid-row: auto;
}

.school-preview-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 10px;
}

.school-preview-day small {
  color: var(--muted-strong);
}

@media (max-width: 620px) {
  .arts-day-subject-row,
  .practice-day-row,
  .sport-day-row,
  .arts-time-popover {
    grid-template-columns: 1fr;
  }

  .arts-time-popover {
    max-width: none;
  }

  .practice-day-button,
  .sport-day-button {
    width: fit-content;
  }

  .practice-day-sessions,
  .sport-day-sessions {
    grid-column: 1;
  }
}

.schedule-type-head {
  display: grid;
  gap: 4px;
}

.schedule-type-head strong,
.schedule-preview strong,
.schedule-entry-head strong {
  color: var(--text);
}

.schedule-type-head span,
.schedule-type-card span,
.schedule-preview small,
.schedule-entry-head span {
  color: var(--muted);
  font-size: 0.88rem;
}

.schedule-type-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.schedule-type-card {
  display: grid;
  gap: 6px;
  min-height: 108px;
  align-content: start;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  color: var(--text);
  background: linear-gradient(180deg, var(--surface), var(--surface-muted));
  box-shadow: var(--shadow-xs);
  padding: 16px;
  text-align: left;
  transition: transform 160ms ease, border-color 160ms ease, box-shadow 160ms ease;
}

.schedule-type-card:hover,
.schedule-type-card:focus-visible {
  border-color: color-mix(in srgb, var(--primary) 42%, var(--line));
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
}

.schedule-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.schedule-form-grid .span-2 {
  grid-column: 1 / -1;
}

.schedule-color-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding-top: 6px;
}

.status-toggle {
  display: inline-flex;
  min-height: 44px;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface) 82%, transparent);
  color: var(--muted-strong);
  font-weight: 700;
  padding: 7px 9px 7px 12px;
}

.status-toggle input {
  position: absolute;
  width: 1px;
  min-height: 1px;
  margin: 0;
  padding: 0;
  border: 0;
  opacity: 0;
  appearance: none;
  -webkit-appearance: none;
  pointer-events: none;
}

.status-toggle i {
  position: relative;
  order: 2;
  width: 46px;
  height: 26px;
  flex: 0 0 auto;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  background: var(--surface-muted);
  box-shadow: inset 0 1px 2px rgba(28, 26, 24, 0.08);
  transition: 180ms ease;
}

.status-toggle i::before {
  position: absolute;
  top: 3px;
  left: 3px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--surface-raised);
  box-shadow: var(--shadow-sm);
  content: "";
  transition: 180ms ease;
}

.status-toggle input:checked + i {
  border-color: var(--primary);
  background: var(--primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 18%, transparent);
}

.status-toggle input:checked + i::before {
  transform: translateX(20px);
}

.status-toggle span {
  order: 1;
  color: inherit;
}

.schedule-preview {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  border: 1px solid color-mix(in srgb, var(--primary) 20%, var(--line));
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--primary-soft) 42%, var(--surface));
  padding: 14px;
}

.schedule-preview-dot {
  width: 12px;
  height: 12px;
  border-radius: 999px;
  margin-top: 5px;
  box-shadow: 0 0 0 4px color-mix(in srgb, currentColor 10%, transparent);
}

.schedule-preview div,
.schedule-entry {
  display: grid;
  gap: 6px;
}

.schedule-entry.is-paused {
  opacity: 0.72;
}

.schedule-entry[data-open-schedule] {
  cursor: pointer;
  transition: border-color 180ms ease, background 180ms ease, transform 180ms ease;
}

.schedule-entry[data-open-schedule]:hover,
.schedule-entry[data-open-schedule]:focus-visible {
  border-color: color-mix(in srgb, var(--primary) 42%, var(--line));
  background: color-mix(in srgb, var(--primary-soft) 18%, var(--surface));
  transform: translateY(-1px);
  outline: none;
}

.schedule-entry-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.schedule-entry-head > span {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface-muted);
  padding: 3px 8px;
}

.schedule-entry-toggle {
  min-height: 34px;
  flex: 0 0 auto;
  gap: 8px;
  border-radius: 999px;
  padding: 4px 6px 4px 10px;
}

.schedule-entry-toggle i {
  width: 38px;
  height: 22px;
}

.schedule-entry-toggle i::before {
  top: 2px;
  left: 2px;
  width: 16px;
  height: 16px;
}

.schedule-entry-toggle input:checked + i::before {
  transform: translateX(16px);
}

.schedule-entry-toggle span {
  font-size: 0.84rem;
}

.schedule-detail-view {
  display: grid;
  gap: 14px;
}

.schedule-detail-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.schedule-detail-edit {
  justify-self: end;
}

.schedule-detail-card {
  display: grid;
  gap: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface) 88%, transparent);
  padding: 14px;
}

.schedule-detail-heading {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  align-items: start;
}

.schedule-detail-heading strong {
  display: block;
  font-size: 1.05rem;
}

.schedule-detail-heading small,
.schedule-detail-lesson small {
  color: var(--muted-strong);
}

.schedule-days-detail {
  display: grid;
  gap: 10px;
}

.schedule-day-detail {
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--surface-muted);
  padding: 12px;
}

.schedule-day-detail h3 {
  margin: 0;
  color: var(--primary);
  font-size: 1rem;
}

.schedule-day-lessons {
  display: grid;
  gap: 7px;
}

.schedule-detail-lesson {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(150px, 0.8fr);
  gap: 12px;
  align-items: center;
  border: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  border-radius: var(--radius-sm);
  background: var(--surface);
  padding: 9px 10px;
}

.schedule-detail-lesson span,
.schedule-detail-lesson strong {
  min-width: 0;
}

.schedule-detail-lesson strong {
  color: var(--text);
  text-align: right;
}

.lessons-board {
  display: grid;
  gap: 10px;
}

.lesson-day {
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--surface-muted);
  overflow: clip;
}

.lesson-day summary {
  display: flex;
  cursor: pointer;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: var(--text);
  font-weight: 800;
  list-style: none;
  padding: 12px 14px;
}

.lesson-day summary::-webkit-details-marker {
  display: none;
}

.lesson-day summary small {
  color: var(--muted);
  font-weight: 700;
}

.lesson-list {
  display: grid;
  gap: 10px;
  padding: 0 12px 12px;
}

.lesson-row {
  display: grid;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--surface);
  padding: 12px;
}

.lesson-row-head,
.lesson-row-grid {
  display: grid;
  grid-template-columns: 84px minmax(0, 1fr);
  gap: 10px;
}

.lesson-row-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.lesson-actions {
  display: flex;
  justify-content: flex-end;
  gap: 4px;
}

.icon-action.up::after,
.icon-action.down::after {
  content: "";
  width: 10px;
  height: 10px;
  border-top: 2px solid currentColor;
  border-left: 2px solid currentColor;
}

.icon-action.move.up,
.icon-action.move.down {
  background-image: none;
}

.icon-action.up::after {
  transform: translateY(3px) rotate(45deg);
}

.icon-action.down::after {
  transform: translateY(-2px) rotate(225deg);
}

@media (max-width: 720px) {
  .schedule-type-grid,
  .schedule-form-grid,
  .lesson-row-grid {
    grid-template-columns: 1fr;
  }

  .lesson-row-head {
    grid-template-columns: 72px minmax(0, 1fr);
  }

  .schedule-entry-head {
    align-items: flex-start;
    flex-direction: column;
  }
}

.skeleton-card {
  display: grid;
  gap: 9px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--surface-muted);
  padding: var(--density-pad) calc(var(--density-pad) + 4px);
}

.skeleton-card.list {
  list-style: none;
}

.skeleton-card span {
  display: block;
  height: 11px;
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--line) 80%, transparent),
    color-mix(in srgb, var(--surface) 90%, transparent),
    color-mix(in srgb, var(--line) 80%, transparent)
  );
  background-size: 220% 100%;
  animation: skeleton-pulse 1.25s ease-in-out infinite;
}

.skeleton-card span:first-child {
  width: 72%;
}

.skeleton-card span:last-child {
  width: 44%;
}

@keyframes skeleton-pulse {
  from { background-position: 100% 0; }
  to { background-position: -100% 0; }
}

.modal {
  width: min(680px, calc(100vw - 32px));
  max-height: min(820px, calc(100vh - 32px));
  border: 0;
  background: transparent;
  overflow: visible;
  overflow-x: hidden;
  padding: 0;
}

.modal[data-action="schedule"] {
  width: min(620px, calc(100vw - 32px));
}

.modal.wide {
  width: min(1180px, calc(100vw - 32px));
}

.modal::backdrop {
  background: rgba(17, 16, 15, 0.42);
  backdrop-filter: blur(8px);
}

.modal-panel {
  display: grid;
  width: 100%;
  max-height: min(820px, calc(100vh - 32px));
  max-width: 100%;
  overflow-y: auto;
  overflow-x: hidden;
  padding: var(--density-panel-pad);
  box-shadow: var(--shadow-lg);
}

.modal[data-action="schedule"] .modal-panel {
  align-content: start;
  padding: 18px 18px 10px;
}

.modal[data-action="schedule"] .modal-actions {
  display: none;
}

.modal-panel > *,
.modal-fields,
.create-fields,
.modal-actions,
.voice-box {
  min-width: 0;
  max-width: 100%;
}

.modal-fields,
.create-fields {
  overflow-x: hidden;
}

.modal-head {
  justify-content: space-between;
  gap: var(--density-section-gap);
  border-bottom: 1px solid var(--line);
  margin-bottom: var(--density-section-gap);
  padding-bottom: var(--density-pad);
}

.modal-head h2 {
  margin: 0;
  font-size: 1.35rem;
  line-height: 28px;
  font-weight: 650;
}

.modal[data-action="schedule"] .modal-head {
  margin-bottom: 10px;
  padding-bottom: 10px;
}

.modal[data-action="schedule"] .modal-fields,
.modal[data-action="schedule"] .schedule-wizard {
  gap: 6px;
}

.modal[data-action="schedule"] #scheduleWizard {
  align-items: center;
  column-gap: 12px;
  grid-template-columns: minmax(0, 1fr) auto;
}

.modal[data-action="schedule"] #scheduleWizard .wizard-topline,
.modal[data-action="schedule"] #scheduleWizard .wizard-progress,
.modal[data-action="schedule"] #scheduleWizard .wizard-card {
  grid-column: 1 / -1;
}

.modal[data-action="schedule"] .wizard-card {
  gap: 10px;
  padding: 12px 14px;
}

.modal[data-action="schedule"] .schedule-form-grid {
  gap: 10px;
}

.modal[data-action="schedule"] .wizard-actions {
  align-self: center;
  grid-column: 2;
  margin-top: 8px;
}

.modal[data-action="schedule"] .schedule-picker-actions {
  grid-column: 1 / -1;
  justify-content: flex-end;
  align-self: auto;
  margin-top: 2px;
}

.modal[data-action="schedule"] input {
  min-height: 38px;
}

input[data-date-picker] {
  cursor: pointer;
  background:
    linear-gradient(180deg, var(--surface), var(--surface-muted));
  padding-right: 42px;
}

.date-popover {
  display: grid;
  grid-column: 1 / -1;
  gap: 12px;
  width: 100%;
  max-width: 380px;
  justify-self: start;
  border: 1px solid color-mix(in srgb, var(--line-strong) 86%, var(--primary));
  border-radius: 18px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface-raised) 94%, transparent), color-mix(in srgb, var(--surface) 98%, var(--primary-soft)));
  box-shadow: var(--shadow-lg), inset 0 1px 0 color-mix(in srgb, #fff 12%, transparent);
  backdrop-filter: blur(18px);
  padding: 14px;
}

.date-popover[hidden] {
  display: none;
}

.date-picker-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 112px;
  gap: 10px;
}

.date-picker-head label {
  min-width: 0;
}

.date-picker-head span {
  margin-bottom: 5px;
  color: color-mix(in srgb, var(--text) 78%, var(--primary));
  font-size: 0.74rem;
  font-weight: 800;
}

.date-picker-head select {
  min-height: 36px;
  border-color: color-mix(in srgb, var(--primary) 36%, var(--line-strong));
  border-radius: 12px;
  color: var(--text);
  background:
    linear-gradient(180deg, var(--surface), var(--surface-muted));
  font-size: 0.9rem;
  font-weight: 700;
}

.date-picker-head select option {
  color: #201c18;
  background: #fffaf1;
}

.date-picker-weekdays,
.date-picker-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 5px;
}

.date-picker-weekdays span {
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 800;
  text-align: center;
}

.date-picker-day {
  aspect-ratio: 1;
  min-height: 0;
  border: 1px solid transparent;
  border-radius: 11px;
  color: var(--text);
  background: color-mix(in srgb, var(--surface) 68%, transparent);
  font-size: 0.9rem;
  font-weight: 750;
  transition:
    transform 120ms ease,
    border-color 140ms ease,
    background 140ms ease,
    color 140ms ease;
}

.date-picker-day:hover,
.date-picker-day:focus-visible {
  border-color: color-mix(in srgb, var(--primary) 46%, var(--line));
  background: var(--primary-soft);
  color: var(--primary);
  transform: translateY(-1px);
}

.date-picker-day.muted {
  color: color-mix(in srgb, var(--muted) 62%, transparent);
}

.date-picker-day.today {
  border-color: color-mix(in srgb, var(--primary) 34%, var(--line));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--primary) 18%, transparent);
}

.date-picker-day.selected {
  border-color: var(--primary);
  color: #fff;
  background: linear-gradient(135deg, var(--primary), var(--primary-2));
  box-shadow: 0 8px 18px color-mix(in srgb, var(--primary) 28%, transparent);
}

.date-picker-actions {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  border-top: 1px solid var(--line);
  padding-top: 10px;
}

.date-picker-actions button {
  min-height: 34px;
  border: 0;
  border-radius: 10px;
  color: var(--primary);
  background: transparent;
  font-size: 0.88rem;
  font-weight: 800;
  padding: 0 10px;
}

.date-picker-actions button:hover,
.date-picker-actions button:focus-visible {
  background: var(--primary-soft);
}

.voice-box {
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--surface-muted);
  margin-top: 8px;
  padding: 8px 10px;
}

.voice-head {
  justify-content: space-between;
  gap: 10px;
}

.voice-head strong {
  font-size: 0.94rem;
  font-weight: 650;
}

.reminder-composer {
  display: grid;
  gap: 10px;
}

.smart-reminder-field {
  display: grid;
  gap: 8px;
}

.smart-reminder-field label {
  color: var(--text);
  font-size: 1.02rem;
  font-weight: 700;
}

.smart-reminder-input {
  position: relative;
}

.smart-reminder-input textarea {
  width: 100%;
  min-height: 82px;
  border-color: color-mix(in srgb, var(--primary) 22%, var(--line));
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface-raised) 92%, transparent), var(--surface));
  font-size: 1rem;
  padding-right: 14px;
  padding-bottom: 50px;
  resize: vertical;
}

.reminder-clear {
  position: absolute;
  top: auto;
  right: 10px;
  bottom: 10px;
  width: 34px;
  height: 34px;
  min-height: 34px;
  border: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  border-radius: var(--radius-sm);
  background-color: color-mix(in srgb, var(--surface-raised) 86%, transparent);
  color: var(--muted-strong);
  padding: 0;
}

.reminder-clear:hover {
  border-color: color-mix(in srgb, var(--primary) 42%, var(--line));
  color: var(--red);
}

.recognition-card {
  display: grid;
  gap: 8px;
  border: 1px solid color-mix(in srgb, var(--primary) 20%, var(--line));
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--primary-soft) 58%, var(--surface));
  padding: 12px;
}

.recognition-card.is-empty {
  display: none;
}

.recognition-card strong {
  color: var(--primary);
  font-size: 0.86rem;
  font-weight: 750;
  text-transform: uppercase;
}

.recognition-card dl {
  display: grid;
  gap: 6px;
  margin: 0;
}

.recognition-card div {
  display: grid;
  grid-template-columns: 74px minmax(0, 1fr);
  gap: 8px;
}

.recognition-card dt,
.recognition-card dd {
  margin: 0;
}

.recognition-card dt {
  color: var(--muted);
}

.recognition-card dd {
  color: var(--text);
  font-weight: 650;
}

.reminder-details {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  border-top: 1px solid var(--line);
  margin-top: 2px;
  padding-top: 10px;
}

.modal[data-action="reminder"] .voice-box {
  border: 0;
  background: transparent;
  margin-top: 8px;
  padding: 0;
}

.modal[data-action="reminder"] .voice-head {
  justify-content: flex-start;
}

.modal[data-action="reminder"] .voice-head strong,
.modal[data-action="reminder"] #voiceText,
.modal[data-action="reminder"] #parseVoiceButton {
  display: none;
}

.voice-box.compact-voice {
  border: 0;
  background: transparent;
  margin-top: 8px;
  padding: 0;
}

.voice-box.compact-voice .voice-head {
  justify-content: flex-start;
}

.voice-box.compact-voice .voice-head strong,
.voice-box.compact-voice #voiceText,
.voice-box.compact-voice #parseVoiceButton {
  display: none;
}

.modal[data-action="reminder"] #voiceButton {
  min-height: 38px;
  touch-action: none;
  user-select: none;
  border-color: transparent;
  background: transparent;
  color: var(--muted-strong);
  box-shadow: none;
  padding-inline: 14px;
  font-weight: 650;
  font-size: 0.94rem;
}

#voiceButton.primary {
  border-color: color-mix(in srgb, var(--primary) 48%, var(--line));
  color: var(--primary);
  background: color-mix(in srgb, var(--primary-soft) 72%, var(--surface));
}

.modal[data-action="reminder"] #voiceButton:hover {
  color: var(--text);
  background: var(--surface-muted);
}

.voice-box.compact-voice #voiceButton {
  min-height: 38px;
  touch-action: none;
  user-select: none;
  border-color: transparent;
  background: transparent;
  color: var(--muted-strong);
  box-shadow: none;
  padding-inline: 14px;
  font-weight: 650;
  font-size: 0.94rem;
}

.voice-box.compact-voice #voiceButton:hover {
  color: var(--text);
  background: var(--surface-muted);
}

.modal[data-action="reminder"] #voiceButton .icon,
.voice-box.compact-voice #voiceButton .icon {
  filter: none;
}

.modal[data-action="birthday"][data-mode="list"] .voice-box,
.modal[data-action="birthday"][data-mode="edit"] .voice-box {
  display: none !important;
}

.modal[data-action="birthday"][data-mode="create"] #recordsList,
.modal[data-action="birthday"][data-mode="edit"] #recordsList {
  display: none !important;
}

.modal[data-action="reminder"] .modal-head {
  margin-bottom: 10px;
  padding-bottom: 10px;
}

.modal[data-action="reminder"] .modal-fields {
  gap: 10px;
}

.modal[data-action="birthday"] #createFields {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(160px, 0.8fr);
  gap: 10px;
}

.checkbox-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(38px, 1fr));
  gap: 8px;
}

.weekday-chip {
  position: relative;
  display: grid;
  min-height: 40px;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--surface);
  color: var(--muted-strong);
  font-size: 0.94rem;
  font-weight: 650;
  user-select: none;
}

.weekday-chip input {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  opacity: 0;
  cursor: pointer;
}

.weekday-chip:has(input:checked) {
  border-color: var(--primary);
  color: #fff;
  background: var(--primary);
}

.color-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.color-choice {
  position: relative;
  display: grid;
  width: 38px;
  height: 38px;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 50%;
  background: var(--surface);
  padding: 0;
  cursor: pointer;
}

.color-choice input {
  position: absolute;
  inset: 0;
  margin: 0;
  opacity: 0;
  cursor: pointer;
}

.color-choice span {
  display: block;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--choice-color);
}

.color-choice:has(input:checked),
.color-choice.selected {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 20%, transparent);
}

.color-choice.used {
  opacity: 0.34;
  cursor: not-allowed;
}

.color-choice.used input {
  cursor: not-allowed;
}

.settings-grid {
  display: grid;
  gap: 16px;
}

.settings-group {
  display: grid;
  gap: 8px;
}

.settings-group.span-2 {
  grid-column: 1 / -1;
}

.settings-note {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.45;
}

.settings-note.warning {
  color: var(--muted-strong);
}

.model-status-card {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--panel) 78%, transparent);
}

.model-status-card > div:first-child {
  display: grid;
  gap: 3px;
}

.model-status-card strong {
  color: var(--text);
  font-size: 0.98rem;
}

.model-status-card span {
  color: var(--muted);
  font-size: 0.9rem;
}

.readiness-list {
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: 14px;
  background: color-mix(in srgb, var(--surface-2) 72%, transparent);
}

.readiness-list > strong {
  color: var(--primary);
}

.readiness-item {
  display: grid;
  grid-template-columns: 14px minmax(120px, 0.8fr) minmax(160px, 1fr);
  gap: 8px;
  align-items: center;
  color: var(--muted);
  font-size: 0.9rem;
}

.readiness-item i {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: var(--muted);
}

.readiness-item.is-ready i {
  background: #22c55e;
  box-shadow: 0 0 0 4px color-mix(in srgb, #22c55e 18%, transparent);
}

.readiness-item.is-missing i {
  background: #f59e0b;
  box-shadow: 0 0 0 4px color-mix(in srgb, #f59e0b 16%, transparent);
}

.readiness-item b {
  color: var(--text);
  font-weight: 700;
}

.readiness-item em {
  font-style: normal;
}

.model-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.segmented-options {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.segmented-options label {
  position: relative;
}

.segmented-options input {
  position: absolute;
  inset: 0;
  opacity: 0;
}

.segmented-options span {
  display: inline-flex;
  min-height: var(--density-button-height);
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--surface);
  color: var(--muted-strong);
  font-size: 0.94rem;
  font-weight: 600;
  padding: 0 12px;
}

.segmented-options input:checked + span {
  border-color: var(--primary);
  color: #fff;
  background: var(--primary);
}

.switch-row {
  display: flex;
  min-height: var(--density-button-height);
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--surface);
  color: var(--muted-strong);
  font-size: 0.94rem;
  font-weight: 650;
  padding: 6px 8px 6px 12px;
}

.switch-row span {
  display: inline-flex;
  margin: 0;
  color: inherit;
  font-size: inherit;
  line-height: 1.2;
}

.switch-row input {
  position: absolute;
  width: 1px;
  min-height: 1px;
  margin: 0;
  padding: 0;
  border: 0;
  opacity: 0;
  appearance: none;
  -webkit-appearance: none;
  pointer-events: none;
}

.switch-row i {
  position: relative;
  width: 46px;
  height: 26px;
  flex: 0 0 auto;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  background: var(--surface-muted);
  box-shadow: inset 0 1px 2px rgba(28, 26, 24, 0.08);
  transition: 180ms ease;
}

.switch-row i::before {
  position: absolute;
  top: 3px;
  left: 3px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--surface-raised);
  box-shadow: var(--shadow-sm);
  content: "";
  transition: 180ms ease;
}

.switch-row input:checked + i {
  border-color: var(--primary);
  background: var(--primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 18%, transparent);
}

.switch-row input:checked + i::before {
  transform: translateX(20px);
}

/* Focus Warm Glass OS: phase 1 component skin */
body {
  background:
    radial-gradient(circle at 8% -8%, color-mix(in srgb, var(--primary) 14%, transparent), transparent 32rem),
    radial-gradient(circle at 90% 4%, color-mix(in srgb, var(--yellow) 16%, transparent), transparent 30rem),
    radial-gradient(circle at 48% 112%, color-mix(in srgb, var(--ai) 10%, transparent), transparent 34rem),
    linear-gradient(180deg, color-mix(in srgb, var(--bg-soft) 50%, transparent), transparent 38rem),
    var(--bg);
}

.auth-panel,
.legend,
.current-date,
.info-panel,
.quote-ticker,
.day-summary,
.summary-item,
.calendar-sheet,
.plan-panel,
.modal-panel,
.wizard-card,
.wizard-subsection,
.wizard-lesson,
.wizard-person-row,
.school-preview-day,
.week-column,
.schedule-card,
.managed-card,
.diary-entry,
.note-entry,
.model-status-card,
.switch-row,
.skeleton-card {
  border-color: var(--glass-border);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 92%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  box-shadow: var(--focus-shadow), inset 0 1px 0 color-mix(in srgb, #fff 34%, transparent);
  backdrop-filter: blur(var(--focus-blur));
  -webkit-backdrop-filter: blur(var(--focus-blur));
}

.info-panel,
.quote-ticker,
.day-summary,
.legend,
.calendar-sheet,
.modal-panel,
.wizard-card,
.plan-panel {
  border-radius: var(--radius-lg);
}

.sidebar {
  border-right: 1px solid var(--glass-border);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--glass-elevated) 76%, transparent), color-mix(in srgb, var(--glass-surface) 92%, transparent));
  box-shadow: 12px 0 44px rgba(0, 0, 0, 0.06);
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
}

.topbar {
  border-bottom: 1px solid var(--glass-border);
  background: color-mix(in srgb, var(--bg) 54%, transparent);
  box-shadow: 0 10px 34px rgba(0, 0, 0, 0.04);
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
}

.main-surface {
  border-right: 1px solid var(--glass-border);
}

.side-button,
.logout-button,
.icon-button,
.round-control,
.button,
.weekday-chip,
.wizard-chip,
.wizard-tag,
.wizard-option,
.text-link,
.sport-add-more {
  transition:
    background var(--motion-standard),
    border-color var(--motion-standard),
    color var(--motion-standard),
    box-shadow var(--motion-standard),
    transform var(--motion-fast);
}

.side-button {
  border-radius: var(--radius-md);
}

.side-button:hover,
.side-button.active {
  border-color: color-mix(in srgb, var(--primary) 32%, var(--glass-border));
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--primary) 16%, transparent), color-mix(in srgb, var(--glass-elevated) 72%, transparent));
  box-shadow: inset 3px 0 0 var(--primary), var(--focus-glow);
  transform: translateX(2px);
}

.button.primary {
  color: #fff;
  background:
    linear-gradient(
      135deg,
      color-mix(in srgb, var(--primary) 92%, #ffffff),
      color-mix(in srgb, var(--primary) 78%, #29326d)
    );
  box-shadow: var(--focus-shadow), 0 0 24px color-mix(in srgb, var(--primary) 20%, transparent);
}

.button.primary:hover {
  background:
    linear-gradient(
      135deg,
      color-mix(in srgb, var(--primary) 98%, #ffffff),
      color-mix(in srgb, var(--primary) 84%, #29326d)
    );
  box-shadow: var(--focus-shadow-elevated), 0 0 30px color-mix(in srgb, var(--primary) 24%, transparent);
}

.button.secondary,
.button.ghost,
.logout-button,
.icon-button,
.round-control,
.text-link {
  border-color: var(--glass-border);
  background: color-mix(in srgb, var(--glass-surface) 86%, transparent);
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 24%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.button.secondary:hover,
.button.ghost:hover,
.logout-button:hover,
.icon-button:hover,
.round-control:hover,
.text-link:hover {
  border-color: color-mix(in srgb, var(--primary) 30%, var(--glass-border));
  background: color-mix(in srgb, var(--glass-elevated) 88%, var(--primary-soft));
  box-shadow: var(--focus-shadow), var(--focus-glow);
}

input,
textarea,
select {
  border-color: var(--glass-border-strong);
  background: color-mix(in srgb, var(--glass-surface) 84%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

input:focus,
textarea:focus,
select:focus {
  border-color: color-mix(in srgb, var(--primary) 50%, var(--glass-border-strong));
  box-shadow: var(--ring-soft), inset 0 1px 0 color-mix(in srgb, #fff 20%, transparent);
}

.info-panel::before,
.quote-ticker::before,
.day-summary::before {
  left: 20px;
  right: 20px;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--primary), color-mix(in srgb, var(--yellow) 70%, var(--primary)), transparent);
}

.calendar-sheet {
  border-color: rgba(255, 255, 255, 0.14);
  border-radius: var(--radius-xl);
  background: rgba(20, 20, 20, 0.16);
  box-shadow: var(--focus-shadow-elevated), inset 0 1px 0 rgba(255, 255, 255, 0.10);
}

.calendar-sheet::after {
  background:
    radial-gradient(circle at 20% 10%, rgba(255, 255, 255, 0.10), transparent 24%),
    repeating-radial-gradient(circle at 12% 18%, rgba(255, 255, 255, 0.018) 0 1px, transparent 1px 4px),
    linear-gradient(180deg, rgba(18, 17, 15, 0.24), rgba(12, 11, 10, 0.44));
}

.calendar-day {
  border-color: rgba(255, 255, 255, 0.16);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.10);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition:
    transform var(--motion-fast),
    border-color var(--motion-standard),
    background var(--motion-standard),
    box-shadow var(--motion-standard);
}

.calendar-day:hover {
  border-color: color-mix(in srgb, var(--calendar-season-accent, var(--primary)) 52%, rgba(255, 255, 255, 0.18));
  background: rgba(255, 255, 255, 0.16);
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.18), 0 0 22px color-mix(in srgb, var(--calendar-season-accent, var(--primary)) 22%, transparent);
  transform: translateY(-2px);
}

.calendar-day.today {
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--calendar-season-accent, var(--primary)) 64%, transparent), 0 0 28px color-mix(in srgb, var(--calendar-season-accent, var(--primary)) 34%, transparent);
}

.modal::backdrop {
  background: rgba(0, 0, 0, 0.28);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.modal-panel {
  border-color: var(--glass-border-strong);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 94%, transparent), color-mix(in srgb, var(--glass-surface) 98%, transparent));
  box-shadow: var(--focus-shadow-elevated);
  backdrop-filter: blur(var(--focus-blur-strong));
  -webkit-backdrop-filter: blur(var(--focus-blur-strong));
}

.modal-head {
  border-bottom-color: var(--glass-border);
}

.wizard-progress {
  background: color-mix(in srgb, var(--glass-border) 72%, transparent);
}

.wizard-progress i {
  background: linear-gradient(90deg, var(--primary), color-mix(in srgb, var(--primary) 62%, var(--yellow)));
  box-shadow: var(--focus-glow);
}

.wizard-option.selected,
.wizard-chip.selected,
.wizard-chip:hover,
.segmented-options input:checked + span,
.weekday-chip:has(input:checked) {
  border-color: color-mix(in srgb, var(--primary) 42%, var(--glass-border));
  color: var(--primary);
  background: color-mix(in srgb, var(--primary) 14%, var(--glass-surface));
  box-shadow: var(--focus-glow);
}

/* Focus Warm Glass OS: phase 2 calendar and shell polish */
.main-surface {
  background:
    radial-gradient(circle at 12% 8%, color-mix(in srgb, var(--primary) 8%, transparent), transparent 28rem),
    linear-gradient(180deg, color-mix(in srgb, var(--bg-soft) 42%, transparent), transparent 34rem);
}

.today-board {
  align-items: stretch;
}

.current-date,
.topbar .quote-ticker {
  border-color: var(--glass-border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--glass-elevated) 82%, transparent);
  box-shadow: var(--focus-shadow), inset 0 1px 0 color-mix(in srgb, #fff 28%, transparent);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.calendar-sheet::before {
  filter: blur(1.2px) saturate(1.08) contrast(1.02);
  transform: scale(1.018);
  transition: opacity var(--motion-smooth), filter var(--motion-smooth), transform var(--motion-smooth);
}

.day-cell {
  border-color: rgba(255, 255, 255, 0.16);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.12);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.18), inset 0 1px 0 rgba(255, 255, 255, 0.12);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition:
    transform var(--motion-fast),
    border-color var(--motion-standard),
    background var(--motion-standard),
    box-shadow var(--motion-standard);
}

.day-cell:hover {
  border-color: color-mix(in srgb, var(--calendar-season-accent, var(--primary)) 52%, rgba(255, 255, 255, 0.18));
  background: rgba(255, 255, 255, 0.18);
  box-shadow: 0 16px 38px rgba(0, 0, 0, 0.24), 0 0 24px color-mix(in srgb, var(--calendar-season-accent, var(--primary)) 22%, transparent);
  transform: translateY(-2px);
}

.day-cell.outside {
  background: rgba(255, 255, 255, 0.06);
}

.day-cell.today {
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--calendar-season-accent, var(--primary)) 68%, transparent),
    0 0 30px color-mix(in srgb, var(--calendar-season-accent, var(--primary)) 34%, transparent),
    0 16px 38px rgba(0, 0, 0, 0.24);
}

.day-cell.selected {
  border-color: color-mix(in srgb, var(--primary) 84%, #ffffff);
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--primary) 34%, transparent), transparent 64%),
    rgba(255, 255, 255, 0.16);
  box-shadow: inset 0 0 0 2px color-mix(in srgb, var(--primary) 88%, #ffffff), 0 18px 44px rgba(0, 0, 0, 0.30);
}

/* Focus Warm Glass OS: phase 3 modal system */
.modal {
  padding: clamp(10px, 2vw, 24px);
}

.modal::backdrop {
  background:
    radial-gradient(circle at 50% 20%, color-mix(in srgb, var(--primary) 10%, transparent), transparent 34rem),
    rgba(0, 0, 0, 0.28);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.modal-panel {
  border-radius: var(--radius-xl);
  border-color: var(--glass-border-strong);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 96%, transparent), color-mix(in srgb, var(--glass-surface) 98%, transparent)),
    radial-gradient(circle at 12% 0%, color-mix(in srgb, var(--primary) 8%, transparent), transparent 24rem);
  box-shadow: var(--focus-shadow-elevated), inset 0 1px 0 color-mix(in srgb, #fff 28%, transparent);
  backdrop-filter: blur(var(--focus-blur-strong));
  -webkit-backdrop-filter: blur(var(--focus-blur-strong));
}

.modal-head {
  border-bottom-color: var(--glass-border);
  margin-bottom: clamp(10px, 1.8vw, 18px);
  padding-bottom: clamp(10px, 1.5vw, 14px);
}

.modal-head h2 {
  font-weight: 650;
}

.modal-actions {
  align-items: center;
  margin-top: clamp(10px, 1.8vw, 18px);
  padding-top: 0;
}

.modal-fields,
.create-fields,
.schedule-wizard {
  gap: clamp(10px, 1.5vw, 14px);
}

.wizard-card {
  border-radius: var(--radius-lg);
  border-color: var(--glass-border);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 80%, transparent), color-mix(in srgb, var(--glass-surface) 94%, transparent));
  box-shadow: var(--focus-shadow), inset 0 1px 0 color-mix(in srgb, #fff 20%, transparent);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.wizard-subsection,
.wizard-lesson,
.wizard-person-row {
  border-color: var(--glass-border);
  background: color-mix(in srgb, var(--glass-surface) 84%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
}

.wizard-actions {
  align-items: center;
}

.date-popover,
.time-picker-panel {
  border-color: var(--glass-border-strong);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 92%, transparent), color-mix(in srgb, var(--glass-surface) 98%, transparent));
  box-shadow: var(--focus-shadow-elevated), inset 0 1px 0 color-mix(in srgb, #fff 22%, transparent);
  backdrop-filter: blur(var(--focus-blur));
  -webkit-backdrop-filter: blur(var(--focus-blur));
}

.date-picker-day,
.time-picker-column button {
  transition:
    color var(--motion-fast),
    background var(--motion-fast),
    border-color var(--motion-fast),
    transform var(--motion-fast);
}

.date-picker-day:hover,
.time-picker-column button:hover {
  box-shadow: var(--focus-glow);
}

.voice-box {
  border-color: color-mix(in srgb, var(--primary) 18%, var(--glass-border));
  background: color-mix(in srgb, var(--glass-surface) 76%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.modal[data-action="reminder"] .voice-box,
.voice-box.compact-voice {
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

/* Focus Warm Glass OS: phase 4 app shell */
.sidebar {
  border-right-color: var(--glass-border);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--glass-elevated) 72%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  box-shadow: 14px 0 48px rgba(0, 0, 0, 0.08), inset -1px 0 0 color-mix(in srgb, #fff 10%, transparent);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
}

.sidebar-top {
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--glass-surface) 76%, transparent);
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 24%, transparent);
  padding: 6px;
}

.side-actions {
  gap: 6px;
}

.side-button {
  border-radius: var(--radius-lg);
  border-color: transparent;
  color: var(--muted-strong);
  background: transparent;
  box-shadow: none;
  padding-inline: 10px;
}

.side-button .icon {
  border-radius: var(--radius-md);
  filter: drop-shadow(0 8px 16px rgba(0, 0, 0, 0.10));
}

.side-button:hover,
.side-button.active {
  border-color: color-mix(in srgb, var(--primary) 30%, var(--glass-border));
  color: var(--text);
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--primary) 14%, transparent), color-mix(in srgb, var(--glass-elevated) 70%, transparent));
  box-shadow: inset 3px 0 0 var(--primary), var(--focus-glow), inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
  transform: translateX(3px);
}

.logout-button {
  border-color: var(--glass-border);
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--glass-surface) 82%, transparent);
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 20%, transparent);
}

.logout-button:hover {
  border-color: color-mix(in srgb, var(--red) 28%, var(--glass-border));
  background: color-mix(in srgb, var(--red) 10%, var(--glass-elevated));
  box-shadow: var(--focus-shadow), 0 0 22px color-mix(in srgb, var(--red) 14%, transparent);
}

.plan-panel {
  border-left-color: var(--glass-border);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--glass-elevated) 78%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  box-shadow: -14px 0 48px rgba(0, 0, 0, 0.06), inset 1px 0 0 color-mix(in srgb, #fff 10%, transparent);
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
}

.plan-panel .panel-title h2 {
  color: var(--primary);
}

.task-item,
.event-pill,
.plan-content > p {
  border-color: var(--glass-border);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 78%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.task-item {
  border-left-color: color-mix(in srgb, var(--primary) 76%, var(--glass-border));
}

.task-item:hover,
.event-pill:hover {
  border-color: color-mix(in srgb, var(--primary) 24%, var(--glass-border));
  box-shadow: var(--focus-shadow), var(--focus-glow);
}

.app-shell.sidebar-collapsed .side-button {
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--glass-surface) 54%, transparent);
}

.app-shell.sidebar-collapsed .side-button:hover,
.app-shell.sidebar-collapsed .side-button.active {
  transform: translateY(-1px);
}

.week-view {
  display: grid;
  grid-template-columns: repeat(7, minmax(138px, 1fr));
  gap: 10px;
  overflow-x: auto;
  padding-bottom: 2px;
}

.week-column {
  display: grid;
  align-content: start;
  min-height: 340px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: linear-gradient(180deg, var(--surface-muted), color-mix(in srgb, var(--surface-muted) 84%, var(--primary-soft)));
  padding: 12px;
}

.week-column.selected {
  border-color: var(--primary);
  box-shadow: inset 0 0 0 1px var(--primary), var(--ring-soft);
}

.week-column h3 {
  margin: 0 0 12px;
  font-size: 0.94rem;
  line-height: 20px;
  font-weight: 650;
}

.week-items {
  display: grid;
  gap: 8px;
}

.event-pill {
  position: relative;
  display: grid;
  gap: 4px;
  background: linear-gradient(180deg, var(--surface-raised), var(--surface));
  padding-right: 44px;
  padding-bottom: 44px;
}

.event-pill .icon-action {
  position: absolute;
  right: 8px;
  bottom: 8px;
}

.event-pill strong {
  font-size: 0.94rem;
  font-weight: 650;
}

.event-pill small {
  color: var(--muted);
  font-size: 0.8rem;
}

.event-pill.reminder { border-left: 4px solid var(--reminder); }
.event-pill.birthday { border-left: 4px solid var(--red); }
.event-pill.schedule { border-left: 4px solid var(--event-color, var(--green)); }

.diary-entry {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  background: linear-gradient(180deg, var(--surface-raised), var(--surface));
}

.diary-entry > strong,
.diary-entry > p,
.diary-entry > small {
  grid-column: 1;
}

.diary-entry > .item-actions {
  grid-column: 2;
  grid-row: 1 / span 3;
  align-self: start;
}

.diary-entry > .icon-action {
  grid-column: 2;
  grid-row: 1 / span 3;
  align-self: end;
  justify-self: end;
}

.diary-entry small {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--muted);
}

.text-link {
  justify-self: start;
  min-height: calc(var(--density-button-height) - 8px);
  color: var(--primary);
  background: transparent;
  font-size: 0.94rem;
  font-weight: 650;
  padding: 0;
}

.text-link:hover {
  color: var(--primary-2);
  transform: none;
}

.icon {
  position: relative;
  display: inline-block;
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
  color: currentColor;
}

.icon::before,
.icon::after,
.chevron::before,
.x-icon::before,
.x-icon::after {
  position: absolute;
  content: "";
}

.icon.bell::before {
  inset: 3px 5px 4px;
  border: 2px solid currentColor;
  border-bottom: 0;
  border-radius: 9px 9px 3px 3px;
}

.icon.bell::after {
  left: 7px;
  bottom: 2px;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: currentColor;
}

.icon.cake::before {
  left: 3px;
  right: 3px;
  bottom: 3px;
  height: 9px;
  border: 2px solid currentColor;
  border-radius: 3px;
}

.icon.cake::after {
  left: 8px;
  top: 1px;
  width: 2px;
  height: 8px;
  background: currentColor;
}

.icon.repeat::before {
  inset: 4px 2px;
  border: 2px solid currentColor;
  border-left-color: transparent;
  border-radius: 50%;
}

.icon.repeat::after {
  top: 2px;
  right: 2px;
  border: 4px solid transparent;
  border-left-color: currentColor;
}

.icon.pen::before {
  left: 4px;
  top: 3px;
  width: 10px;
  height: 3px;
  border-radius: 2px;
  background: currentColor;
  transform: rotate(-42deg);
  transform-origin: left center;
}

.icon.mic {
  width: 22px;
  height: 22px;
  background: currentColor;
  -webkit-mask: var(--icon-mic) center / contain no-repeat;
  mask: var(--icon-mic) center / contain no-repeat;
}

.icon.mic::before,
.icon.mic::after {
  display: none;
}

.icon.spark::before {
  inset: 2px 8px;
  background: currentColor;
  transform: rotate(35deg);
}

.icon.spark::after {
  inset: 8px 2px;
  background: currentColor;
  transform: rotate(35deg);
}

.icon.flag::before {
  left: 4px;
  top: 3px;
  width: 2px;
  height: 13px;
  background: currentColor;
}

.icon.flag::after {
  left: 6px;
  top: 3px;
  width: 9px;
  height: 7px;
  border-radius: 2px;
  background: currentColor;
}

.icon.list::before {
  left: 4px;
  top: 4px;
  width: 11px;
  height: 2px;
  background: currentColor;
  box-shadow: 0 5px 0 currentColor, 0 10px 0 currentColor;
}

.icon.panel::before {
  inset: 3px;
  border: 2px solid currentColor;
  border-radius: 3px;
}

.icon.panel::after {
  left: 7px;
  top: 4px;
  bottom: 4px;
  width: 2px;
  background: currentColor;
}

.chevron {
  position: relative;
  display: inline-block;
  width: 16px;
  height: 16px;
}

.chevron::before {
  inset: 3px;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
}

.chevron.left::before {
  transform: rotate(-135deg);
}

.chevron.right::before {
  transform: rotate(45deg);
}

.x-icon {
  position: relative;
  display: inline-block;
  width: 16px;
  height: 16px;
}

.x-icon::before,
.x-icon::after {
  left: 7px;
  top: 2px;
  width: 2px;
  height: 12px;
  border-radius: 2px;
  background: currentColor;
}

.x-icon::before { transform: rotate(45deg); }
.x-icon::after { transform: rotate(-45deg); }

.app-shell.sidebar-collapsed {
  --sidebar: 64px;
}

.app-shell.sidebar-collapsed .sidebar {
  align-items: center;
  padding-inline: 10px;
}

.app-shell.sidebar-collapsed .brand strong,
.app-shell.sidebar-collapsed .side-button span:last-child {
  display: none;
}

.app-shell.sidebar-collapsed .sidebar-top {
  display: grid;
  justify-items: center;
  padding: 0;
}

.app-shell.sidebar-collapsed .side-button {
  justify-content: center;
  width: 44px;
  height: 44px;
  padding: 0;
}

.app-shell.sidebar-collapsed .desktop-logout {
  display: inline-flex;
  width: 44px;
  height: 44px;
  min-height: 44px;
  padding: 0;
  font-size: 0;
}

.app-shell.sidebar-collapsed .desktop-logout::before {
  width: 25px;
  height: 25px;
}

@media (max-width: 1180px) {
  .app-shell {
    grid-template-columns: var(--sidebar) minmax(0, 1fr);
  }

  .plan-panel {
    position: relative;
    grid-column: 2;
    height: auto;
    min-height: 280px;
    border-top: 1px solid var(--line);
    border-left: 0;
  }

  .week-view {
    grid-template-columns: 1fr;
    overflow-x: hidden;
  }

  .week-column {
    grid-template-columns: 132px minmax(0, 1fr);
    gap: 14px;
    min-height: 0;
    align-items: start;
  }

  .week-column h3 {
    position: sticky;
    top: 0;
    margin: 0;
    border-radius: var(--radius-sm);
    background: var(--surface);
    padding: 8px 10px;
  }

  .week-items {
    min-width: 0;
  }
}

@media (max-width: 880px) {
  .app-shell {
    display: flex;
    flex-direction: column;
    grid-template-columns: 1fr;
    padding-bottom: env(safe-area-inset-bottom);
  }

  .sidebar {
    position: relative;
    order: 1;
    min-height: auto;
    height: auto;
    border-right: 0;
    border-bottom: 1px solid var(--line);
    padding-top: max(14px, env(safe-area-inset-top));
    padding-bottom: max(14px, env(safe-area-inset-bottom));
  }

  .app-shell.sidebar-collapsed {
    --sidebar: 1fr;
  }

  .mobile-current-date {
    display: none;
  }

  .main-surface {
    display: contents;
  }

  .topbar {
    display: flex;
    order: 2;
    min-height: auto;
    padding: 12px 16px;
  }

  .top-actions {
    grid-template-columns: 1fr;
  }

  .today-board {
    order: 3;
  }

  .summary-list {
    grid-template-columns: 1fr;
  }

  .plan-panel {
    order: 4;
  }

  .legend {
    order: 5;
    margin: 16px 16px 0;
  }

  .calendar-sheet {
    order: 6;
  }

  .mobile-logout {
    display: block;
    order: 7;
    width: auto;
    margin: 0 16px max(18px, env(safe-area-inset-bottom));
  }

  .desktop-logout {
    display: none;
  }

  .app-shell.sidebar-collapsed .sidebar {
    min-height: auto;
    display: grid;
    grid-template-columns: 40px minmax(0, 1fr) 40px;
    align-items: center;
    column-gap: 8px;
    padding-inline: 12px;
    padding-block: max(10px, env(safe-area-inset-top)) 10px;
  }

  .app-shell.sidebar-collapsed .brand strong { display: none; }
  .app-shell.sidebar-collapsed .side-button span:last-child {
    display: none;
  }

  .app-shell.sidebar-collapsed .sidebar-top {
    display: contents;
  }

  .app-shell.sidebar-collapsed .brand {
    grid-column: 1;
    justify-self: start;
  }

  .app-shell.sidebar-collapsed .icon-button {
    grid-column: 3;
    order: 3;
    justify-self: end;
    width: 40px;
    height: 40px;
  }

  .app-shell.sidebar-collapsed .side-button {
    justify-content: center;
    width: 36px;
    height: 36px;
    padding: 0;
  }

  .side-actions {
    grid-template-columns: 1fr;
  }

.app-shell.sidebar-collapsed .side-actions {
    grid-column: 2;
    display: flex;
    justify-self: center;
    justify-content: center;
    gap: 4px;
    min-width: 0;
  }

  .app-shell.sidebar-collapsed .mobile-logout {
    display: block;
  }

  .today-board {
    grid-template-columns: 1fr;
    padding-inline: 16px;
  }

  .quote-ticker {
    grid-column: auto;
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .ticker-window {
    width: 100%;
  }

  .ticker-window p {
    animation-duration: 24s;
  }

  .ticker-window p span {
    padding-right: 44px;
  }

  .calendar-sheet {
    margin-inline: 16px;
  }

  .plan-panel {
    grid-column: auto;
    margin: 16px 16px 0;
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    padding-bottom: max(18px, env(safe-area-inset-bottom));
  }

  .modal {
    width: min(720px, calc(100vw - 20px));
    max-height: calc(100dvh - 20px);
  }

  .modal-panel {
    max-height: calc(100dvh - 20px);
    padding: 0;
  }

  .modal-head {
    position: sticky;
    top: 0;
    z-index: 2;
    background: color-mix(in srgb, var(--surface) 94%, transparent);
    backdrop-filter: blur(14px);
    margin: 0;
    padding: max(14px, env(safe-area-inset-top)) 16px 12px;
  }

  .modal-fields,
  .voice-box,
  .voice-status,
  .form-error {
    margin-inline: 16px;
  }

  .modal-fields {
    padding-top: 16px;
  }

  .modal-actions {
    position: sticky;
    bottom: 0;
    z-index: 2;
    border-top: 1px solid var(--line);
    background: color-mix(in srgb, var(--surface) 94%, transparent);
    backdrop-filter: blur(14px);
    margin: 16px 0 0;
    padding: 12px 16px max(12px, env(safe-area-inset-bottom));
  }

  .modal.wide .modal-panel {
    border-radius: var(--radius-xl);
  }

  input {
    min-height: 44px;
  }

  textarea {
    min-height: 96px;
  }

  input,
  textarea {
    font-size: 1rem;
  }
}

@media (max-width: 640px) {
  body {
    font-size: var(--app-font-size);
  }

  .modal[data-action="schedule"] #scheduleWizard {
    grid-template-columns: 1fr;
  }

  .modal[data-action="schedule"] .wizard-actions,
  .modal[data-action="schedule"] .schedule-voice-slot {
    grid-column: 1 / -1;
  }

  .modal[data-action="schedule"] .wizard-actions {
    justify-content: flex-end;
    margin-top: 8px;
  }

  .reminder-details {
    grid-template-columns: 1fr;
  }

  .modal[data-action="birthday"] #createFields {
    grid-template-columns: 1fr;
  }

  .topbar {
    padding-inline: 16px;
  }

  .current-date {
    width: 100%;
    justify-content: center;
  }

  .calendar-sheet {
    padding: var(--density-panel-pad);
  }

  .calendar-sheet::before {
    filter: saturate(1.08) contrast(1.02);
  }

  .calendar-sheet::after {
    background:
      radial-gradient(circle at 20% 10%, rgba(255, 255, 255, 0.08), transparent 24%),
      repeating-radial-gradient(circle at 12% 18%, rgba(255, 255, 255, 0.016) 0 1px, transparent 1px 4px),
      linear-gradient(180deg, rgba(18, 17, 15, 0.28), rgba(12, 11, 10, 0.46));
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

  .day-cell,
  .calendar-sheet .round-control {
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
  }

  .sheet-head {
    gap: var(--density-gap);
  }

  .sheet-head h2 {
    font-size: 1.35rem;
    line-height: 28px;
  }

  .weekdays,
  .calendar-grid {
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 5px;
  }

  .day-cell {
    min-height: 48px;
    padding: var(--density-pad);
  }

  .day-cell > span:last-child {
    font-size: 0.94rem;
  }

  .marker-row {
    gap: 3px;
  }

  .dot {
    width: 7px;
    height: 7px;
  }

  .checkbox-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .week-view {
    gap: 10px;
  }

  .week-column {
    grid-template-columns: 1fr;
    gap: 12px;
    min-height: 0;
    padding: 12px;
  }

  .week-column h3 {
    position: static;
    display: inline-flex;
    width: 100%;
    min-height: 40px;
    align-items: center;
    justify-content: space-between;
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    background: var(--surface);
    padding: 0 12px;
  }

  .week-column.selected h3 {
    border-color: var(--primary);
    color: var(--primary);
    background: var(--primary-soft);
  }

  .event-pill {
    padding: var(--density-pad);
    padding-right: calc(var(--density-pad) + 40px);
    padding-bottom: calc(var(--density-pad) + 40px);
  }

  .event-pill .icon-action {
    width: 34px;
    min-height: 34px;
    height: 34px;
  }

  .task-item {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .diary-entry {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .diary-entry > .item-actions {
    grid-column: 1;
    grid-row: auto;
    justify-self: stretch;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(78px, 1fr));
    gap: 8px;
  }

  .task-item .item-actions {
    grid-column: 1;
    grid-row: auto;
    justify-self: end;
    display: inline-flex;
    gap: 6px;
  }

  .diary-entry > .icon-action {
    grid-column: 1;
    grid-row: auto;
    justify-self: end;
  }

  .schedule-detail-lesson {
    grid-template-columns: 1fr;
  }

  .schedule-detail-lesson strong {
    text-align: left;
  }

  .text-action {
    min-height: 44px;
  }

  .icon-action {
    width: 100%;
    min-height: 44px;
    border-color: var(--line);
    background-color: var(--surface);
    background-size: 25px 25px;
  }

  .icon-action:hover {
    transform: none;
  }

  .event-pill .icon-action,
  .reminder-clear {
    width: 34px;
    min-height: 34px;
    height: 34px;
  }

  .auth-actions,
  .modal-actions {
    display: grid;
  }

  .button,
  .logout-button,
  .side-button {
    min-height: 44px;
  }

  .modal {
    width: 100vw;
    max-height: 100dvh;
  }

  .modal-panel {
    min-height: 100dvh;
    max-height: 100dvh;
    border-radius: 0;
    padding: 0;
  }

  .toast-region {
    right: 12px;
    bottom: max(12px, env(safe-area-inset-bottom));
    left: 12px;
    justify-items: stretch;
  }

  .toast {
    max-width: none;
  }
}

/* Focus Warm Glass OS: phase 5 responsive system */
@media (max-width: 1180px) {
  .main-surface {
    border-right: 0;
  }

  .plan-panel {
    margin: 0 var(--density-panel-pad) var(--density-panel-pad);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    background:
      linear-gradient(180deg, color-mix(in srgb, var(--glass-elevated) 78%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
    box-shadow: var(--focus-shadow), inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
  }
}

@media (max-width: 880px) {
  .sidebar {
    border-bottom-color: var(--glass-border);
    background:
      linear-gradient(135deg, color-mix(in srgb, var(--glass-elevated) 82%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
    box-shadow: 0 12px 36px rgba(0, 0, 0, 0.08);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
  }

  .topbar {
    padding: 12px;
  }

  .top-actions,
  .today-board,
  .summary-list {
    grid-template-columns: 1fr;
  }

  .today-board {
    gap: 12px;
    padding-inline: 12px;
  }

  .info-panel,
  .quote-ticker,
  .day-summary,
  .legend,
  .calendar-sheet,
  .plan-panel {
    border-radius: var(--radius-lg);
  }

  .calendar-sheet {
    margin: 12px;
    border-color: rgba(255, 255, 255, 0.14);
    border-radius: var(--radius-lg);
    padding: 14px;
  }

  .calendar-grid,
  .weekdays {
    gap: 6px;
  }

  .day-cell {
    min-height: clamp(48px, 10vw, 68px);
    border-radius: var(--radius-md);
    padding: 8px;
  }

  .plan-panel {
    margin: 12px;
    padding: 14px;
  }

  .modal {
    width: min(720px, calc(100vw - 16px));
    max-height: calc(100dvh - 16px);
  }

  .modal-panel {
    max-height: calc(100dvh - 16px);
    border-radius: var(--radius-lg);
    border-color: var(--glass-border-strong);
    background:
      linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 96%, transparent), color-mix(in srgb, var(--glass-surface) 98%, transparent));
    box-shadow: var(--focus-shadow-elevated);
  }
}

@media (max-width: 640px) {
  .app-shell {
    gap: 0;
  }

  .app-shell.sidebar-collapsed .side-button {
    width: 40px;
    height: 40px;
    min-height: 40px;
  }

  .app-shell.sidebar-collapsed .side-actions {
    overflow-x: auto;
    justify-content: flex-start;
    scrollbar-width: none;
  }

  .app-shell.sidebar-collapsed .side-actions::-webkit-scrollbar {
    display: none;
  }

  .info-panel,
  .day-summary,
  .legend,
  .plan-panel {
    padding: 14px;
  }

  .quote-ticker {
    grid-template-columns: 1fr;
    gap: 6px;
  }

  .calendar-sheet {
    margin: 10px;
    padding: 12px;
  }

  .sheet-head {
    gap: 8px;
  }

  .sheet-head h2 {
    font-size: 1.18rem;
    line-height: 1.45rem;
  }

  .calendar-grid,
  .weekdays {
    gap: 4px;
  }

  .day-cell {
    min-height: clamp(44px, 12vw, 58px);
    border-radius: 14px;
    padding: 6px;
  }

  .modal {
    width: min(100%, calc(100vw - 16px));
    max-height: calc(100dvh - 16px);
  }

  .modal-panel {
    min-height: auto;
    max-height: calc(100dvh - 16px);
    border-radius: var(--radius-lg);
  }

  .modal-head {
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  }
}

/* Focus Warm Glass OS: phase 6 settings screen */
.settings-grid {
  gap: 18px;
}

.settings-group {
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 84%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  box-shadow: var(--focus-shadow), inset 0 1px 0 color-mix(in srgb, #fff 22%, transparent);
  backdrop-filter: blur(var(--focus-blur));
  -webkit-backdrop-filter: blur(var(--focus-blur));
  padding: 14px;
}

.settings-group > .field-caption {
  margin-bottom: 10px;
  color: var(--primary);
  font-size: 0.86rem;
  letter-spacing: 0;
}

.theme-preview-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.theme-preview-card {
  position: relative;
  display: grid;
  min-height: 150px;
  gap: 12px;
  overflow: hidden;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 14% 0%, color-mix(in srgb, var(--primary) 12%, transparent), transparent 50%),
    color-mix(in srgb, var(--glass-surface) 78%, transparent);
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 22%, transparent);
  cursor: pointer;
  padding: 14px;
  transition:
    transform var(--motion-fast),
    border-color var(--motion-standard),
    box-shadow var(--motion-standard),
    background var(--motion-standard);
}

.theme-preview-card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--primary) 28%, var(--glass-border));
  box-shadow: var(--focus-shadow), var(--focus-glow);
}

.theme-preview-card input {
  position: absolute;
  inset: 0;
  min-height: 0;
  margin: 0;
  opacity: 0;
  cursor: pointer;
}

.theme-preview-card:has(input:checked) {
  border-color: color-mix(in srgb, var(--primary) 62%, var(--glass-border));
  box-shadow: var(--focus-shadow), var(--focus-glow), inset 0 1px 0 color-mix(in srgb, #fff 28%, transparent);
}

.theme-preview-head {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.theme-preview-head strong {
  color: var(--text);
  font-size: 0.94rem;
  font-weight: 650;
}

.theme-preview-head i {
  display: grid;
  width: 20px;
  height: 20px;
  flex: 0 0 auto;
  place-items: center;
  border: 1px solid var(--glass-border-strong);
  border-radius: 50%;
  background: color-mix(in srgb, var(--glass-elevated) 72%, transparent);
}

.theme-preview-head i::before {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: transparent;
  content: "";
}

.theme-preview-card:has(input:checked) .theme-preview-head i {
  border-color: var(--primary);
  background: color-mix(in srgb, var(--primary) 18%, transparent);
}

.theme-preview-card:has(input:checked) .theme-preview-head i::before {
  background: var(--primary);
}

.theme-preview-ui {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 6px;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--glass-elevated) 64%, transparent);
  padding: 8px;
}

.theme-preview-ui b,
.theme-preview-ui em {
  display: block;
  border-radius: 999px;
  background: color-mix(in srgb, var(--text) 14%, transparent);
}

.theme-preview-ui b {
  width: 58%;
  height: 9px;
}

.theme-preview-ui em {
  width: 100%;
  height: 7px;
}

.theme-preview-ui em:last-child {
  width: 72%;
}

.theme-palette {
  position: relative;
  z-index: 1;
  display: flex;
  gap: 6px;
}

.theme-palette span {
  width: 18px;
  height: 18px;
  border: 1px solid color-mix(in srgb, #fff 36%, transparent);
  border-radius: 50%;
  background: var(--swatch);
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 24%, transparent);
}

.theme-preview-card small {
  position: relative;
  z-index: 1;
  color: var(--muted-strong);
  font-size: 0.78rem;
  line-height: 1.25;
}

.theme-preview-card[data-theme-preview="contrast"] {
  background:
    radial-gradient(circle at 16% 0%, rgba(51, 102, 255, 0.12), transparent 50%),
    rgba(255, 255, 255, 0.66);
}

.theme-preview-card[data-theme-preview="warm"] {
  background:
    radial-gradient(circle at 16% 0%, rgba(216, 154, 61, 0.16), transparent 50%),
    rgba(255, 255, 255, 0.42);
}

.theme-preview-card[data-theme-preview="dark"] {
  background:
    radial-gradient(circle at 16% 0%, rgba(111, 140, 255, 0.20), transparent 50%),
    rgba(19, 23, 34, 0.68);
}

.theme-preview-card[data-theme-preview="dark"] .theme-preview-head strong,
.theme-preview-card[data-theme-preview="dark"] small {
  color: #f2f1ee;
}

.settings-grid .segmented-options {
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--glass-surface) 64%, transparent);
  padding: 4px;
}

.switch-row {
  border-color: var(--glass-border);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 84%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  box-shadow: var(--focus-shadow), inset 0 1px 0 color-mix(in srgb, #fff 20%, transparent);
  padding: 10px 12px;
}

.switch-row i {
  background: color-mix(in srgb, var(--glass-surface) 74%, transparent);
  transition:
    background var(--motion-standard),
    border-color var(--motion-standard),
    box-shadow var(--motion-standard);
}

@media (max-width: 880px) {
  .theme-preview-grid {
    grid-template-columns: 1fr;
  }

  .theme-preview-card {
    min-height: 128px;
  }
}

/* Focus Warm Glass OS: phase 7 controls and inputs */
.button,
.logout-button,
.icon-button,
.round-control,
.text-link {
  border-radius: var(--radius-lg);
  transition:
    background var(--motion-standard),
    border-color var(--motion-standard),
    color var(--motion-standard),
    box-shadow var(--motion-standard),
    transform var(--motion-fast),
    filter var(--motion-fast);
}

.button {
  min-height: var(--density-button-height);
  border-radius: var(--radius-lg);
  padding-inline: 16px;
}

.button.primary {
  border-color: color-mix(in srgb, var(--primary) 38%, transparent);
  background:
    linear-gradient(
      135deg,
      color-mix(in srgb, var(--primary) 96%, #ffffff),
      color-mix(in srgb, var(--primary) 78%, #29326d)
    );
  box-shadow:
    var(--focus-shadow),
    0 0 26px color-mix(in srgb, var(--primary) 22%, transparent),
    inset 0 1px 0 color-mix(in srgb, #fff 28%, transparent);
}

.button.primary:hover {
  filter: saturate(1.04);
  box-shadow:
    var(--focus-shadow-elevated),
    0 0 34px color-mix(in srgb, var(--primary) 28%, transparent),
    inset 0 1px 0 color-mix(in srgb, #fff 32%, transparent);
}

.button.secondary,
.button.ghost {
  border-color: var(--glass-border);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 76%, transparent), color-mix(in srgb, var(--glass-surface) 94%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 22%, transparent);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.button.ghost {
  color: var(--muted-strong);
}

.button.secondary:hover,
.button.ghost:hover {
  border-color: color-mix(in srgb, var(--primary) 30%, var(--glass-border));
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 84%, transparent), color-mix(in srgb, var(--primary-soft) 70%, transparent));
  box-shadow: var(--focus-shadow), var(--focus-glow);
}

input,
textarea,
select {
  border-color: var(--glass-border-strong);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 54%, transparent), color-mix(in srgb, var(--glass-surface) 92%, transparent));
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  transition:
    background var(--motion-standard),
    border-color var(--motion-standard),
    box-shadow var(--motion-standard);
}

input:focus,
textarea:focus,
select:focus {
  border-color: color-mix(in srgb, var(--primary) 54%, var(--glass-border-strong));
  box-shadow: var(--ring-soft), var(--focus-glow), inset 0 1px 0 color-mix(in srgb, #fff 22%, transparent);
}

.icon-action {
  border-color: var(--glass-border);
  border-radius: var(--radius-md);
  background-color: color-mix(in srgb, var(--glass-surface) 80%, transparent);
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition:
    background-color var(--motion-standard),
    border-color var(--motion-standard),
    box-shadow var(--motion-standard),
    transform var(--motion-fast);
}

.icon-action:hover {
  border-color: color-mix(in srgb, var(--primary) 34%, var(--glass-border));
  background-color: color-mix(in srgb, var(--glass-elevated) 84%, var(--primary-soft));
  box-shadow: var(--focus-shadow), var(--focus-glow);
  transform: translateY(-1px) scale(1.04);
}

.round-control,
.icon-button {
  border-color: var(--glass-border);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 76%, transparent), color-mix(in srgb, var(--glass-surface) 94%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 22%, transparent);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.round-control:hover,
.icon-button:hover {
  border-color: color-mix(in srgb, var(--primary) 34%, var(--glass-border));
  box-shadow: var(--focus-shadow), var(--focus-glow);
}

.text-link {
  border: 1px solid transparent;
  padding-inline: 10px;
}

.text-link:hover {
  border-color: color-mix(in srgb, var(--primary) 20%, transparent);
  background: color-mix(in srgb, var(--primary-soft) 42%, transparent);
}

/* Focus Warm Glass OS: phase 8 overview cards */
.info-panel,
.day-summary,
.legend {
  position: relative;
  overflow: hidden;
  border-color: var(--glass-border);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 10% 0%, color-mix(in srgb, var(--primary) 8%, transparent), transparent 20rem),
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 84%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  box-shadow: var(--focus-shadow), inset 0 1px 0 color-mix(in srgb, #fff 24%, transparent);
  backdrop-filter: blur(var(--focus-blur));
  -webkit-backdrop-filter: blur(var(--focus-blur));
}

.info-panel::before,
.day-summary::before {
  left: 20px;
  right: 20px;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--primary), color-mix(in srgb, var(--yellow) 72%, var(--primary)), transparent);
}

.panel-title {
  justify-content: space-between;
  gap: 12px;
}

.panel-title h2,
.panel-title h3 {
  color: var(--primary);
  font-size: clamp(1.12rem, 1.8vw, 1.32rem);
  font-weight: 650;
}

.info-list {
  gap: 8px;
}

.info-list li {
  border: 1px solid color-mix(in srgb, var(--glass-border) 70%, transparent);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--glass-surface) 58%, transparent);
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 14%, transparent);
  padding: 10px 12px;
}

.info-list li:first-child {
  border-top: 1px solid color-mix(in srgb, var(--glass-border) 70%, transparent);
  padding-top: 10px;
}

.info-list strong {
  color: var(--text);
}

.info-list small {
  color: var(--muted-strong);
}

.scroll-list {
  scrollbar-color: color-mix(in srgb, var(--primary) 42%, transparent) transparent;
  scrollbar-width: thin;
}

.scroll-list::-webkit-scrollbar {
  width: 7px;
}

.scroll-list::-webkit-scrollbar-track {
  background: transparent;
}

.scroll-list::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: color-mix(in srgb, var(--primary) 42%, transparent);
}

.summary-item {
  border-color: var(--glass-border);
  border-radius: var(--radius-md);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 72%, transparent), color-mix(in srgb, var(--glass-surface) 94%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.summary-item:hover {
  border-color: color-mix(in srgb, var(--primary) 24%, var(--glass-border));
  box-shadow: var(--focus-shadow), var(--focus-glow);
}

.legend {
  padding: 14px;
}

.legend p {
  color: var(--primary);
  font-weight: 650;
}

#markerLegendItems span {
  border: 1px solid var(--glass-border);
  border-radius: 999px;
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 70%, transparent), color-mix(in srgb, var(--glass-surface) 94%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  padding: 6px 10px;
}

/* Focus Warm Glass OS: phase 9 schedule wizard */
.wizard-card {
  border-color: var(--glass-border-strong);
  border-radius: var(--radius-xl);
  background:
    radial-gradient(circle at 8% 0%, color-mix(in srgb, var(--primary) 10%, transparent), transparent 20rem),
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 82%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  box-shadow: var(--focus-shadow), inset 0 1px 0 color-mix(in srgb, #fff 24%, transparent);
  backdrop-filter: blur(var(--focus-blur));
  -webkit-backdrop-filter: blur(var(--focus-blur));
}

.wizard-card h3 {
  color: var(--primary);
  font-weight: 650;
}

.wizard-option {
  border-color: var(--glass-border);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 70%, transparent), color-mix(in srgb, var(--glass-surface) 92%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.wizard-option:hover {
  border-color: color-mix(in srgb, var(--primary) 28%, var(--glass-border));
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 78%, transparent), color-mix(in srgb, var(--primary-soft) 60%, transparent));
  box-shadow: var(--focus-shadow), var(--focus-glow);
  transform: translateY(-1px);
}

.wizard-chip,
.wizard-tag {
  border-color: var(--glass-border);
  border-radius: 999px;
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 68%, transparent), color-mix(in srgb, var(--glass-surface) 94%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
}

.wizard-option.selected,
.wizard-chip.selected {
  border-color: color-mix(in srgb, var(--primary) 48%, var(--glass-border));
  color: var(--primary);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--primary-soft) 78%, transparent), color-mix(in srgb, var(--glass-surface) 94%, transparent));
  box-shadow: var(--focus-shadow), var(--focus-glow);
}

.wizard-tag button {
  border: 1px solid color-mix(in srgb, var(--glass-border) 70%, transparent);
  background: color-mix(in srgb, var(--glass-elevated) 72%, transparent);
}

.wizard-subsection,
.wizard-lesson,
.wizard-person-row,
.school-preview-day {
  border-color: var(--glass-border);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 64%, transparent), color-mix(in srgb, var(--glass-surface) 92%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.lesson-row {
  border-color: var(--glass-border);
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--glass-surface) 86%, transparent);
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 14%, transparent);
}

.arts-day-subject-row {
  border-radius: var(--radius-lg);
  padding: 10px;
}

.wizard-add-row {
  align-items: stretch;
}

/* Focus Warm Glass OS: phase 10 semantic labels and icons */
:root {
  --label-reminder: #5678f5;
  --label-birthday: #d96b5f;
  --label-schedule: #5f9073;
  --label-work: #d89a3d;
  --label-important: #c56a4b;
  --label-family: #c96a87;
  --label-creative: #8c7ae6;
  --label-sport: #47a7b8;
}

:root[data-theme="contrast"] {
  --label-reminder: #3366ff;
  --label-birthday: #c95f54;
  --label-schedule: #4f8567;
}

:root[data-theme="warm"] {
  --label-reminder: #5678f5;
  --label-birthday: #d96b5f;
  --label-schedule: #5f9073;
  --label-creative: #8c7ae6;
}

:root[data-theme="dark"] {
  --label-reminder: #6f8cff;
  --label-birthday: #e07a70;
  --label-schedule: #72b58f;
  --label-creative: #9b8cff;
}

.dot.blue {
  background: var(--label-reminder);
}

.dot.red {
  background: var(--label-birthday);
}

.dot.green {
  background: var(--label-schedule);
}

.marker-dot.reminder {
  background: var(--label-reminder);
}

.marker-dot.birthday {
  background: var(--label-birthday);
}

.marker-dot.schedule {
  background: var(--label-schedule);
}

.dot,
.marker-dot {
  box-shadow:
    0 0 0 1px color-mix(in srgb, #fff 24%, transparent),
    0 0 14px color-mix(in srgb, currentColor 18%, transparent);
}

#markerLegendItems span {
  border: 1px solid var(--glass-border);
  border-radius: 999px;
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 74%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

#markerLegendItems span:hover {
  border-color: color-mix(in srgb, var(--primary) 28%, var(--glass-border));
  box-shadow: var(--focus-shadow), var(--focus-glow);
  transform: translateY(-1px);
}

.icon-action {
  border-color: var(--glass-border);
  border-radius: var(--radius-md);
  background-color: color-mix(in srgb, var(--glass-surface) 82%, transparent);
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
  transition:
    background-color var(--motion-fast),
    border-color var(--motion-fast),
    box-shadow var(--motion-fast),
    filter var(--motion-fast),
    transform var(--motion-fast);
}

.icon-action:hover {
  border-color: color-mix(in srgb, var(--primary) 36%, var(--glass-border));
  background-color: color-mix(in srgb, var(--glass-elevated) 88%, var(--primary-soft));
  box-shadow: var(--focus-shadow), var(--focus-glow);
  filter: brightness(1.08) contrast(1.04);
  transform: translateY(-1px) scale(1.05);
}

.icon-action.delete:hover {
  border-color: color-mix(in srgb, var(--label-birthday) 40%, var(--glass-border));
  box-shadow: var(--focus-shadow), 0 0 20px color-mix(in srgb, var(--label-birthday) 20%, transparent);
}

/* Focus Warm Glass OS: phase 11 saved lists and detail cards */
.managed-card,
.schedule-entry,
.note-entry,
.diary-entry {
  border-color: var(--glass-border);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 10% 0%, color-mix(in srgb, var(--primary) 8%, transparent), transparent 16rem),
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 76%, transparent), color-mix(in srgb, var(--glass-surface) 98%, transparent));
  box-shadow: var(--focus-shadow), inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.managed-card:hover,
.note-entry:hover,
.diary-entry:hover {
  border-color: color-mix(in srgb, var(--primary) 24%, var(--glass-border));
  box-shadow: var(--focus-shadow), var(--focus-glow);
}

.schedule-entry[data-open-schedule]:hover,
.schedule-entry[data-open-schedule]:focus-visible {
  border-color: color-mix(in srgb, var(--primary) 42%, var(--glass-border));
  background:
    radial-gradient(circle at 12% 0%, color-mix(in srgb, var(--primary) 12%, transparent), transparent 18rem),
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 82%, transparent), color-mix(in srgb, var(--glass-surface) 98%, transparent));
  box-shadow: var(--focus-shadow), var(--focus-glow);
  transform: translateY(-2px);
}

.schedule-entry-head > span {
  border-color: var(--glass-border);
  background: color-mix(in srgb, var(--glass-surface) 82%, transparent);
  box-shadow: var(--shadow-xs);
}

.schedule-entry-toggle {
  border-color: var(--glass-border);
  background: color-mix(in srgb, var(--glass-surface) 82%, transparent);
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.event-pill {
  border-color: var(--glass-border);
  border-left: 4px solid var(--label-reminder);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 78%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.event-pill.reminder {
  border-left-color: var(--label-reminder);
}

.event-pill.birthday {
  border-left-color: var(--label-birthday);
}

.event-pill.schedule {
  border-left-color: var(--event-color, var(--label-schedule));
}

.schedule-detail-card,
.schedule-day-detail {
  border-color: var(--glass-border);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 72%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  box-shadow: var(--focus-shadow), inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.schedule-detail-lesson {
  border-color: var(--glass-border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--glass-surface) 78%, transparent);
}

/* Focus Warm Glass OS: phase 12 atmospheric calendar and topbar */
.top-actions {
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl);
  background:
    radial-gradient(circle at 10% 0%, color-mix(in srgb, var(--primary) 10%, transparent), transparent 18rem),
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 72%, transparent), color-mix(in srgb, var(--glass-surface) 94%, transparent));
  box-shadow: var(--focus-shadow), inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
  padding: 8px;
}

.current-date,
.topbar .quote-ticker {
  border-color: var(--glass-border);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 82%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  box-shadow: var(--focus-shadow), inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
}

.quote-ticker strong {
  color: var(--primary);
  letter-spacing: 0;
}

.ticker-window {
  mask-image: linear-gradient(90deg, transparent, #000 9%, #000 91%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 9%, #000 91%, transparent);
}

.ticker-window p {
  animation-timing-function: linear;
  will-change: transform;
}

.calendar-sheet::after {
  background:
    radial-gradient(circle at 20% 10%, rgba(255, 255, 255, 0.10), transparent 24%),
    repeating-radial-gradient(circle at 12% 18%, rgba(255, 255, 255, 0.018) 0 1px, transparent 1px 4px),
    linear-gradient(180deg, rgba(18, 17, 15, 0.30), rgba(12, 11, 10, 0.50));
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}

.calendar-day {
  background: rgba(255, 255, 255, 0.13);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.calendar-day.selected {
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--primary) 78%, #ffffff),
    0 0 0 4px color-mix(in srgb, var(--primary) 18%, transparent),
    var(--focus-glow),
    0 18px 42px rgba(0, 0, 0, 0.26);
}

/* Focus Warm Glass OS: phase 13 support states */
.empty-state {
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 68%, transparent), color-mix(in srgb, var(--glass-surface) 94%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  padding: 14px 16px;
}

.toast {
  border-color: color-mix(in srgb, var(--label-schedule) 34%, var(--glass-border));
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 10% 0%, color-mix(in srgb, var(--label-schedule) 12%, transparent), transparent 12rem),
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 88%, transparent), color-mix(in srgb, var(--glass-surface) 98%, transparent));
  box-shadow: var(--focus-shadow), var(--focus-glow), inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.toast.error {
  border-color: color-mix(in srgb, var(--label-birthday) 42%, var(--glass-border));
  background:
    radial-gradient(circle at 10% 0%, color-mix(in srgb, var(--label-birthday) 12%, transparent), transparent 12rem),
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 88%, transparent), color-mix(in srgb, var(--glass-surface) 98%, transparent));
}

.floating-tooltip {
  border-color: var(--glass-border);
  border-radius: 999px;
  background: color-mix(in srgb, var(--glass-elevated) 92%, transparent);
  box-shadow: var(--focus-shadow), var(--focus-glow);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.skeleton-card {
  border-color: var(--glass-border);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 74%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  box-shadow: var(--focus-shadow), inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.skeleton-card span {
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--glass-surface) 88%, transparent),
    var(--primary-soft),
    color-mix(in srgb, var(--glass-surface) 88%, transparent)
  );
  background-size: 220% 100%;
}

.voice-status:not(:empty),
.form-error:not(:empty) {
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--glass-surface) 82%, transparent);
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 14%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding: 8px 10px;
}

.form-error:not(:empty) {
  border-color: color-mix(in srgb, var(--label-birthday) 34%, var(--glass-border));
  color: var(--label-birthday);
}

/* Focus Warm Glass OS: phase 19 choice surfaces */
:where(.wizard-chip, .wizard-tag, .wizard-option, .weekday-chip, .schedule-type-card) {
  border-color: var(--glass-border);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 72%, transparent), color-mix(in srgb, var(--glass-surface) 94%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

:where(.wizard-chip, .wizard-option, .weekday-chip, .schedule-type-card):hover {
  border-color: color-mix(in srgb, var(--primary) 28%, var(--glass-border));
  transform: translateY(-1px);
  box-shadow: var(--focus-shadow), var(--focus-glow);
}

:where(.wizard-option.selected, .wizard-chip.selected, .weekday-chip:has(input:checked), .segmented-options input:checked + span) {
  border-color: color-mix(in srgb, var(--primary) 42%, var(--glass-border));
  color: var(--primary);
  background: color-mix(in srgb, var(--primary) 16%, var(--glass-surface));
  box-shadow: var(--focus-glow);
}

.color-choice {
  border-color: var(--glass-border);
  background: color-mix(in srgb, var(--glass-surface) 82%, transparent);
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.color-choice:has(input:checked),
.color-choice.selected {
  border-color: color-mix(in srgb, var(--primary) 58%, var(--glass-border));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 22%, transparent), var(--focus-glow);
}

@media (max-width: 640px) {
  .schedule-type-grid {
    grid-template-columns: 1fr;
  }
}

/* Focus Warm Glass OS: phase 18 scrollbars and overflow */
:where(.modal-panel, .modal-fields, .week-view, .scroll-list, .time-picker-column) {
  scrollbar-color: color-mix(in srgb, var(--primary) 38%, transparent) transparent;
  scrollbar-width: thin;
  overscroll-behavior: contain;
}

:where(.modal-panel, .modal-fields, .week-view, .scroll-list, .time-picker-column)::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

:where(.modal-panel, .modal-fields, .week-view, .scroll-list, .time-picker-column)::-webkit-scrollbar-track {
  border-radius: 999px;
  background: transparent;
}

:where(.modal-panel, .modal-fields, .week-view, .scroll-list, .time-picker-column)::-webkit-scrollbar-thumb {
  border: 2px solid transparent;
  border-radius: 999px;
  background: color-mix(in srgb, var(--primary) 34%, transparent);
  background-clip: padding-box;
}

:where(.modal-panel, .modal-fields, .week-view, .scroll-list, .time-picker-column)::-webkit-scrollbar-thumb:hover {
  background: color-mix(in srgb, var(--primary) 48%, transparent);
  background-clip: padding-box;
}

@media (max-width: 640px) {
  .modal-panel {
    scroll-padding-bottom: 96px;
  }
}

/* Focus Warm Glass OS: phase 17 picker surfaces */
.date-popover {
  border-color: var(--glass-border-strong);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 12% 0%, color-mix(in srgb, var(--primary) 10%, transparent), transparent 12rem),
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 92%, transparent), color-mix(in srgb, var(--glass-surface) 98%, transparent));
  box-shadow: var(--focus-shadow-elevated), inset 0 1px 0 color-mix(in srgb, #fff 20%, transparent);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
}

.date-picker-head select {
  border-color: color-mix(in srgb, var(--primary) 30%, var(--glass-border));
  border-radius: var(--radius-md);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 72%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
}

.date-picker-day.today {
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--primary) 20%, transparent),
    var(--focus-glow);
}

.date-picker-day.selected {
  box-shadow:
    0 10px 22px color-mix(in srgb, var(--primary) 26%, transparent),
    var(--focus-glow);
}

.time-picker-panel {
  border-color: var(--glass-border-strong);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 50% 0%, color-mix(in srgb, var(--primary) 9%, transparent), transparent 9rem),
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 92%, transparent), color-mix(in srgb, var(--glass-surface) 98%, transparent));
  box-shadow: var(--focus-shadow), inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
}

.time-picker-column {
  scrollbar-color: color-mix(in srgb, var(--primary) 44%, transparent) transparent;
}

.time-picker-column button.selected {
  border-color: color-mix(in srgb, var(--primary) 54%, var(--glass-border));
  background: color-mix(in srgb, var(--primary) 28%, transparent);
  box-shadow: var(--focus-glow);
}

@media (max-width: 640px) {
  .date-popover {
    max-width: 100%;
    border-radius: var(--radius-lg);
  }
}

/* Focus Warm Glass OS: phase 16 auth welcome screen */
.auth-screen {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background:
    radial-gradient(circle at 12% 8%, color-mix(in srgb, var(--primary) 16%, transparent), transparent 24rem),
    radial-gradient(circle at 88% 12%, color-mix(in srgb, var(--yellow) 18%, transparent), transparent 28rem),
    radial-gradient(circle at 50% 110%, color-mix(in srgb, var(--ai) 10%, transparent), transparent 34rem),
    linear-gradient(145deg, color-mix(in srgb, var(--bg-soft) 82%, transparent), var(--bg));
}

.auth-screen::before {
  content: "";
  position: absolute;
  inset: -8%;
  z-index: -1;
  background:
    radial-gradient(circle at 24% 28%, color-mix(in srgb, #fff 18%, transparent), transparent 18rem),
    repeating-radial-gradient(circle at 20% 18%, color-mix(in srgb, var(--text) 4%, transparent) 0 1px, transparent 1px 5px);
  opacity: .72;
  filter: saturate(1.06);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  pointer-events: none;
}

.auth-panel {
  position: relative;
  overflow: hidden;
  border-color: var(--glass-border-strong);
  border-radius: var(--radius-xl);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 88%, transparent), color-mix(in srgb, var(--glass-surface) 98%, transparent));
  box-shadow: var(--focus-shadow-elevated), inset 0 1px 0 color-mix(in srgb, #fff 24%, transparent);
  backdrop-filter: blur(28px);
  -webkit-backdrop-filter: blur(28px);
}

.auth-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: radial-gradient(circle at 20% 0%, color-mix(in srgb, var(--primary) 14%, transparent), transparent 16rem);
  opacity: .9;
  pointer-events: none;
}

.brand-lockup {
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--glass-surface) 72%, transparent);
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
  padding: 10px;
}

@media (max-width: 640px) {
  .auth-screen {
    align-items: start;
    padding: max(14px, env(safe-area-inset-top)) 12px max(14px, env(safe-area-inset-bottom));
  }

  .auth-panel {
    border-radius: var(--radius-lg);
    padding: 20px;
  }

  .auth-actions {
    grid-template-columns: 1fr;
  }
}

/* Focus Warm Glass OS: phase 15 motion and focus polish */
:where(button, input, textarea, select, a, [tabindex]):focus-visible {
  outline: 0;
  box-shadow: var(--ring-soft), var(--focus-glow);
}

:where(.button, .logout-button, .side-button, .icon-button, .round-control, .text-link):active {
  transform: translateY(0) scale(.98);
  transition-duration: 90ms;
}

:where(button, .button):disabled,
:where(button, .button)[aria-busy="true"] {
  filter: saturate(.78);
  box-shadow: none;
}

.calendar-day:focus-visible,
.schedule-type-card:focus-visible,
.schedule-entry[data-open-schedule]:focus-visible {
  outline: 0;
  box-shadow: var(--ring-soft), var(--focus-glow);
}

@media (hover: none) {
  :where(.button, .logout-button, .side-button, .icon-button, .round-control, .text-link):hover {
    transform: none;
  }
}

/* Focus Warm Glass OS: phase 14 mobile touch polish */
@media (max-width: 880px) {
  .app-shell.sidebar-collapsed .side-actions {
    max-width: calc(100vw - 120px);
    overflow-x: auto;
    border: 1px solid var(--glass-border);
    border-radius: 999px;
    background:
      linear-gradient(135deg, color-mix(in srgb, var(--glass-elevated) 84%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
    box-shadow: var(--focus-shadow), inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    padding: 5px;
    scrollbar-width: none;
  }

  .app-shell.sidebar-collapsed .side-actions::-webkit-scrollbar {
    display: none;
  }

  .app-shell.sidebar-collapsed .side-button {
    flex: 0 0 40px;
    border: 1px solid transparent;
    border-radius: 999px;
    background: color-mix(in srgb, var(--glass-surface) 72%, transparent);
    box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 12%, transparent);
    transition:
      transform var(--motion-fast),
      background var(--motion-standard),
      border-color var(--motion-standard),
      box-shadow var(--motion-standard);
  }

  .app-shell.sidebar-collapsed .side-button:hover,
  .app-shell.sidebar-collapsed .side-button.active {
    border-color: color-mix(in srgb, var(--primary) 28%, var(--glass-border));
    background: color-mix(in srgb, var(--primary-soft) 74%, var(--glass-surface));
    box-shadow: var(--focus-glow), inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
    transform: translateY(-1px);
  }

  .mobile-logout {
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    background:
      linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 82%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
    box-shadow: var(--focus-shadow), inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
  }
}

@media (max-width: 640px) {
  .topbar {
    position: sticky;
    top: 0;
    z-index: 4;
    background: color-mix(in srgb, var(--bg) 72%, transparent);
    box-shadow: 0 10px 28px color-mix(in srgb, var(--text) 7%, transparent);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
  }

  .modal-panel {
    background:
      radial-gradient(circle at 14% 0%, color-mix(in srgb, var(--primary) 9%, transparent), transparent 18rem),
      linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 96%, transparent), color-mix(in srgb, var(--glass-surface) 98%, transparent));
    box-shadow: var(--focus-shadow-elevated);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
  }

  .modal-actions {
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    background:
      linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 88%, transparent), color-mix(in srgb, var(--glass-surface) 98%, transparent));
    box-shadow: var(--focus-shadow), inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    margin: 12px;
  }
}

.side-button .icon {
  display: inline-block;
  width: 30px;
  height: 30px;
  flex: 0 0 30px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: 28px 28px;
}

.side-button .icon::before,
.side-button .icon::after {
  display: none;
}

.side-button .icon.bell {
  --side-icon: var(--icon-reminder);
}

.side-button .icon.cake {
  --side-icon: var(--icon-birthday);
}

.side-button .icon.repeat {
  --side-icon: var(--icon-schedule);
}

.side-button .icon.pen {
  --side-icon: var(--icon-diary);
}

.side-button .icon.note {
  --side-icon: var(--icon-note);
}

.side-button .icon.settings {
  --side-icon: var(--icon-settings);
}

/* Focus Warm Glass OS: phase 20 form fields */
:where(input, textarea, select) {
  border-color: var(--glass-border);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 58%, transparent), color-mix(in srgb, var(--glass-surface) 94%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 14%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition:
    border-color var(--motion-standard),
    background var(--motion-standard),
    box-shadow var(--motion-standard),
    color var(--motion-fast);
}

:where(input, textarea, select)::placeholder {
  color: color-mix(in srgb, var(--muted) 68%, transparent);
}

:where(input, textarea, select):focus {
  border-color: color-mix(in srgb, var(--primary) 48%, var(--glass-border));
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 72%, transparent), color-mix(in srgb, var(--glass-surface) 98%, transparent));
  box-shadow: var(--ring-soft), inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
}

input[data-date-picker] {
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 62%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  padding-right: 44px;
}

.schedule-form-grid label,
.modal-fields label {
  min-width: 0;
}

@media (max-width: 640px) {
  :where(input, textarea, select) {
    font-size: 1rem;
    min-height: 44px;
  }
}

/* Focus Warm Glass OS: phase 21 card rhythm */
:where(.info-panel, .quote-ticker, .day-summary, .plan-panel, .summary-item, .task-item, .event-pill, .diary-entry) {
  border-color: var(--glass-border);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 62%, transparent), color-mix(in srgb, var(--glass-surface) 94%, transparent));
  box-shadow: var(--focus-shadow), inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.panel-title {
  align-items: flex-start;
  gap: clamp(8px, 1vw, 12px);
}

.panel-title h2,
.panel-title h3 {
  font-weight: 650;
  letter-spacing: 0;
}

.today-board {
  gap: clamp(12px, 1.8vw, var(--density-section-gap));
}

.plan-content :where(.task-item, .event-pill, .diary-entry) {
  transition:
    border-color var(--motion-standard),
    background var(--motion-standard),
    box-shadow var(--motion-standard),
    transform var(--motion-fast);
}

.summary-item:hover,
.task-item:hover,
.event-pill:hover,
.diary-entry:hover {
  border-color: color-mix(in srgb, var(--primary) 22%, var(--glass-border));
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 74%, transparent), color-mix(in srgb, var(--glass-surface) 98%, transparent));
  box-shadow: var(--focus-shadow), var(--focus-glow), inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
  transform: translateY(-1px);
}

@media (max-width: 880px) {
  .today-board {
    gap: 12px;
    padding-inline: max(12px, var(--density-panel-pad));
  }
}

/* Focus Warm Glass OS: phase 22 action docks */
:where(.modal-actions, .wizard-actions, .schedule-picker-actions) {
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
}

:where(.modal-actions, .wizard-actions):not(:empty) {
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 52%, transparent), color-mix(in srgb, var(--glass-surface) 90%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 14%, transparent);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  padding: 6px;
}

.modal[data-action="schedule"] .wizard-actions {
  padding: 6px;
  width: max-content;
}

:where(.back-image-button, .next-image-button, .save-image-button) {
  border: 1px solid color-mix(in srgb, var(--primary) 26%, var(--glass-border));
  border-color: color-mix(in srgb, var(--primary) 26%, var(--glass-border));
  background-color: color-mix(in srgb, var(--glass-surface) 78%, transparent);
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
}

:where(.back-image-button, .next-image-button, .save-image-button):hover {
  border-color: color-mix(in srgb, var(--primary) 44%, var(--glass-border));
  transform: translateY(-1px) scale(1.02);
  box-shadow: var(--focus-glow);
}

@media (max-width: 640px) {
  :where(.modal-actions, .wizard-actions):not(:empty) {
    border-radius: var(--radius-md);
    padding: 5px;
  }
}

/* Focus Warm Glass OS: phase 23 topbar status dock */
.topbar {
  border-bottom-color: color-mix(in srgb, var(--glass-border) 76%, transparent);
  background: linear-gradient(180deg, color-mix(in srgb, var(--bg) 86%, transparent), color-mix(in srgb, var(--bg-soft) 58%, transparent));
  box-shadow: 0 12px 32px color-mix(in srgb, var(--text) 7%, transparent);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  padding: 10px clamp(12px, 2vw, 24px);
}

.top-actions {
  grid-template-columns: max-content minmax(0, 1fr);
  border-radius: var(--radius-xl);
  background:
    radial-gradient(circle at 8% 0%, color-mix(in srgb, var(--primary) 12%, transparent), transparent 18rem),
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 76%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
}

.current-date {
  letter-spacing: 0;
  white-space: nowrap;
  box-shadow: var(--shadow-xs);
}

.topbar .quote-ticker {
  min-width: 0;
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.topbar .quote-ticker strong {
  font-size: 0.82rem;
  letter-spacing: 0.04em;
}

@media (max-width: 720px) {
  .top-actions {
    grid-template-columns: 1fr;
  }

  .topbar .quote-ticker {
    min-height: 42px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .ticker-window p {
    animation: none;
  }
}

/* Focus Warm Glass OS: phase 24 today focus rail */
.plan-panel {
  position: sticky;
  isolation: isolate;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 0%, color-mix(in srgb, var(--primary) 12%, transparent), transparent 18rem),
    radial-gradient(circle at 100% 18%, color-mix(in srgb, var(--yellow) 8%, transparent), transparent 20rem),
    linear-gradient(180deg, color-mix(in srgb, var(--glass-elevated) 78%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
}

.plan-panel::before {
  content: "";
  position: absolute;
  inset: 12px;
  z-index: -1;
  border: 1px solid color-mix(in srgb, var(--glass-border) 70%, transparent);
  border-radius: var(--radius-xl);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-surface) 42%, transparent), transparent 68%);
  pointer-events: none;
}

.plan-panel .panel-title {
  border-bottom: 1px solid var(--glass-border);
  padding-bottom: 12px;
}

.plan-motto {
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 62%, transparent), color-mix(in srgb, var(--glass-surface) 92%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 14%, transparent);
  line-height: 1.45;
  margin: 0;
  padding: 12px 14px;
}

.plan-content {
  align-content: start;
  scrollbar-gutter: stable;
}

.plan-panel > .button.full {
  margin-top: auto;
  border-color: color-mix(in srgb, var(--primary) 24%, var(--glass-border));
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 70%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

@media (max-width: 880px) {
  .plan-panel::before {
    inset: 8px;
  }
}

/* Focus Warm Glass OS: phase 25 floating sidebar dock */
.sidebar {
  isolation: isolate;
  overflow: hidden;
  background:
    radial-gradient(circle at 0% 0%, color-mix(in srgb, var(--primary) 10%, transparent), transparent 18rem),
    radial-gradient(circle at 100% 18%, color-mix(in srgb, var(--yellow) 7%, transparent), transparent 18rem),
    linear-gradient(180deg, color-mix(in srgb, var(--glass-elevated) 74%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
}

.sidebar::before {
  content: "";
  position: absolute;
  inset: 12px;
  z-index: -1;
  border: 1px solid color-mix(in srgb, var(--glass-border) 70%, transparent);
  border-radius: var(--radius-xl);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--glass-surface) 36%, transparent), transparent 72%);
  pointer-events: none;
}

.sidebar-top {
  border-color: var(--glass-border);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 62%, transparent), color-mix(in srgb, var(--glass-surface) 92%, transparent));
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.side-actions {
  gap: 8px;
  padding: 4px;
}

.side-button {
  min-height: 46px;
  border-radius: var(--radius-lg);
  transition:
    border-color var(--motion-standard),
    background var(--motion-standard),
    box-shadow var(--motion-standard),
    color var(--motion-standard),
    transform var(--motion-fast);
}

.side-button:hover,
.side-button.active {
  transform: translateX(2px);
  box-shadow: var(--focus-glow);
}

.app-shell.sidebar-collapsed .sidebar::before {
  inset: 8px;
}

@media (max-width: 880px) {
  .app-shell.sidebar-collapsed .side-actions {
    border-radius: 999px;
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
  }
}

/* Focus Warm Glass OS: phase 26 quiet states */
:where(.form-error, .voice-status, .empty-state, .managed-empty) {
  border: 1px solid transparent;
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 48%, transparent), color-mix(in srgb, var(--glass-surface) 88%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 12%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  padding: 10px 12px;
}

.form-error:not(:empty) {
  border-color: color-mix(in srgb, var(--red) 28%, var(--glass-border));
  color: color-mix(in srgb, var(--red) 84%, var(--text));
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--red) 10%, var(--glass-elevated)), color-mix(in srgb, var(--glass-surface) 92%, transparent));
}

.voice-status:not(:empty) {
  border-color: color-mix(in srgb, var(--primary) 20%, var(--glass-border));
  color: var(--muted-strong);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--primary) 8%, var(--glass-elevated)), color-mix(in srgb, var(--glass-surface) 94%, transparent));
}

.skeleton-card {
  border-color: var(--glass-border);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 50%, transparent), color-mix(in srgb, var(--glass-surface) 92%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 12%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.skeleton-card span {
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--glass-border) 72%, transparent),
    color-mix(in srgb, var(--primary) 12%, transparent),
    color-mix(in srgb, var(--glass-border) 72%, transparent)
  );
}

.toast {
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 76%, transparent), color-mix(in srgb, var(--glass-surface) 98%, transparent));
  box-shadow: var(--focus-shadow), inset 0 1px 0 color-mix(in srgb, #fff 14%, transparent);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

@media (max-width: 640px) {
  :where(.form-error, .voice-status, .empty-state, .managed-empty) {
    padding: 10px 12px;
  }
}

/* Focus Warm Glass OS: phase 27 detail rhythm */
.schedule-detail-toolbar {
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 54%, transparent), color-mix(in srgb, var(--glass-surface) 90%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 14%, transparent);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  padding: 8px;
}

:where(.schedule-detail-card, .schedule-day-detail, .week-column) {
  border-color: var(--glass-border);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 8% 0%, color-mix(in srgb, var(--primary) 9%, transparent), transparent 13rem),
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 62%, transparent), color-mix(in srgb, var(--glass-surface) 94%, transparent));
  box-shadow: var(--focus-shadow), inset 0 1px 0 color-mix(in srgb, #fff 14%, transparent);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.week-column {
  transition:
    border-color var(--motion-standard),
    background var(--motion-standard),
    box-shadow var(--motion-standard),
    transform var(--motion-fast);
}

.week-column:hover {
  border-color: color-mix(in srgb, var(--primary) 24%, var(--glass-border));
  transform: translateY(-1px);
}

.week-column.selected {
  border-color: color-mix(in srgb, var(--primary) 42%, var(--glass-border));
  box-shadow: var(--focus-shadow), var(--focus-glow);
}

:where(.schedule-detail-lesson, .event-pill) {
  border-color: color-mix(in srgb, var(--glass-border) 88%, transparent);
  border-radius: var(--radius-md);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 52%, transparent), color-mix(in srgb, var(--glass-surface) 92%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 12%, transparent);
}

.schedule-day-detail h3,
.week-column h3 {
  color: var(--primary);
  text-shadow: 0 0 18px color-mix(in srgb, var(--primary) 22%, transparent);
}

@media (max-width: 640px) {
  .schedule-detail-toolbar {
    padding: 8px;
  }
}

/* Focus Warm Glass OS: phase 28 micro actions */
:where(.icon-action, .text-action, .wizard-chip, .wizard-tag, .weekday-chip, .round-control, .icon-button) {
  transition:
    border-color var(--motion-standard),
    background var(--motion-standard),
    box-shadow var(--motion-standard),
    color var(--motion-standard),
    filter var(--motion-standard),
    transform var(--motion-fast);
}

.icon-action {
  overflow: hidden;
  background-position: center;
  background-repeat: no-repeat;
  background-size: 20px 20px;
}

:where(.icon-action, .text-action, .wizard-chip, .weekday-chip, .round-control, .icon-button):is(:hover, :focus-visible) {
  border-color: color-mix(in srgb, var(--primary) 34%, var(--glass-border));
  background-color: color-mix(in srgb, var(--glass-elevated) 86%, var(--primary-soft));
  box-shadow: var(--focus-shadow), var(--focus-glow);
  filter: brightness(1.04) saturate(1.04);
  transform: translateY(-1px);
}

.icon-action:is(:hover, :focus-visible) {
  transform: translateY(-1px) scale(1.03);
}

.wizard-tag {
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 14%, transparent);
}

.wizard-tag button:is(:hover, :focus-visible) {
  background: color-mix(in srgb, var(--red) 12%, var(--glass-elevated));
  color: color-mix(in srgb, var(--red) 86%, var(--text));
}

@media (hover: none) {
  :where(.icon-action, .text-action, .wizard-chip, .weekday-chip, .round-control, .icon-button):is(:hover, :focus-visible) {
    transform: none;
  }
}

/* Focus Warm Glass OS: phase 29 typography hierarchy */
:where(.panel-title h2, .panel-title h3, .modal-head h2, .sheet-head h2, .wizard-card h3) {
  font-weight: 650;
  letter-spacing: 0;
  text-wrap: balance;
}

:where(.panel-title h2, .panel-title h3, .wizard-card h3, .schedule-day-detail h3, .week-column h3) {
  color: var(--primary);
  text-shadow: 0 0 18px color-mix(in srgb, var(--primary) 16%, transparent);
}

:where(.field-caption, label span, .legend p, .modal-head p, .sheet-head p) {
  color: var(--muted-strong);
  font-weight: 650;
  letter-spacing: 0;
}

:where(.info-list strong, .summary-item strong, .event-pill strong, .task-item strong, .schedule-detail-heading strong) {
  font-weight: 650;
  line-height: 1.32;
}

@media (max-width: 640px) {
  :where(.panel-title h2, .panel-title h3, .modal-head h2, .sheet-head h2, .wizard-card h3) {
    font-size: clamp(1.08rem, 5vw, 1.32rem);
  }
}

/* Focus Warm Glass OS: phase 30 record cards */
.records-list {
  gap: clamp(10px, 1.4vw, 14px);
  align-content: start;
}

:where(.managed-card, .schedule-entry, .note-entry, .diary-entry) {
  position: relative;
  overflow: hidden;
  border-color: var(--glass-border);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 62%, transparent), color-mix(in srgb, var(--glass-surface) 94%, transparent));
  box-shadow: var(--focus-shadow), inset 0 1px 0 color-mix(in srgb, #fff 14%, transparent);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

:where(.managed-card, .schedule-entry, .note-entry, .diary-entry)::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: radial-gradient(circle at 0% 0%, color-mix(in srgb, var(--primary) 10%, transparent), transparent 14rem);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--motion-standard);
}

:where(.managed-card, .schedule-entry, .note-entry, .diary-entry):is(:hover, :focus-visible)::before {
  opacity: 1;
}

:where(.managed-card, .schedule-entry, .note-entry, .diary-entry):is(:hover, :focus-visible) {
  border-color: color-mix(in srgb, var(--primary) 28%, var(--glass-border));
  box-shadow: var(--focus-shadow), var(--focus-glow), inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
}

.schedule-entry.is-paused {
  opacity: 1;
  filter: saturate(.72);
}

.item-actions {
  border: 1px solid color-mix(in srgb, var(--glass-border) 72%, transparent);
  border-radius: 999px;
  background: color-mix(in srgb, var(--glass-surface) 82%, transparent);
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 12%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding: 3px;
}

.schedule-entry-head > span {
  border-color: color-mix(in srgb, var(--primary) 18%, var(--glass-border));
  color: var(--muted-strong);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 64%, transparent), color-mix(in srgb, var(--glass-surface) 92%, transparent));
}

@media (max-width: 640px) {
  .item-actions {
    border-radius: var(--radius-lg);
  }
}

/* Focus Warm Glass OS: phase 31 semantic markers */
.dot {
  width: 10px;
  height: 10px;
  border: 1px solid color-mix(in srgb, #fff 46%, transparent);
  box-shadow:
    0 0 0 3px color-mix(in srgb, currentColor 14%, transparent),
    0 0 14px color-mix(in srgb, currentColor 34%, transparent);
}

.dot.blue {
  color: var(--label-reminder);
  background: var(--label-reminder);
}

.dot.red {
  color: var(--label-birthday);
  background: var(--label-birthday);
}

.dot.green {
  color: var(--label-schedule);
  background: var(--label-schedule);
}

.marker-row {
  gap: 6px;
  align-items: center;
  filter: drop-shadow(0 3px 8px rgba(0, 0, 0, .16));
}

#markerLegendItems span {
  border-color: color-mix(in srgb, var(--primary) 18%, var(--glass-border));
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 70%, transparent), color-mix(in srgb, var(--glass-surface) 94%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 14%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.day-cell.holiday {
  border-color: color-mix(in srgb, var(--red) 46%, var(--glass-border));
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--red) 18%, transparent),
    0 0 18px color-mix(in srgb, var(--red) 18%, transparent),
    0 12px 30px rgba(0, 0, 0, 0.18);
}

.day-cell.holiday > span:last-child {
  color: color-mix(in srgb, var(--red) 82%, var(--text));
}

@media (max-width: 640px) {
  .dot {
    width: 9px;
    height: 9px;
  }
}

/* Focus Warm Glass OS: phase 32 empty states */
:where(.empty-state, .managed-empty, .schedule-empty) {
  position: relative;
  overflow: hidden;
  border-color: color-mix(in srgb, var(--primary) 12%, var(--glass-border));
  color: var(--muted-strong);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 58%, transparent), color-mix(in srgb, var(--glass-surface) 92%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 14%, transparent);
  text-wrap: balance;
}

:where(.empty-state, .managed-empty, .schedule-empty)::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at 0% 0%, color-mix(in srgb, var(--primary) 10%, transparent), transparent 12rem),
    radial-gradient(circle at 100% 100%, color-mix(in srgb, var(--yellow) 8%, transparent), transparent 10rem);
  pointer-events: none;
}

.schedule-empty {
  min-height: 88px;
  display: grid;
  align-content: center;
}

.week-items .empty-state {
  font-size: 0.88rem;
  padding: 9px 10px;
}

@media (max-width: 640px) {
  :where(.empty-state, .managed-empty, .schedule-empty) {
    border-radius: var(--radius-md);
    padding: 10px 12px;
  }
}

/* Focus Warm Glass OS: phase 33 wizard progress */
.modal[data-action="schedule"] #scheduleWizard {
  gap: clamp(10px, 1.5vw, 14px);
}

.wizard-topline {
  align-items: center;
  justify-content: flex-end;
  color: var(--muted-strong);
  font-size: 0.9rem;
  font-weight: 650;
}

.wizard-progress {
  height: 7px;
  padding: 1px;
  border: 1px solid color-mix(in srgb, var(--primary) 12%, var(--glass-border));
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 48%, transparent), color-mix(in srgb, var(--glass-surface) 86%, transparent));
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 12%, transparent), var(--shadow-xs);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.wizard-progress i {
  background: linear-gradient(90deg, color-mix(in srgb, var(--primary) 92%, #fff), color-mix(in srgb, var(--primary) 58%, var(--yellow)));
  box-shadow: 0 0 18px color-mix(in srgb, var(--primary) 34%, transparent);
}

@media (max-width: 640px) {
  .wizard-progress {
    height: 6px;
  }
}

/* Focus Warm Glass OS: phase 34 voice input */
.voice-box {
  border-color: color-mix(in srgb, var(--primary) 16%, var(--glass-border));
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 54%, transparent), color-mix(in srgb, var(--glass-surface) 90%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 14%, transparent);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-radius: var(--radius-lg);
}

.schedule-voice-slot {
  align-self: start;
  margin-top: clamp(6px, 1vw, 10px);
}

#voiceButton {
  border: 1px solid color-mix(in srgb, var(--primary) 22%, var(--glass-border));
  border-radius: 999px;
  min-height: 38px;
  color: var(--muted-strong);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 58%, transparent), color-mix(in srgb, var(--glass-surface) 92%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 14%, transparent);
}

#voiceButton.primary {
  color: #fff;
  background: linear-gradient(135deg, color-mix(in srgb, var(--primary) 82%, #fff), var(--primary));
  box-shadow: var(--focus-shadow), 0 0 22px color-mix(in srgb, var(--primary) 28%, transparent);
}

.voice-status:not(:empty) {
  border-color: color-mix(in srgb, var(--primary) 18%, var(--glass-border));
  font-size: 0.86rem;
}

@media (max-width: 640px) {
  #voiceButton {
    min-height: 36px;
    padding-inline: 10px;
  }
}

/* Focus Warm Glass OS: phase 35 theme previews */
.theme-preview-card {
  isolation: isolate;
  border-color: color-mix(in srgb, var(--primary) 14%, var(--glass-border));
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 64%, transparent), color-mix(in srgb, var(--glass-surface) 94%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
}

.theme-preview-card::before {
  position: absolute;
  inset: -38% -20% auto -20%;
  height: 72%;
  border-radius: 999px;
  background: radial-gradient(circle at 16% 0%, color-mix(in srgb, var(--primary) 22%, transparent), transparent 66%);
  opacity: 0.72;
  pointer-events: none;
  content: "";
}

.theme-preview-card::after {
  position: absolute;
  inset: auto 12px 12px auto;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--primary) 16%, transparent), transparent 66%);
  opacity: 0.52;
  pointer-events: none;
  content: "";
}

.theme-preview-card:has(input:checked) {
  border-color: color-mix(in srgb, var(--primary) 58%, var(--glass-border));
  box-shadow: var(--focus-shadow), var(--focus-glow), inset 0 1px 0 color-mix(in srgb, #fff 24%, transparent);
}

.theme-preview-ui {
  min-height: 72px;
  overflow: hidden;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--glass-strong) 54%, transparent), color-mix(in srgb, var(--glass-surface) 94%, transparent));
}

.theme-preview-ui::after {
  position: absolute;
  top: 0;
  right: 0;
  width: 34%;
  height: 100%;
  border-left: 1px solid color-mix(in srgb, var(--primary) 14%, var(--glass-border));
  background: color-mix(in srgb, var(--primary) 18%, transparent);
  content: "";
}

.theme-preview-ui b,
.theme-preview-ui em {
  position: relative;
  z-index: 1;
}

.theme-palette {
  align-items: center;
}

.theme-palette span {
  width: 14px;
  height: 14px;
  box-shadow: 0 0 0 1px color-mix(in srgb, #fff 38%, transparent), inset 0 1px 0 color-mix(in srgb, #fff 24%, transparent);
}

@media (max-width: 640px) {
  .theme-preview-card {
    min-height: 118px;
  }

  .theme-preview-ui {
    min-height: 58px;
  }
}

/* Focus Warm Glass OS: phase 36 feedback layer */
.toast-region {
  pointer-events: none;
  gap: 10px;
}

.toast {
  position: relative;
  overflow: hidden;
  padding: 14px 18px 14px 20px;
  border-color: color-mix(in srgb, var(--label-schedule) 26%, var(--glass-border));
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 70%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  box-shadow: var(--focus-shadow), 0 18px 48px color-mix(in srgb, var(--text) 10%, transparent), inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
}

.toast::before {
  position: absolute;
  top: 10px;
  bottom: 10px;
  left: 10px;
  width: 4px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--label-schedule), color-mix(in srgb, var(--label-schedule) 42%, var(--primary)));
  content: "";
}

.toast::after {
  position: absolute;
  inset: -40% -10% auto 8%;
  height: 82%;
  border-radius: 999px;
  background: radial-gradient(circle at 20% 0%, color-mix(in srgb, var(--label-schedule) 16%, transparent), transparent 66%);
  opacity: 0.64;
  pointer-events: none;
  content: "";
}

.toast.error {
  border-color: color-mix(in srgb, var(--label-birthday) 34%, var(--glass-border));
}

.toast.error::before {
  background: linear-gradient(180deg, var(--label-birthday), color-mix(in srgb, var(--label-birthday) 56%, var(--red)));
}

.toast.error::after {
  background: radial-gradient(circle at 20% 0%, color-mix(in srgb, var(--label-birthday) 16%, transparent), transparent 66%);
}

@media (max-width: 640px) {
  .toast-region {
    bottom: max(16px, env(safe-area-inset-bottom));
  }

  .toast {
    border-radius: var(--radius-md);
    padding-block: 12px;
  }
}

/* Focus Warm Glass OS: phase 37 settings controls */
.settings-group:has(.color-grid) {
  background:
    radial-gradient(circle at 12% 0%, color-mix(in srgb, var(--primary) 12%, transparent), transparent 12rem),
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 72%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
}

.color-grid {
  width: fit-content;
  max-width: 100%;
  padding: 8px;
  border: 1px solid color-mix(in srgb, var(--primary) 12%, var(--glass-border));
  border-radius: 999px;
  background: color-mix(in srgb, var(--glass-surface) 70%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 14%, transparent), var(--shadow-xs);
}

.color-choice {
  width: 34px;
  height: 34px;
  transition: transform var(--motion-fast), border-color var(--motion-standard), box-shadow var(--motion-standard);
}

.color-choice:hover {
  transform: translateY(-1px) scale(1.04);
}

.color-choice span {
  width: 20px;
  height: 20px;
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 26%, transparent);
}

.color-choice:has(input:checked)::after,
.color-choice.selected::after {
  position: absolute;
  inset: 9px;
  border: 2px solid color-mix(in srgb, #fff 86%, transparent);
  border-radius: 50%;
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--primary) 34%, transparent);
  content: "";
  pointer-events: none;
}

.settings-grid > .switch-row {
  grid-column: 1 / -1;
  border-color: color-mix(in srgb, var(--primary) 12%, var(--glass-border));
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 68%, transparent), color-mix(in srgb, var(--glass-surface) 94%, transparent));
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

.settings-grid > .switch-row i {
  border-color: color-mix(in srgb, var(--primary) 18%, var(--glass-border));
  background: color-mix(in srgb, var(--glass-surface) 78%, transparent);
}

.settings-grid > .switch-row input:checked + i {
  background: linear-gradient(135deg, color-mix(in srgb, var(--primary) 84%, #fff), var(--primary));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 16%, transparent), 0 0 18px color-mix(in srgb, var(--primary) 24%, transparent);
}

@media (max-width: 640px) {
  .color-grid {
    border-radius: var(--radius-lg);
  }
}

/* Focus Warm Glass OS: phase 38 modal headers */
.modal-head {
  position: relative;
  isolation: isolate;
  border-bottom-color: color-mix(in srgb, var(--primary) 14%, var(--glass-border));
}

.modal-head::before {
  position: absolute;
  right: 0;
  bottom: -1px;
  left: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--primary) 42%, transparent), transparent);
  opacity: 0.72;
  content: "";
  pointer-events: none;
}

.modal-head h2 {
  font-size: clamp(1.34rem, 2.5vw, 1.72rem);
  line-height: 1.14;
  text-shadow: 0 0 22px color-mix(in srgb, var(--primary) 14%, transparent);
}

.modal-head p {
  text-transform: none;
  max-width: 52ch;
}

.modal-head .round-control {
  width: 52px;
  height: 52px;
  min-height: 52px;
  flex: 0 0 auto;
  border-color: color-mix(in srgb, var(--primary) 18%, var(--glass-border));
  background:
    radial-gradient(circle at 35% 18%, color-mix(in srgb, #fff 18%, transparent), transparent 60%),
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 62%, transparent), color-mix(in srgb, var(--glass-surface) 94%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.modal-head .round-control:hover {
  border-color: color-mix(in srgb, var(--primary) 42%, var(--glass-border));
  transform: translateY(-1px) scale(1.03);
  box-shadow: var(--focus-shadow), var(--focus-glow);
}

@media (max-width: 640px) {
  .modal-head .round-control {
    width: 44px;
    height: 44px;
    min-height: 44px;
  }
}

/* Focus Warm Glass OS: phase 39 managed lists */
.managed-head {
  position: relative;
  overflow: hidden;
  padding: 10px;
  border: 1px solid color-mix(in srgb, var(--primary) 12%, var(--glass-border));
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 0% 0%, color-mix(in srgb, var(--primary) 10%, transparent), transparent 13rem),
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 58%, transparent), color-mix(in srgb, var(--glass-surface) 92%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 14%, transparent);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.managed-head::before {
  position: absolute;
  inset: -78px auto auto -42px;
  width: 180px;
  height: 180px;
  border-radius: 50%;
  background: radial-gradient(circle at 0% 0%, color-mix(in srgb, var(--primary) 18%, transparent), transparent 68%);
  opacity: 0.72;
  content: "";
  pointer-events: none;
}

.managed-head .text-link {
  position: relative;
  justify-self: start;
  min-height: 38px;
  border-radius: 999px;
  border-color: color-mix(in srgb, var(--primary) 18%, transparent);
  padding: 0 14px;
  background: color-mix(in srgb, var(--primary) 10%, var(--glass-surface));
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 14%, transparent);
}

.managed-head .text-link:hover {
  border-color: color-mix(in srgb, var(--primary) 34%, var(--glass-border));
  background: color-mix(in srgb, var(--primary) 14%, var(--glass-elevated));
  transform: translateY(-1px);
  box-shadow: var(--focus-shadow), var(--focus-glow);
}

.records-list {
  gap: clamp(10px, 1.5vw, 15px);
  align-content: start;
  scroll-padding-bottom: 96px;
}

.managed-card {
  position: relative;
  border-color: color-mix(in srgb, var(--primary) 12%, var(--glass-border));
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.managed-card::after {
  position: absolute;
  top: 18px;
  bottom: 18px;
  left: 0;
  width: 3px;
  border-radius: 0 999px 999px 0;
  background: linear-gradient(180deg, var(--primary), color-mix(in srgb, var(--primary) 34%, transparent));
  opacity: 0.56;
  content: "";
  pointer-events: none;
}

@media (max-width: 640px) {
  .managed-head {
    border-radius: var(--radius-md);
    padding: 8px;
  }

  .managed-head .text-link {
    min-height: 36px;
    padding-inline: 12px;
  }
}

/* Focus Warm Glass OS: phase 40 soft rows */
:where(.summary-item, .task-item, .event-pill, .lesson-row) {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  border-color: color-mix(in srgb, var(--primary) 10%, var(--glass-border));
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 62%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 12%, transparent);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  transition:
    border-color var(--motion-standard),
    box-shadow var(--motion-standard),
    transform var(--motion-fast);
}

:where(.summary-item, .task-item, .event-pill, .lesson-row)::before {
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(90deg, color-mix(in srgb, #fff 12%, transparent), transparent 42%),
    radial-gradient(circle at 0% 0%, color-mix(in srgb, var(--primary) 10%, transparent), transparent 11rem);
  opacity: 0.66;
  content: "";
  pointer-events: none;
}

:where(.summary-item, .task-item, .event-pill, .lesson-row):hover {
  border-color: color-mix(in srgb, var(--primary) 26%, var(--glass-border));
  transform: translateY(-1px);
  box-shadow: var(--focus-shadow), var(--focus-glow), inset 0 1px 0 color-mix(in srgb, #fff 14%, transparent);
}

.summary-item small,
.event-pill small,
.diary-entry small {
  color: color-mix(in srgb, var(--muted-strong) 78%, var(--muted));
  letter-spacing: 0;
}

@media (max-width: 640px) {
  :where(.summary-item, .task-item, .event-pill, .lesson-row) {
    border-radius: var(--radius-md);
    padding: 10px 12px;
  }
}

/* Focus Warm Glass OS: phase 41 form groups */
:where(.schedule-form-grid, .wizard-subsection) {
  position: relative;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--primary) 10%, var(--glass-border));
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 42%, transparent), color-mix(in srgb, var(--glass-surface) 90%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 12%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  padding: 14px;
}

:where(.schedule-form-grid, .wizard-subsection)::before {
  position: absolute;
  inset: -72px -72px auto auto;
  width: 190px;
  height: 190px;
  border-radius: 50%;
  background: radial-gradient(circle at 100% 0%, color-mix(in srgb, var(--primary) 12%, transparent), transparent 68%);
  opacity: 0.48;
  content: "";
  pointer-events: none;
}

.schedule-form-grid label {
  position: relative;
  border-radius: var(--radius-sm);
  padding: 2px;
}

:where(.schedule-form-grid label span, .wizard-subsection label span) {
  color: var(--muted-strong);
  font-weight: 650;
  letter-spacing: 0;
}

.wizard-card h3 {
  position: relative;
  width: fit-content;
}

.wizard-card h3::after {
  display: block;
  width: 42px;
  height: 2px;
  margin-top: 7px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--primary), transparent);
  content: "";
}

@media (max-width: 640px) {
  :where(.schedule-form-grid, .wizard-subsection) {
    padding: 12px;
    border-radius: var(--radius-md);
  }
}

/* Focus Warm Glass OS: phase 42 week view */
.week-view {
  gap: clamp(10px, 1.4vw, 16px);
  scroll-snap-type: x proximity;
  padding: 4px 2px 10px;
}

.week-column {
  position: relative;
  overflow: hidden;
  scroll-snap-align: center;
  border-color: color-mix(in srgb, var(--primary) 10%, var(--glass-border));
  background:
    radial-gradient(circle at 50% 0%, color-mix(in srgb, var(--primary) 10%, transparent), transparent 12rem),
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 56%, transparent), color-mix(in srgb, var(--glass-surface) 94%, transparent));
}

.week-column::before {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 0%, color-mix(in srgb, #fff 13%, transparent), transparent 9rem),
    linear-gradient(180deg, color-mix(in srgb, var(--primary) 6%, transparent), transparent 48%);
  opacity: 0.58;
  content: "";
  pointer-events: none;
}

.week-column.selected {
  border-color: color-mix(in srgb, var(--primary) 56%, var(--glass-border));
  box-shadow: var(--focus-shadow), var(--focus-glow), inset 0 0 0 1px color-mix(in srgb, var(--primary) 38%, transparent);
}

.week-column h3,
.week-items {
  position: relative;
}

.week-items {
  gap: 10px;
  align-content: start;
}

@media (max-width: 760px) {
  .week-view {
    grid-template-columns: 1fr;
    overflow-x: visible;
    scroll-snap-type: none;
  }

  .week-column {
    min-height: auto;
  }
}

/* Focus Warm Glass OS: phase 43 picker controls */
.date-picker-head {
  border: 1px solid color-mix(in srgb, var(--primary) 10%, var(--glass-border));
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--glass-surface) 72%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 12%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding: 8px;
}

.date-picker-weekdays {
  border-bottom: 1px solid color-mix(in srgb, var(--primary) 10%, var(--glass-border));
  padding-bottom: 6px;
}

.date-picker-day {
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--glass-surface) 76%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 10%, transparent);
}

.time-picker-trigger {
  border-color: color-mix(in srgb, var(--primary) 18%, var(--glass-border));
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 62%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 12%, transparent);
}

.time-picker-column {
  border: 1px solid color-mix(in srgb, var(--primary) 10%, var(--glass-border));
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--glass-surface) 74%, transparent);
  padding: 4px;
}

.date-picker-actions {
  border-top: 1px solid color-mix(in srgb, var(--primary) 10%, var(--glass-border));
  padding-top: 12px;
}

/* Focus Warm Glass OS: phase 44 calendar header */
.calendar-sheet .sheet-head {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.10);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.10), rgba(18, 17, 15, 0.22));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12), 0 14px 36px rgba(0, 0, 0, 0.14);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  padding: 12px;
}

.calendar-sheet .sheet-head::before {
  position: absolute;
  inset: -90px 10% auto;
  height: 180px;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 0%, color-mix(in srgb, var(--calendar-season-accent, var(--primary)) 26%, transparent), transparent 68%);
  opacity: 0.62;
  content: "";
  pointer-events: none;
}

.calendar-sheet .sheet-head h2 {
  text-shadow: 0 0 24px color-mix(in srgb, var(--calendar-season-accent, var(--primary)) 28%, transparent);
  letter-spacing: 0;
}

.calendar-sheet .sheet-head .round-control {
  border-radius: var(--radius-md);
  background: rgba(18, 17, 15, 0.38);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.14);
}

.calendar-sheet .weekdays {
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  background: rgba(18, 17, 15, 0.22);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  padding: 8px;
}

@media (max-width: 640px) {
  .calendar-sheet .sheet-head {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    padding: 10px;
  }
}

/* Focus Warm Glass OS: phase 45 calendar markers */
.calendar-sheet .marker-row {
  min-height: 14px;
  gap: 5px;
  align-items: center;
  padding: 2px 3px;
  filter: drop-shadow(0 5px 12px rgba(0, 0, 0, 0.22));
}

.calendar-sheet .marker-row .dot {
  width: 9px;
  height: 9px;
  border: 1px solid color-mix(in srgb, #fff 58%, transparent);
  background: currentColor;
  box-shadow:
    0 0 0 2px rgba(18, 17, 15, 0.34),
    0 0 0 4px color-mix(in srgb, currentColor 13%, transparent),
    0 0 16px color-mix(in srgb, currentColor 42%, transparent);
  transition:
    transform var(--motion-fast),
    box-shadow var(--motion-standard),
    border-color var(--motion-standard);
}

.calendar-sheet .day-cell:hover .marker-row .dot {
  border-color: color-mix(in srgb, #fff 72%, transparent);
  transform: translateY(-1px) scale(1.08);
  box-shadow:
    0 0 0 2px rgba(18, 17, 15, 0.28),
    0 0 0 5px color-mix(in srgb, currentColor 17%, transparent),
    0 0 20px color-mix(in srgb, currentColor 52%, transparent);
}

.legend:not(.is-hidden) {
  background:
    radial-gradient(circle at 12% 0%, color-mix(in srgb, var(--primary) 12%, transparent), transparent 12rem),
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 58%, transparent), color-mix(in srgb, var(--glass-surface) 94%, transparent));
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

#markerLegendItems span {
  min-height: 34px;
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 74%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  transition:
    border-color var(--motion-standard),
    box-shadow var(--motion-standard),
    transform var(--motion-fast);
}

#markerLegendItems span:hover {
  border-color: color-mix(in srgb, var(--primary) 30%, var(--glass-border));
  box-shadow: var(--shadow-xs), var(--focus-glow), inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
}

#markerLegendItems span .dot {
  margin-right: 2px;
  box-shadow:
    0 0 0 2px color-mix(in srgb, var(--glass-surface) 86%, transparent),
    0 0 0 4px color-mix(in srgb, currentColor 12%, transparent),
    0 0 18px color-mix(in srgb, currentColor 44%, transparent);
}

@media (max-width: 640px) {
  .calendar-sheet .marker-row {
    min-height: 12px;
    gap: 4px;
    padding: 1px 2px;
  }

  .calendar-sheet .marker-row .dot {
    width: 8px;
    height: 8px;
  }

  #markerLegendItems span {
    min-height: 32px;
  }
}

/* Focus Warm Glass OS: phase 46 today panel dock */
.plan-panel {
  border-left: 1px solid color-mix(in srgb, var(--primary) 10%, var(--glass-border));
  box-shadow:
    var(--focus-shadow-elevated),
    inset 1px 0 0 color-mix(in srgb, #fff 10%, transparent);
}

.plan-panel .panel-title {
  border: 1px solid color-mix(in srgb, var(--primary) 10%, var(--glass-border));
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 64%, transparent), color-mix(in srgb, var(--glass-surface) 94%, transparent));
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 14%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  padding: 12px 14px;
}

.plan-panel .panel-title h2 {
  color: var(--primary);
  text-shadow: 0 0 22px color-mix(in srgb, var(--primary) 20%, transparent);
}

.plan-motto {
  position: relative;
  overflow: hidden;
  text-wrap: balance;
}

.plan-motto::before {
  position: absolute;
  inset: -80px auto auto -40px;
  width: 170px;
  height: 170px;
  border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--yellow) 16%, transparent), transparent 68%);
  opacity: 0.72;
  content: "";
  pointer-events: none;
}

.plan-content {
  border: 1px solid color-mix(in srgb, var(--primary) 8%, var(--glass-border));
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--glass-surface) 38%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 10%, transparent);
  padding: 10px;
}

.plan-content > p {
  border-style: dashed;
  color: var(--muted-strong);
  text-align: center;
}

.plan-panel > .button.full:hover {
  border-color: color-mix(in srgb, var(--primary) 38%, var(--glass-border));
  box-shadow: var(--focus-shadow), var(--focus-glow), inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
  transform: translateY(-1px);
}

@media (max-width: 880px) {
  .plan-panel {
    box-shadow: var(--focus-shadow);
  }
}

/* Focus Warm Glass OS: phase 47 today task cards */
.plan-content .task-item {
  border-left: 0;
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 0% 0%, color-mix(in srgb, var(--label-reminder) 10%, transparent), transparent 10rem),
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 68%, transparent), color-mix(in srgb, var(--glass-surface) 98%, transparent));
  padding: 12px;
}

.plan-content .task-item::after {
  position: absolute;
  inset: 12px auto 12px 10px;
  width: 3px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--label-reminder), color-mix(in srgb, var(--label-reminder) 38%, transparent));
  opacity: 0.72;
  content: "";
  pointer-events: none;
  transition:
    opacity var(--motion-standard),
    box-shadow var(--motion-standard);
}

.plan-content .task-item p {
  margin: 0;
  padding-right: 4px;
  padding-left: 12px;
  text-wrap: pretty;
}

.plan-content .task-item .item-actions {
  border: 1px solid color-mix(in srgb, var(--primary) 9%, var(--glass-border));
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--glass-surface) 62%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 10%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding: 3px;
}

.plan-content .task-item .icon-action {
  width: 30px;
  height: 30px;
  background-size: 68% 68%;
}

.plan-content .task-item:hover::after {
  opacity: 1;
  box-shadow: 0 0 18px color-mix(in srgb, var(--label-reminder) 36%, transparent);
}

@media (max-width: 640px) {
  .plan-content .task-item .item-actions {
    justify-content: flex-end;
  }
}

/* Focus Warm Glass OS: phase 48 day summary radar */
.day-summary {
  border-color: color-mix(in srgb, var(--primary) 12%, var(--glass-border));
  background:
    radial-gradient(circle at 12% 0%, color-mix(in srgb, var(--primary) 10%, transparent), transparent 13rem),
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 64%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

.day-summary .panel-title {
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--glass-elevated) 46%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 12%, transparent);
  padding: 10px 12px;
}

.summary-list {
  display: grid;
  gap: 8px;
  max-height: clamp(150px, 20vw, 230px);
  overflow: auto;
  padding-right: 2px;
  scrollbar-gutter: stable;
}

.day-summary .summary-item {
  grid-template-columns: auto minmax(0, 1fr);
  border-radius: var(--radius-md);
  padding: 10px 12px;
}

.day-summary .summary-item i {
  width: 12px;
  height: 12px;
  margin-top: 4px;
  border: 1px solid color-mix(in srgb, #fff 56%, transparent);
  box-shadow:
    0 0 0 3px color-mix(in srgb, var(--summary-color, var(--primary)) 14%, transparent),
    0 0 18px color-mix(in srgb, var(--summary-color, var(--primary)) 42%, transparent);
}

.day-summary .summary-item small {
  display: block;
  margin-top: 2px;
  color: color-mix(in srgb, var(--muted-strong) 82%, var(--muted));
}

.day-summary .empty-state {
  border-style: dashed;
  text-align: center;
  text-wrap: balance;
}

@media (max-width: 640px) {
  .summary-list {
    max-height: none;
  }
}

/* Focus Warm Glass OS: phase 49 info panels */
.today-board .info-panel {
  border-color: color-mix(in srgb, var(--primary) 11%, var(--glass-border));
  background:
    radial-gradient(circle at 8% 0%, color-mix(in srgb, var(--yellow) 10%, transparent), transparent 12rem),
    linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 62%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

.today-board .info-panel::after {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 100% 0%, color-mix(in srgb, var(--primary) 9%, transparent), transparent 12rem),
    linear-gradient(180deg, color-mix(in srgb, #fff 8%, transparent), transparent 48%);
  opacity: 0.72;
  content: "";
  pointer-events: none;
}

.today-board .info-panel .panel-title,
.today-board .info-list {
  position: relative;
  z-index: 1;
}

.today-board .info-panel .panel-title {
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--glass-elevated) 44%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 12%, transparent);
  padding: 10px 12px;
}

.today-board .compact-info {
  max-height: 188px;
  mask-image: linear-gradient(180deg, #000 78%, transparent);
}

.today-board .info-list li {
  position: relative;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--primary) 8%, var(--glass-border));
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--glass-surface) 62%, transparent);
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 10%, transparent);
  padding: 10px 12px;
  transition:
    border-color var(--motion-standard),
    box-shadow var(--motion-standard),
    transform var(--motion-fast);
}

.today-board .info-list li::before {
  position: absolute;
  inset: 10px auto 10px 8px;
  width: 3px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--primary), color-mix(in srgb, var(--yellow) 54%, var(--primary)));
  opacity: 0.68;
  content: "";
}

.today-board .info-list li > * {
  position: relative;
  padding-left: 12px;
}

.today-board .info-list li:hover {
  border-color: color-mix(in srgb, var(--primary) 24%, var(--glass-border));
  transform: translateY(-1px);
  box-shadow: var(--focus-shadow), var(--focus-glow);
}

@media (max-width: 640px) {
  .today-board .compact-info {
    max-height: none;
    mask-image: none;
  }
}

/* Focus Warm Glass OS: phase 50 seasonal engine */
.calendar-sheet {
  transition:
    border-color var(--motion-smooth),
    box-shadow var(--motion-smooth),
    background-color var(--motion-smooth);
}

.calendar-sheet::before {
  will-change: opacity, filter, transform;
}

.calendar-sheet.is-season-changing::before {
  opacity: 0.74;
  filter: blur(2px) saturate(1.14) contrast(1.04);
  transform: scale(1.03);
}

.calendar-sheet[data-season="winter"],
.calendar-sheet[data-season="spring"],
.calendar-sheet[data-season="summer"],
.calendar-sheet[data-season="autumn"] {
  box-shadow:
    var(--focus-shadow-elevated),
    inset 0 1px 0 rgba(255, 255, 255, 0.10),
    var(--calendar-season-glow);
}

@media (prefers-reduced-motion: reduce) {
  .calendar-sheet.is-season-changing::before {
    opacity: 1;
    filter: blur(1.2px) saturate(1.08) contrast(1.02);
    transform: scale(1.018);
  }
}

/* Focus Warm Glass OS: phase 52 icon system */
:where(.back-image-button, .next-image-button, .save-image-button, .cancel-image-button) {
  display: inline-grid;
  width: 46px;
  min-width: 46px;
  height: 46px;
  min-height: 46px;
  place-items: center;
  overflow: hidden;
  padding: 0;
}

.button.cancel-image-button::before {
  --action-icon: var(--icon-cancel);
}

.button.cancel-image-button {
  color: color-mix(in srgb, var(--muted-strong) 82%, var(--text));
}

.button.cancel-image-button:is(:hover, :focus-visible) {
  color: color-mix(in srgb, var(--primary) 74%, var(--text));
}

.icon-action {
  width: 32px;
  height: 32px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: 20px 20px;
}

.icon-action:is(:hover, :focus-visible) {
  background-size: 22px 22px;
  transform: translateY(-1px) scale(1.04);
}

/* Focus Warm Glass OS: phase 53 mobile command dock */
@media (max-width: 880px) {
  .app-shell.sidebar-collapsed .sidebar {
    position: sticky;
    top: max(10px, env(safe-area-inset-top));
    z-index: 8;
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr) 44px;
    align-items: center;
    gap: 8px;
    min-height: 60px;
    margin: 10px 12px 6px;
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-xl);
    background:
      radial-gradient(circle at 12% 0%, color-mix(in srgb, var(--primary) 14%, transparent), transparent 11rem),
      linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 76%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
    box-shadow: var(--focus-shadow), inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
    backdrop-filter: blur(22px);
    -webkit-backdrop-filter: blur(22px);
    padding: 8px;
  }

  .app-shell.sidebar-collapsed .sidebar::before {
    display: none;
  }

  .app-shell.sidebar-collapsed .brand {
    grid-column: 1;
    justify-self: start;
  }

  .app-shell.sidebar-collapsed #sidebarToggle {
    grid-column: 3;
    justify-self: end;
    width: 42px;
    height: 42px;
    min-height: 42px;
    border-radius: var(--radius-lg);
  }

  .app-shell.sidebar-collapsed .side-actions {
    grid-column: 2;
    display: flex;
    justify-self: center;
    justify-content: flex-start;
    gap: 6px;
    width: max-content;
    max-width: min(520px, calc(100vw - 128px));
    overflow-x: auto;
    border: 1px solid var(--glass-border);
    border-radius: 999px;
    background: color-mix(in srgb, var(--glass-surface) 72%, transparent);
    box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 14%, transparent);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    padding: 4px;
    scrollbar-width: none;
    scroll-snap-type: x proximity;
  }

  .app-shell.sidebar-collapsed .side-actions::-webkit-scrollbar {
    display: none;
  }

  .app-shell.sidebar-collapsed .side-button {
    flex: 0 0 42px;
    width: 42px;
    height: 42px;
    min-height: 42px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--glass-elevated) 54%, transparent);
    padding: 0;
    scroll-snap-align: center;
  }

  .app-shell.sidebar-collapsed .side-button .icon {
    width: 30px;
    height: 30px;
    flex-basis: 30px;
  }

  .app-shell.sidebar-collapsed .desktop-logout {
    display: none;
  }

  .mobile-logout {
    display: block;
    order: 99;
    margin: 8px 16px max(18px, env(safe-area-inset-bottom));
  }
}

@media (max-width: 640px) {
  .app-shell.sidebar-collapsed .side-actions {
    max-width: calc(100vw - 116px);
    padding: 4px;
  }
}

/* Focus Warm Glass OS: phase 54 mobile bottom sheets */
@media (max-width: 640px) {
  .modal {
    width: 100vw;
    max-width: 100vw;
    max-height: 100dvh;
    margin: auto 0 0;
    padding: 0;
  }

  .modal::backdrop {
    background:
      radial-gradient(circle at 50% 100%, color-mix(in srgb, var(--primary) 13%, transparent), transparent 42%),
      rgba(10, 9, 8, 0.36);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
  }

  .modal-panel {
    position: relative;
    min-height: auto;
    max-height: min(92dvh, calc(100dvh - 10px));
    border-width: 1px 1px 0;
    border-radius: 28px 28px 0 0;
    overflow: hidden;
    background:
      linear-gradient(155deg, color-mix(in srgb, var(--glass-elevated) 96%, transparent), color-mix(in srgb, var(--glass-surface) 98%, transparent));
    box-shadow: 0 -18px 70px rgba(0, 0, 0, 0.22), inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
    backdrop-filter: blur(var(--focus-blur-strong));
    -webkit-backdrop-filter: blur(var(--focus-blur-strong));
  }

  .modal-panel::before {
    content: "";
    position: sticky;
    top: 8px;
    z-index: 4;
    display: block;
    width: 46px;
    height: 4px;
    margin: 8px auto -4px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--muted) 45%, transparent);
    pointer-events: none;
  }

  .modal-head {
    top: 0;
    border-radius: 28px 28px 0 0;
    background:
      linear-gradient(180deg, color-mix(in srgb, var(--glass-elevated) 98%, transparent), color-mix(in srgb, var(--glass-surface) 92%, transparent));
    padding: max(20px, env(safe-area-inset-top)) 18px 14px;
    backdrop-filter: blur(var(--focus-blur));
    -webkit-backdrop-filter: blur(var(--focus-blur));
  }

  .modal-fields,
  .voice-box,
  .voice-status,
  .form-error {
    margin-inline: 18px;
  }

  .modal-actions {
    border-top: 1px solid var(--glass-border);
    padding: 12px 18px max(18px, env(safe-area-inset-bottom));
    background:
      linear-gradient(180deg, color-mix(in srgb, var(--glass-surface) 90%, transparent), color-mix(in srgb, var(--glass-elevated) 98%, transparent));
    backdrop-filter: blur(var(--focus-blur));
    -webkit-backdrop-filter: blur(var(--focus-blur));
  }
}

/* Focus Warm Glass OS: phase 55 mobile wizard sheets */
@media (max-width: 640px) {
  .modal[data-action="schedule"] .modal-panel {
    max-height: min(94dvh, calc(100dvh - 8px));
    grid-template-rows: auto minmax(0, 1fr);
  }

  .modal[data-action="schedule"] .modal-fields {
    display: grid;
    min-height: 0;
    padding-top: 12px;
  }

  .modal[data-action="schedule"] #scheduleWizard {
    display: grid;
    grid-template-rows: auto auto minmax(0, 1fr) auto;
    min-height: 0;
    gap: 10px;
  }

  .modal[data-action="schedule"] #scheduleWizard .wizard-topline,
  .modal[data-action="schedule"] #scheduleWizard .wizard-progress {
    position: sticky;
    z-index: 2;
    background: color-mix(in srgb, var(--glass-elevated) 82%, transparent);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
  }

  .modal[data-action="schedule"] #scheduleWizard .wizard-topline {
    top: 0;
    border-radius: var(--radius-md);
    padding: 6px 8px;
  }

  .modal[data-action="schedule"] .wizard-card {
    max-height: min(58dvh, 520px);
    overflow-y: auto;
    overscroll-behavior: contain;
    scrollbar-gutter: stable;
    padding: 14px;
  }

  .modal[data-action="schedule"] .wizard-actions {
    position: sticky;
    bottom: max(10px, env(safe-area-inset-bottom));
    z-index: 3;
    justify-self: end;
    width: max-content;
    margin-top: 0;
    border-radius: 999px;
    background:
      linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 88%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
    box-shadow: var(--focus-shadow), inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
    backdrop-filter: blur(var(--focus-blur));
    -webkit-backdrop-filter: blur(var(--focus-blur));
  }

  .modal[data-action="schedule"] :where(.choice-grid, .lesson-subject-picker, .arts-day-subject-list, .practice-day-list) {
    max-height: 34dvh;
    overflow-y: auto;
    overscroll-behavior: contain;
    padding-right: 4px;
    scrollbar-gutter: stable;
  }

  .modal[data-action="schedule"] .schedule-form-grid {
    grid-template-columns: 1fr;
  }
}

/* Focus Warm Glass OS: phase 56 mobile bottom navigation */
@media (max-width: 640px) {
  .app-shell.sidebar-collapsed .sidebar {
    position: sticky;
    top: max(10px, env(safe-area-inset-top));
    grid-template-columns: 44px minmax(0, 1fr) 44px;
    margin: 10px 12px 0;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

  .app-shell.sidebar-collapsed .sidebar-top {
    display: contents;
  }

  .app-shell.sidebar-collapsed #sidebarToggle {
    display: inline-flex !important;
    position: fixed;
    top: max(18px, env(safe-area-inset-top));
    right: max(18px, env(safe-area-inset-right));
    z-index: 41;
    opacity: 1 !important;
    visibility: visible !important;
    grid-column: 3;
    justify-self: end;
    width: 40px;
    height: 40px;
    min-height: 40px;
    border: 1px solid color-mix(in srgb, var(--primary) 18%, var(--glass-border-strong));
    background: color-mix(in srgb, var(--glass-elevated) 90%, transparent);
    box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 20%, transparent);
  }

  .app-shell.sidebar-collapsed .side-actions {
    position: fixed;
    right: max(12px, env(safe-area-inset-right));
    bottom: max(12px, env(safe-area-inset-bottom));
    left: max(12px, env(safe-area-inset-left));
    z-index: 40;
    display: flex;
    grid-column: auto;
    justify-content: space-between;
    gap: 4px;
    width: auto;
    max-width: none;
    margin-inline: auto;
    overflow: visible;
    border: 1px solid var(--glass-border-strong);
    border-radius: 999px;
    background:
      radial-gradient(circle at 18% 0%, color-mix(in srgb, var(--primary) 13%, transparent), transparent 12rem),
      linear-gradient(145deg, color-mix(in srgb, var(--glass-elevated) 88%, transparent), color-mix(in srgb, var(--glass-surface) 96%, transparent));
    box-shadow: 0 18px 54px rgba(0, 0, 0, 0.18), inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    padding: 6px;
    scrollbar-width: none;
    scroll-snap-type: none;
  }

  .app-shell.sidebar-collapsed .side-button {
    flex: 1 1 0;
    justify-content: center;
    width: auto;
    max-width: 54px;
    height: 42px;
    min-height: 42px;
    border-radius: 999px;
    padding: 0;
  }

  .app-shell.sidebar-collapsed .side-button span:last-child {
    display: none;
  }

  .main-surface {
    padding-bottom: calc(86px + env(safe-area-inset-bottom));
  }

  .mobile-logout {
    margin: 8px 16px calc(96px + env(safe-area-inset-bottom));
  }
}

/* Focus Warm Glass OS: phase 57 mobile workspace polish */
@media (max-width: 640px) {
  .app-shell.sidebar-collapsed {
    padding-bottom: calc(98px + env(safe-area-inset-bottom));
  }

  body:has(.modal[open]) .app-shell.sidebar-collapsed .side-actions,
  body:has(.modal[open]) .app-shell.sidebar-collapsed #sidebarToggle {
    opacity: 0 !important;
    pointer-events: none;
    transform: translateY(calc(100% + 20px));
  }

  .modal-panel {
    padding-bottom: max(12px, env(safe-area-inset-bottom));
  }

  .modal[data-action="schedule"] .wizard-card {
    max-height: min(52dvh, 480px);
  }

  .calendar-sheet {
    margin-bottom: 18px;
  }

  .plan-panel {
    margin-bottom: calc(18px + env(safe-area-inset-bottom));
  }
}

@media (min-width: 641px) and (max-width: 880px) {
  .app-shell {
    padding-bottom: 24px;
  }

  .plan-panel {
    margin-bottom: 24px;
  }
}

/* Focus Warm Glass OS: phase 59 seasonal readability */
.calendar-sheet::after {
  background:
    radial-gradient(circle at 20% 10%, rgba(255, 255, 255, 0.10), transparent 24%),
    var(--calendar-season-vignette),
    var(--calendar-season-noise),
    linear-gradient(180deg, var(--calendar-season-overlay-top), var(--calendar-season-overlay-bottom));
  backdrop-filter: blur(1.4px);
  -webkit-backdrop-filter: blur(1.4px);
}

.calendar-sheet[data-season="winter"] .day-cell {
  background: rgba(255, 255, 255, 0.14);
}

.calendar-sheet[data-season="spring"] .day-cell {
  background: rgba(255, 255, 255, 0.13);
}

.calendar-sheet[data-season="summer"] .day-cell,
.calendar-sheet[data-season="autumn"] .day-cell {
  background: rgba(18, 17, 15, 0.22);
}

/* Focus Warm Glass OS: phase 60 icon polish */
:root {
  --action-image-button-size: 46px;
  --action-image-glyph-size: 36px;
  --micro-icon-button-size: 32px;
  --micro-icon-glyph-size: 20px;
  --micro-icon-glyph-hover-size: 22px;
  --sidebar-icon-size: 30px;
}

.button.action-image-button {
  display: inline-grid;
  width: var(--action-image-button-size);
  min-width: var(--action-image-button-size);
  height: var(--action-image-button-size);
  min-height: var(--action-image-button-size);
  place-items: center;
  overflow: visible;
  padding: 0;
  background-clip: padding-box;
}

.button.action-image-button::before {
  width: var(--action-image-glyph-size);
  height: var(--action-image-glyph-size);
  margin: 0;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  transform-origin: center;
}

.button.action-image-button:is(:hover, :focus-visible)::before {
  transform: translateX(var(--action-icon-shift-x, 0)) scale(1.06);
}

.button.save-image-button,
.button.save-image-button:is(:hover, :focus-visible) {
  width: var(--action-image-button-size);
  min-width: var(--action-image-button-size);
  height: var(--action-image-button-size);
  min-height: var(--action-image-button-size);
  border: 1px solid color-mix(in srgb, var(--line) 72%, var(--primary));
  background: color-mix(in srgb, var(--surface-raised) 88%, transparent);
  box-shadow: var(--shadow-xs), inset 0 1px 0 color-mix(in srgb, #fff 10%, transparent);
}

.button.save-image-button:is(:hover, :focus-visible) {
  filter: brightness(1.08) contrast(1.04) drop-shadow(0 10px 18px rgba(76, 141, 255, 0.20));
}

.button.save-image-button::before {
  display: block;
  --action-icon: var(--icon-save);
}

.icon-action {
  width: var(--micro-icon-button-size);
  min-width: var(--micro-icon-button-size);
  height: var(--micro-icon-button-size);
  min-height: var(--micro-icon-button-size);
  background-position: center;
  background-repeat: no-repeat;
  background-size: var(--micro-icon-glyph-size) var(--micro-icon-glyph-size);
  overflow: visible;
  transform-origin: center;
}

.icon-action:is(:hover, :focus-visible) {
  background-size: var(--micro-icon-glyph-hover-size) var(--micro-icon-glyph-hover-size);
  transform: translateY(-1px) scale(1.04);
}

.side-button .icon,
.logout-button::before,
#sidebarToggle .icon.panel {
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}

.side-button .icon {
  width: var(--sidebar-icon-size);
  min-width: var(--sidebar-icon-size);
  height: var(--sidebar-icon-size);
  flex: 0 0 var(--sidebar-icon-size);
}

.side-button .icon.bell,
.side-button .icon.cake,
.side-button .icon.repeat,
.side-button .icon.pen,
.side-button .icon.note,
.side-button .icon.settings {
  background-position: center;
  background-size: contain;
}

/* Focus Warm Glass OS: phase 61 mobile-tablet visual verification */
@media (max-width: 880px) {
  .app-shell.sidebar-collapsed .sidebar {
    width: auto;
  }
}

@media (min-width: 641px) and (max-width: 880px) {
  .app-shell.sidebar-collapsed .side-actions {
    max-width: min(520px, calc(100vw - 128px));
  }
}

/* Focus Warm Glass OS: phase 62 reference alignment */
:root {
  --reference-card-radius: 24px;
  --reference-shell-gap: 24px;
  --reference-cream: #f6f0e7;
  --reference-card-bg: color-mix(in srgb, var(--glass-elevated) 92%, transparent);
  --reference-card-border: color-mix(in srgb, var(--line) 72%, rgba(255, 255, 255, 0.32));
  --reference-soft-shadow: 0 18px 52px color-mix(in srgb, var(--text) 8%, transparent);
}

body {
  background:
    radial-gradient(circle at 7% 4%, color-mix(in srgb, var(--primary) 8%, transparent), transparent 23rem),
    radial-gradient(circle at 82% 2%, color-mix(in srgb, var(--yellow) 13%, transparent), transparent 28rem),
    radial-gradient(circle at 52% 96%, color-mix(in srgb, var(--green) 9%, transparent), transparent 30rem),
    linear-gradient(135deg, color-mix(in srgb, var(--bg) 94%, var(--reference-cream)), var(--bg-soft));
}

.app-shell {
  grid-template-columns: 280px minmax(0, 1fr) 300px;
  gap: var(--reference-shell-gap);
  align-items: start;
  min-height: 100dvh;
  padding: 18px;
}

.sidebar,
.top-actions > *,
.info-panel,
.day-summary,
.legend,
.calendar-sheet,
.plan-panel,
.quick-actions-panel,
.modal-panel {
  border: 1px solid var(--reference-card-border);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--reference-card-bg) 90%, transparent), color-mix(in srgb, var(--glass-surface) 78%, transparent));
  box-shadow: var(--reference-soft-shadow), inset 0 1px 0 color-mix(in srgb, #fff 22%, transparent);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
}

.sidebar {
  position: sticky;
  top: 18px;
  min-height: calc(100dvh - 36px);
  border-radius: var(--reference-card-radius);
  padding: 18px 14px;
}

.sidebar-top {
  margin-bottom: 20px;
}

.brand.compact {
  gap: 12px;
}

.brand.compact .brand-mark {
  width: 42px;
  height: 42px;
  border-radius: 13px;
}

.brand.compact strong {
  font-size: 1.08rem;
}

.side-actions {
  gap: 8px;
}

.side-button {
  min-height: 48px;
  border-color: transparent;
  border-radius: 14px;
  background: transparent;
  color: var(--text);
  padding-inline: 12px;
}

.side-button:hover,
.side-button.active {
  border-color: color-mix(in srgb, var(--primary) 16%, transparent);
  background: color-mix(in srgb, var(--primary) 11%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 22%, transparent);
}

.main-surface {
  display: grid;
  gap: 18px;
  min-width: 0;
  padding: 0;
}

.topbar {
  position: static;
  min-height: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
}

.top-actions {
  display: grid;
  grid-template-columns: minmax(230px, 260px) minmax(280px, 1fr) minmax(170px, 190px);
  gap: 18px;
  align-items: stretch;
  width: 100%;
}

.top-actions > * {
  min-height: 86px;
  border-radius: var(--reference-card-radius);
  padding: 18px;
}

.current-date {
  display: flex;
  align-items: center;
  gap: 14px;
  color: var(--text);
  font-size: 1rem;
  font-weight: 650;
  line-height: 1.28;
  overflow: hidden;
  white-space: normal;
}

.current-date::before {
  content: "";
  display: grid;
  width: 42px;
  height: 42px;
  flex: 0 0 auto;
  border: 1px solid var(--line);
  border-radius: 14px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--glass-strong) 82%, transparent), color-mix(in srgb, var(--glass-surface) 88%, transparent));
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 22%, transparent);
}

.quote-ticker {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 14px;
  align-items: center;
}

.quote-ticker strong {
  display: none;
}

.ticker-window {
  min-width: 0;
}

.bookmark-card {
  display: flex;
  align-items: center;
  gap: 14px;
  color: var(--text);
  font-weight: 650;
  text-align: left;
}

.bookmark-card-icon {
  width: 26px;
  height: 26px;
  flex: 0 0 auto;
  background: color-mix(in srgb, var(--text) 72%, transparent);
}

.today-board {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.today-board .mobile-current-date {
  display: none;
}

.info-panel,
.day-summary,
.plan-panel,
.quick-actions-panel {
  border-radius: var(--reference-card-radius);
  padding: 20px;
}

.compact-info {
  min-height: 226px;
}

.panel-title h2,
.panel-title h3,
.quick-actions-panel h3 {
  color: var(--primary);
  font-size: 1.08rem;
  font-weight: 700;
}

.info-list li,
.summary-item,
.task-card,
.quick-action {
  border: 1px solid color-mix(in srgb, var(--line) 74%, transparent);
  border-radius: 14px;
  background: color-mix(in srgb, var(--glass-surface) 76%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
}

.day-summary {
  grid-column: 1 / -1;
}

.legend {
  border-radius: 18px;
  padding: 12px 16px;
}

.calendar-sheet {
  border-radius: var(--reference-card-radius);
  padding: 18px;
}

.calendar-grid {
  gap: 8px;
}

.day-cell {
  border-radius: 14px;
  min-height: 58px;
  background: color-mix(in srgb, rgba(255, 255, 255, 0.30) 65%, transparent);
}

.plan-panel {
  position: sticky;
  top: 18px;
  display: grid;
  gap: 16px;
  align-self: start;
}

.plan-panel > .button.full {
  min-height: 46px;
  border-radius: 16px;
}

.quick-actions-panel {
  display: grid;
  gap: 10px;
  padding: 16px;
}

.quick-actions-panel h3 {
  margin: 0 0 4px;
}

.quick-action {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 44px;
  color: var(--text);
  font-weight: 650;
  padding: 0 12px;
  text-align: left;
}

.quick-action span {
  display: grid;
  width: 22px;
  height: 22px;
  flex: 0 0 auto;
  place-items: center;
  border-radius: 8px;
  color: var(--primary);
  background: color-mix(in srgb, var(--primary) 10%, transparent);
}

.quick-action:hover {
  border-color: color-mix(in srgb, var(--primary) 20%, transparent);
  background: color-mix(in srgb, var(--primary) 7%, var(--glass-surface));
}

:root[data-theme="dark"] .bookmark-card-icon {
  background: color-mix(in srgb, var(--text) 82%, transparent);
}

:root[data-theme="dark"] body {
  background:
    radial-gradient(circle at 10% 0%, color-mix(in srgb, var(--primary) 14%, transparent), transparent 26rem),
    radial-gradient(circle at 86% 8%, rgba(216, 154, 61, 0.08), transparent 28rem),
    linear-gradient(135deg, #131722, #171b27 48%, #10131c);
}

@media (max-width: 1180px) {
  .app-shell {
    grid-template-columns: 72px minmax(0, 1fr);
    gap: 16px;
  }

  .plan-panel {
    position: static;
    grid-column: 2;
  }

  .top-actions {
    grid-template-columns: minmax(210px, 240px) minmax(260px, 1fr);
  }

  .bookmark-card {
    display: none;
  }
}

@media (max-width: 880px) {
  .app-shell,
  .app-shell.sidebar-collapsed {
    display: block;
    padding: 12px;
    overflow-x: hidden;
  }

  .sidebar {
    position: static;
    width: auto;
    max-width: calc(100vw - 24px);
    box-sizing: border-box;
    min-height: 0;
    margin-bottom: 14px;
    padding: 10px;
  }

  .main-surface {
    gap: 14px;
    width: 100%;
    max-width: calc(100vw - 24px);
    overflow-x: hidden;
  }

  .topbar,
  .top-actions,
  .today-board,
  .calendar-sheet,
  .plan-panel {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
  }

  .topbar,
  .quote-ticker,
  .ticker-window {
    overflow: hidden;
  }

  .topbar {
    display: block;
  }

  .top-actions {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .top-actions > * {
    min-height: 58px;
    padding: 12px 14px;
  }

  .today-board {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .day-summary {
    grid-column: auto;
  }

  .plan-panel {
    margin-top: 14px;
  }
}

@media (max-width: 640px) {
  .quote-ticker {
    grid-template-columns: 1fr;
  }

  .quote-ticker::before {
    display: none;
  }

  .compact-info {
    min-height: 0;
  }

  .day-cell {
    min-height: 50px;
  }
}

/* Focus Warm Glass OS: phase 63 reference gap fixes */
:root {
  --icon-calendar: url("/assets/icons/outline-calendar.svg?v=20260517");
  --icon-reminder: url("/assets/icons/outline-reminder.svg?v=20260517");
  --icon-birthday: url("/assets/icons/outline-birthday.svg?v=20260517");
  --icon-schedule: url("/assets/icons/outline-schedule.svg?v=20260517");
  --icon-diary: url("/assets/icons/outline-diary.svg?v=20260517");
  --icon-note: url("/assets/icons/outline-note.svg?v=20260517");
  --icon-settings: url("/assets/icons/outline-settings.svg?v=20260517");
  --icon-edit: url("/assets/icons/outline-edit.svg?v=20260517");
  --icon-delete: url("/assets/icons/outline-delete.svg?v=20260517");
  --icon-mic: url("/assets/icons/outline-mic.svg?v=20260517");
  --icon-back: url("/assets/icons/outline-back.svg?v=20260517");
  --icon-next: url("/assets/icons/outline-next.svg?v=20260517");
  --icon-save: url("/assets/icons/outline-save.svg?v=20260517");
  --icon-cancel: url("/assets/icons/outline-cancel.svg?v=20260517");
  --icon-bookmark: url("/assets/icons/outline-bookmark.svg?v=20260517");
  --icon-plus: url("/assets/icons/outline-plus.svg?v=20260517");
  --icon-move: url("/assets/icons/outline-move.svg?v=20260517");
}

.top-actions {
  border: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.current-date::before {
  position: relative;
  background: linear-gradient(180deg, color-mix(in srgb, var(--glass-strong) 82%, transparent), color-mix(in srgb, var(--glass-surface) 88%, transparent));
}

.current-date::before::after {
  content: none;
}

.current-date::before {
  -webkit-mask: none;
  mask: none;
}

.current-date {
  position: relative;
}

.current-date::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 28px;
  display: block;
  width: 22px;
  height: 22px;
  flex: 0 0 auto;
  background: currentColor;
  -webkit-mask: var(--icon-calendar) center / contain no-repeat;
  mask: var(--icon-calendar) center / contain no-repeat;
  pointer-events: none;
  transform: translateY(-50%);
}

.quote-ticker::before {
  position: static;
  inset: auto;
  width: auto;
  height: auto;
  border-radius: 0;
  background: none;
  content: "“";
}

.button.action-image-button {
  color: var(--primary);
  overflow: visible;
}

.button.action-image-button::before {
  background: currentColor;
  background-image: none;
  -webkit-mask: var(--action-icon, var(--icon-back)) center / var(--action-image-glyph-size, 32px) var(--action-image-glyph-size, 32px) no-repeat;
  mask: var(--action-icon, var(--icon-back)) center / var(--action-image-glyph-size, 32px) var(--action-image-glyph-size, 32px) no-repeat;
  filter: none;
}

.button.back-image-button::before {
  --action-icon: var(--icon-back);
}

.button.next-image-button::before {
  --action-icon: var(--icon-next);
}

.button.save-image-button::before {
  --action-icon: var(--icon-save);
}

.button.cancel-image-button::before {
  --action-icon: var(--icon-cancel);
}

.icon-action {
  background-image: none;
}

.icon-action::before {
  position: static;
  display: block !important;
  width: var(--micro-icon-glyph-size, 20px);
  height: var(--micro-icon-glyph-size, 20px);
  border: 0;
  border-radius: 0;
  background: currentColor;
  -webkit-mask: var(--micro-icon, var(--icon-note)) center / contain no-repeat;
  mask: var(--micro-icon, var(--icon-note)) center / contain no-repeat;
  transform: none;
  transition: transform var(--motion-fast);
}

.icon-action:is(:hover, :focus-visible)::before {
  transform: scale(1.08);
}

.icon.mic,
.side-button .icon {
  background-color: currentColor;
  background-image: none;
  -webkit-mask: var(--side-icon, var(--icon-note)) center / contain no-repeat;
  mask: var(--side-icon, var(--icon-note)) center / contain no-repeat;
}

.icon.mic {
  -webkit-mask-image: var(--icon-mic);
  mask-image: var(--icon-mic);
}

.side-button .icon.bell {
  --side-icon: var(--icon-reminder);
}

.side-button .icon.cake {
  --side-icon: var(--icon-birthday);
}

.side-button .icon.repeat {
  --side-icon: var(--icon-schedule);
}

.side-button .icon.pen {
  --side-icon: var(--icon-diary);
}

.side-button .icon.note {
  --side-icon: var(--icon-note);
}

.side-button .icon.settings {
  --side-icon: var(--icon-settings);
}

.bookmark-card-icon {
  clip-path: none;
  background: currentColor;
  -webkit-mask: var(--icon-bookmark) center / contain no-repeat;
  mask: var(--icon-bookmark) center / contain no-repeat;
}

.quick-action [data-quick-icon] {
  color: var(--primary);
}

.quick-action [data-quick-icon]::before {
  content: "";
  display: block;
  width: 16px;
  height: 16px;
  background: currentColor;
  -webkit-mask: var(--quick-icon, var(--icon-plus)) center / contain no-repeat;
  mask: var(--quick-icon, var(--icon-plus)) center / contain no-repeat;
}

.quick-action [data-quick-icon="schedule"] {
  --quick-icon: var(--icon-schedule);
}

.quick-action [data-quick-icon="reminder"] {
  --quick-icon: var(--icon-reminder);
}

.quick-action [data-quick-icon="note"] {
  --quick-icon: var(--icon-note);
}

.quick-action [data-quick-icon="diary"] {
  --quick-icon: var(--icon-diary);
}

.calendar-sheet::before {
  filter: saturate(1.1) contrast(1.04);
  transform: none;
}

.calendar-sheet::after {
  background:
    radial-gradient(circle at 18% 10%, rgba(255, 255, 255, 0.08), transparent 24%),
    var(--calendar-season-noise),
    linear-gradient(180deg, rgba(18, 17, 15, 0.08), rgba(12, 11, 10, 0.22));
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.day-cell {
  background: rgba(255, 255, 255, 0.14);
  backdrop-filter: blur(7px);
  -webkit-backdrop-filter: blur(7px);
}

.calendar-sheet[data-season="summer"] .day-cell,
.calendar-sheet[data-season="autumn"] .day-cell {
  background: rgba(18, 17, 15, 0.16);
}

@media (max-width: 640px) {
  .quote-ticker::before {
    display: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
  }
}

/* Focus Warm Glass OS: phase 64 main screen reference pass */
:root {
  --main-screen-gap: 22px;
  --main-screen-pad: 18px;
  --reference-card-radius: 24px;
  --reference-dock-radius: 22px;
  --reference-card-bg: color-mix(in srgb, var(--glass-elevated) 84%, transparent);
  --reference-card-border: color-mix(in srgb, var(--glass-border-strong) 72%, var(--line));
  --reference-card-highlight: inset 0 1px 0 color-mix(in srgb, #fff 28%, transparent);
  --reference-soft-shadow: 0 18px 52px color-mix(in srgb, var(--text) 8%, transparent);
  --reference-floating-shadow: 0 24px 70px color-mix(in srgb, var(--text) 11%, transparent);
}

body {
  background:
    radial-gradient(circle at 11% 3%, color-mix(in srgb, var(--primary) 10%, transparent), transparent 28rem),
    radial-gradient(circle at 82% 4%, color-mix(in srgb, var(--yellow) 12%, transparent), transparent 30rem),
    radial-gradient(circle at 50% 110%, color-mix(in srgb, var(--green) 8%, transparent), transparent 34rem),
    linear-gradient(135deg, color-mix(in srgb, var(--bg) 94%, #f8efe2), var(--bg-soft));
}

.app-shell {
  grid-template-columns: var(--sidebar) minmax(0, 1fr) 300px;
  gap: 22px;
  align-items: start;
  min-height: 100dvh;
  padding: 18px;
}

.app-shell.sidebar-collapsed {
  grid-template-columns: 72px minmax(0, 1fr) 300px;
}

.sidebar {
  position: sticky;
  top: 18px;
  height: calc(100vh - 36px);
  min-height: 0;
  border: 1px solid var(--reference-card-border);
  border-radius: var(--radius-xl);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--reference-card-bg) 94%, transparent), color-mix(in srgb, var(--glass-surface) 78%, transparent));
  box-shadow: var(--reference-floating-shadow), var(--reference-card-highlight);
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
  padding: 18px 14px;
}

.sidebar-top {
  min-height: 44px;
  margin-bottom: 20px;
  padding: 0 4px;
}

.brand.compact .brand-mark {
  width: 42px;
  height: 42px;
  border-radius: 14px;
}

.side-actions {
  gap: 8px;
}

.side-button {
  min-height: 48px;
  border-radius: 14px;
  color: var(--text);
  padding-inline: 12px;
}

.side-button:hover,
.side-button.active {
  border-color: color-mix(in srgb, var(--primary) 16%, transparent);
  background: color-mix(in srgb, var(--primary) 11%, transparent);
  box-shadow: var(--reference-card-highlight), 0 10px 28px color-mix(in srgb, var(--primary) 9%, transparent);
  transform: translateX(2px);
}

.main-surface {
  display: grid;
  gap: 18px;
  min-width: 0;
  border-right: 0;
  padding: 0;
}

.topbar {
  position: sticky;
  top: 18px;
  z-index: 12;
  min-height: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  padding: 0;
}

.top-actions {
  display: grid;
  grid-template-columns: minmax(190px, 240px) minmax(0, 1fr) minmax(180px, 220px);
  align-items: stretch;
  gap: 18px;
  width: 100%;
}

.top-actions > *,
:where(.info-panel, .day-summary, .legend, .plan-panel, .quick-actions-panel) {
  border: 1px solid var(--reference-card-border);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--reference-card-bg) 96%, transparent), color-mix(in srgb, var(--glass-surface) 78%, transparent));
  box-shadow: var(--reference-soft-shadow), var(--reference-card-highlight);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

.top-actions > * {
  min-height: 74px;
  padding: 16px 18px;
}

.current-date {
  min-height: 74px;
  border: 1px solid var(--reference-card-border);
  border-radius: var(--radius-lg);
  color: var(--text);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--reference-card-bg) 96%, transparent), color-mix(in srgb, var(--glass-surface) 78%, transparent));
  box-shadow: var(--reference-soft-shadow), var(--reference-card-highlight);
  font-size: 1rem;
  font-weight: 650;
  line-height: 1.3;
  padding: 0 18px 0 68px;
  white-space: normal;
}

.current-date::after {
  left: 24px;
  width: 24px;
  height: 24px;
}

.current-date::before {
  position: absolute;
  left: 14px;
  top: 50%;
  width: 44px;
  height: 44px;
  border: 1px solid var(--reference-card-border);
  border-radius: 14px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--glass-strong) 86%, transparent), color-mix(in srgb, var(--glass-surface) 90%, transparent));
  box-shadow: var(--reference-card-highlight);
  content: "";
  transform: translateY(-50%);
}

.quote-ticker {
  grid-column: auto;
  grid-template-columns: auto minmax(0, 1fr);
  min-height: 74px;
  gap: 14px;
  padding: 16px 18px;
}

.quote-ticker::before {
  display: block;
  color: var(--text);
  content: "“";
  font-family: Georgia, serif;
  font-size: 2.3rem;
  line-height: 1;
}

.quote-ticker strong {
  display: none;
}

.ticker-window {
  align-self: center;
  border-radius: 999px;
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--glass-surface) 64%, transparent), color-mix(in srgb, var(--glass-elevated) 38%, transparent));
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
  padding: 3px 0;
}

.bookmark-card {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 14px;
  min-height: 74px;
  color: var(--text);
  font-size: 0.96rem;
  font-weight: 650;
  text-align: left;
}

.bookmark-card-icon {
  width: 26px;
  height: 26px;
  flex: 0 0 auto;
}

.today-board {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(260px, 0.8fr);
  gap: 18px;
  padding: 0;
}

.today-board .day-summary {
  grid-column: auto;
}

.info-panel,
.day-summary {
  min-height: 226px;
  padding: 20px;
}

.info-panel::before,
.day-summary::before {
  display: none;
}

.panel-title {
  margin-bottom: 14px;
}

.panel-title h2,
.panel-title h3,
.quick-actions-panel h3 {
  color: var(--primary);
  font-size: 1.08rem;
  font-weight: 750;
}

.scroll-list {
  max-height: 142px;
}

.summary-list {
  grid-template-columns: 1fr;
}

.summary-item,
.task-item,
.quick-action {
  border: 1px solid color-mix(in srgb, var(--line) 74%, transparent);
  border-radius: 14px;
  background: color-mix(in srgb, var(--glass-surface) 72%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
}

.legend {
  margin: 0;
  padding: 12px 16px;
}

.calendar-sheet {
  margin: 0;
  border-radius: var(--radius-lg);
  box-shadow: var(--focus-shadow-elevated), inset 0 1px 0 rgba(255, 255, 255, 0.12), var(--calendar-season-glow);
  padding: 18px;
}

.calendar-sheet::before {
  filter: saturate(1.18) contrast(1.08) brightness(1.03);
  transform: none;
}

.calendar-sheet::after {
  background:
    radial-gradient(circle at 18% 8%, rgba(255, 255, 255, 0.10), transparent 28%),
    var(--calendar-season-noise),
    linear-gradient(180deg, rgba(18, 17, 15, 0.04), rgba(12, 11, 10, 0.16));
}

.day-cell {
  min-height: clamp(62px, 6.4vw, 92px);
  border-color: rgba(255, 255, 255, 0.18);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.16);
  box-shadow: 0 9px 24px rgba(0, 0, 0, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.12);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  text-shadow: 0 1px 12px rgba(0, 0, 0, 0.38);
}

.calendar-sheet[data-season="summer"] .day-cell,
.calendar-sheet[data-season="autumn"] .day-cell {
  background: rgba(18, 17, 15, 0.14);
}

.plan-panel {
  position: sticky;
  top: 18px;
  height: calc(100vh - 36px);
  align-self: start;
  border-width: 1px;
  border-radius: var(--radius-xl);
  padding: 20px;
}

.quick-actions-panel {
  display: grid;
  gap: 10px;
  margin-top: 4px;
  padding: 16px;
}

.quick-actions-panel h3 {
  margin: 0 0 4px;
}

.quick-action {
  min-height: 44px;
  color: var(--text);
  font-weight: 650;
  padding: 0 12px;
}

.quick-action span {
  display: grid;
  width: 22px;
  height: 22px;
  flex: 0 0 auto;
  place-items: center;
  border-radius: 8px;
  color: var(--primary);
  background: color-mix(in srgb, var(--primary) 10%, transparent);
}

.quick-action:hover {
  border-color: color-mix(in srgb, var(--primary) 20%, transparent);
  background: color-mix(in srgb, var(--primary) 7%, var(--glass-surface));
}

:root[data-theme="dark"] body {
  background:
    radial-gradient(circle at 12% 0%, color-mix(in srgb, var(--primary) 14%, transparent), transparent 27rem),
    radial-gradient(circle at 86% 8%, rgba(216, 154, 61, 0.08), transparent 28rem),
    linear-gradient(135deg, #131722, #171b27 48%, #10131c);
}

@media (max-width: 1280px) {
  .app-shell {
    grid-template-columns: var(--sidebar) minmax(0, 1fr);
  }

  .app-shell.sidebar-collapsed {
    grid-template-columns: 72px minmax(0, 1fr);
  }

  .plan-panel {
    position: static;
    grid-column: 2;
    height: auto;
    min-height: 0;
  }
}

@media (max-width: 1120px) {
  .top-actions {
    grid-template-columns: minmax(190px, 230px) minmax(0, 1fr);
  }

  .bookmark-card {
    display: none;
  }

  .today-board {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .today-board .day-summary {
    grid-column: 1 / -1;
  }
}

@media (max-width: 880px) {
  .app-shell,
  .app-shell.sidebar-collapsed {
    display: block;
    padding: 12px;
    overflow-x: hidden;
  }

  .sidebar {
    position: static;
    width: auto;
    max-width: calc(100vw - 24px);
    height: auto;
    min-height: 0;
    margin-bottom: 14px;
    padding: 10px;
  }

  .topbar {
    position: static;
  }

  .top-actions,
  .today-board {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .top-actions > *,
  .current-date,
  .quote-ticker,
  .bookmark-card {
    min-height: 58px;
    padding-block: 12px;
  }

  .today-board .day-summary {
    grid-column: auto;
  }

  .plan-panel {
    height: auto;
    margin-top: 14px;
  }
}

@media (max-width: 640px) {
  .current-date {
    padding-left: 58px;
  }

  .current-date::before {
    left: 10px;
    width: 38px;
    height: 38px;
  }

  .current-date::after {
    left: 20px;
    width: 18px;
    height: 18px;
  }

  .quote-ticker {
    grid-template-columns: 1fr;
  }

  .quote-ticker::before {
    display: none;
  }

  .info-panel,
  .day-summary {
    min-height: 0;
  }
}

/* Focus Warm Glass OS: phase 65 CSS cleanup */
.bookmark-card-icon {
  clip-path: none;
}

/* Focus Warm Glass OS: right panel split */
.right-panel {
  position: sticky;
  top: 18px;
  display: grid;
  gap: 18px;
  align-self: start;
  min-width: 0;
}

.right-panel .plan-panel {
  position: static;
  grid-column: auto;
  height: auto;
  min-height: 0;
}

.right-panel .quick-actions-panel {
  margin-top: 0;
}

@media (max-width: 1280px) {
  .right-panel {
    position: static;
    grid-column: 2;
  }
}

@media (max-width: 880px) {
  .right-panel {
    display: grid;
    gap: 14px;
    margin-top: 14px;
  }
}

/* Focus Warm Glass OS: sidebar footer polish */
.sidebar-footer {
  display: grid;
  gap: 12px;
  margin-top: auto;
}

.sidebar-user-card {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  min-height: 62px;
  padding: 10px;
  border: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  border-radius: 18px;
  background: color-mix(in srgb, var(--glass-surface) 76%, transparent);
  box-shadow: var(--focus-shadow-soft), inset 0 1px 0 color-mix(in srgb, #fff 20%, transparent);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.sidebar-user-avatar {
  display: grid;
  width: 42px;
  height: 42px;
  place-items: center;
  border-radius: 14px;
  color: #f0a01f;
  font-size: 20px;
  font-weight: 750;
  background: linear-gradient(145deg, #151511, #25231d);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.14), 0 10px 24px rgba(0, 0, 0, 0.12);
}

.sidebar-user-text {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.sidebar-user-text strong,
.sidebar-user-text small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sidebar-user-text strong {
  color: var(--text);
  font-size: 14px;
  font-weight: 700;
}

.sidebar-user-text small {
  color: var(--text-muted);
  font-size: 12px;
  font-weight: 550;
}

.app-shell.sidebar-collapsed .sidebar-footer {
  align-items: center;
}

.app-shell.sidebar-collapsed .sidebar-user-card {
  grid-template-columns: 42px;
  justify-content: center;
  width: 48px;
  min-height: 48px;
  padding: 3px;
}

.app-shell.sidebar-collapsed .sidebar-user-text {
  display: none;
}

@media (max-width: 880px) {
  .sidebar-footer {
    margin-top: 0;
  }

  .sidebar-user-card {
    display: none;
  }
}

/* Focus Warm Glass OS: sidebar nav rhythm */
.side-actions {
  gap: 10px;
  align-content: start;
}

.side-button {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  min-height: 50px;
  border-radius: 16px;
  padding: 0 12px 0 8px;
}

.side-button .icon {
  display: grid;
  width: 34px;
  min-width: 34px;
  height: 34px;
  place-self: center;
  border-radius: 12px;
  background-color: currentColor;
}

.side-button:hover,
.side-button.active {
  border-color: color-mix(in srgb, var(--primary) 18%, transparent);
  color: var(--text);
  background:
    radial-gradient(circle at 10% 50%, color-mix(in srgb, var(--primary) 13%, transparent), transparent 62%),
    color-mix(in srgb, var(--primary) 12%, transparent);
  box-shadow: var(--reference-card-highlight), 0 12px 28px color-mix(in srgb, var(--primary) 10%, transparent);
  transform: translateX(2px);
}

.side-button:focus-visible {
  outline: none;
  box-shadow:
    0 0 0 4px color-mix(in srgb, var(--primary) 16%, transparent),
    var(--reference-card-highlight);
}

.settings-action {
  margin-top: 10px;
  padding-top: 0;
  border-top: 0;
}

.app-shell.sidebar-collapsed .side-button {
  grid-template-columns: 1fr;
  width: 48px;
  height: 48px;
  min-height: 48px;
  place-items: center;
  padding: 0;
}

.app-shell.sidebar-collapsed .side-button .icon {
  width: 32px;
  min-width: 32px;
  height: 32px;
}

@media (max-width: 880px) {
  .app-shell.sidebar-collapsed .side-button {
    width: 42px;
    height: 42px;
    min-height: 42px;
  }

  .app-shell.sidebar-collapsed .side-button .icon {
    width: 30px;
    min-width: 30px;
    height: 30px;
  }
}

/* Focus Warm Glass OS: right rail rhythm */
.quick-actions-panel {
  display: grid;
  gap: 12px;
  padding: 18px;
}

.quick-actions-panel h3 {
  margin: 0 0 2px;
  letter-spacing: 0;
}

.quick-action {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  min-height: 50px;
  border-radius: 16px;
  padding: 0 12px 0 8px;
  text-align: left;
}

.quick-action [data-quick-icon] {
  display: grid;
  width: 34px;
  height: 34px;
  place-items: center;
  border-radius: 12px;
  color: var(--primary);
  background:
    radial-gradient(circle at 35% 25%, color-mix(in srgb, #fff 24%, transparent), transparent 52%),
    color-mix(in srgb, var(--primary) 11%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 20%, transparent);
}

.quick-action [data-quick-icon]::before {
  width: 19px;
  height: 19px;
}

.quick-action:hover {
  border-color: color-mix(in srgb, var(--primary) 18%, transparent);
  background:
    radial-gradient(circle at 10% 50%, color-mix(in srgb, var(--primary) 11%, transparent), transparent 60%),
    color-mix(in srgb, var(--primary) 7%, var(--glass-surface));
  box-shadow: var(--reference-card-highlight), 0 12px 28px color-mix(in srgb, var(--primary) 9%, transparent);
  transform: translateY(-1px);
}

.quick-action:focus-visible {
  outline: none;
  box-shadow:
    0 0 0 4px color-mix(in srgb, var(--primary) 16%, transparent),
    var(--reference-card-highlight);
}

.plan-panel > .button.full {
  min-height: 50px;
  border-radius: 16px;
}

@media (max-width: 880px) {
  .quick-actions-panel {
    padding: 16px;
  }

  .quick-action {
    min-height: 48px;
  }
}

/* Focus Warm Glass OS: today overview rhythm */
.today-board :where(.info-panel, .day-summary) {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 14px;
  min-height: 226px;
}

.today-board .panel-title {
  position: relative;
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  margin: 0;
}

.today-board .panel-title::before {
  display: grid;
  width: 38px;
  height: 38px;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--primary) 18%, transparent);
  border-radius: 13px;
  color: var(--primary);
  background:
    radial-gradient(circle at 34% 20%, color-mix(in srgb, #fff 26%, transparent), transparent 54%),
    color-mix(in srgb, var(--primary) 10%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 20%, transparent);
  content: "";
}

.today-board .panel-title::after {
  position: absolute;
  left: 8.5px;
  top: 50%;
  display: block;
  width: 21px;
  height: 21px;
  background: var(--primary);
  content: "";
  transform: translateY(-50%);
  -webkit-mask: var(--overview-icon, var(--icon-calendar)) center / contain no-repeat;
  mask: var(--overview-icon, var(--icon-calendar)) center / contain no-repeat;
}

.today-board .info-panel:nth-of-type(1) .panel-title {
  --overview-icon: var(--icon-birthday);
}

.today-board .info-panel:nth-of-type(2) .panel-title {
  --overview-icon: var(--icon-calendar);
}

.today-board .day-summary .panel-title {
  --overview-icon: var(--icon-schedule);
}

.today-board .panel-title h3 {
  margin: 0;
  line-height: 1.2;
}

.today-board .info-list {
  display: grid;
  align-content: start;
  gap: 8px;
  margin: 0;
  padding: 0 2px 0 0;
}

.today-board .info-list li {
  display: grid;
  gap: 3px;
  min-height: 52px;
  border: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  border-radius: 14px;
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--glass-surface) 76%, transparent), color-mix(in srgb, var(--glass-elevated) 34%, transparent));
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
  padding: 10px 12px;
}

.today-board .info-list li:first-child {
  border-top: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
}

.today-board .info-list strong,
.day-summary .summary-item strong {
  color: var(--text);
  line-height: 1.25;
}

.today-board .info-list small,
.day-summary .summary-item small {
  color: var(--text-muted);
  font-size: 0.82rem;
  line-height: 1.25;
}

.day-summary .summary-list {
  align-content: start;
  gap: 8px;
}

.day-summary .summary-item {
  display: grid;
  grid-template-columns: 10px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  min-height: 54px;
  padding: 10px 12px;
}

.day-summary .summary-item i {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--summary-color, var(--primary));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--summary-color, var(--primary)) 14%, transparent);
}

.day-summary .summary-item:hover,
.today-board .info-list li:hover {
  border-color: color-mix(in srgb, var(--primary) 16%, transparent);
  background:
    radial-gradient(circle at 10% 50%, color-mix(in srgb, var(--primary) 8%, transparent), transparent 62%),
    color-mix(in srgb, var(--glass-surface) 78%, transparent);
  transform: translateY(-1px);
}

@media (max-width: 880px) {
  .today-board :where(.info-panel, .day-summary) {
    min-height: 0;
  }
}

/* Focus Warm Glass OS: calendar image clarity */
.calendar-sheet::before {
  filter: saturate(1.24) contrast(1.1) brightness(1.08);
}

.calendar-sheet::after {
  background:
    radial-gradient(circle at 18% 8%, rgba(255, 255, 255, 0.08), transparent 24%),
    var(--calendar-season-noise),
    linear-gradient(180deg, rgba(18, 17, 15, 0.02), rgba(12, 11, 10, 0.12));
}

.day-cell {
  border-color: rgba(255, 255, 255, 0.20);
  background: rgba(255, 255, 255, 0.105);
  box-shadow: 0 9px 24px rgba(0, 0, 0, 0.10), inset 0 1px 0 rgba(255, 255, 255, 0.14);
  backdrop-filter: blur(1.5px);
  -webkit-backdrop-filter: blur(1.5px);
}

.calendar-sheet[data-season="summer"] .day-cell,
.calendar-sheet[data-season="autumn"] .day-cell {
  background: rgba(18, 17, 15, 0.08);
}

.day-cell.outside {
  background: rgba(18, 17, 15, 0.055);
}

.day-cell.today {
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--calendar-season-accent, var(--primary)) 28%, transparent), transparent 62%),
    rgba(255, 255, 255, 0.15);
}

.day-cell.selected {
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--primary) 32%, transparent), transparent 62%),
    rgba(18, 17, 15, 0.18);
}
