:root {
  --font-display: "Lora", Georgia, serif;
  --font-ui: "Inter", system-ui, sans-serif;

  --bg: #fff8f3;
  --bg-soft: #fdf0e8;
  --panel: #ffffff;
  --surface: #ffffff;
  --surface-warm: #fff3ec;
  --ink: #2a171a;
  --muted: #7a6261;
  --text-soft: #a58a86;
  --line: #f0dcd4;
  --line-strong: #e5c8bd;
  --accent: #e85d56;
  --accent-dark: #d94d47;
  --primary-soft: #ffe2dc;
  --secondary-soft: #ffe8d6;
  --success: #2f8f6b;
  --success-soft: #effaf4;
  --success-line: #9dd7b7;
  --blue: #f28c52;
  --amber: #d9a441;
  --danger: #c94a4a;
  --soft: #ffe2dc;
  --sidebar: #3a2026;
  --sidebar-hover: #4a2a31;
  --sidebar-active: #b85c5c;
  --sidebar-text: #fff7f1;
  --sidebar-muted: #e7cfc8;
  --input-bg: #fffdfb;
  --entry-bg: #fffaf6;
  --track: #f3dfd8;
  --actual-bar: linear-gradient(90deg, #e85d56, #f28c52);
  --shadow: 0 14px 32px rgba(91, 45, 38, 0.10);
  --focus-ring: rgba(232, 93, 86, 0.14);
  --drag-ring: rgba(232, 93, 86, 0.30);
  --button-text: #ffffff;
}

:root[data-theme="dark"] {
  --bg: #211318;
  --bg-soft: #2d1a20;
  --panel: #2a1a20;
  --surface: #2a1a20;
  --surface-warm: #342129;
  --ink: #fff7f1;
  --muted: #d8bcb4;
  --text-soft: #b99891;
  --line: #53343b;
  --line-strong: #74464c;
  --accent: #ff7a70;
  --accent-dark: #ff8f6a;
  --primary-soft: #44252b;
  --success: #43b783;
  --success-soft: #1f372b;
  --success-line: #3d8d67;
  --blue: #f2a164;
  --amber: #f0c063;
  --danger: #ff7b72;
  --soft: #44252b;
  --sidebar: #1a0f13;
  --sidebar-hover: #3b2229;
  --sidebar-active: #7d3f45;
  --sidebar-text: #fff7f1;
  --sidebar-muted: #d8bcb4;
  --input-bg: #21161b;
  --entry-bg: #25181d;
  --track: #4a3035;
  --actual-bar: linear-gradient(90deg, #ff7a70, #f2a164);
  --shadow: 0 16px 40px rgba(0, 0, 0, 0.30);
  --focus-ring: rgba(255, 122, 112, 0.18);
  --drag-ring: rgba(255, 122, 112, 0.38);
  --button-text: #211318;
}

:root[data-color-theme="solar"] {
  --bg: #fff8e9;
  --bg-soft: #ffefcf;
  --panel: #fffdf8;
  --surface: #fffdf8;
  --surface-warm: #fff2d8;
  --ink: #1d2440;
  --muted: #68615c;
  --text-soft: #94887d;
  --line: #f1d9ad;
  --line-strong: #e8c57f;
  --accent: #d43a00;
  --accent-dark: #9b0800;
  --primary-soft: #ffe0c2;
  --secondary-soft: #fff0c9;
  --blue: #f69a0b;
  --amber: #fdbf5c;
  --danger: #9b0800;
  --soft: #ffead3;
  --sidebar: #1d2440;
  --sidebar-hover: #293250;
  --sidebar-active: #d43a00;
  --sidebar-text: #fff8e9;
  --sidebar-muted: #f1d9ad;
  --input-bg: #fffdf8;
  --entry-bg: #fffbf2;
  --track: #f4dfc5;
  --actual-bar: linear-gradient(90deg, #d43a00, #f69a0b);
  --shadow: 0 14px 32px rgba(83, 48, 9, 0.11);
  --focus-ring: rgba(212, 58, 0, 0.15);
  --drag-ring: rgba(212, 58, 0, 0.32);
}

:root[data-color-theme="slate"] {
  --bg: #f5f5f1;
  --bg-soft: #e9eae6;
  --panel: #ffffff;
  --surface: #ffffff;
  --surface-warm: #f1f2ef;
  --ink: #30333b;
  --muted: #707671;
  --text-soft: #929792;
  --line: #d9dbd7;
  --line-strong: #c3bdbd;
  --accent: #535661;
  --accent-dark: #3f424b;
  --primary-soft: #e2e3e5;
  --secondary-soft: #e8ebe7;
  --blue: #707671;
  --amber: #b08b48;
  --danger: #a54a4a;
  --soft: #eceeeb;
  --sidebar: #535661;
  --sidebar-hover: #646872;
  --sidebar-active: #707671;
  --sidebar-text: #f5f5f1;
  --sidebar-muted: #e1e2df;
  --input-bg: #fbfbf9;
  --entry-bg: #f8f9f7;
  --track: #e1e3e0;
  --actual-bar: linear-gradient(90deg, #535661, #707671);
  --shadow: 0 14px 32px rgba(43, 47, 48, 0.10);
  --focus-ring: rgba(83, 86, 97, 0.15);
  --drag-ring: rgba(83, 86, 97, 0.30);
}

:root[data-color-theme="olive"] {
  --bg: #f5e6c5;
  --bg-soft: #eee0bf;
  --panel: #fffaf0;
  --surface: #fffaf0;
  --surface-warm: #f5edda;
  --ink: #313323;
  --muted: #746c54;
  --text-soft: #9a8e70;
  --line: #dfd0ad;
  --line-strong: #c8b889;
  --accent: #667727;
  --accent-dark: #4f5e1e;
  --primary-soft: #e1e7c8;
  --secondary-soft: #f8dfad;
  --blue: #ca763a;
  --amber: #efa83c;
  --danger: #ad4e3d;
  --soft: #eef0d9;
  --sidebar: #3f422f;
  --sidebar-hover: #50543b;
  --sidebar-active: #667727;
  --sidebar-text: #fff8e9;
  --sidebar-muted: #dfe1c8;
  --input-bg: #fffdf7;
  --entry-bg: #fbf5e8;
  --track: #e7dcc3;
  --actual-bar: linear-gradient(90deg, #667727, #efa83c);
  --shadow: 0 14px 32px rgba(63, 66, 47, 0.13);
  --focus-ring: rgba(102, 119, 39, 0.16);
  --drag-ring: rgba(102, 119, 39, 0.32);
}

:root[data-theme="dark"][data-color-theme="solar"] {
  --bg: #111626;
  --bg-soft: #1a2035;
  --panel: #1d2440;
  --surface: #1d2440;
  --surface-warm: #272d47;
  --ink: #fff8e9;
  --muted: #d7c7ad;
  --text-soft: #a99e8e;
  --line: #3c4669;
  --line-strong: #586383;
  --accent: #ff7a32;
  --accent-dark: #f69a0b;
  --primary-soft: #43251d;
  --secondary-soft: #49351c;
  --blue: #f69a0b;
  --amber: #fdbf5c;
  --danger: #ff6a58;
  --soft: #342722;
  --sidebar: #090d19;
  --sidebar-hover: #242c48;
  --sidebar-active: #9b0800;
  --sidebar-text: #fff8e9;
  --sidebar-muted: #d7c7ad;
  --input-bg: #151b2e;
  --entry-bg: #182038;
  --track: #343d5b;
  --actual-bar: linear-gradient(90deg, #ff7a32, #f69a0b);
  --shadow: 0 16px 40px rgba(0, 0, 0, 0.34);
  --focus-ring: rgba(255, 122, 50, 0.20);
  --drag-ring: rgba(255, 122, 50, 0.40);
  --button-text: #111626;
}

:root[data-theme="dark"][data-color-theme="slate"] {
  --bg: #202226;
  --bg-soft: #292c31;
  --panel: #2d3036;
  --surface: #2d3036;
  --surface-warm: #363a40;
  --ink: #f5f5f1;
  --muted: #c3c6c2;
  --text-soft: #9da19d;
  --line: #484c53;
  --line-strong: #62666d;
  --accent: #aeb4bd;
  --accent-dark: #c3c8cf;
  --primary-soft: #40444b;
  --secondary-soft: #414842;
  --blue: #8f9a92;
  --amber: #d4ad62;
  --danger: #e07878;
  --soft: #3a3e44;
  --sidebar: #15171a;
  --sidebar-hover: #343840;
  --sidebar-active: #535661;
  --sidebar-text: #f5f5f1;
  --sidebar-muted: #c3c6c2;
  --input-bg: #25282d;
  --entry-bg: #292c31;
  --track: #454950;
  --actual-bar: linear-gradient(90deg, #8f969f, #b6bbb5);
  --shadow: 0 16px 40px rgba(0, 0, 0, 0.32);
  --focus-ring: rgba(174, 180, 189, 0.18);
  --drag-ring: rgba(174, 180, 189, 0.36);
  --button-text: #202226;
}

:root[data-theme="dark"][data-color-theme="olive"] {
  --bg: #202319;
  --bg-soft: #2b2f21;
  --panel: #303426;
  --surface: #303426;
  --surface-warm: #3a3f2c;
  --ink: #fff7e5;
  --muted: #d2ccb5;
  --text-soft: #aaa38d;
  --line: #51583c;
  --line-strong: #6d754e;
  --accent: #aeba6a;
  --accent-dark: #efa83c;
  --primary-soft: #42492b;
  --secondary-soft: #514226;
  --blue: #ca763a;
  --amber: #efa83c;
  --danger: #e27b68;
  --soft: #3e452b;
  --sidebar: #11140d;
  --sidebar-hover: #373d29;
  --sidebar-active: #667727;
  --sidebar-text: #fff7e5;
  --sidebar-muted: #d2ccb5;
  --input-bg: #292d20;
  --entry-bg: #2c3022;
  --track: #4a5038;
  --actual-bar: linear-gradient(90deg, #aeba6a, #efa83c);
  --shadow: 0 16px 40px rgba(0, 0, 0, 0.34);
  --focus-ring: rgba(174, 186, 106, 0.20);
  --drag-ring: rgba(174, 186, 106, 0.40);
  --button-text: #202319;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-ui);
  font-size: 15px;
}

button,
input,
select {
  font: inherit;
}

input,
select,
textarea {
  color-scheme: light;
}

:root[data-theme="dark"] input,
:root[data-theme="dark"] select,
:root[data-theme="dark"] textarea {
  color-scheme: dark;
}

button {
  cursor: pointer;
}

.auth-screen {
  position: fixed;
  inset: 0;
  z-index: 20;
  display: grid;
  place-items: center;
  padding: 24px;
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--accent) 14%, transparent), transparent 34%),
    var(--bg);
}

.auth-screen[hidden] {
  display: none;
}

.auth-card {
  display: grid;
  gap: 16px;
  width: min(430px, 100%);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 28px;
  background: var(--panel);
  box-shadow: var(--shadow);
}

.auth-card h1 {
  margin: 0;
  color: var(--ink);
  font-family: var(--font-display);
  font-size: 34px;
  font-weight: 500;
  letter-spacing: -0.035em;
}

.auth-card p {
  margin: 8px 0 0;
  color: var(--muted);
}

.auth-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.auth-message {
  min-height: 20px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

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

.sidebar {
  background: var(--sidebar);
  color: var(--sidebar-text);
  padding: 24px;
  box-shadow: inset -1px 0 0 rgba(255, 247, 241, 0.08);
}

.brand {
  display: grid;
  gap: 12px;
  margin-bottom: 30px;
}

.brand-lockup {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 56px;
}

.brand-feather {
  width: 44px;
  height: 56px;
  object-fit: contain;
  object-position: center;
  flex: 0 0 auto;
  filter: drop-shadow(0 8px 14px rgba(0, 0, 0, 0.2));
}

.brand-wordmark {
  display: grid;
  gap: 3px;
  color: var(--amber);
  font-family: Georgia, "Times New Roman", serif;
  letter-spacing: 0;
  text-transform: uppercase;
  min-width: 0;
}

.brand-wordmark span {
  font-size: 26px;
  line-height: 0.95;
  letter-spacing: 1.6px;
}

.brand-wordmark small {
  color: var(--sidebar-muted);
  font-size: 9px;
  letter-spacing: 4.8px;
  line-height: 1;
}

.brand p {
  margin: 0;
  color: var(--sidebar-muted);
  font-size: 13px;
}

.nav {
  display: grid;
  gap: 8px;
}

.nav-item {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  border: 0;
  border-radius: 8px;
  padding: 12px 14px;
  background: transparent;
  color: var(--sidebar-muted);
  text-align: left;
  font-weight: 700;
}

.nav-item:hover,
.nav-item.active {
  background: var(--sidebar-active);
  color: var(--sidebar-text);
}

.nav-icon {
  display: inline-grid;
  width: 22px;
  height: 22px;
  place-items: center;
  border: 1px solid rgba(255, 247, 241, 0.22);
  border-radius: 7px;
  color: var(--sidebar-text);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
}

.nav-item.active .nav-icon,
.nav-item:hover .nav-icon {
  border-color: rgba(255, 247, 241, 0.44);
  background: rgba(255, 247, 241, 0.16);
}

.theme-picker {
  position: relative;
  margin-top: 20px;
}

.theme-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  border: 1px solid rgba(214, 163, 78, 0.36);
  border-radius: 8px;
  padding: 11px 12px;
  background: rgba(214, 163, 78, 0.08);
  color: var(--sidebar-text);
  font-weight: 800;
}

.theme-toggle:hover {
  background: rgba(214, 163, 78, 0.16);
}

.user-toggle {
  margin-top: 12px;
}

.theme-toggle-icon {
  color: var(--amber);
  font-size: 16px;
}

.theme-menu {
  position: absolute;
  z-index: 12;
  bottom: calc(100% + 10px);
  left: 0;
  width: min(320px, calc(100vw - 32px));
  overflow: hidden;
  border: 1px solid var(--line-strong);
  border-radius: 8px;
  padding: 12px;
  background: var(--panel);
  color: var(--ink);
  box-shadow: var(--shadow);
}

.theme-menu[hidden] {
  display: none;
}

.theme-menu-section {
  display: grid;
  gap: 8px;
}

.theme-menu-section + .theme-menu-section {
  margin-top: 12px;
  border-top: 1px solid var(--line);
  padding-top: 12px;
}

.theme-menu-label {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

.appearance-options {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
}

.appearance-option,
.color-theme-option {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--input-bg);
  color: var(--ink);
}

.appearance-option {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  padding: 9px;
  font-size: 13px;
  font-weight: 700;
}

.appearance-option:hover,
.appearance-option.active,
.color-theme-option:hover,
.color-theme-option.active {
  border-color: var(--accent);
  background: var(--primary-soft);
}

.color-theme-options {
  display: grid;
  gap: 6px;
}

.color-theme-option {
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr) 18px;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 9px 10px;
  text-align: left;
}

.color-theme-option > span:nth-child(2) {
  display: grid;
  gap: 2px;
}

.color-theme-option strong {
  font-size: 13px;
}

.color-theme-option small {
  color: var(--muted);
  font-size: 11px;
}

.theme-swatches {
  display: flex;
  overflow: hidden;
  width: 48px;
  height: 28px;
  border: 1px solid var(--line);
  border-radius: 6px;
}

.theme-swatches i {
  flex: 1;
  background: var(--swatch);
}

.theme-check {
  visibility: hidden;
  color: var(--accent);
  font-size: 14px;
}

.color-theme-option.active .theme-check {
  visibility: visible;
}

.content {
  padding: 28px;
  overflow-x: hidden;
}

.user-bar {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 14px;
  max-width: 1440px;
  margin: 0 auto -62px;
  min-height: 62px;
  pointer-events: none;
}

.quick-action {
  display: inline-grid;
  position: relative;
  width: 52px;
  height: 52px;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: color-mix(in srgb, var(--panel) 88%, transparent);
  color: var(--sidebar);
  box-shadow: 0 10px 22px rgba(91, 45, 38, 0.08);
  transition: transform 0.16s ease, border-color 0.16s ease, color 0.16s ease, background 0.16s ease;
  pointer-events: auto;
}

.quick-action:hover {
  transform: translateY(-1px);
  border-color: var(--accent);
  background: var(--surface);
  color: var(--accent);
}

.quick-action-icon {
  display: grid;
  width: 24px;
  height: 24px;
  place-items: center;
  border: 1.5px solid currentColor;
  border-radius: 7px;
  font-size: 16px;
  font-weight: 800;
  line-height: 1;
}

.quick-action-icon.agenda-icon {
  position: relative;
  width: 26px;
  height: 28px;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 900;
}

.quick-action-icon.agenda-icon::before,
.quick-action-icon.agenda-icon::after {
  content: "";
  position: absolute;
  top: -3px;
  width: 4px;
  height: 8px;
  border-radius: 3px;
  background: currentColor;
}

.quick-action-icon.agenda-icon::before {
  left: 6px;
}

.quick-action-icon.agenda-icon::after {
  right: 6px;
}

.quick-action-icon.agenda-icon span {
  display: grid;
  width: 100%;
  height: 100%;
  place-items: center;
  padding-top: 6px;
}

.quick-action-icon.agenda-icon span::before {
  content: "";
  position: absolute;
  top: 9px;
  left: 0;
  width: 100%;
  border-top: 1.5px solid currentColor;
}

.quick-action-badge {
  position: absolute;
  top: -6px;
  right: -6px;
  min-width: 20px;
  height: 20px;
  border: 2px solid var(--bg);
  border-radius: 999px;
  padding: 0 5px;
  background: var(--danger);
  color: #ffffff;
  font-size: 11px;
  font-weight: 900;
  line-height: 16px;
  text-align: center;
}

.quick-action-badge[hidden] {
  display: none;
}

.user-card {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 280px;
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 10px 12px;
  background: color-mix(in srgb, var(--panel) 90%, transparent);
  box-shadow: 0 10px 22px rgba(91, 45, 38, 0.08);
  pointer-events: auto;
}

.user-week-field {
  width: 240px;
  pointer-events: auto;
}

.user-week-field span {
  display: none;
}

.user-week-field select {
  min-height: 50px;
  padding-top: 0;
  padding-bottom: 0;
}

body:not([data-active-view="dashboard"]) .user-bar {
  margin-bottom: 18px;
}

body:not([data-active-view="dashboard"]) .user-week-field {
  display: none;
}

.user-avatar {
  display: grid;
  width: 46px;
  height: 46px;
  flex: 0 0 auto;
  place-items: center;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--primary-soft), var(--secondary-soft, #ffe8d6));
  color: var(--accent);
  font-family: var(--font-display);
  font-size: 24px;
  font-weight: 700;
}

.user-copy {
  display: grid;
  min-width: 0;
  gap: 2px;
  flex: 1;
}

.user-copy strong,
.user-copy span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.user-copy strong {
  font-size: 15px;
  font-weight: 700;
}

.user-copy span {
  color: var(--muted);
  font-size: 13px;
}

.user-copy small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
  line-height: 1.2;
}

.user-copy small[data-tone="success"] {
  color: var(--success);
}

.user-copy small[data-tone="pending"] {
  color: var(--secondary);
}

.user-copy small[data-tone="error"] {
  color: var(--danger);
}

.user-sign-out {
  border: 0;
  border-radius: 10px;
  padding: 8px 10px;
  background: var(--surface-warm);
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.user-sign-out:hover {
  background: var(--primary-soft);
  color: var(--accent);
}

:root[data-theme="dark"] .quick-action,
:root[data-theme="dark"] .user-card {
  background: color-mix(in srgb, var(--panel) 92%, #ffffff 4%);
  border-color: var(--line);
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.22);
}

:root[data-theme="dark"] .quick-action {
  color: var(--sidebar-text);
}

:root[data-theme="dark"] .quick-action:hover {
  color: var(--accent);
  background: var(--surface-warm);
}

:root[data-theme="dark"] .user-sign-out {
  background: var(--sidebar-hover);
  color: var(--sidebar-text);
}

.view {
  display: none;
  max-width: 1280px;
  margin: 0 auto;
}

.view.active {
  display: block;
}

.view-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 20px;
}

.eyebrow {
  margin: 0 0 6px;
  color: var(--accent);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

h2,
h3 {
  margin: 0;
  letter-spacing: 0;
}

h2 {
  font-family: var(--font-display);
  font-size: 40px;
  font-weight: 500;
  letter-spacing: -0.035em;
  line-height: 1;
}

h3 {
  font-family: var(--font-ui);
  font-size: 16px;
  font-weight: 700;
  line-height: 1.2;
}

.header-actions {
  display: flex;
  align-items: flex-end;
  gap: 12px;
}

.tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}

.tab-button {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px 14px;
  background: var(--input-bg);
  color: var(--muted);
  font-weight: 800;
}

.tab-button.active,
.tab-button:hover {
  border-color: var(--accent);
  background: var(--soft);
  color: var(--ink);
}

.summary-tab {
  display: none;
}

.summary-tab.active {
  display: block;
}

.topic-tree {
  gap: 0;
  border: 1px solid var(--line);
  padding: 0;
  background: var(--entry-bg);
  overflow: hidden;
  border-radius: 6px;
  box-shadow: none;
}

#topicsBySubject {
  gap: 4px;
}

.topic-tree > summary,
.topic-major > summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  cursor: pointer;
  list-style: none;
}

.topic-tree > summary {
  min-height: 32px;
  padding: 6px 10px;
}

.topic-tree > summary:focus {
  outline: none;
}

.topic-tree > summary:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
  border-radius: 5px;
}

.topic-tree > summary::-webkit-details-marker,
.topic-major > summary::-webkit-details-marker {
  display: none;
}

.topic-tree > summary::before,
.topic-major > summary::before {
  content: ">";
  color: var(--accent);
  font-weight: 900;
  transition: transform 0.15s ease;
}

.topic-tree[open] > summary::before,
.topic-major[open] > summary::before {
  transform: rotate(90deg);
}

.topic-tree > summary span {
  flex: 1;
  color: var(--ink);
  font-size: 14px;
  font-weight: 900;
}

.topic-tree summary small,
.topic-major summary small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.topic-major-list {
  display: grid;
  gap: 4px;
  padding: 0 10px 8px 30px;
}

.topic-major {
  border: 1px solid var(--line);
  border-radius: 7px;
  background: var(--input-bg);
}

.topic-major > summary {
  min-height: 28px;
  padding: 5px 8px;
}

.topic-edit-button,
.topic-pill {
  border: 0;
  background: transparent;
  color: var(--ink);
  text-align: left;
}

.topic-edit-button {
  flex: 1;
  padding: 0;
  font-size: 13px;
  font-weight: 600;
}

.topic-edit-button:hover,
.topic-pill:hover {
  color: var(--accent);
}

.topic-minor-list {
  display: grid;
  gap: 5px;
  padding: 0 10px 10px 30px;
}

.topic-pill {
  width: fit-content;
  max-width: 100%;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 5px 9px;
  background: var(--soft);
  overflow-wrap: anywhere;
  font-size: 12px;
  font-weight: 500;
}

.topic-pill.muted {
  color: var(--muted);
  cursor: default;
}

.modal-note {
  grid-column: 1 / -1;
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 16px;
}

.kpi,
.panel {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--shadow);
}

.kpi {
  padding: 18px;
}

.kpi span {
  color: var(--muted);
  font-size: 13px;
}

.kpi strong {
  display: block;
  margin-top: 8px;
  font-size: 28px;
}

#view-dashboard {
  max-width: 1440px;
}

.dashboard-header {
  min-height: 62px;
  align-items: center;
  margin-bottom: 24px;
  padding-right: 650px;
}

.dashboard-header h2 {
  font-family: "Lora", Georgia, serif;
  font-size: 42px;
  font-weight: 500;
  letter-spacing: -0.035em;
  line-height: 1;
}

.dashboard-kpi-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 22px;
  margin-bottom: 22px;
}

#view-dashboard .kpi,
#view-dashboard .panel {
  border-radius: 18px;
  box-shadow: 0 18px 44px rgba(91, 45, 38, 0.08);
}

#view-dashboard .kpi {
  position: relative;
  min-height: 96px;
  padding: 20px 22px 16px 74px;
}

#view-dashboard .kpi::before {
  position: absolute;
  top: 20px;
  left: 22px;
  display: grid;
  width: 42px;
  height: 42px;
  place-items: center;
  border-radius: 50%;
  background: var(--primary-soft, #ffe2dc);
  color: var(--accent);
  font-size: 22px;
}

#view-dashboard .kpi:nth-child(1)::before { content: "◎"; }
#view-dashboard .kpi:nth-child(2)::before { content: "◷"; }
#view-dashboard .kpi:nth-child(3)::before { content: "▥"; }
#view-dashboard .kpi:nth-child(4)::before { content: "?"; }

#view-dashboard .kpi span {
  color: var(--ink);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

#view-dashboard .kpi strong {
  margin-top: 4px;
  font-family: var(--font-display);
  font-size: 30px;
  font-weight: 500;
  line-height: 1;
}

.dashboard-daily-panel {
  margin-bottom: 22px;
}

#view-dashboard .panel {
  padding: 22px;
}

#view-dashboard .dashboard-daily-panel {
  border: 0;
  padding: 0;
  background: transparent;
  box-shadow: none;
}

#view-dashboard .panel-header {
  margin-bottom: 18px;
}

#view-dashboard .dashboard-daily-panel > .panel-header {
  padding: 0 4px;
}

.daily-completion-hidden {
  display: none;
}

#view-dashboard .daily-calendar {
  grid-template-columns: minmax(360px, 1fr) minmax(560px, 1.7fr) minmax(360px, 1fr);
  gap: 22px;
}

#view-dashboard .daily-planner-detail,
#view-dashboard .weekly-tasks,
#view-dashboard .daily-detail-summary article,
#view-dashboard .daily-subject {
  border-radius: 12px;
}

#view-dashboard .daily-planner-days {
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 18px 18px;
  background: var(--panel);
  box-shadow: 0 18px 44px rgba(91, 45, 38, 0.08);
}

.dashboard-bottom-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 0.95fr);
  gap: 22px;
  align-items: start;
}

.panel {
  margin-bottom: 16px;
  padding: 18px;
}

.panel-header {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  margin-bottom: 14px;
}

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

.field {
  display: grid;
  gap: 6px;
}

.field span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.field input,
.field select,
textarea,
.goal-row > input,
.simulation-row > input {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px 12px;
  background: var(--input-bg);
  color: var(--ink);
  outline: none;
}

.goal-row > input,
.simulation-row > input {
  height: 42px;
}

.field input:focus,
.field select:focus,
.goal-row > input:focus,
.simulation-row > input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--focus-ring);
}

.small-field {
  min-width: 190px;
}

.primary,
.secondary,
.danger {
  border: 0;
  border-radius: 8px;
  padding: 11px 14px;
  color: var(--button-text);
  font-weight: 800;
}

.primary {
  background: var(--accent);
}

.primary:hover {
  background: var(--accent-dark);
}

.secondary {
  background: var(--blue);
}

.danger {
  background: var(--danger);
}

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

.timer-panel .panel-header strong {
  color: var(--accent);
  font-variant-numeric: tabular-nums;
  font-size: 22px;
}

.timer-grid {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(180px, 1fr) 150px 120px;
  gap: 14px;
  align-items: end;
}

.timer-meta {
  display: grid;
  min-height: 42px;
  align-content: center;
  gap: 3px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px 12px;
  background: var(--input-bg);
}

.timer-meta span {
  color: var(--ink);
  font-weight: 800;
}

.timer-meta small {
  color: var(--muted);
}

.form-submit {
  align-self: end;
  min-height: 42px;
}

.agenda-grid {
  display: grid;
  grid-template-columns: minmax(420px, 1.2fr) minmax(320px, 0.8fr);
  gap: 16px;
  align-items: start;
}

.agenda-calendar-panel .panel-header {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) 42px;
  text-align: center;
}

.agenda-month-button {
  min-height: 38px;
  padding: 0;
  font-size: 22px;
  line-height: 1;
}

.muted-note {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

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

.agenda-weekdays {
  margin-bottom: 8px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  text-align: center;
  text-transform: uppercase;
}

.agenda-day {
  display: grid;
  min-height: 70px;
  align-content: space-between;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px;
  background: var(--input-bg);
}

.agenda-day.empty {
  border-color: transparent;
  background: transparent;
}

.agenda-day strong {
  font-size: 13px;
}

.agenda-day span {
  justify-self: end;
  min-width: 22px;
  border-radius: 999px;
  padding: 3px 7px;
  background: var(--soft);
  color: var(--accent);
  font-size: 11px;
  font-weight: 900;
  text-align: center;
}

.agenda-day.today {
  border-color: var(--accent);
  box-shadow: inset 3px 0 0 var(--accent);
}

.agenda-day.urgent {
  background: var(--primary-soft);
}

.agenda-day.done {
  border-color: var(--success-line);
  background: var(--success-soft);
}

.agenda-upcoming {
  display: grid;
  gap: 9px;
}

.agenda-event-group {
  display: grid;
  gap: 7px;
}

.agenda-event-group h4 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin: 2px 0 0;
  color: var(--primary);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.04em;
  line-height: 1;
  text-transform: uppercase;
}

.agenda-event-group h4 small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0;
}

.agenda-event-group-list {
  display: grid;
  gap: 8px;
}

.agenda-event {
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 11px;
  background: var(--input-bg);
  cursor: pointer;
}

.agenda-event.late,
.agenda-event.today {
  border-color: var(--danger);
  background: var(--primary-soft);
}

.agenda-event.soon {
  border-color: var(--accent);
}

.agenda-event.done {
  border-color: var(--success-line);
  background: var(--success-soft);
  opacity: 0.78;
}

.agenda-completed-panel {
  margin-top: -4px;
}

.agenda-event-main {
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr);
  gap: 9px;
  align-items: start;
}

.agenda-event-main input {
  width: 18px;
  height: 18px;
  accent-color: var(--success);
}

.agenda-event-main span {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.agenda-event-main strong {
  color: var(--ink);
  overflow-wrap: anywhere;
}

.agenda-event-main small,
.agenda-event p {
  color: var(--muted);
  font-size: 12px;
}

.agenda-event p {
  margin: 0;
}

.agenda-event-meta {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.agenda-form {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.agenda-notes-field {
  grid-column: span 2;
}

.editable-list {
  display: grid;
  gap: 10px;
}

.goal-row {
  display: grid;
  grid-template-columns: 34px minmax(180px, 1fr) 130px 112px 42px;
  gap: 10px;
  align-items: center;
}

.task-goal-row {
  display: grid;
  gap: 10px;
}

.task-goal-main {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) 120px 112px 42px;
  gap: 10px;
  align-items: center;
}

.task-goal-main > input,
.subtask-row > input,
.subtask-input {
  width: 100%;
  height: 42px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px 12px;
  background: var(--input-bg);
  color: var(--ink);
  outline: none;
}

.task-goal-main > input:focus,
.subtask-row > input:focus,
.subtask-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--focus-ring);
}

.task-time-hint {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-align: right;
}

.subtask-editor {
  display: grid;
  gap: 8px;
  margin-left: 18px;
  padding-left: 14px;
  border-left: 2px solid var(--line);
}

.subtask-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 42px;
  gap: 8px;
}

.simulation-meta {
  margin-bottom: 14px;
  grid-template-columns: repeat(2, minmax(220px, 300px));
}

.simulation-header {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) 130px 130px 42px;
  gap: 10px;
  margin-bottom: 8px;
  padding: 0 2px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

.simulation-row {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) 130px 130px 42px;
  gap: 10px;
  align-items: center;
}

.simulation-list {
  gap: 8px;
}

.simulation-actions {
  display: flex;
  justify-content: flex-start;
  margin-top: 14px;
}

.simulation-subjects {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
}

.simulation-subjects span {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 5px 9px;
  background: var(--soft);
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

[data-edit-simulation] {
  cursor: pointer;
}

.subject-autocomplete-menu {
  position: absolute;
  z-index: 30;
  display: grid;
  gap: 4px;
  max-height: 260px;
  overflow-y: auto;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 6px;
  background: var(--panel);
  box-shadow: var(--shadow);
}

.subject-autocomplete-menu[hidden] {
  display: none;
}

.subject-autocomplete-menu button {
  border: 0;
  border-radius: 6px;
  padding: 9px 10px;
  background: transparent;
  color: var(--ink);
  font-weight: 800;
  text-align: left;
}

.subject-autocomplete-menu button:hover,
.subject-autocomplete-menu button.active {
  background: var(--soft);
  color: var(--accent);
}

.drag-handle {
  border: 1px solid var(--line);
  border-radius: 8px;
  height: 42px;
  background: var(--input-bg);
  color: var(--muted);
  cursor: grab;
  font-size: 15px;
  font-weight: 900;
  letter-spacing: -2px;
  line-height: 1;
}

.drag-handle:active {
  cursor: grabbing;
}

.goal-row.dragging {
  opacity: 0.55;
}

.goal-row.drag-over {
  border-radius: 8px;
  outline: 2px solid var(--drag-ring);
  outline-offset: 3px;
}

.toggle-field {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 42px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--input-bg);
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.toggle-field input {
  width: 16px;
  height: 16px;
  accent-color: var(--accent);
}

:root[data-theme="dark"] .toggle-field input {
  filter: saturate(1.1);
}

.daily-options {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(180px, 240px);
  gap: 12px;
  align-items: start;
}

.daily-day-options {
  display: grid;
  grid-template-columns: repeat(7, minmax(88px, 1fr));
  gap: 8px;
}

.daily-option {
  display: grid;
  gap: 6px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px;
  background: var(--input-bg);
}

.daily-option.inactive {
  opacity: 0.58;
}

.daily-limit-field {
  margin: 0;
}

.daily-toggle {
  min-height: 36px;
  padding: 0 10px;
}

.daily-toggle.active {
  border-color: var(--accent);
  background: var(--soft);
  color: var(--ink);
}

.distribution-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 14px;
}

.distribution-board {
  display: grid;
  grid-template-columns: repeat(7, minmax(120px, 1fr));
  gap: 10px;
  overflow-x: auto;
  padding-bottom: 4px;
}

.distribution-day {
  display: grid;
  align-content: start;
  min-height: 190px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 10px;
  background: color-mix(in srgb, var(--panel) 86%, var(--surface-warm));
}

.distribution-day-header {
  display: grid;
  gap: 2px;
  margin-bottom: 10px;
  text-align: center;
}

.distribution-day-header strong {
  color: var(--ink);
  font-size: 14px;
}

.distribution-day-header span,
.distribution-day-header small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.distribution-card-list {
  display: grid;
  gap: 8px;
  min-height: 116px;
}

.distribution-card {
  display: grid;
  gap: 4px;
  border: 1px solid var(--line);
  border-radius: 9px;
  padding: 8px;
  background: var(--panel);
  box-shadow: 0 8px 18px rgba(91, 45, 38, 0.07);
  cursor: grab;
}

.distribution-card.dragging {
  opacity: 0.55;
}

.distribution-card strong {
  overflow-wrap: anywhere;
  color: var(--ink);
  font-size: 12px;
  line-height: 1.25;
}

.distribution-card span {
  color: var(--accent);
  font-size: 12px;
  font-weight: 900;
}

.empty.tiny {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  text-align: center;
}

.daily-weight {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
}

.weight-button {
  border: 1px solid var(--line);
  border-radius: 8px;
  min-height: 32px;
  padding: 0 8px;
  background: var(--input-bg);
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.weight-button.active {
  border-color: var(--accent);
  background: var(--accent);
  color: var(--button-text);
}

.icon-button {
  border: 1px solid var(--line);
  border-radius: 8px;
  height: 42px;
  background: var(--input-bg);
  color: var(--danger);
  font-weight: 900;
}

.text-button {
  justify-self: start;
  border: 0;
  padding: 0;
  background: transparent;
  color: var(--danger);
  font-size: 13px;
  font-weight: 800;
}

.daily-calendar {
  display: grid;
  grid-template-columns: minmax(170px, 220px) minmax(0, 1fr) minmax(220px, 300px);
  gap: 18px;
  align-items: start;
}

.daily-card {
  display: grid;
  align-content: start;
  gap: 12px;
  min-width: 0;
  min-height: 160px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: var(--input-bg);
}

.daily-card.past {
  opacity: 0.58;
  filter: grayscale(0.55);
}

.daily-card.complete {
  border-color: var(--accent);
}

.daily-card-header {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 8px;
  min-width: 0;
}

.daily-card-header > div {
  min-width: 0;
}

.daily-card-header strong,
.daily-subject-line span {
  color: var(--ink);
  font-weight: 900;
}

.daily-card-header span,
.daily-subject small {
  color: var(--muted);
  font-size: 12px;
}

.daily-card-header input {
  width: 17px;
  height: 17px;
  accent-color: var(--accent);
}

.daily-subjects {
  display: grid;
  gap: 9px;
  min-width: 0;
}

.daily-subject {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.daily-subject-line {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 38px;
  align-items: baseline;
  gap: 8px;
  font-size: 12px;
}

.daily-subject-line span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.daily-subject-line strong {
  color: var(--muted);
  font-size: 12px;
}

.daily-subject.complete .daily-subject-line strong {
  color: var(--accent);
}

.daily-track {
  height: 7px;
  overflow: hidden;
  border-radius: 999px;
  background: var(--track);
  min-width: 0;
}

.daily-fill {
  height: 100%;
  border-radius: inherit;
}

.daily-planner-days {
  display: grid;
  gap: 0;
  align-content: start;
}

.daily-plan-alert {
  margin: -4px 0 12px;
  border: 1px solid var(--accent);
  border-radius: 8px;
  padding: 9px 10px;
  background: var(--accent-soft);
  color: var(--ink);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.35;
}

.daily-planner-days-header,
.weekly-tasks-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
}

.daily-planner-days-header > strong,
.weekly-tasks-header > strong {
  color: var(--ink);
  font-size: 14px;
  font-weight: 900;
}

.daily-panel-title {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  color: var(--ink);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0.025em;
  text-transform: uppercase;
}

.panel-title-icon {
  display: inline-grid;
  width: 18px;
  height: 18px;
  place-items: center;
  border: 1px solid var(--accent);
  border-radius: 4px;
  color: var(--accent);
  font-size: 12px;
  line-height: 1;
}

.daily-day-button {
  display: grid;
  position: relative;
  grid-template-columns: 58px 62px 52px minmax(52px, 1fr) 36px;
  align-items: center;
  gap: 10px;
  width: 100%;
  border: 0;
  border-bottom: 1px solid var(--line);
  border-radius: 0;
  padding: 8px 0 8px 2px;
  background: transparent;
  color: var(--muted);
  text-align: left;
}

.daily-day-button:last-child {
  border-bottom: 0;
}

.daily-day-button:hover,
.daily-day-button.selected {
  background: var(--surface-warm);
}

.daily-day-button.today {
  box-shadow: none;
}

.daily-day-button.complete {
  border-bottom-color: var(--line);
  background: linear-gradient(90deg, var(--success-soft), rgba(255, 255, 255, 0) 92%);
  box-shadow: inset 2px 0 0 var(--success);
}

.daily-day-button.complete.selected,
.daily-day-button.complete:hover {
  background: var(--success-soft);
}

.daily-day-button.complete .daily-day-percent {
  color: var(--success);
}

.daily-day-button.complete .daily-nav-track div {
  background: var(--success);
}

.daily-day-main {
  display: block;
  min-width: 0;
  border-right: 1px solid var(--line);
  padding-right: 8px;
  text-align: center;
}

.daily-day-main strong {
  display: block;
  color: var(--ink);
  font-size: 12px;
  line-height: 1.1;
}

.daily-day-main span,
.daily-day-done,
.daily-day-target {
  color: var(--muted);
  font-size: 11px;
}

.daily-day-date-short {
  display: none;
}

.daily-day-done {
  color: var(--ink);
  font-weight: 700;
  white-space: nowrap;
}

.daily-day-target {
  white-space: nowrap;
}

.daily-nav-track {
  justify-self: stretch;
}

.daily-day-percent {
  color: var(--accent);
  font-size: 12px;
  font-weight: 900;
  text-align: right;
}

.daily-nav-track,
.daily-overall-track {
  height: 5px;
  overflow: hidden;
  border-radius: 999px;
  background: var(--track);
}

.daily-nav-track div,
.daily-overall-track div {
  height: 100%;
  border-radius: inherit;
  background: var(--accent);
}

.daily-planner-detail {
  display: grid;
  gap: 18px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 20px;
  background: var(--input-bg);
}

.daily-detail-header {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 16px;
}

.daily-detail-header h3 {
  font-family: var(--font-ui);
  margin-top: 2px;
  font-size: 20px;
  letter-spacing: 0;
}

.daily-detail-header > strong {
  color: var(--accent);
  font-size: 28px;
}

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

.daily-detail-summary article {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: var(--panel);
}

.daily-detail-summary span {
  display: block;
  margin-bottom: 4px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

.daily-detail-summary strong {
  color: var(--ink);
  font-size: 18px;
}

.daily-detail-subjects {
  display: grid;
  gap: 12px;
}

.daily-subject {
  grid-template-columns: 20px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: var(--panel);
}

.daily-subject.extra {
  border-style: dashed;
  background: color-mix(in srgb, var(--panel) 82%, var(--surface-warm));
}

.daily-subject.extra .daily-subject-line strong,
.daily-subject.extra small {
  color: var(--muted);
}

.daily-subject > input[type="checkbox"] {
  width: 18px;
  height: 18px;
  appearance: none;
  display: grid;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 3px;
  background: var(--input-bg);
  opacity: 1;
}

.daily-subject > input[type="checkbox"]:checked {
  border-color: var(--success);
  background: var(--success);
}

.daily-subject > input[type="checkbox"]:checked::after {
  content: "";
  width: 9px;
  height: 5px;
  border-left: 2px solid #ffffff;
  border-bottom: 2px solid #ffffff;
  transform: rotate(-45deg) translateY(-1px);
}

.daily-subject-body {
  display: grid;
  gap: 6px;
  min-width: 0;
}

.daily-plan-editor {
  display: grid;
  gap: 10px;
  border: 1px dashed var(--line);
  border-radius: 8px;
  padding: 10px;
  background: color-mix(in srgb, var(--panel) 82%, var(--surface-warm));
}

.daily-plan-editor > div:first-child {
  display: grid;
  gap: 2px;
}

.daily-plan-editor strong {
  color: var(--ink);
  font-size: 13px;
}

.daily-plan-editor span {
  color: var(--muted);
  font-size: 12px;
}

.daily-plan-editor-fields {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 86px auto auto;
  gap: 8px;
  align-items: center;
}

.daily-plan-editor-fields select,
.daily-plan-editor-fields input,
.daily-subject-editor input {
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px 10px;
  background: var(--input-bg);
  color: var(--ink);
  font: inherit;
}

.daily-subject-editor {
  display: flex;
  align-items: center;
  gap: 8px;
}

.daily-subject-editor input {
  width: 82px;
  min-height: 34px;
}

.weekly-tasks {
  display: grid;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: var(--input-bg);
}

.weekly-tasks-header h4 {
  margin: 0;
}

.weekly-tasks .weekly-tasks-header {
  margin-bottom: 0;
}

.weekly-task-list {
  display: grid;
  gap: 7px;
}

.weekly-task {
  display: grid;
  gap: 7px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  background: var(--panel);
}

.weekly-task-main {
  display: grid;
  grid-template-columns: 20px minmax(0, 1fr);
  align-items: center;
  gap: 10px;
}

.weekly-task input,
.weekly-subtask input {
  width: 18px;
  height: 18px;
  accent-color: var(--accent);
}

.weekly-task.complete input,
.weekly-subtask.complete input {
  accent-color: var(--success);
}

.weekly-task span,
.weekly-subtask span {
  color: var(--ink);
  font-weight: 900;
  overflow-wrap: anywhere;
  white-space: normal;
}

.weekly-task small {
  grid-column: 2;
  color: var(--muted);
  font-size: 12px;
}

.weekly-task.complete {
  border-color: var(--success-line);
  background: var(--success-soft);
  box-shadow: inset 3px 0 0 var(--success);
}

.weekly-task.complete > .weekly-task-main span {
  color: var(--success);
}

.weekly-subtasks {
  display: grid;
  gap: 6px;
  margin-left: 24px;
  padding-top: 2px;
}

.weekly-subtask {
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  color: var(--muted);
  font-size: 12px;
}

.weekly-subtask.complete span {
  color: var(--success);
}

.weekly-subtask span {
  font-weight: 600;
}

.bar-chart {
  display: grid;
  gap: 12px;
}

.bar-row {
  display: grid;
  grid-template-columns: minmax(260px, 340px) minmax(0, 1fr) 118px;
  gap: 12px;
  align-items: center;
}

.bar-label {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-height: 1.25;
  font-weight: 700;
}

.bar-track {
  position: relative;
  height: 28px;
  overflow: hidden;
  border-radius: 8px;
  background: var(--track);
}

.bar-actual {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
}

.bar-actual {
  background: var(--actual-bar);
}

.bar-value {
  display: grid;
  gap: 2px;
  color: var(--muted);
  font-size: 12px;
  text-align: right;
}

.bar-value strong {
  color: var(--ink);
  font-size: 14px;
}

.bar-value span {
  white-space: nowrap;
}

.compact .bar-row {
  grid-template-columns: 150px minmax(0, 1fr) 60px;
}

.table-wrap {
  overflow-x: auto;
}

table {
  width: 100%;
  border-collapse: collapse;
}

th,
td {
  border-bottom: 1px solid var(--line);
  padding: 11px 9px;
  text-align: left;
  vertical-align: top;
}

th {
  color: var(--muted);
  font-size: 12px;
  text-transform: uppercase;
}

tbody tr:hover {
  background: var(--soft);
}

.table-link {
  border: 0;
  padding: 0;
  background: transparent;
  color: var(--accent);
  font-weight: 800;
  text-align: left;
}

.week-row {
  cursor: pointer;
}

.week-row.active {
  background: var(--soft);
}

.list {
  display: grid;
  gap: 10px;
}

.entry {
  display: grid;
  gap: 4px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: var(--entry-bg);
}

.entry strong {
  font-size: 14px;
}

.entry span {
  color: var(--muted);
  font-size: 13px;
}

.entry-notes {
  border-left: 3px solid var(--accent);
  margin-top: 4px;
  padding: 6px 8px;
  background: var(--soft);
  color: var(--ink) !important;
  white-space: pre-wrap;
}

.clickable-entry {
  cursor: pointer;
  transition:
    border-color 0.15s ease,
    transform 0.15s ease,
    background 0.15s ease;
}

.clickable-entry:hover,
.clickable-entry:focus {
  border-color: var(--accent);
  background: var(--soft);
  outline: none;
  transform: translateY(-1px);
}

.empty {
  color: var(--muted);
  padding: 12px 0;
}

.data-actions {
  display: flex;
  gap: 12px;
  align-items: center;
}

.file-button input {
  display: none;
}

.modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 10;
  display: grid;
  place-items: center;
  padding: 22px;
  background: rgba(3, 7, 18, 0.62);
}

.modal-backdrop[hidden] {
  display: none;
}

.modal {
  width: min(760px, 100%);
  max-height: min(860px, calc(100vh - 44px));
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
  box-shadow: var(--shadow);
}

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 20px;
  border-bottom: 1px solid var(--line);
}

.modal-header h2 {
  font-size: 22px;
}

.modal-close {
  width: 38px;
  height: 38px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--input-bg);
  color: var(--ink);
  font-size: 24px;
  line-height: 1;
}

.modal-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  padding: 20px;
}

.modal-list {
  display: grid;
  gap: 10px;
  padding: 20px;
}

.edit-study-fields,
.edit-question-fields {
  display: contents;
}

.edit-study-fields[hidden],
.edit-question-fields[hidden] {
  display: none;
}

.modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  grid-column: 1 / -1;
  padding-top: 4px;
}

.mobile-app-header,
.mobile-bottom-nav,
.mobile-more-sheet,
.mobile-sheet-backdrop {
  display: none;
}

@media (max-width: 1024px) {
  html {
    scroll-padding-bottom: 104px;
  }

  body {
    min-width: 320px;
    padding-bottom: 96px;
    font-size: 14px;
  }

  body.mobile-sheet-open {
    overflow: hidden;
  }

  .app-shell {
    display: block;
    min-height: 100vh;
  }

  .sidebar,
  .user-bar {
    display: none;
  }

  .content {
    width: 100%;
    max-width: 860px;
    margin: 0 auto;
    padding: 22px 16px 18px;
    overflow: visible;
  }

  .mobile-app-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 22px;
  }

  .mobile-heading {
    min-width: 0;
  }

  .mobile-heading h1 {
    overflow-wrap: anywhere;
    margin: 0;
    color: var(--ink);
    font-family: var(--font-display);
    font-size: 27px;
    font-weight: 600;
    line-height: 1.05;
  }

  .mobile-heading p {
    margin: 5px 0 0;
    color: var(--muted);
    font-size: 12px;
    line-height: 1.3;
  }

  .mobile-quick-actions {
    display: flex;
    flex: 0 0 auto;
    gap: 8px;
  }

  .mobile-round-action {
    position: relative;
    display: grid;
    width: 42px;
    height: 42px;
    flex: 0 0 42px;
    place-items: center;
    border: 1px solid var(--line);
    border-radius: 50%;
    padding: 0;
    background: var(--panel);
    color: var(--sidebar);
    box-shadow: 0 7px 18px rgba(91, 45, 38, 0.09);
  }

  .mobile-round-action:active {
    border-color: var(--accent);
    color: var(--accent);
    transform: scale(0.96);
  }

  .mobile-round-action .quick-action-icon {
    width: 19px;
    height: 19px;
    border-radius: 5px;
    font-size: 11px;
  }

  .mobile-round-action .quick-action-icon.agenda-icon {
    width: 20px;
    height: 21px;
  }

  .mobile-round-action .quick-action-icon.agenda-icon::before,
  .mobile-round-action .quick-action-icon.agenda-icon::after {
    top: -2px;
    width: 3px;
    height: 6px;
  }

  .mobile-round-action .quick-action-icon.agenda-icon::before {
    left: 4px;
  }

  .mobile-round-action .quick-action-icon.agenda-icon::after {
    right: 4px;
  }

  .mobile-round-action .quick-action-icon.agenda-icon span {
    padding-top: 5px;
  }

  .mobile-round-action .quick-action-icon.agenda-icon span::before {
    top: 7px;
  }

  .mobile-clock-icon {
    position: relative;
    width: 20px;
    height: 20px;
    border: 1.7px solid currentColor;
    border-radius: 50%;
  }

  .mobile-clock-icon::before,
  .mobile-clock-icon::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 1.7px;
    border-radius: 2px;
    background: currentColor;
    transform-origin: bottom center;
  }

  .mobile-clock-icon::before {
    height: 6px;
    transform: translate(-50%, -100%);
  }

  .mobile-clock-icon::after {
    height: 5px;
    transform: translate(-50%, -100%) rotate(125deg);
  }

  .mobile-question-icon {
    font-family: var(--font-display);
    font-size: 24px;
    line-height: 1;
  }

  .mobile-round-action .quick-action-badge {
    top: -5px;
    right: -5px;
  }

  .view {
    width: 100%;
    max-width: none;
  }

  .view-header {
    display: none;
  }

  #view-metas .view-header {
    display: block;
    margin: 0 0 14px;
  }

  #view-metas .view-header > div:first-child {
    display: none;
  }

  #view-metas .header-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }

  #view-metas .header-actions .field {
    grid-column: 1 / -1;
  }

  #view-metas .header-actions button {
    min-height: 44px;
  }

  h2 {
    font-size: 30px;
  }

  h3 {
    font-size: 14px;
  }

  .panel,
  .kpi,
  #view-dashboard .panel,
  #view-dashboard .kpi {
    border-radius: 14px;
    box-shadow: 0 9px 26px rgba(91, 45, 38, 0.08);
  }

  .panel,
  #view-dashboard .panel {
    min-width: 0;
    margin-bottom: 14px;
    padding: 16px;
  }

  .panel-header,
  #view-dashboard .panel-header {
    align-items: center;
    margin-bottom: 13px;
  }

  .dashboard-kpi-grid,
  .kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin-bottom: 14px;
  }

  #view-dashboard .kpi {
    min-height: 114px;
    padding: 16px 12px 13px;
  }

  #view-dashboard .kpi::before {
    top: 13px;
    right: 12px;
    left: auto;
    width: 30px;
    height: 30px;
    font-size: 16px;
  }

  #view-dashboard .kpi span {
    display: block;
    max-width: calc(100% - 30px);
    font-size: 10px;
    line-height: 1.25;
  }

  #view-dashboard .kpi strong {
    margin-top: 20px;
    font-size: 25px;
  }

  #view-dashboard .dashboard-daily-panel {
    margin-bottom: 14px;
  }

  #view-dashboard .daily-calendar {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }

  #view-dashboard .daily-calendar > *,
  #view-dashboard .daily-planner-days,
  #view-dashboard .daily-planner-detail,
  #view-dashboard .daily-planner-tasks,
  #view-dashboard .weekly-tasks {
    width: 100%;
    min-width: 0;
    max-width: none;
  }

  #view-dashboard .daily-planner-detail {
    order: 2;
  }

  #view-dashboard .daily-planner-days {
    order: 1;
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 5px;
    overflow: visible;
    padding: 14px;
    border-radius: 14px;
  }

  #view-dashboard .daily-planner-tasks {
    order: 3;
  }

  .daily-planner-days-header {
    grid-column: 1 / -1;
    margin-bottom: 6px;
  }

  .daily-day-button {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
    min-width: 0;
    min-height: 58px;
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 7px 2px;
    background: var(--input-bg);
    text-align: center;
  }

  .daily-day-button:last-child {
    border-bottom: 1px solid var(--line);
  }

  .daily-day-button:hover,
  .daily-day-button.selected {
    border-color: var(--accent);
    background: var(--sidebar);
    color: var(--sidebar-text);
  }

  .daily-day-button.today:not(.selected) {
    border-color: var(--accent);
    box-shadow: inset 0 0 0 1px var(--accent);
  }

  .daily-day-button.complete {
    border-color: var(--success-line);
    background: var(--success-soft);
    box-shadow: none;
  }

  .daily-day-button.complete.selected {
    border-color: var(--success);
    background: var(--success);
  }

  .daily-day-main {
    border-right: 0;
    padding-right: 0;
    text-align: center;
  }

  .daily-day-button.selected .daily-day-main strong,
  .daily-day-button.selected .daily-day-main span,
  .daily-day-button.complete.selected .daily-day-main strong,
  .daily-day-button.complete.selected .daily-day-main span {
    color: #ffffff;
  }

  .daily-day-done,
  .daily-day-target,
  .daily-nav-track,
  .daily-day-percent {
    display: none;
  }

  .daily-day-main strong {
    font-size: 11px;
    line-height: 1.15;
  }

  .daily-day-main span {
    display: block;
    margin-top: 5px;
    color: var(--ink);
    font-size: 15px;
    font-weight: 800;
    line-height: 1;
  }

  .daily-day-date-full {
    display: none !important;
  }

  .daily-day-date-short {
    display: block !important;
  }

  .daily-planner-detail,
  .weekly-tasks {
    padding: 15px;
  }

  .daily-detail-header h3 {
    font-size: 20px;
  }

  .daily-detail-header > strong {
    font-size: 28px;
  }

  .daily-detail-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .daily-detail-summary article {
    padding: 12px;
  }

  .daily-subject {
    padding: 12px;
  }

  .daily-subject-line {
    gap: 8px;
  }

  .dashboard-bottom-grid {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .dashboard-bottom-grid > * {
    min-width: 0;
  }

  .bar-row,
  .compact .bar-row {
    grid-template-columns: minmax(0, 1fr) 54px;
    gap: 7px;
  }

  .bar-label {
    grid-column: 1 / -1;
    font-size: 12px;
  }

  .bar-track {
    height: 10px;
    border-radius: 999px;
  }

  .bar-value {
    font-size: 10px;
    text-align: right;
  }

  .bar-value strong {
    font-size: 12px;
  }

  .table-wrap {
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    margin-inline: -4px;
    padding-bottom: 4px;
  }

  table {
    min-width: 620px;
  }

  th,
  td {
    padding: 9px 7px;
    font-size: 11px;
  }

  .form-grid,
  .timer-grid,
  .agenda-form,
  .agenda-grid,
  .split-grid {
    grid-template-columns: 1fr;
    gap: 11px;
  }

  .field input,
  .field select,
  .field textarea,
  button.primary,
  button.secondary,
  button.danger {
    min-height: 44px;
  }

  .form-submit,
  .agenda-notes-field {
    grid-column: auto;
  }

  .timer-grid .timer-meta {
    min-height: 44px;
  }

  .data-actions,
  .simulation-actions {
    display: grid;
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .goal-row {
    grid-template-columns: 34px minmax(0, 1fr) 72px 40px;
    gap: 7px;
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 9px;
    background: var(--entry-bg);
  }

  .goal-row .toggle-field {
    grid-column: 2 / 4;
    grid-row: 2;
    justify-content: flex-start;
  }

  .goal-row > .icon-button {
    grid-column: 4;
    grid-row: 1;
  }

  .task-goal-row,
  .task-goal-main {
    grid-template-columns: 1fr;
  }

  .task-goal-row {
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 10px;
  }

  .simulation-header {
    display: none;
  }

  .simulation-row {
    grid-template-columns: minmax(0, 1fr) 72px 72px 40px;
    gap: 6px;
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 8px;
    background: var(--entry-bg);
  }

  .simulation-row > input {
    min-width: 0;
  }

  .simulation-row > .icon-button {
    align-self: stretch;
  }

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

  .distribution-board {
    display: grid;
    grid-template-columns: repeat(7, minmax(142px, 1fr));
    gap: 8px;
    overflow-x: auto;
    scroll-snap-type: x proximity;
    margin-inline: -16px;
    padding: 4px 16px 12px;
  }

  .distribution-day {
    min-height: 180px;
    scroll-snap-align: start;
  }

  .tabs {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 4px;
  }

  .tab-button {
    flex: 0 0 auto;
  }

  .agenda-calendar-panel {
    overflow: hidden;
  }

  .agenda-weekdays {
    font-size: 9px;
  }

  .agenda-day {
    min-height: 48px;
    padding: 4px;
    font-size: 10px;
  }

  .modal-backdrop {
    align-items: end;
    padding: 0;
  }

  .modal {
    width: 100%;
    max-height: 90vh;
    border-radius: 18px 18px 0 0;
  }

  .modal-form {
    grid-template-columns: 1fr;
    padding: 16px;
  }

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

  .mobile-bottom-nav {
    position: fixed;
    z-index: 30;
    right: 12px;
    bottom: max(10px, env(safe-area-inset-bottom));
    left: 12px;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    min-height: 70px;
    border: 1px solid color-mix(in srgb, var(--sidebar-text) 12%, transparent);
    border-radius: 22px;
    padding: 7px 5px;
    background: color-mix(in srgb, var(--sidebar) 96%, transparent);
    box-shadow: 0 14px 30px rgba(42, 23, 26, 0.28);
    backdrop-filter: blur(16px);
  }

  .mobile-nav-item {
    display: grid;
    grid-template-rows: 26px auto;
    place-items: center;
    gap: 2px;
    border: 0;
    border-radius: 14px;
    padding: 4px 2px;
    background: transparent;
    color: var(--sidebar-muted);
    font-size: 9px;
    font-weight: 600;
  }

  .mobile-nav-item.active {
    color: var(--accent);
  }

  #mobileMoreButton.active {
    color: var(--accent);
  }

  .mobile-nav-icon {
    display: grid;
    height: 25px;
    place-items: center;
    font-size: 23px;
    line-height: 1;
  }

  .mobile-calendar-icon {
    position: relative;
    width: 21px;
    height: 20px;
    border: 1.5px solid currentColor;
    border-radius: 4px;
  }

  .mobile-calendar-icon::before {
    content: "";
    position: absolute;
    top: 5px;
    left: 0;
    width: 100%;
    border-top: 1.5px solid currentColor;
  }

  .mobile-sheet-backdrop {
    position: fixed;
    z-index: 39;
    inset: 0;
    display: block;
    background: rgba(20, 12, 15, 0.42);
    backdrop-filter: blur(2px);
  }

  .mobile-sheet-backdrop[hidden],
  .mobile-more-sheet[hidden] {
    display: none;
  }

  .mobile-more-sheet {
    position: fixed;
    z-index: 40;
    right: 0;
    bottom: 0;
    left: 0;
    display: grid;
    gap: 16px;
    max-height: 82vh;
    overflow-y: auto;
    border: 1px solid var(--line);
    border-radius: 22px 22px 0 0;
    padding: 10px 18px calc(22px + env(safe-area-inset-bottom));
    background: var(--panel);
    box-shadow: 0 -18px 44px rgba(20, 12, 15, 0.2);
  }

  .mobile-sheet-handle {
    width: 42px;
    height: 4px;
    margin: 0 auto;
    border-radius: 999px;
    background: var(--line-strong);
  }

  .mobile-sheet-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
  }

  .mobile-sheet-header > div {
    display: grid;
    gap: 3px;
    min-width: 0;
  }

  .mobile-sheet-header strong {
    font-family: var(--font-display);
    font-size: 22px;
  }

  .mobile-sheet-header span {
    overflow: hidden;
    color: var(--muted);
    font-size: 12px;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .mobile-sheet-close {
    width: 38px;
    height: 38px;
    border: 1px solid var(--line);
    border-radius: 50%;
    background: var(--surface-warm);
    color: var(--ink);
    font-size: 22px;
  }

  .mobile-more-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .mobile-more-actions button {
    display: flex;
    align-items: center;
    gap: 9px;
    min-height: 52px;
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 10px 12px;
    background: var(--entry-bg);
    color: var(--ink);
    font-weight: 700;
    text-align: left;
  }

  .mobile-theme-section {
    display: grid;
    gap: 8px;
    border-top: 1px solid var(--line);
    padding-top: 14px;
  }

  .mobile-theme-section > span {
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
  }

  .mobile-appearance-options,
  .mobile-theme-options {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 7px;
  }

  .mobile-appearance-options button,
  .mobile-theme-options button {
    min-height: 42px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: var(--input-bg);
    color: var(--ink);
    font-size: 12px;
    font-weight: 700;
  }

  .mobile-appearance-options button.active,
  .mobile-theme-options button.active {
    border-color: var(--accent);
    background: var(--primary-soft);
  }

  .mobile-theme-options button {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
  }

  .mobile-theme-options i {
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: var(--theme-color);
  }

  .mobile-sign-out {
    min-height: 44px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: transparent;
    color: var(--danger);
    font-weight: 800;
  }

  .auth-screen {
    padding: 14px;
  }

  .auth-card {
    border-radius: 18px;
    padding: 22px 18px;
  }
}

@media (max-width: 374px) {
  .content {
    padding-inline: 12px;
  }

  .mobile-app-header {
    gap: 8px;
  }

  .mobile-heading h1 {
    font-size: 24px;
  }

  .mobile-quick-actions {
    gap: 6px;
  }

  .mobile-round-action {
    width: 39px;
    height: 39px;
    flex-basis: 39px;
  }

  .daily-day-button {
    grid-template-columns: 1fr;
    min-height: 54px;
    padding-inline: 1px;
  }

  #view-dashboard .daily-planner-days {
    gap: 4px;
    padding-inline: 10px;
  }

  .daily-day-main strong {
    font-size: 10px;
  }

  .daily-day-main span {
    font-size: 14px;
  }

  .simulation-row {
    grid-template-columns: minmax(0, 1fr) 62px 62px 38px;
  }

  .mobile-bottom-nav {
    right: 8px;
    left: 8px;
  }
}
