
:root {
  --bg: #f5f5f1;
  --surface: #ffffff;
  --surface-soft: #fafaf8;
  --text: #20221f;
  --muted: #6e726a;
  --border: #e2e4dd;
  --primary: #2f7d4c;
  --primary-dark: #23663d;
  --primary-soft: #e7f4ec;
  --danger: #b93838;
  --warning: #f4b740;
  --shadow: 0 12px 32px rgba(32,34,31,.08);
  --radius: 24px;
  --radius-sm: 16px;
  --content: 1220px;
}

* { box-sizing: border-box; }
html { min-height: 100%; }
body.tn-body, body {
  margin: 0;
  min-height: 100%;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at top left, rgba(47,125,76,.14), transparent 35%),
    linear-gradient(180deg, #fbfbf8, var(--bg));
  line-height: 1.45;
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; }

.app-shell { min-height: 100vh; display: flex; }
.app-sidebar {
  width: 280px;
  flex: 0 0 280px;
  min-height: 100vh;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(14px);
  border-right: 1px solid var(--border);
  padding: 22px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: sticky;
  top: 0;
  height: 100vh;
}

.brand-block {
  display: flex;
  gap: 12px;
  align-items: center;
  margin-bottom: 34px;
}
.brand-mark {
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  background: var(--primary);
  color: white;
  border-radius: 18px;
  font-size: 24px;
  box-shadow: var(--shadow);
}
.brand-block strong { display:block; font-size: 1.35rem; letter-spacing: -.03em; }
.brand-block small { display:block; color: var(--muted); font-size: .82rem; margin-top: 2px; }

.side-nav { display: grid; gap: 6px; }
.side-nav a {
  padding: 13px 14px;
  border-radius: 16px;
  color: #30332d;
  font-weight: 650;
  font-size: .95rem;
}
.side-nav a:hover, .side-nav a:focus {
  background: var(--primary-soft);
  color: var(--primary-dark);
}
.side-nav .admin-link {
  margin-top: 12px;
  background: #1f2520;
  color: #fff;
}
.side-nav .admin-link:hover { background: #111; color: #fff; }

.sidebar-user {
  border-top: 1px solid var(--border);
  padding-top: 16px;
  display: grid;
  gap: 4px;
}
.sidebar-user strong { font-size: 1rem; }
.sidebar-user small { color: var(--muted); }
.sidebar-user a { color: var(--primary-dark); font-weight: 700; margin-top: 8px; }

.app-main { min-width: 0; flex: 1; display: flex; flex-direction: column; }
.app-content {
  width: min(100%, var(--content));
  margin: 0 auto;
  padding: 30px 28px 94px;
  flex: 1;
}

.mobile-topbar {
  display: none;
  height: 62px;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  background: rgba(255,255,255,.94);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 50;
}
.mobile-brand { font-weight: 800; font-size: 1.08rem; }
.icon-button {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border: 1px solid var(--border);
  background: var(--surface);
  border-radius: 14px;
  font-size: 1.1rem;
}

.page-hero {
  background: linear-gradient(135deg, rgba(255,255,255,.94), rgba(231,244,236,.88));
  border: 1px solid rgba(47,125,76,.16);
  border-radius: 32px;
  padding: 28px;
  box-shadow: var(--shadow);
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 22px;
  margin-bottom: 30px;
}
.eyebrow {
  color: var(--primary-dark);
  text-transform: uppercase;
  font-size: .76rem;
  font-weight: 850;
  letter-spacing: .08em;
  margin: 0 0 8px;
}
h1, h2, h3 { letter-spacing: -.035em; line-height: 1.08; }
h1 { margin: 0; font-size: clamp(2rem, 4vw, 3.2rem); }
h2 { margin: 0 0 8px; font-size: clamp(1.25rem, 2vw, 1.55rem); }
p { margin-top: 0; }
.muted { color: var(--muted); }
.hero-actions, .actions, .card-actions { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }

.section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}

.grid, .cards-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.card {
  background: rgba(255,255,255,.96);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 22px;
  box-shadow: 0 6px 22px rgba(32,34,31,.055);
}
.diary-card-modern, .feature-card {
  min-height: 286px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.diary-card-modern:hover, .feature-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow);
  border-color: rgba(47,125,76,.28);
}
.card-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; }
.card-icon {
  width: 58px;
  height: 58px;
  border-radius: 22px;
  background: var(--primary-soft);
  display: grid;
  place-items: center;
  font-size: 2rem;
  flex: 0 0 auto;
}
.badge {
  background: var(--surface-soft);
  border: 1px solid var(--border);
  color: var(--primary-dark);
  padding: 7px 10px;
  border-radius: 999px;
  font-size: .78rem;
  font-weight: 800;
  white-space: nowrap;
}
.card-body { margin: 18px 0; }
.card-body p, .feature-card p { color: var(--muted); min-height: 44px; }

.mini-stats {
  display: grid;
  gap: 8px;
  margin: 0 0 18px;
  padding: 14px;
  border-radius: 18px;
  background: var(--surface-soft);
}
.mini-stats div, dl div { display:flex; justify-content:space-between; gap: 12px; }
dt { color: var(--muted); font-size: .82rem; }
dd { margin: 0; font-weight: 750; text-align: right; }

.add-card {
  min-height: 286px;
  border: 2px dashed #cfd5ca;
  display: grid;
  place-items: center;
  text-align: center;
  color: var(--muted);
  transition: .16s ease;
}
.add-card span { font-size: 3rem; color: var(--primary); }
.add-card strong { display:block; color: var(--text); font-size: 1.2rem; margin-top: 8px; }
.add-card small { max-width: 220px; display:block; margin-top: 6px; }
.add-card:hover { background: var(--primary-soft); border-color: var(--primary); }

.button, button {
  border: 0;
  border-radius: 15px;
  padding: 11px 16px;
  font-weight: 800;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
}
.button.primary, .button:not(.secondary), button:not(.secondary) {
  background: var(--primary);
  color: #fff;
}
.button.secondary, .secondary {
  background: var(--surface-soft);
  color: var(--text);
  border: 1px solid var(--border);
}
.button:hover, button:hover { filter: brightness(.98); }

.success, .alert {
  border-radius: 18px;
  padding: 14px 16px;
  margin-bottom: 18px;
  font-weight: 700;
}
.success { background: #e7f4ec; color: #245f3d; border: 1px solid #bfe3ce; }
.alert { background: #fff1f1; color: var(--danger); border: 1px solid #f2c2c2; }

.form, form.form { display: grid; gap: 15px; }
label { display: grid; gap: 7px; font-weight: 750; }
input, textarea, select {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 13px 14px;
  font: inherit;
  background: #fff;
  color: var(--text);
}
textarea { min-height: 110px; resize: vertical; }
input:focus, textarea:focus, select:focus {
  outline: 3px solid rgba(47,125,76,.16);
  border-color: var(--primary);
}

.field-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 14px;
}
.field-grid > * { grid-column: span 4; }
.field-grid .half { grid-column: span 6; }
.field-grid .span { grid-column: span 12; }
.field-grid .compact { grid-column: span 4; }

.topbar {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 28px;
  padding: 20px;
  margin-bottom: 22px;
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
}
.back { color: var(--primary-dark); font-weight: 800; }
.diary-card { min-height: 260px; display:flex; flex-direction:column; justify-content:space-between; }

.fab {
  position: fixed;
  right: 24px;
  bottom: 26px;
  width: 62px;
  height: 62px;
  border-radius: 50%;
  display: none;
  place-items: center;
  background: var(--primary);
  color: #fff;
  font-size: 2rem;
  box-shadow: var(--shadow);
  z-index: 60;
}

.bottom-nav {
  display: none;
  position: fixed;
  left: 0; right: 0; bottom: 0;
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(14px);
  border-top: 1px solid var(--border);
  z-index: 80;
  padding: 7px 10px calc(7px + env(safe-area-inset-bottom));
  justify-content: space-around;
}
.bottom-nav a {
  min-width: 54px;
  display: grid;
  place-items: center;
  gap: 1px;
  color: var(--muted);
  font-weight: 750;
  font-size: .75rem;
}
.bottom-nav span { font-size: 1.25rem; }
.bottom-nav .bottom-plus {
  width: 62px;
  height: 62px;
  border-radius: 50%;
  background: var(--primary);
  color: #fff;
  margin-top: -34px;
  box-shadow: var(--shadow);
  border: 4px solid var(--bg);
}
.bottom-nav .bottom-plus span { font-size: 2rem; line-height: 1; }

.app-footer {
  color: var(--muted);
  font-size: .82rem;
  text-align: center;
  padding: 20px 10px 28px;
}
.maintenance-banner {
  background: var(--warning);
  color: #332300;
  padding: 10px 18px;
  font-weight: 850;
  text-align: center;
}
.feature-card { color: inherit; }
.feature-card h2 { margin-top: 16px; }
.segmented { display:flex; gap: 6px; flex-wrap:wrap; }
.segmented button { background: var(--surface-soft); color: var(--text); border: 1px solid var(--border); min-height: 38px; padding: 8px 12px; }

@media (prefers-color-scheme: dark) {
  body[data-theme="auto"], body:not([data-theme]) {
    --bg: #111512;
    --surface: #1a201c;
    --surface-soft: #232a25;
    --text: #f3f5ef;
    --muted: #aeb7ad;
    --border: #30392f;
    --primary-soft: #173322;
    --shadow: 0 16px 42px rgba(0,0,0,.28);
  }
}
body[data-theme="dark"] {
  --bg: #111512;
  --surface: #1a201c;
  --surface-soft: #232a25;
  --text: #f3f5ef;
  --muted: #aeb7ad;
  --border: #30392f;
  --primary-soft: #173322;
  --shadow: 0 16px 42px rgba(0,0,0,.28);
}
body[data-theme="dark"] input,
body[data-theme="dark"] textarea,
body[data-theme="dark"] select { background:#151914; }

@media (max-width: 960px) {
  .app-sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    z-index: 100;
    transform: translateX(-105%);
    transition: transform .18s ease;
    box-shadow: var(--shadow);
  }
  body.sidebar-open .app-sidebar { transform: translateX(0); }
  .mobile-topbar { display: flex; }
  .app-content { padding: 18px 14px 100px; }
  .page-hero { padding: 22px; border-radius: 26px; display:block; }
  .hero-actions { margin-top: 18px; }
  .topbar { display:block; border-radius: 24px; }
  .topbar .actions { margin-top: 14px; }
  .grid, .cards-grid { grid-template-columns: 1fr; gap: 14px; }
  .diary-card-modern, .feature-card, .add-card { min-height: auto; }
  .card { padding: 18px; border-radius: 22px; }
  .field-grid { grid-template-columns: 1fr; }
  .field-grid > *, .field-grid .half, .field-grid .span, .field-grid .compact { grid-column: auto; }
  .bottom-nav { display: flex; }
  .fab { display: none; }
  .mini-stats div, dl div { display:block; }
  dd { text-align:left; margin-top: 2px; }
}

@media (max-width: 520px) {
  h1 { font-size: 2rem; }
  .page-hero { margin-bottom: 20px; }
  .section-head { display:block; }
  .card-actions, .hero-actions, .actions { flex-direction: column; align-items: stretch; }
  .button { width: 100%; }
  .card-icon { width: 50px; height: 50px; border-radius: 18px; font-size: 1.6rem; }
  .card-body p { min-height: 0; }
}


/* v0.4.3 Mobile UX Polish */
:root {
  --muted: #4f574e;
  --text: #171b16;
  --border: #d6dbd2;
}

.muted { color: var(--muted); }
dt { color: #495046; font-weight: 750; }
dd { color: var(--text); }

.sidebar-close {
  display: none;
  position: absolute;
  top: 14px;
  right: 14px;
  width: 40px;
  height: 40px;
  border-radius: 14px;
  background: var(--surface-soft);
  color: var(--text);
  border: 1px solid var(--border);
  font-weight: 900;
}

.logout-link {
  color: #b42323 !important;
  font-weight: 850 !important;
}

.section-card {
  background: rgba(255,255,255,.96);
  border: 1px solid var(--border);
  border-radius: 24px;
  padding: 18px 20px;
  box-shadow: 0 6px 22px rgba(32,34,31,.055);
}

.profile-list {
  display: grid;
  gap: 14px;
}

.profile-list .feature-card {
  min-height: auto;
  display: grid;
  grid-template-columns: 58px 1fr;
  gap: 14px 16px;
  align-items: center;
  padding: 18px;
}

.profile-list .feature-card .card-icon {
  grid-row: span 2;
}

.profile-list .feature-card h2,
.profile-list .feature-card p {
  margin: 0;
  min-height: 0;
}

.profile-list .feature-card .segmented {
  grid-column: 1 / -1;
}

.manage-section {
  overflow: visible;
}

.manage-list {
  display: grid;
  gap: 16px;
}

.manage-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 24px;
  padding: 18px;
  box-shadow: 0 6px 22px rgba(32,34,31,.055);
}

.manage-card.is-disabled {
  opacity: .66;
}

.manage-card-head {
  display: grid;
  grid-template-columns: 58px 1fr auto;
  gap: 14px;
  align-items: center;
  margin-bottom: 16px;
}

.manage-card-head h3 {
  margin: 0;
  font-size: 1.22rem;
  letter-spacing: -.03em;
}

.manage-icon {
  width: 54px;
  height: 54px;
  display: grid;
  place-items: center;
  border-radius: 18px;
  background: var(--primary-soft);
  font-size: 1.8rem;
}

.manage-fields {
  display: grid;
  grid-template-columns: 90px 1fr 1fr 160px 160px auto;
  gap: 12px;
  align-items: end;
}

.manage-fields .span {
  grid-column: span 2;
}

.checkline {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 9px;
  min-height: 48px;
}

.checkline input {
  width: auto;
}

.compact-button {
  min-height: 40px;
  padding: 9px 12px;
  white-space: nowrap;
}

.perm-details {
  margin-top: 14px;
  border-top: 1px solid var(--border);
  padding-top: 12px;
}

.perm-details summary {
  font-weight: 850;
  cursor: pointer;
  color: var(--primary-dark);
}

.sticky-actions {
  position: sticky;
  bottom: 82px;
  z-index: 30;
  display: flex;
  justify-content: flex-end;
  margin-top: 18px;
  padding: 10px 0;
}

.sticky-actions button {
  box-shadow: var(--shadow);
}

.image-gallery {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.image-card {
  border: 1px solid var(--border);
  border-radius: 22px;
  overflow: hidden;
  background: var(--surface);
}

.image-card img {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  background: var(--surface-soft);
}

.image-meta {
  padding: 14px;
  display: grid;
  gap: 8px;
}

body[data-theme="dark"] {
  --muted: #c4cdc2;
  --text: #f6f8f2;
  --border: #3f4a3e;
}

@media (max-width: 960px) {
  .sidebar-close {
    display: grid;
    place-items: center;
  }

  .app-sidebar {
    padding-top: 66px;
  }

  .mobile-topbar {
    box-shadow: 0 6px 18px rgba(32,34,31,.06);
  }

  .page-hero {
    background: rgba(255,255,255,.96);
  }

  .manage-card-head {
    grid-template-columns: 52px 1fr auto;
  }

  .manage-fields {
    grid-template-columns: 1fr 1fr;
  }

  .manage-fields .span {
    grid-column: 1 / -1;
  }

  .perm-grid {
    grid-template-columns: 1fr;
  }

  .sticky-actions {
    bottom: 78px;
  }

  .sticky-actions button {
    width: 100%;
  }
}

@media (max-width: 520px) {
  .app-content {
    padding-left: 12px;
    padding-right: 12px;
  }

  .page-hero {
    padding: 18px;
  }

  .section-card {
    padding: 15px;
  }

  .manage-card {
    padding: 15px;
    border-radius: 22px;
  }

  .manage-card-head {
    grid-template-columns: 48px 1fr;
  }

  .manage-card-head .compact-button {
    grid-column: 1 / -1;
    width: 100%;
  }

  .manage-icon {
    width: 48px;
    height: 48px;
    border-radius: 16px;
    font-size: 1.55rem;
  }

  .manage-fields {
    grid-template-columns: 1fr;
  }

  .profile-list .feature-card {
    grid-template-columns: 46px 1fr;
  }

  .profile-list .feature-card .card-icon {
    width: 46px;
    height: 46px;
    border-radius: 16px;
    font-size: 1.45rem;
  }

  .mini-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .mini-stats div {
    display: block;
  }
}


/* v0.4.4 Feedback + Login Polish */
.login-page {
  min-height: calc(100vh - 80px);
  display: grid;
  place-items: center;
  padding: 28px 14px 70px;
  position: relative;
}

.login-page::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -2;
  background:
    linear-gradient(rgba(245,245,241,.82), rgba(245,245,241,.92)),
    radial-gradient(circle at top left, rgba(47,125,76,.28), transparent 38%),
    radial-gradient(circle at bottom right, rgba(47,125,76,.14), transparent 44%);
}

.login-card {
  width: min(100%, 460px);
  background: rgba(255,255,255,.94);
  border: 1px solid var(--border);
  border-radius: 32px;
  padding: 30px;
  box-shadow: var(--shadow);
}

.login-brand {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 24px;
}

.login-brand h1 {
  font-size: 2rem;
  margin: 0 0 2px;
}

.login-brand p {
  margin: 0;
  color: var(--muted);
  font-weight: 650;
}

.login-intro {
  color: var(--muted);
  margin-bottom: 18px;
}

.login-form {
  gap: 16px;
}

.feedback-card textarea {
  min-height: 180px;
}

.message-list {
  display: grid;
  gap: 16px;
}

.message-card {
  display: grid;
  gap: 16px;
}

.message-head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
}

.message-head h2 {
  margin-top: 12px;
}

.message-body {
  padding: 16px;
  border-radius: 18px;
  background: var(--surface-soft);
  line-height: 1.7;
  white-space: normal;
}

.message-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.message-meta {
  border-top: 1px solid var(--border);
  padding-top: 10px;
}

.status-open {
  border-color: rgba(47,125,76,.45);
}

.status-read {
  opacity: .86;
}

.status-archived {
  opacity: .64;
}

@media (max-width: 520px) {
  .login-page {
    place-items: start center;
    padding-top: 18px;
  }

  .login-card {
    padding: 22px;
    border-radius: 26px;
  }

  .login-brand h1 {
    font-size: 1.75rem;
  }

  .message-head {
    display: grid;
  }

  .message-actions {
    display: grid;
  }

  .message-actions button {
    width: 100%;
  }
}


/* v0.4.5 Tracknote Management Rebuild + Message Badges */
.nav-badge {
  display: inline-grid;
  place-items: center;
  min-width: 22px;
  height: 22px;
  padding: 0 7px;
  margin-left: 6px;
  border-radius: 999px;
  background: #d63a3a;
  color: #fff;
  font-size: .75rem;
  font-weight: 900;
}

.badge-alert {
  background: #d63a3a;
  color: #fff;
  border-color: #d63a3a;
}

.manage-topbar {
  margin-bottom: 18px;
}

.manage-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(360px, .8fr);
  gap: 20px;
  align-items: start;
}

.manage-main {
  min-width: 0;
}

.panel-card {
  background: rgba(255,255,255,.97);
  border: 1px solid var(--border);
  border-radius: 28px;
  padding: 22px;
  box-shadow: 0 8px 26px rgba(32,34,31,.06);
}

.panel-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}

.tracknote-manage-list {
  display: grid;
  gap: 16px;
}

.tracknote-manage-card {
  border: 1px solid var(--border);
  background: var(--surface);
  border-radius: 24px;
  padding: 18px;
  display: grid;
  gap: 16px;
  box-shadow: 0 5px 18px rgba(32,34,31,.045);
}

.tracknote-manage-card.is-disabled {
  opacity: .62;
}

.tmc-head {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
}

.tmc-icon {
  width: 54px;
  height: 54px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  background: var(--primary-soft);
  font-size: 1.75rem;
}

.tmc-title {
  min-width: 0;
}

.tmc-title h3 {
  margin: 0;
  font-size: 1.24rem;
  letter-spacing: -.035em;
}

.tmc-title p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: .92rem;
}

.tmc-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.tmc-fields {
  display: grid;
  grid-template-columns: 84px minmax(170px, .85fr) minmax(220px, 1.4fr) 160px 150px 86px;
  gap: 12px;
  align-items: end;
}

.tmc-fields label {
  min-width: 0;
}

.tmc-fields input,
.tmc-fields select {
  min-height: 42px;
}

.switch-row {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 9px;
  min-height: 44px;
  padding: 0 4px;
}

.switch-row input {
  width: auto;
}

.create-panel {
  position: sticky;
  top: 20px;
}

.create-tracknote-form {
  gap: 16px;
}

.category-packets {
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 16px;
  background: var(--surface-soft);
}

.category-packets legend {
  font-weight: 900;
  padding: 0 8px;
}

.category-package {
  border: 1px solid var(--border);
  border-radius: 16px;
  background: var(--surface);
  padding: 10px 12px;
  margin-top: 10px;
}

.category-package summary {
  cursor: pointer;
  font-weight: 850;
  color: var(--primary-dark);
}

.checkbox-grid {
  display: grid;
  gap: 9px;
  margin-top: 10px;
}

.checkbox-grid label {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 7px 10px;
  align-items: start;
  padding: 10px;
  border-radius: 14px;
  background: var(--surface-soft);
}

.checkbox-grid label input {
  width: auto;
  margin-top: 3px;
}

.checkbox-grid label small {
  grid-column: 2;
  color: var(--muted);
  line-height: 1.45;
}

.option-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  align-items: end;
}

.reply-box {
  border-top: 1px solid var(--border);
  padding-top: 12px;
}

.reply-box summary {
  cursor: pointer;
  font-weight: 850;
  color: var(--primary-dark);
}

@media (max-width: 1180px) {
  .manage-layout {
    grid-template-columns: 1fr;
  }

  .create-panel {
    position: static;
  }

  .tmc-fields {
    grid-template-columns: 80px 1fr 1fr;
  }

  .tmc-fields .wide {
    grid-column: span 2;
  }
}

@media (max-width: 760px) {
  .panel-card {
    padding: 16px;
    border-radius: 24px;
  }

  .tmc-head {
    grid-template-columns: 50px minmax(0, 1fr);
  }

  .tmc-actions {
    grid-column: 1 / -1;
    justify-content: stretch;
  }

  .tmc-actions .button {
    flex: 1;
  }

  .tmc-icon {
    width: 48px;
    height: 48px;
    border-radius: 16px;
    font-size: 1.55rem;
  }

  .tmc-fields {
    grid-template-columns: 1fr;
  }

  .tmc-fields .wide {
    grid-column: auto;
  }

  .perm-grid {
    grid-template-columns: 1fr;
  }

  .category-packets {
    padding: 12px;
  }
}


/* v0.4.7 User Preferences + Stronger Mobile Contrast */
:root {
  --muted: #30372f;
  --text: #101510;
  --label: #101510;
  --input-text: #101510;
  --input-bg: #ffffff;
  --input-border: #9ba697;
}

body[data-accent="blue"] {
  --primary: #2f6fa3;
  --primary-dark: #25577f;
  --primary-soft: #e4f0fa;
}

body[data-accent="violet"] {
  --primary: #7653b5;
  --primary-dark: #5c3d96;
  --primary-soft: #efe9fb;
}

body[data-accent="orange"] {
  --primary: #b7662d;
  --primary-dark: #925020;
  --primary-soft: #fff0e4;
}

body[data-font-size="compact"] {
  font-size: 15px;
}

body[data-font-size="normal"] {
  font-size: 16px;
}

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

body[data-font-size="xlarge"] {
  font-size: 20px;
}

body[data-density="compact"] .card,
body[data-density="compact"] .panel-card,
body[data-density="compact"] .tracknote-manage-card {
  padding: 14px;
}

label {
  color: var(--label);
}

label,
.login-form label,
.form label {
  font-weight: 850;
}

input,
textarea,
select {
  color: var(--input-text);
  background: var(--input-bg);
  border-color: var(--input-border);
  font-weight: 650;
}

input::placeholder,
textarea::placeholder {
  color: #596357;
  opacity: 1;
}

.hint,
.login-card .hint,
.login-intro,
.login-brand p,
.card-body p,
.feature-card p,
.muted {
  color: var(--muted) !important;
}

.login-card {
  color: var(--text);
}

.login-brand h1 {
  color: var(--text);
}

.login-brand p {
  font-weight: 800;
}

.login-intro {
  font-weight: 750;
}

.login-card .hint {
  font-weight: 750;
}

.preference-form {
  grid-column: 1 / -1;
  display: grid;
  gap: 14px;
  margin-top: 10px;
}

.preference-form button {
  margin-top: 4px;
}

body[data-theme="dark"] {
  --muted: #e0e7dc;
  --text: #fbfdf7;
  --label: #fbfdf7;
  --input-text: #fbfdf7;
  --input-bg: #151b16;
  --input-border: #62715f;
}

@media (prefers-color-scheme: dark) {
  body[data-theme="auto"] {
    --muted: #e0e7dc;
    --text: #fbfdf7;
    --label: #fbfdf7;
    --input-text: #fbfdf7;
    --input-bg: #151b16;
    --input-border: #62715f;
  }
}

@media (max-width: 760px) {
  :root {
    --muted: #20281f;
    --text: #070b07;
    --label: #070b07;
  }

  body[data-theme="dark"],
  body[data-theme="auto"] {
    --muted: #edf4ea;
    --text: #ffffff;
    --label: #ffffff;
  }

  .login-card {
    background: rgba(255,255,255,.985);
  }

  .login-brand p,
  .login-intro,
  .login-card .hint,
  .muted {
    color: var(--muted) !important;
  }

  .form label,
  .login-form label {
    color: var(--label);
    font-size: 1rem;
  }

  input,
  textarea,
  select {
    border-width: 2px;
  }
}
