:root {
  color-scheme: light;
  --bg: #f6f8fa;
  --surface: #ffffff;
  --surface-soft: #f6f8fa;
  --line: #d8dee4;
  --line-strong: #d0d7de;
  --text: #24292f;
  --muted: #57606a;
  --accent: #1f883d;
  --accent-strong: #1a7f37;
  --blue: #0969da;
  --amber: #9a6700;
  --danger: #cf222e;
  --shadow: none;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans JP", sans-serif;
  background: var(--bg);
  color: var(--text);
}
* { box-sizing: border-box; }
body {
  margin: 0;
  min-height: 100vh;
  background: #ffffff;
}
body.login-view {
  background: var(--bg);
  display: grid;
  place-items: center;
  padding: 20px;
}
body.welcome-view {
  background: var(--bg);
  padding: 0 16px 28px;
}
.auth-shell {
  width: min(420px, 100%);
}
.welcome-shell {
  width: min(1216px, 100%);
  margin: 0 auto;
}
.auth-panel,
.panel {
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--surface);
  box-shadow: var(--shadow);
}
.auth-panel {
  padding: clamp(20px, 5vw, 28px);
}
.dashboard-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 0 12px;
}
.top-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}
.app-nav {
  display: flex;
  gap: 6px;
}
.nav-link,
.download-link,
.table-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  border: 1px solid var(--line-strong);
  border-radius: 6px;
  color: var(--blue);
  font-size: 0.86rem;
  font-weight: 600;
  padding: 5px 10px;
  text-decoration: none;
}
.nav-link.active {
  border-color: rgba(9, 105, 218, 0.3);
  background: #ddf4ff;
  color: #0969da;
}
.nav-link:hover,
.nav-link:focus,
.download-link:hover,
.download-link:focus,
.table-link:hover,
.table-link:focus {
  border-color: var(--blue);
  outline: none;
}
.eyebrow {
  margin: 0 0 4px;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0;
  text-transform: uppercase;
}
h1,
h2 {
  margin: 0;
  color: var(--text);
  letter-spacing: 0;
}
h1 {
  font-size: clamp(1.55rem, 3vw, 2rem);
  line-height: 1.18;
}
h2 {
  font-size: clamp(1.05rem, 1.8vw, 1.25rem);
  line-height: 1.25;
}
.lede {
  max-width: 58ch;
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.45;
}
.reservation-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(340px, 390px);
  grid-template-areas: "calendar form";
  gap: 12px;
  align-items: start;
}
.calendar-stack {
  grid-area: calendar;
  display: grid;
  gap: 10px;
  min-width: 0;
}
.schedule-layout {
  display: grid;
  gap: 12px;
}
.settings-layout {
  display: grid;
  gap: 12px;
}
.panel {
  padding: clamp(12px, 2vw, 16px);
}
.form-panel {
  grid-area: form;
  position: sticky;
  top: 12px;
}
.panel-heading {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}
.panel-heading.simple {
  grid-template-columns: minmax(0, 1fr) auto;
}
.calendar-panel .panel-heading {
  grid-template-columns: minmax(0, 1fr) auto;
  grid-template-areas:
    "title nav"
    "selected selected";
}
.calendar-panel .panel-heading > div:first-child {
  grid-area: title;
}
.calendar-panel .month-nav {
  grid-area: nav;
}
.selected-date {
  grid-area: selected;
  min-width: 0;
  border-top: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-top: 10px;
}
.selected-date span {
  display: block;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 600;
}
.selected-date strong {
  display: block;
  margin-top: 0;
  color: var(--text);
  font-size: 0.9rem;
}
.month-nav {
  display: flex;
  gap: 6px;
}
.month-nav a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  border: 1px solid var(--line-strong);
  border-radius: 6px;
  color: var(--blue);
  font-size: 0.84rem;
  font-weight: 600;
  padding: 5px 10px;
  text-decoration: none;
}
.month-nav a:hover,
.month-nav a:focus {
  border-color: var(--blue);
  outline: none;
}
.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
}
.calendar-weekdays {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 600;
  margin-bottom: 6px;
  text-align: center;
}
.calendar-weekdays .weekend-saturday {
  color: var(--blue);
}
.calendar-weekdays .weekend-sunday {
  color: #b42318;
}
.calendar-grid:not(.calendar-weekdays) {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--line);
  gap: 1px;
}
.calendar-day {
  min-height: 68px;
  background: var(--surface);
  color: var(--text);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 5px;
  padding: 7px;
  position: relative;
  text-decoration: none;
}
.calendar-day .day-link {
  color: inherit;
  display: grid;
  gap: 3px;
  min-width: 0;
  text-decoration: none;
}
.calendar-day.weekend-saturday {
  background: #f4f9ff;
}
.calendar-day.weekend-saturday .day-number {
  color: var(--blue);
}
.calendar-day.weekend-sunday,
.calendar-day.holiday {
  background: #fff7f7;
}
.calendar-day.weekend-sunday .day-number,
.calendar-day.holiday .day-number {
  color: #b42318;
}
.holiday-name {
  color: #b42318;
  display: block;
  font-size: 0.64rem;
  font-weight: 600;
  line-height: 1.25;
  max-width: 78px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.calendar-day.weekend-saturday:not(.holiday) .holiday-name {
  color: var(--blue);
}
.visit-count {
  align-self: flex-end;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
  height: 22px;
  border-radius: 999px;
  background: var(--blue);
  color: #ffffff;
  font-size: 0.72rem;
  font-weight: 600;
  line-height: 1;
  padding: 0 7px;
  text-decoration: none;
  box-shadow: 0 5px 14px rgba(31, 95, 153, 0.22);
}
.visit-count:hover,
.visit-count:focus {
  background: #164f80;
  outline: none;
}
.calendar-day:hover,
.calendar-day:focus {
  background: #f6f8fa;
  outline: 2px solid rgba(9, 105, 218, 0.16);
  outline-offset: -2px;
}
.day-number {
  display: inline-grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  font-weight: 600;
}
.calendar-day small {
  align-self: flex-end;
  min-width: 30px;
  border-radius: 999px;
  background: #fff7ed;
  color: var(--amber);
  font-size: 0.68rem;
  font-weight: 600;
  line-height: 18px;
  text-align: center;
}
.outside-month {
  background: var(--surface-soft);
  color: #9aa7b7;
}
.outside-month.weekend-saturday,
.outside-month.weekend-sunday,
.outside-month.holiday {
  background: #fafbfc;
}
.outside-month .holiday-name {
  color: #b98a8a;
}
.today .day-number {
  border: 1px solid var(--accent);
  color: var(--accent);
}
.selected {
  background: #edf7fd;
  box-shadow: inset 0 0 0 2px var(--blue);
}
.selected .day-number {
  background: var(--blue);
  color: #ffffff;
}
.calendar-day.selected .day-number,
.calendar-day.selected.weekend-saturday .day-number,
.calendar-day.selected.weekend-sunday .day-number,
.calendar-day.selected.holiday .day-number {
  background: #17202c;
  border-color: #17202c;
  color: #ffffff;
}
.disabled {
  background: var(--surface-soft);
  color: #b7c0cc;
}
.login-form,
.reservation-form {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}
.login-form button[type="submit"] {
  margin-top: 10px;
}
.schedule-filter-form {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr)) auto;
  gap: 10px;
  align-items: end;
  margin-top: 10px;
}
.filter-summary {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-top: 10px;
  padding: 8px 10px;
  border: 1px solid #b6e3ff;
  border-radius: 6px;
  background: #ddf4ff;
}
.filter-summary-label {
  display: block;
  color: #0550ae;
  font-size: 0.72rem;
  font-weight: 600;
  margin-bottom: 6px;
}
.filter-summary-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.filter-summary-list li {
  border: 1px solid rgba(9, 105, 218, 0.18);
  border-radius: 999px;
  background: #ffffff;
  color: var(--text);
  font-size: 0.78rem;
  font-weight: 600;
  line-height: 1.3;
  padding: 4px 8px;
}
.filter-summary-clear {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  border: 1px solid rgba(9, 105, 218, 0.18);
  border-radius: 6px;
  background: #ffffff;
  color: var(--blue);
  font-size: 0.78rem;
  font-weight: 600;
  padding: 4px 10px;
  text-decoration: none;
  white-space: nowrap;
}
.filter-summary-clear:hover,
.filter-summary-clear:focus {
  border-color: var(--blue);
  outline: none;
}
.field-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.field {
  display: grid;
  gap: 5px;
  min-width: 0;
}
.field.full {
  grid-column: 1 / -1;
}
.visitor-list {
  display: grid;
  gap: 6px;
}
.visitor-row-header {
  display: grid;
  grid-template-columns: minmax(110px, 0.75fr) minmax(0, 1fr) 42px;
  gap: 6px;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 600;
  margin-bottom: 2px;
}
.visitor-row-header span {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-width: 0;
}
.visitor-row {
  display: grid;
  grid-template-columns: minmax(110px, 0.75fr) minmax(0, 1fr) 42px;
  gap: 6px;
}
.company-field {
  display: grid;
  gap: 6px;
}
.checkbox-line {
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 600;
}
.checkbox-line input {
  flex: 0 0 auto;
  width: 16px;
  min-height: 16px;
  height: 16px;
  accent-color: var(--accent);
  padding: 0;
}
.icon-button,
.add-visitor {
  margin: 0;
}
.icon-button {
  min-height: 34px;
  padding: 0;
  background: var(--surface-soft);
  color: var(--text);
}
.icon-button:hover {
  background: #eef2f6;
}
.icon-button:disabled {
  cursor: not-allowed;
  opacity: 0.45;
}
.add-visitor {
  min-height: 32px;
  border: 1px dashed var(--line-strong);
  background: var(--surface-soft);
  color: var(--blue);
  padding: 5px 10px;
}
.add-visitor:hover {
  background: #edf4fb;
}
label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  color: #273344;
  font-size: 0.82rem;
  font-weight: 600;
  line-height: 1.3;
}
.required-badge,
.optional-badge {
  flex: 0 0 auto;
  border-radius: 999px;
  font-size: 0.64rem;
  font-weight: 600;
  line-height: 1;
  padding: 3px 6px;
}
.required-badge {
  border: 1px solid #f0c28a;
  background: #fff7ed;
  color: var(--amber);
}
.optional-badge {
  border: 1px solid #cbd5e1;
  background: #f8fafc;
  color: #64748b;
}
input,
select,
textarea {
  width: 100%;
  min-width: 0;
  max-width: 100%;
  min-height: 34px;
  border: 1px solid var(--line-strong);
  border-radius: 6px;
  background: var(--surface);
  color: var(--text);
  font: inherit;
  font-size: 0.88rem;
  padding: 6px 8px;
  outline: none;
}
input[type="date"] {
  inline-size: 100%;
  min-inline-size: 0;
  max-inline-size: 100%;
}
input[type="date"]::-webkit-date-and-time-value {
  min-width: 0;
  text-align: left;
}
.date-compact {
  display: block;
  min-width: 0;
  max-width: 100%;
  position: relative;
}
.date-compact-value {
  display: none;
}
textarea {
  min-height: 66px;
  line-height: 1.45;
  resize: vertical;
}
select {
  cursor: pointer;
}
input:focus,
select:focus,
textarea:focus {
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(9, 105, 218, 0.16);
}
.textarea-shell {
  display: grid;
  gap: 6px;
}
.textarea-shell.is-expanded textarea {
  min-height: 170px;
}
.textarea-toggle {
  justify-self: end;
  min-height: 32px;
  border: 1px solid var(--line-strong);
  background: #ffffff;
  color: var(--blue);
  padding: 5px 10px;
}
.textarea-toggle:hover,
.textarea-toggle:focus-visible {
  border-color: var(--blue);
  background: #edf7fd;
  color: #164f80;
}
button {
  min-height: 34px;
  border: 0;
  border-radius: 6px;
  background: var(--accent);
  color: #ffffff;
  cursor: pointer;
  font: inherit;
  font-size: 0.88rem;
  font-weight: 600;
  padding: 6px 12px;
}
.form-actions {
  display: grid;
  gap: 8px;
}
.cancel-link,
.modify-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  border: 1px solid var(--line-strong);
  border-radius: 6px;
  color: var(--blue);
  font-size: 0.86rem;
  font-weight: 600;
  padding: 5px 10px;
  text-decoration: none;
}
.cancel-link:hover,
.cancel-link:focus,
.modify-link:hover,
.modify-link:focus {
  border-color: var(--blue);
  outline: none;
}
.schedule-card-actions,
.table-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
}
.table-actions {
  flex-wrap: nowrap;
  white-space: nowrap;
}
.table-actions > * {
  flex: 0 0 auto;
}
.table-actions .table-link,
.table-actions .delete-button {
  min-width: 3.8em;
  white-space: nowrap;
  word-break: keep-all;
  writing-mode: horizontal-tb;
  text-orientation: mixed;
}
.schedule-card-actions {
  gap: 4px;
}
.schedule-card-actions .modify-link,
.schedule-card-actions .delete-button {
  min-height: 28px;
  font-size: 0.78rem;
  padding: 4px 8px;
}
.inline-delete-form {
  margin: 0;
}
.delete-button {
  min-height: 32px;
  border: 1px solid #efb6a8;
  background: #ffffff;
  color: var(--danger);
  padding: 5px 10px;
}
.delete-button:hover,
.delete-button:focus-visible {
  border-color: var(--danger);
  background: #fff4f0;
  color: #842c17;
}
.table-delete {
  min-width: 62px;
}
.form-hint {
  border-left: 3px solid var(--accent);
  color: var(--muted);
  font-size: 0.84rem;
  line-height: 1.45;
  margin: 8px 0 0;
  padding-left: 10px;
}
button:hover {
  background: var(--accent-strong);
}
button:focus-visible {
  outline: 3px solid rgba(9, 105, 218, 0.2);
  outline-offset: 2px;
}
.secondary {
  background: #24292f;
}
.secondary:hover {
  background: #32383f;
}
.compact {
  min-width: 96px;
}
.alert,
.notice {
  border-radius: 6px;
  font-size: 0.88rem;
  line-height: 1.45;
  margin: 10px 0 0;
  padding: 8px 10px;
}
.alert {
  border: 1px solid #efb29b;
  background: #fff4ef;
  color: var(--danger);
}
.alert ul {
  margin: 0;
  padding-left: 18px;
}
.notice {
  border: 1px solid #a8dec5;
  background: #effaf4;
  color: #176147;
  font-weight: 600;
  margin: 0 0 12px;
}
.smtp-status {
  border-radius: 6px;
  line-height: 1.45;
  margin: 10px 0 0;
  padding: 8px 10px;
}
.smtp-ok {
  border: 1px solid #a8dec5;
  background: #effaf4;
  color: #176147;
}
.smtp-missing {
  border: 1px solid #f0c28a;
  background: #fff7ed;
  color: var(--amber);
}
.recipient-add-form,
.recipient-edit-form,
.test-mail-form {
  display: grid;
  gap: 10px;
  margin-top: 10px;
}
.recipient-list {
  display: grid;
  gap: 10px;
  list-style: none;
  margin: 10px 0 0;
  padding: 0;
}
.recipient-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: end;
  border-top: 1px solid var(--line);
  padding-top: 10px;
}
.recipient-row:first-child {
  border-top: 0;
  padding-top: 0;
}
.recipient-edit-form {
  grid-template-columns: minmax(150px, 0.7fr) minmax(220px, 1fr) auto auto;
  align-items: end;
  margin-top: 0;
}
.recipient-enabled {
  min-height: 34px;
}
.reservation-list {
  display: grid;
  list-style: none;
  margin: 10px 0 0;
  padding: 0;
}
.graph-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}
.graph-total {
  min-width: 104px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--surface-soft);
  padding: 8px 10px;
  text-align: right;
}
.graph-total span {
  display: block;
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 600;
}
.graph-total strong {
  display: block;
  color: var(--text);
  font-size: 1.12rem;
  line-height: 1.2;
}
.graph-toolbar {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}
.graph-toolbar strong {
  display: block;
  color: var(--text);
  font-size: 0.9rem;
  line-height: 1.35;
}
.graph-window-label {
  display: block;
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 600;
}
.graph-window-note {
  display: block;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 600;
  margin-top: 2px;
  overflow-wrap: anywhere;
}
.graph-span-switch {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 4px;
}
.graph-span-select-mobile {
  display: none;
  min-width: 0;
}
.graph-span-select-label {
  display: block;
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 600;
  margin-bottom: 4px;
}
.graph-span-select-input {
  min-width: 0;
}
.graph-span-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #fff;
  color: var(--blue);
  font-size: 0.78rem;
  font-weight: 600;
  padding: 4px 9px;
  text-decoration: none;
}
.graph-span-link:hover {
  border-color: var(--blue);
  background: var(--surface-soft);
}
.graph-span-link.active {
  border-color: rgba(9, 105, 218, 0.3);
  background: #ddf4ff;
  color: #0969da;
}
.graph-nav {
  display: flex;
  align-items: center;
  gap: 6px;
}
.graph-nav-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  min-width: 64px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #fff;
  color: var(--blue);
  font-size: 0.78rem;
  font-weight: 600;
  text-decoration: none;
}
.graph-nav-link:hover {
  border-color: var(--blue);
  background: var(--surface-soft);
}
.graph-nav-link.is-disabled {
  background: var(--surface-soft);
  color: #a5afbd;
  pointer-events: none;
}
.schedule-graph-panel,
.graph-heading > *,
.graph-toolbar > * {
  min-width: 0;
}
.visitor-chart {
  --chart-height: 170px;
  display: flex;
  align-items: end;
  gap: 6px;
  height: var(--chart-height);
  list-style: none;
  margin: 0;
  overflow-x: hidden;
  padding: 4px 2px 0;
  width: 100%;
}
.visitor-chart-item {
  --bar-height: 10%;
  flex: 1 1 0;
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  gap: 6px;
  min-width: 0;
  height: 100%;
}
.visitor-chart-item.bar-h-0 { --bar-height: 0%; }
.visitor-chart-item.bar-h-10 { --bar-height: 8%; }
.visitor-chart-item.bar-h-20 { --bar-height: 17%; }
.visitor-chart-item.bar-h-30 { --bar-height: 25%; }
.visitor-chart-item.bar-h-40 { --bar-height: 34%; }
.visitor-chart-item.bar-h-50 { --bar-height: 42%; }
.visitor-chart-item.bar-h-60 { --bar-height: 50%; }
.visitor-chart-item.bar-h-70 { --bar-height: 59%; }
.visitor-chart-item.bar-h-80 { --bar-height: 67%; }
.visitor-chart-item.bar-h-90 { --bar-height: 76%; }
.visitor-chart-item.bar-h-100 { --bar-height: 84%; }
.visitor-bar {
  align-self: end;
  display: flex;
  align-items: end;
  justify-content: center;
  height: 100%;
  position: relative;
}
.visitor-bar-fill {
  width: 100%;
  max-width: 52px;
  height: var(--bar-height);
  min-height: 14px;
  border-radius: 5px 5px 2px 2px;
  background: linear-gradient(180deg, #2f7fb8 0%, #1f5f99 100%);
}
.visitor-chart-item.is-weekend-saturday .visitor-bar-fill {
  background: linear-gradient(180deg, #4a90c8 0%, #2568a2 100%);
}
.visitor-chart-item.is-weekend-sunday .visitor-bar-fill,
.visitor-chart-item.is-holiday .visitor-bar-fill {
  background: linear-gradient(180deg, #dc6c5a 0%, #b42318 100%);
}
.visitor-chart-item.is-zero .visitor-bar-fill {
  min-height: 3px;
  border-radius: 999px;
  background: #d7dee8;
}
.visitor-chart-item.is-zero.is-weekend-saturday .visitor-bar-fill {
  background: #b9d9ee;
}
.visitor-chart-item.is-zero.is-weekend-sunday .visitor-bar-fill,
.visitor-chart-item.is-zero.is-holiday .visitor-bar-fill {
  background: #efb6a8;
}
.visitor-bar-value {
  position: absolute;
  bottom: min(calc(var(--bar-height) + 5px), calc(100% - 18px));
  color: var(--text);
  font-size: 0.68rem;
  font-weight: 600;
  line-height: 1;
}
.visitor-chart-item.is-zero .visitor-bar-value {
  bottom: 8px;
  color: #98a4b3;
}
.visitor-chart-item.is-weekend-saturday .visitor-bar-value,
.visitor-chart-item.is-weekend-saturday .visitor-bar-date {
  color: var(--blue);
}
.visitor-chart-item.is-weekend-sunday .visitor-bar-value,
.visitor-chart-item.is-weekend-sunday .visitor-bar-date,
.visitor-chart-item.is-holiday .visitor-bar-value,
.visitor-chart-item.is-holiday .visitor-bar-date {
  color: #b42318;
}
.visitor-bar-date {
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 600;
  line-height: 1.2;
  min-height: 1.2em;
  text-align: center;
  overflow-wrap: normal;
  white-space: nowrap;
  word-break: keep-all;
}
.visitor-bar-date.dense-hidden {
  visibility: hidden;
}
.table-wrap {
  overflow-x: auto;
  margin-top: 10px;
}
.schedule-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 960px;
}
.schedule-table th,
.schedule-table td {
  border-bottom: 1px solid var(--line);
  padding: 8px 10px;
  text-align: left;
  vertical-align: top;
}
.schedule-table th {
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 600;
  white-space: nowrap;
}
.schedule-table td {
  color: var(--text);
  font-size: 0.86rem;
  line-height: 1.4;
}
.schedule-table tbody tr:hover {
  background: var(--surface-soft);
}
.date-cell {
  color: var(--blue);
  font-weight: 600;
  white-space: nowrap;
}
.table-date-mobile {
  display: none;
}
.day-schedule-list {
  display: grid;
  gap: 6px;
  list-style: none;
  margin: 8px 0 0;
  padding: 0;
}
.day-schedule-list li {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--surface-soft);
  padding: 7px 8px;
}
.day-schedule-panel .eyebrow {
  margin-bottom: 2px;
}
.day-schedule-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}
.day-schedule-panel h2 {
  font-size: 1rem;
}
.day-schedule-total {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 26px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface-soft);
  color: var(--text);
  font-size: 0.78rem;
  font-weight: 600;
  line-height: 1;
  padding: 0 9px;
}
.schedule-card-main {
  display: grid;
  gap: 4px;
  min-width: 0;
}
.schedule-card-titleline {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 4px 10px;
  min-width: 0;
}
.schedule-card-titleline time {
  color: var(--blue);
  font-weight: 600;
  white-space: nowrap;
}
.schedule-card-titleline strong {
  color: var(--text);
  font-size: 0.9rem;
  line-height: 1.25;
}
.schedule-card-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 3px 10px;
  min-width: 0;
}
.schedule-card-main span,
.schedule-card-main p {
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.32;
  margin: 0;
}
.schedule-card-main p {
  color: #57606a;
}
.multiline-text {
  white-space: pre-line;
}
.reservation-list li {
  display: grid;
  grid-template-columns: minmax(190px, 0.7fr) minmax(0, 1fr);
  gap: 12px;
  border-top: 1px solid var(--line);
  padding: 10px 0;
}
.reservation-list li:first-child {
  border-top: 0;
  padding-top: 0;
}
.reservation-time,
.reservation-detail {
  display: grid;
  gap: 3px;
}
.reservation-time time {
  color: var(--blue);
  font-weight: 600;
}
.reservation-time span,
.reservation-detail span,
.reservation-detail p,
.empty-state {
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.45;
  margin: 0;
}
.reservation-detail strong {
  color: var(--text);
  font-size: 0.92rem;
}
@media (max-width: 960px) {
  body.welcome-view {
    padding-inline: 12px;
  }
  .reservation-layout {
    grid-template-columns: 1fr;
    grid-template-areas:
      "calendar"
      "form";
  }
  .form-panel {
    position: static;
  }
}
@media (max-width: 680px) {
  body.login-view {
    align-content: start;
    min-height: 100svh;
    padding-top: max(12px, env(safe-area-inset-top));
    place-items: start center;
  }
  .auth-shell {
    margin-top: 0;
  }
  .login-form input,
  .login-form button {
    font-size: 16px;
  }
  .dashboard-header,
  .panel-heading {
    align-items: stretch;
    grid-template-columns: 1fr;
  }
  .dashboard-header {
    display: grid;
  }
  .top-actions {
    align-items: stretch;
    display: grid;
    grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
    gap: 6px;
  }
  .app-nav {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    min-width: 0;
  }
  .top-actions form {
    display: grid;
    min-width: 0;
  }
  .top-actions .nav-link,
  .top-actions .compact {
    min-width: 0;
    width: 100%;
    padding-inline: 6px;
    white-space: nowrap;
  }
  .month-nav {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
  .calendar-panel .panel-heading {
    grid-template-areas:
      "title"
      "selected"
      "nav";
  }
  .selected-date {
    align-items: flex-start;
    display: grid;
  }
  .calendar-day {
    min-height: 50px;
    padding: 6px;
  }
  .calendar-day small {
    display: none;
  }
  .visit-count {
    min-width: 22px;
    height: 22px;
    padding: 0 6px;
  }
  .holiday-name {
    display: none;
  }
  .day-number {
    width: 24px;
    height: 24px;
  }
  .field-grid {
    grid-template-columns: 1fr;
    min-width: 0;
    width: 100%;
  }
  .reservation-form,
  .schedule-filter-form,
  .field,
  .field.full {
    min-width: 0;
    max-width: 100%;
  }
  .reservation-form input,
  .reservation-form select,
  .reservation-form textarea,
  .schedule-filter-form input,
  .schedule-filter-form select,
  .schedule-filter-form textarea {
    font-size: 16px;
  }
  .date-compact {
    overflow: hidden;
    width: 100%;
  }
  .date-compact-value {
    display: flex;
    align-items: center;
    min-height: 36px;
    width: 100%;
    border: 1px solid var(--line-strong);
    border-radius: 6px;
    background: var(--surface);
    color: var(--text);
    font-size: 0.88rem;
    font-weight: 500;
    line-height: 1.2;
    padding: 7px 8px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .date-compact.is-empty .date-compact-value {
    color: var(--muted);
  }
  .date-compact:focus-within .date-compact-value {
    border-color: var(--blue);
    box-shadow: 0 0 0 3px rgba(9, 105, 218, 0.16);
  }
  .reservation-form input[type="date"],
  .schedule-filter-form input[type="date"] {
    display: block;
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    max-width: 100%;
    min-width: 0;
    min-height: 0;
    border: 0;
    opacity: 0;
    padding: 0;
    -webkit-appearance: none;
    appearance: none;
  }
  .reservation-form input[type="date"]::-webkit-calendar-picker-indicator,
  .schedule-filter-form input[type="date"]::-webkit-calendar-picker-indicator {
    height: 100%;
    width: 100%;
    opacity: 0;
  }
  .visitor-row-header {
    grid-template-columns: 1fr 1fr 42px;
    font-size: 0.7rem;
    margin-bottom: 0;
  }
  .visitor-row {
    grid-template-columns: 1fr 1fr 42px;
  }
  .reservation-list li {
    grid-template-columns: 1fr;
    gap: 8px;
  }
  .day-schedule-list li {
    grid-template-columns: 1fr;
    gap: 6px;
  }
  .schedule-card-actions {
    justify-content: flex-start;
  }
  .schedule-filter-form {
    grid-template-columns: 1fr;
  }
  .filter-summary {
    align-items: stretch;
    display: grid;
  }
  .recipient-row,
  .recipient-edit-form {
    grid-template-columns: 1fr;
  }
  .graph-heading {
    align-items: stretch;
    display: grid;
  }
  .graph-total {
    text-align: left;
  }
  .graph-toolbar {
    align-items: stretch;
    display: grid;
    gap: 8px;
  }
  .graph-nav {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    justify-content: stretch;
  }
  .graph-span-switch {
    display: none;
  }
  .graph-span-select-mobile {
    display: grid;
  }
  .graph-nav-link {
    flex: 1;
    min-width: 0;
    width: 100%;
  }
  .visitor-chart {
    --chart-height: 144px;
    gap: 3px;
    overflow-x: hidden;
    padding-inline: 0;
  }
  .visitor-chart-item {
    min-width: 0;
    gap: 4px;
  }
  .visitor-bar-fill {
    max-width: 22px;
  }
  .visitor-bar-value,
  .visitor-bar-date {
    font-size: 0.64rem;
  }
  .visitor-chart.is-month-buckets .visitor-bar-date {
    font-size: 0.52rem;
  }
  body.schedule-view {
    overflow-x: hidden;
  }
  .schedule-view .table-wrap {
    overflow-x: visible;
  }
  .schedule-view .schedule-table {
    display: block;
    min-width: 0;
    width: 100%;
  }
  .schedule-view .schedule-table thead {
    display: none;
  }
  .schedule-view .schedule-table tbody {
    display: grid;
    gap: 8px;
  }
  .schedule-view .schedule-table tr {
    display: grid;
    border: 1px solid var(--line);
    border-radius: 6px;
    background: #fff;
    padding: 8px 10px;
  }
  .schedule-view .schedule-table tbody tr:hover {
    background: #fff;
  }
  .schedule-view .schedule-table td {
    display: grid;
    grid-template-columns: 4.9em minmax(0, 1fr);
    gap: 8px;
    align-items: start;
    min-width: 0;
    border-bottom: 0;
    padding: 4px 0;
    overflow-wrap: anywhere;
    font-size: 0.82rem;
  }
  .schedule-view .schedule-table td::before {
    content: attr(data-label);
    color: var(--muted);
    font-size: 0.7rem;
    font-weight: 600;
    line-height: 1.5;
    white-space: nowrap;
  }
  .schedule-view .date-cell {
    color: var(--text);
    white-space: normal;
  }
  .schedule-view .table-date-desktop {
    display: none;
  }
  .schedule-view .table-date-mobile {
    display: inline;
    color: var(--blue);
    font-weight: 600;
  }
  .schedule-view .actions-cell {
    align-items: center;
    padding-top: 7px;
  }
  .schedule-view .table-actions {
    justify-content: flex-start;
    flex-wrap: wrap;
  }
  .schedule-view .table-actions .table-link,
  .schedule-view .table-actions .delete-button {
    min-width: 0;
  }
}
@media (max-width: 440px) {
  body.login-view,
  body.welcome-view {
    padding-inline: 8px;
  }
  .panel,
  .auth-panel {
    padding: 12px;
  }
  h1 {
    font-size: 1.5rem;
  }
}
