:root {
  --paper:      #f6f2ea;
  --paper-2:    #efe9dd;
  --ink:        #1a1a1a;
  --ink-2:      #3d3a36;
  --rule:       #c9c0ae;
  --rule-soft:  #ddd5c4;
  --oxblood:    #6b1f1f;
  --oxblood-2:  #8a2a2a;
  --gold:       #b08e2c;          /* matches the logo's brighter gold */
  --green:      #1f4d32;          /* matches the logo's deep forest green */
  --green-2:    #2a6342;          /* slightly lighter for hovers */
  --gray-2:     #6e685e;
  --gray-3:     #8a8478;
  --display:    "Fraunces", "Times New Roman", serif;
  --sans:       "Inter", -apple-system, BlinkMacSystemFont, sans-serif;
  --mono:       "JetBrains Mono", ui-monospace, monospace;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 15px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

body::before {
  content: "";
  position: fixed; inset: 0;
  background-image:
    radial-gradient(rgba(0,0,0,0.025) 1px, transparent 1px);
  background-size: 4px 4px;
  pointer-events: none;
  z-index: 0;
}

.masthead {
  padding: 28px 48px 0;
  position: relative;
  z-index: 1;
}
.masthead-inner {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 24px;
}
.brand { display: flex; gap: 20px; align-items: center; }
.brand-mark {
  width: 72px;
  height: 72px;
  display: block;
  /* Clip any white background that may surround the icon's rounded square.
     22% roughly matches the rounded-corner radius of the icon design. */
  border-radius: 22%;
  /* font fallback in case the image fails to load */
  font-family: var(--display);
  font-weight: 900;
  font-size: 64px;
  color: var(--green);
  line-height: 0.85;
  font-feature-settings: "ss01";
}
.brand-text {
  text-align: center;
  width: 320px;          /* fixed reference width so all three lines align */
  max-width: 100%;
}
.brand-title {
  font-family: var(--display);
  font-weight: 900;
  font-size: 44px;
  letter-spacing: 0.34em; /* spreads DOCKET to fill the 320px width */
  text-transform: uppercase;
  color: var(--green);
  margin: 0;
  line-height: 1;
  font-variation-settings: "opsz" 144;
  /* Compensate for trailing letter-spacing which adds extra right padding */
  text-indent: 0.34em;
}
.brand-firm-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin: 8px 0 4px;
}
.brand-rule {
  flex: 1 1 0;            /* expand to fill remaining space on each side */
  height: 1px;
  background: var(--gold);
  min-width: 12px;
}
.brand-firm {
  font-family: var(--display);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 13px;
  color: var(--green);
  margin: 0;
  white-space: nowrap;
  flex: 0 0 auto;
}
.brand-tag {
  font-family: var(--display);
  font-weight: 500;
  font-style: italic;
  text-transform: uppercase;
  letter-spacing: 0.32em;  /* spreads tagline to roughly match width */
  font-size: 11px;
  color: var(--gold);
  margin: 0;
  text-indent: 0.32em;
}
.meta { display: flex; align-items: center; gap: 24px; }
.meta-row { text-align: right; }
.meta-label {
  display: block;
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--gray-2);
}
.meta-value {
  font-family: var(--display);
  font-size: 18px;
  font-weight: 500;
}
.btn-sync {
  background: var(--ink);
  color: var(--paper);
  border: none;
  padding: 12px 22px;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.15s ease;
}
.btn-sync:hover { background: var(--green); }
.btn-sync:disabled { opacity: 0.5; cursor: wait; }

.rule {
  margin-top: 24px;
  height: 1px;
  background: var(--ink);
  position: relative;
}
.rule::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  top: 4px;
  height: 1px;
  background: var(--ink);
}

.tabs {
  display: flex;
  gap: 4px;
  padding: 20px 48px 0;
  border-bottom: 1px solid var(--rule);
  position: relative;
  z-index: 1;
}
.tab {
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  padding: 14px 18px;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--gray-2);
  cursor: pointer;
  margin-bottom: -1px;
}
.tab:hover { color: var(--ink); }
.tab-active {
  color: var(--ink);
  border-bottom-color: var(--green);
  font-weight: 600;
}

main {
  padding: 36px 48px 80px;
  position: relative;
  z-index: 1;
  max-width: 1200px;
}

.empty {
  text-align: center;
  padding: 80px 20px;
  border: 1px dashed var(--rule);
}
.empty-title {
  font-family: var(--display);
  font-size: 28px;
  margin: 0 0 8px;
}
.empty-sub { color: var(--gray-2); margin: 0; }
.hidden { display: none !important; }

/* List view */
.list { display: flex; flex-direction: column; }

.appearance {
  display: grid;
  grid-template-columns: 120px 1fr auto;
  gap: 28px;
  padding: 24px 0;
  border-bottom: 1px solid var(--rule-soft);
  cursor: pointer;
  transition: background 0.15s ease;
  align-items: start;
}
.appearance:hover { background: rgba(0,0,0,0.02); }
.appearance.is-past { opacity: 0.55; }

.date-block {
  font-family: var(--display);
  text-align: center;
  padding-top: 4px;
}
.date-day {
  font-size: 42px;
  font-weight: 700;
  line-height: 1;
  font-variation-settings: "opsz" 144;
}
.date-month {
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--gray-2);
  margin-top: 6px;
}
.date-time {
  font-family: var(--mono);
  font-size: 12px;
  margin-top: 8px;
  color: var(--ink-2);
}
.date-weekday {
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--gray-3);
  margin-top: 4px;
}

.case-block .case-name {
  font-family: var(--display);
  font-size: 22px;
  font-weight: 500;
  margin: 0 0 6px;
  line-height: 1.2;
  font-variation-settings: "opsz" 36;
}
.case-block .case-name em {
  font-style: italic;
  font-weight: 400;
  color: var(--gray-2);
}
.case-meta-row {
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
  margin-top: 8px;
  font-size: 13px;
  color: var(--ink-2);
}
.case-meta-row span strong {
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--gray-2);
  font-weight: 500;
  display: block;
  margin-bottom: 2px;
}
.case-meta-row span {
  font-family: var(--display);
  font-size: 15px;
}
.index-num {
  font-family: var(--mono) !important;
  font-size: 12px !important;
}

.status-block { text-align: right; padding-top: 6px; min-width: 140px; }
.coverage-pill {
  display: inline-block;
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  padding: 5px 10px;
  border: 1px solid currentColor;
  font-weight: 500;
}
.coverage-self     { color: var(--ink);     background: rgba(26,26,26,0.06); }
.coverage-covered  { color: var(--green);   background: rgba(47,93,58,0.06); }
.coverage-unassigned { color: var(--gold); background: rgba(163,128,26,0.06); }

.covered-by {
  display: block;
  font-family: var(--display);
  font-style: italic;
  font-size: 13px;
  margin-top: 8px;
  color: var(--gray-2);
}

/* Calendar view — wrapper holds the controls + either a grid or a list */
.calendar {
  position: relative;
}
.cal-grid {
  display: grid;
  /* minmax(0, 1fr) ensures columns share width equally regardless of content
     length; with plain 1fr, nowrap event labels could push some wider. */
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 1px;
  background: var(--rule);
  border: 1px solid var(--rule);
  border-top: none; /* cal-controls already has bottom border */
}
.cal-day {
  min-width: 0;
}
.cal-list {
  border: 1px solid var(--rule);
  border-top: none;
  padding: 8px 16px;
}

/* === Time-grid week / day views (Google Calendar style) === */

.tg-wrap {
  border: 1px solid var(--rule);
  border-top: none;
  background: var(--paper);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.tg-header {
  display: grid;
  border-bottom: 1px solid var(--rule);
  background: var(--paper-2);
}
.tg-corner {
  background: var(--paper-2);
  border-right: 1px solid var(--rule);
}
.tg-day-header {
  padding: 10px 12px;
  text-align: center;
  border-right: 1px solid var(--rule);
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.tg-day-header:last-child { border-right: none; }
.tg-day-header .tg-dow {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gray-2);
}
.tg-day-header .tg-dnum {
  font-family: var(--display);
  font-size: 22px;
  font-weight: 500;
  font-variation-settings: "opsz" 36;
}
.tg-day-header.is-today .tg-dnum {
  color: var(--green);
  font-weight: 700;
}

.tg-allday {
  display: grid;
  border-bottom: 1px solid var(--rule);
  background: var(--paper);
}
.tg-allday-label {
  padding: 6px 10px;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gray-2);
  border-right: 1px solid var(--rule);
  align-self: center;
}
.tg-allday-cell {
  padding: 4px 6px;
  border-right: 1px solid var(--rule);
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-height: 28px;
  min-width: 0;
}
.tg-allday-cell:last-child { border-right: none; }
.tg-allday-chip {
  background: var(--ink);
  color: var(--paper);
  font-size: 11px;
  padding: 3px 6px;
  cursor: pointer;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.tg-allday-chip.mode-inperson { background: var(--gold); color: var(--ink); }
.tg-allday-chip.mode-virtual  { background: var(--ink-2); }
.tg-allday-chip.mode-none     { background: var(--green); }
.tg-allday-chip.mode-unknown  { background: var(--ink-2); }

.tg-body {
  display: grid;
  position: relative;
}
.tg-time-axis {
  border-right: 1px solid var(--rule);
  background: var(--paper-2);
}
.tg-time-label {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  color: var(--gray-2);
  padding: 4px 8px 0 8px;
  border-top: 1px solid var(--rule-soft);
  text-align: right;
  text-transform: uppercase;
}
.tg-time-label:first-child { border-top: none; }

.tg-day-col {
  position: relative;
  border-right: 1px solid var(--rule);
  /* Repeating hourly grid lines via background — every 48px (one hour) */
  background-image: linear-gradient(to bottom, var(--rule-soft) 1px, transparent 1px);
  background-size: 100% 48px;
  min-width: 0;
}
.tg-day-col:last-child { border-right: none; }
.tg-day-col.is-today { background-color: rgba(31, 77, 50, 0.04); }

.tg-event {
  position: absolute;
  left: 4px;
  right: 4px;
  background: var(--ink);
  color: var(--paper);
  border-left: 3px solid rgba(0,0,0,0.25);
  padding: 3px 6px;
  font-size: 11px;
  line-height: 1.25;
  overflow: hidden;
  cursor: pointer;
  border-radius: 2px;
  z-index: 1;
}
.tg-event.mode-inperson { background: var(--gold); color: var(--ink); border-left-color: rgba(0,0,0,0.2); }
.tg-event.mode-virtual  { background: var(--ink-2); }
.tg-event.mode-none     { background: var(--green); }
.tg-event.mode-unknown  { background: var(--ink-2); }
.tg-event-time {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.04em;
  opacity: 0.85;
}
.tg-event-title {
  font-family: var(--display);
  font-size: 12px;
  font-weight: 500;
  margin-top: 1px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.tg-now-line {
  position: absolute;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--green);
  z-index: 2;
  pointer-events: none;
}
.tg-now-line::before {
  content: '';
  position: absolute;
  left: -4px;
  top: -3px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--green);
}
.cal-list-empty {
  border: 1px solid var(--rule);
  border-top: none;
  padding: 60px 20px;
  text-align: center;
  font-family: var(--display);
  font-style: italic;
  color: var(--gray-2);
}
.cal-view-switch {
  display: flex;
  gap: 0;
}
.cal-view-switch button {
  background: transparent;
  border: 1px solid var(--rule);
  border-right-width: 0;
  padding: 6px 14px;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--ink-2);
  cursor: pointer;
  transition: all 0.12s ease;
}
.cal-view-switch button:last-child { border-right-width: 1px; }
.cal-view-switch button:hover { color: var(--ink); }
.cal-view-switch button.is-active {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--paper);
}
.cal-nav {
  display: flex;
  gap: 4px;
}
.cal-event-more {
  background: var(--gray-2);
}
.cal-header {
  background: var(--paper-2);
  padding: 10px 12px;
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--gray-2);
}
.cal-day {
  background: var(--paper);
  min-height: 110px;
  padding: 8px 10px;
  position: relative;
}
.cal-day.is-other { background: var(--paper-2); opacity: 0.5; }
.cal-day.is-today { background: #fffaf0; }
.cal-day.is-today .cal-num { color: var(--green); font-weight: 900; }
.cal-num {
  font-family: var(--display);
  font-size: 18px;
  font-weight: 500;
}
.cal-event {
  display: block;
  font-size: 11px;
  margin-top: 4px;
  padding: 3px 6px;
  background: var(--ink);
  color: var(--paper);
  cursor: pointer;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.cal-event.is-self { background: var(--ink); }
.cal-event.is-covered { background: var(--green); }
.cal-event.is-unassigned { background: var(--gold); color: var(--ink); }

/* Drawer */
.drawer {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: 520px;
  max-width: 90vw;
  background: var(--paper);
  border-left: 1px solid var(--ink);
  box-shadow: -20px 0 60px rgba(0,0,0,0.15);
  z-index: 100;
  overflow-y: auto;
  transform: translateX(0);
  transition: transform 0.25s ease;
}
.drawer.hidden { transform: translateX(100%); display: block !important; pointer-events: none; }
.drawer-inner { padding: 32px 36px 60px; }
.drawer-close {
  position: absolute;
  top: 18px; right: 18px;
  background: transparent;
  border: none;
  font-size: 28px;
  cursor: pointer;
  color: var(--ink);
  line-height: 1;
}
.drawer h2 {
  font-family: var(--display);
  font-weight: 500;
  font-size: 26px;
  margin: 0 0 6px;
  line-height: 1.2;
  font-variation-settings: "opsz" 36;
}
.drawer .index {
  font-family: var(--mono);
  font-size: 12px;
  color: var(--gray-2);
  margin-bottom: 24px;
}
.drawer-grid {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 10px 16px;
  margin-bottom: 28px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--rule-soft);
}
.drawer-grid dt {
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--gray-2);
  padding-top: 4px;
}
.drawer-grid dd {
  margin: 0;
  font-family: var(--display);
  font-size: 16px;
}

.coverage-controls {
  display: flex;
  gap: 6px;
  margin-bottom: 14px;
}
.coverage-controls button {
  flex: 1;
  padding: 10px;
  background: transparent;
  border: 1px solid var(--rule);
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  cursor: pointer;
  color: var(--ink-2);
}
.coverage-controls button:hover { border-color: var(--ink); }
.coverage-controls button.active {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}
.coverage-controls button.active.self { background: var(--ink); border-color: var(--ink); }
.coverage-controls button.active.covered { background: var(--green); border-color: var(--green); }

.field-label {
  display: block;
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--gray-2);
  margin: 16px 0 6px;
}
.drawer input[type="text"],
.drawer textarea {
  width: 100%;
  padding: 10px 12px;
  background: var(--paper-2);
  border: 1px solid var(--rule);
  font-family: var(--sans);
  font-size: 14px;
  color: var(--ink);
  resize: vertical;
}
.drawer textarea { min-height: 90px; font-family: var(--display); font-size: 15px; }
.drawer input:focus, .drawer textarea:focus {
  outline: none;
  border-color: var(--ink);
}

.drawer-save {
  margin-top: 20px;
  padding: 12px 24px;
  background: var(--ink);
  color: var(--paper);
  border: none;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  cursor: pointer;
}
.drawer-save:hover { background: var(--green); }

.raw-toggle {
  margin-top: 28px;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--gray-2);
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: 0.15em;
}
.raw-body {
  margin-top: 12px;
  padding: 14px;
  background: var(--paper-2);
  font-family: var(--mono);
  font-size: 11px;
  white-space: pre-wrap;
  max-height: 300px;
  overflow-y: auto;
  color: var(--ink-2);
  border: 1px solid var(--rule);
}

.toast {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--ink);
  color: var(--paper);
  padding: 12px 22px;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  z-index: 200;
}

@media (max-width: 720px) {
  /* Tighter outer padding */
  .masthead, .tabs, main { padding-left: 16px; padding-right: 16px; }
  .masthead { padding-top: 18px; }

  /* Masthead: centered, stacked */
  .masthead-inner {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 14px;
  }

  /* Brand: smaller AND centered horizontally */
  .brand {
    gap: 12px;
    justify-content: center;
    align-items: center;
  }
  .brand-mark { width: 54px; height: 54px; font-size: 44px; }
  .brand-text { width: 240px; }
  .brand-title { font-size: 28px; letter-spacing: 0.28em; text-indent: 0.28em; }
  .brand-firm { font-size: 11px; letter-spacing: 0.1em; }
  .brand-tag { font-size: 9px; letter-spacing: 0.28em; text-indent: 0.28em; }
  .brand-firm-row { gap: 8px; margin: 4px 0 2px; }
  .brand-rule { min-width: 8px; }

  /* Meta block: buttons in a centered row, Last Sync demoted to a tiny
     status line below them */
  .meta {
    width: 100%;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    justify-content: center;
  }
  /* Last Sync becomes a tiny full-width status line, mono, gray, BELOW the buttons */
  .meta-row {
    order: 99;
    width: 100%;
    text-align: center;
    margin-top: 2px;
  }
  .meta-label,
  .meta-value {
    display: inline;
    font-family: var(--mono);
    font-size: 10px;
    font-weight: 400;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--gray-2);
  }
  .meta-label::after { content: ' · '; }

  /* Buttons: tighter, all share min-height for consistent touch targets */
  .btn-sync { padding: 11px 16px; font-size: 12px; flex: 0 1 auto; min-height: 42px; }
  /* Reset is destructive and rarely needed from a phone — hide on mobile */
  .btn-wipe { display: none; }

  /* Tabs: horizontal scroll instead of wrapping to 3 rows */
  .tabs {
    overflow-x: auto;
    scrollbar-width: thin;
    -webkit-overflow-scrolling: touch;
    padding-top: 12px;
    padding-bottom: 0;
    gap: 2px;
  }
  .tabs::-webkit-scrollbar { height: 3px; }
  .tabs::-webkit-scrollbar-thumb { background: var(--rule); }
  .tab { white-space: nowrap; padding: 12px 14px; font-size: 12px; flex: 0 0 auto; }

  /* List rows: single column (was already this) */
  .appearance { grid-template-columns: 1fr; gap: 8px; padding: 16px 0; }
  .case-block .case-name { font-size: 19px; }
  .status-block { text-align: left; min-width: 0; padding-top: 0; }
  .date-block { text-align: left; padding-top: 0; }
  .date-day { font-size: 32px; display: inline-block; }
  .date-month { display: inline-block; margin-left: 8px; margin-top: 0; }
  .date-time { display: inline-block; margin-left: 12px; margin-top: 0; }
  .date-weekday { display: inline-block; margin-left: 8px; margin-top: 0; }

  /* Day-heading shrinks */
  .day-heading { font-size: 17px; margin: 12px 0 4px; }

  /* Drawer: full-width with tighter inner padding */
  .drawer { width: 100%; }
  .drawer-inner { padding: 20px 20px 60px; }
  .drawer h2 { font-size: 22px; }
  .drawer-grid { grid-template-columns: 86px 1fr; gap: 8px 12px; }
  .drawer-grid dt { font-size: 9px; }
  .drawer-grid dd { font-size: 15px; }

  /* Calendar grid: force fit by allowing cells to shrink, drop event text
     so columns aren't held wide by long case names. Events become thin
     colored bars; tapping still opens the case drawer. */
  .calendar { font-size: 11px; }
  .calendar .cal-day {
    min-height: 60px;
    padding: 3px 4px;
    min-width: 0;          /* critical: lets the grid actually fit */
    overflow: hidden;
  }
  .calendar .cal-header { padding: 5px 2px; font-size: 9px; }
  .cal-num { font-size: 13px; }
  .cal-event {
    /* Hide text; render as a thin colored bar */
    font-size: 0;
    line-height: 0;
    color: transparent;
    height: 4px;
    padding: 0;
    margin-top: 2px;
    border-radius: 1px;
    text-overflow: clip;
    overflow: hidden;
  }
  .cal-controls { padding: 10px 12px; gap: 8px; }
  .cal-controls .cal-title { font-size: 15px; order: -1; width: 100%; }
  .cal-controls button { padding: 8px 10px; font-size: 11px; min-height: 38px; }
  .cal-view-switch button { padding: 8px 10px; font-size: 10px; }
  .cal-nav button { font-size: 11px; }
  .cal-list { padding: 0 8px; }

  /* Search + Filters toggle: one row, full width */
  .search-wrap {
    width: 100%;
    max-width: none;
    margin: 0;
    order: 2;
    gap: 8px;
  }
  .search-input { padding: 11px 12px; font-size: 15px; }
  .filters-toggle { padding: 9px 12px; font-size: 11px; min-height: 40px; }
  .search-count { display: none; } /* match count would be redundant on mobile */

  /* Filter panel: tighter, county pills scroll horizontally if many */
  .filters { padding: 12px 16px; gap: 10px 16px; }
  .filter-group { flex-wrap: wrap; gap: 6px; }
  .filter-pill { padding: 6px 10px; font-size: 11px; min-height: 36px; }
  #county-pills {
    overflow-x: auto;
    flex-wrap: nowrap;
    max-width: 100%;
    padding-bottom: 4px;
    scrollbar-width: thin;
  }
  .filter-clear {
    margin-left: 0;
    width: 100%;
    text-align: left;
    padding-left: 0;
  }

  /* Connect Gmail button (when shown) matches sync button sizing */
  #connect-gmail { min-height: 40px; padding: 10px 14px; font-size: 12px; }
}

/* Very narrow phones — extra tightening */
@media (max-width: 380px) {
  .brand-title { font-size: 26px; }
  .brand-mark { width: 46px; height: 46px; font-size: 38px; }
  .brand-text { width: 200px; }
  .brand-title { font-size: 24px; letter-spacing: 0.24em; text-indent: 0.24em; }
  .brand-firm { font-size: 10px; }
  .brand-tag { font-size: 8.5px; letter-spacing: 0.24em; text-indent: 0.24em; }
  .tab { padding: 11px 10px; font-size: 11px; }
  .calendar .cal-day { min-height: 56px; padding: 3px 4px; }
  .calendar .cal-header { font-size: 8px; padding: 5px 2px; }
}

/* === v3 additions === */

.btn-wipe {
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--rule);
  padding: 8px 14px;
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  cursor: pointer;
  margin-left: 8px;
}
.btn-wipe:hover { border-color: var(--green); color: var(--green); }

.day-group { margin-bottom: 32px; }
.day-heading {
  font-family: var(--display);
  font-size: 20px;
  font-weight: 500;
  margin: 16px 0 4px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--ink);
  letter-spacing: -0.01em;
  font-variation-settings: "opsz" 36;
}
.day-group .appearance:last-child { border-bottom: none; }

.appearance.is-dim {
  opacity: 0.5;
}
.appearance.is-dim:hover { opacity: 0.75; }

.tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 8px 0 6px;
}
.tag {
  display: inline-block;
  padding: 3px 8px;
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  background: var(--paper-2);
  border: 1px solid var(--rule);
  color: var(--ink-2);
}
.tag-county { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.tag-mode { font-weight: 600; }
.tag-mode-inperson { background: rgba(163,128,26,0.12); color: var(--gold); border-color: var(--gold); }
.tag-mode-virtual  { background: rgba(61,58,54,0.08); color: var(--ink-2); border-color: var(--ink-2); }
.tag-mode-none     { background: rgba(47,93,58,0.08); color: var(--green); border-color: var(--green); }
.tag-adjourned     { background: #fff0e0; color: #8a4a00; border-color: #8a4a00; }
.tag-completed     { background: rgba(47,93,58,0.08); color: var(--green); border-color: var(--green); }
.tag-disposed      { background: #2a2a2a; color: var(--paper); border-color: #2a2a2a; }
.tag-count         { background: var(--green); color: var(--paper); border-color: var(--green); }

.coverage-pill.coverage-none-needed {
  color: var(--gray-2);
  background: var(--paper-2);
  border: 1px solid var(--rule);
  font-size: 10px;
}

.case-meta-row .idx { font-family: var(--mono) !important; font-size: 12px !important; }
.case-meta-row span { font-family: var(--sans); font-size: 13px; }

/* Calendar event colors by mode */
.cal-event.mode-inperson { background: var(--gold); color: var(--ink); }
.cal-event.mode-virtual  { background: var(--ink-2); }
.cal-event.mode-none     { background: var(--green); }
.cal-event.mode-unknown  { background: var(--ink-2); }

.cal-controls {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 16px;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-bottom: none;
  flex-wrap: wrap;
  gap: 10px;
}
.cal-controls .cal-title {
  flex: 1;
  text-align: center;
}
.cal-controls h2 {
  font-family: var(--display);
  font-size: 26px;
  margin: 0;
  font-weight: 500;
}
.cal-controls button {
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--rule);
  padding: 6px 14px;
  font-family: var(--sans);
  font-size: 13px;
  cursor: pointer;
}
.cal-controls button:hover { border-color: var(--ink); }

.hint {
  padding: 12px 14px;
  background: var(--paper-2);
  border-left: 3px solid var(--gold);
  font-family: var(--display);
  font-style: italic;
  font-size: 14px;
  color: var(--ink-2);
  margin: 16px 0 8px;
}

/* === Search + filters === */

.search-wrap {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 12px;
  max-width: 360px;
  margin: 0 24px;
}
.search-input {
  flex: 1;
  padding: 10px 14px;
  background: var(--paper-2);
  border: 1px solid var(--rule);
  font-family: var(--sans);
  font-size: 14px;
  color: var(--ink);
  outline: none;
  transition: border-color 0.15s ease;
}
.search-input:focus {
  border-color: var(--ink);
}
.search-input::placeholder {
  color: var(--gray-3);
  font-style: italic;
}
.search-count {
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--gray-2);
  white-space: nowrap;
}

.filters-toggle {
  background: transparent;
  border: 1px solid var(--rule);
  padding: 9px 14px;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--ink-2);
  cursor: pointer;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: all 0.12s ease;
}
.filters-toggle:hover {
  border-color: var(--ink);
  color: var(--ink);
}
.filters-toggle[aria-expanded="true"] {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--paper);
}
.filters-dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--green);
}
.filters-toggle[aria-expanded="true"] .filters-dot {
  background: var(--paper);
}

.filters {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 18px 24px;
  padding: 14px 48px;
  background: var(--paper-2);
  border-bottom: 1px solid var(--rule);
  position: relative;
  z-index: 1;
}
.filters.is-collapsed {
  display: none;
}
.filter-group {
  display: flex;
  align-items: center;
  gap: 10px;
}
.filter-label {
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--gray-2);
}
.filter-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.filter-pill {
  background: transparent;
  border: 1px solid var(--rule);
  padding: 5px 12px;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--ink-2);
  cursor: pointer;
  transition: all 0.12s ease;
}
.filter-pill:hover {
  border-color: var(--ink);
  color: var(--ink);
}
.filter-pill.is-active {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--paper);
}
.filter-pill.is-active.pill-county {
  background: var(--green);
  border-color: var(--green);
}
.filter-clear {
  margin-left: auto;
  background: transparent;
  border: none;
  font-family: var(--mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--green);
  cursor: pointer;
  padding: 4px 8px;
}
.filter-clear:hover {
  text-decoration: underline;
}
