:root {
  --ink: #173733;
  --green: #123c37;
  --green-2: #245f56;
  --mint: #e8f1ed;
  --cream: #f5f1e8;
  --paper: #fffefa;
  --coral: #df6d59;
  --coral-soft: #f8e8e3;
  --blue: #557d91;
  --blue-soft: #e7f0f3;
  --gold: #b99455;
  --line: #e4e1d9;
  --muted: #71817e;
  --shadow: 0 12px 35px rgba(25, 52, 47, .08);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: #f7f7f3;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
}
.auth-screen {
  position: fixed; inset: 0; z-index: 200; background:
    radial-gradient(circle at 80% 20%, rgba(185,148,85,.14), transparent 30%),
    var(--green);
  display: grid; place-items: center; padding: 20px;
}
.auth-screen.hidden { display: none; }
.auth-card {
  width: min(430px, 100%); background: var(--paper); border-radius: 17px; padding: 34px;
  box-shadow: 0 30px 90px rgba(4,30,26,.35);
}
.auth-brand { color: var(--green); padding: 0 0 28px; }
.auth-brand .fish-body, .auth-brand .fish-tail { border-color: var(--green); }
.auth-card h1 { margin: 0 0 9px; font: 700 25px "Noto Serif JP"; }
.auth-card > p { color: var(--muted); font-size: 11px; line-height: 1.8; }
.auth-card form { display: grid; gap: 14px; margin-top: 24px; }
.auth-card form .button { width: 100%; padding: 12px; }
#loginForm.hidden { display: none; }
.auth-reset.hidden { display: none; }
.auth-message { min-height: 22px; margin: 14px 0 0 !important; color: var(--green-2) !important; }
.app-shell.cloud-loading { visibility: hidden; }
button, input, select, textarea { font: inherit; }
button { color: inherit; }

.app-shell { min-height: 100vh; display: flex; }
.sidebar {
  position: fixed;
  inset: 0 auto 0 0;
  width: 232px;
  padding: 32px 20px 24px;
  background: var(--green);
  color: white;
  display: flex;
  flex-direction: column;
  z-index: 20;
}
.brand { display: flex; align-items: center; gap: 13px; padding: 0 8px 34px; }
.brand-mark { width: 46px; height: 38px; position: relative; }
.fish-body {
  position: absolute; inset: 1px 0 1px 7px; border: 1px solid rgba(255,255,255,.8);
  border-radius: 50% 44% 44% 50%; display: grid; place-items: center;
  font-family: "Noto Serif JP"; font-size: 17px;
}
.fish-tail {
  position: absolute; left: -4px; top: 9px; width: 19px; height: 19px;
  border: 1px solid rgba(255,255,255,.8); transform: rotate(45deg); border-radius: 3px;
}
.brand strong { display: block; font-family: "Noto Serif JP"; font-size: 22px; letter-spacing: .16em; }
.brand span span, .brand > div:last-child > span { font-size: 8px; letter-spacing: .22em; opacity: .65; }
.main-nav { display: grid; gap: 7px; }
.nav-item {
  width: 100%; border: 0; background: transparent; color: rgba(255,255,255,.68);
  display: flex; align-items: center; gap: 13px; padding: 12px 14px;
  border-radius: 9px; cursor: pointer; text-align: left; transition: .2s;
}
.nav-item:hover, .nav-item.active { background: rgba(255,255,255,.11); color: white; }
.nav-icon { width: 21px; text-align: center; font-size: 17px; }
.nav-badge { margin-left: auto; min-width: 21px; padding: 2px 6px; text-align: center; border-radius: 20px; color: white; background: var(--coral); font-size: 11px; }
.sidebar-bottom { margin-top: auto; display: grid; gap: 14px; }
.shop-link {
  color: white; text-decoration: none; padding: 13px 10px; border-top: 1px solid rgba(255,255,255,.13);
  display: flex; align-items: center; gap: 11px;
}
.shop-photo { width: 37px; height: 37px; border-radius: 50%; background: #d7c4a0; display: grid; place-items: center; font-family: serif; color: var(--green); }
.shop-link strong, .shop-link small { display: block; }
.shop-link small { opacity: .55; font-size: 10px; margin-top: 3px; }

.main-content { margin-left: 232px; width: calc(100% - 232px); min-height: 100vh; }
.topbar {
  height: 105px; padding: 0 48px; background: rgba(255,255,255,.84); border-bottom: 1px solid var(--line);
  display: flex; align-items: center; justify-content: space-between; position: sticky; top: 0; z-index: 10;
  backdrop-filter: blur(14px);
}
.topbar-title p { margin: 0 0 4px; color: var(--muted); font-size: 12px; }
.topbar-title h1 { margin: 0; font-family: "Noto Serif JP"; font-size: 22px; }
.topbar-actions, .toolbar-actions { display: flex; align-items: center; gap: 10px; }
.icon-button {
  position: relative; border: 1px solid var(--line); background: white; width: 40px; height: 40px;
  border-radius: 9px; cursor: pointer; font-size: 20px;
}
.notification-dot { position: absolute; width: 7px; height: 7px; border-radius: 50%; background: var(--coral); top: 8px; right: 8px; border: 2px solid white; }
.manager-chip { display: flex; align-items: center; gap: 9px; background: transparent; border: 0; cursor: pointer; }
.avatar { width: 37px; height: 37px; background: var(--mint); color: var(--green); border-radius: 50%; display: grid; place-items: center; font-weight: 700; }
.manager-chip strong, .manager-chip small { display: block; text-align: left; }
.manager-chip small { font-size: 10px; color: var(--muted); }
.mobile-menu { display: none; border: 0; background: transparent; font-size: 22px; }

.view { display: none; padding: 36px 48px 56px; max-width: 1500px; margin: 0 auto; }
.view.active { display: block; animation: fadeIn .28s ease; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(4px); } }

.deadline-card {
  min-height: 245px; padding: 35px 42px; border-radius: 15px; color: white;
  background: var(--green); display: grid; grid-template-columns: 1fr auto; align-items: center;
  position: relative; overflow: hidden; box-shadow: var(--shadow);
}
.deadline-card > * { position: relative; z-index: 2; }
.eyebrow { display: block; margin-bottom: 9px; font-size: 9px; font-weight: 700; letter-spacing: .23em; color: #c9a963; }
.green-text { color: var(--green-2); }
.deadline-card h2 { margin: 0; font: 700 28px/1.5 "Noto Serif JP"; letter-spacing: .03em; }
.deadline-card p { color: rgba(255,255,255,.72); line-height: 1.8; font-size: 12px; }
.deadline-card p strong { color: white; }
.hero-actions { display: flex; gap: 10px; margin-top: 23px; }
.button {
  border: 1px solid var(--line); background: white; border-radius: 8px; padding: 10px 17px;
  font-weight: 600; cursor: pointer; transition: transform .15s, box-shadow .15s, background .15s;
}
.button:hover { transform: translateY(-1px); box-shadow: 0 6px 15px rgba(18,60,55,.12); }
.button.primary { background: var(--coral); border-color: var(--coral); color: white; }
.button.ghost { background: transparent; }
.deadline-card .button.ghost { border-color: rgba(255,255,255,.27); color: white; }
.progress-ring-wrap { margin-right: 60px; display: flex; align-items: center; gap: 25px; }
.progress-ring {
  --size: 127px; width: var(--size); height: var(--size); border-radius: 50%;
  display: grid; place-items: center;
  background: conic-gradient(#d6bd81 calc(var(--progress) * 1%), rgba(255,255,255,.13) 0);
  position: relative;
}
.progress-ring::after { content: ""; position: absolute; width: 101px; height: 101px; border-radius: 50%; background: var(--green); }
.progress-ring div { z-index: 1; text-align: center; }
.progress-ring strong { font: 700 25px "Noto Serif JP"; display: block; }
.progress-ring span { font-size: 9px; opacity: .65; }
.progress-ring-wrap > p strong, .progress-ring-wrap > p span { display: block; }
.progress-ring-wrap > p strong { font-size: 16px; }
.progress-ring-wrap > p span { font-size: 11px; opacity: .6; margin-top: 4px; }
.wave-decoration {
  position: absolute; width: 440px; height: 440px; border: 1px solid rgba(255,255,255,.06);
  border-radius: 48% 52% 50% 47%; right: -130px; top: -105px; transform: rotate(15deg);
}
.wave-decoration::before, .wave-decoration::after { content:""; position:absolute; inset: 25px; border: inherit; border-radius: inherit; }
.wave-decoration::after { inset: 53px; }

.stats-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin: 18px 0; }
.stat-card {
  background: white; border: 1px solid var(--line); border-radius: 11px; padding: 20px;
  display: flex; align-items: center; gap: 14px;
}
.stat-icon, .quick-icon { width: 42px; height: 42px; flex: 0 0 auto; display: grid; place-items: center; border-radius: 9px; font-weight: 700; }
.coral { background: var(--coral-soft); color: var(--coral); }
.green { background: var(--mint); color: var(--green-2); }
.blue { background: var(--blue-soft); color: var(--blue); }
.stat-card small, .stat-card strong { display: block; }
.stat-card small { color: var(--muted); font-size: 10px; margin-bottom: 4px; }
.stat-card strong { font: 700 17px "Noto Serif JP"; }
.trend { margin-left: auto; color: var(--green-2); background: var(--mint); padding: 4px 7px; border-radius: 5px; font-size: 9px; }
.trend.warning { background: var(--coral-soft); color: var(--coral); }

.content-grid { display: grid; grid-template-columns: 1.45fr 1fr; gap: 18px; }
.panel { background: white; border: 1px solid var(--line); border-radius: 12px; padding: 25px; }
.panel-heading { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 20px; }
.panel-heading h3, .panel h3 { margin: 0; font: 700 17px "Noto Serif JP"; }
.month-pill { color: var(--muted); background: #f4f5f2; padding: 6px 10px; border-radius: 6px; font-size: 10px; }
.steps { display: grid; }
.step { min-height: 61px; display: grid; grid-template-columns: 34px 1fr auto; align-items: center; gap: 12px; position: relative; }
.step:not(:last-child)::after { content:""; position: absolute; left: 16px; top: 45px; height: 30px; border-left: 1px dashed #c8d1cf; }
.step-number { width: 33px; height: 33px; border-radius: 50%; display: grid; place-items: center; background: #f0f2ef; color: #95a09e; font-size: 11px; z-index: 1; }
.step.completed .step-number { background: var(--green); color: white; }
.step.current .step-number { background: var(--coral); color: white; box-shadow: 0 0 0 5px var(--coral-soft); }
.step strong, .step small { display: block; }
.step strong { font-size: 12px; margin-bottom: 3px; }
.step small { color: var(--muted); font-size: 9px; }
.step-status { font-size: 9px; color: var(--green-2); }
.step-status.muted { color: #a3aaa8; }
.mini-button, .text-button { border: 0; background: var(--mint); color: var(--green-2); border-radius: 6px; padding: 6px 9px; cursor: pointer; font-size: 9px; font-weight: 600; }
.mini-button.disabled { color: #999; background: #f2f2ef; }
.text-button { background: transparent; text-decoration: underline; }
.activity-list { display: grid; gap: 17px; }
.activity { display: grid; grid-template-columns: 38px 1fr auto; gap: 10px; align-items: center; }
.activity-avatar { width: 36px; height: 36px; border-radius: 50%; display: grid; place-items: center; background: var(--mint); font: 700 13px "Noto Serif JP"; }
.activity strong, .activity small { display: block; }
.activity strong { font-size: 11px; }
.activity small { color: var(--muted); font-size: 9px; margin-top: 3px; }
.activity time { color: #9aa4a1; font-size: 9px; }
.quick-panel { margin-top: 18px; }
.quick-actions { display: grid; grid-template-columns: repeat(3, 1fr); }
.quick-action { border: 0; border-right: 1px solid var(--line); background: transparent; padding: 5px 24px; display: grid; grid-template-columns: 43px 1fr auto; gap: 12px; text-align: left; align-items: center; cursor: pointer; }
.quick-action:first-child { padding-left: 0; }
.quick-action:last-child { border: 0; padding-right: 0; }
.quick-action strong, .quick-action small { display: block; }
.quick-action strong { font-size: 11px; }
.quick-action small { color: var(--muted); font-size: 9px; margin-top: 3px; }

.section-toolbar { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 25px; }
.section-toolbar h2 { margin: 0; font: 700 27px "Noto Serif JP"; }
.section-toolbar p { color: var(--muted); margin: 7px 0 0; }
.mobile-calendar-help { display: none; }
.calendar-controls { background: white; border: 1px solid var(--line); border-bottom: 0; padding: 14px 17px; display: flex; align-items: center; gap: 10px; border-radius: 12px 12px 0 0; }
.calendar-controls h3 { min-width: 125px; text-align: center; font: 700 16px "Noto Serif JP"; }
.calendar-legend { display: flex; gap: 17px; margin-left: 20px; color: var(--muted); font-size: 10px; }
.calendar-legend i { width: 7px; height: 7px; display: inline-block; border-radius: 50%; margin-right: 4px; }
.morning-dot { background: var(--gold); } .lunch-dot { background: var(--green-2); } .night-dot { background: var(--blue); }
.auto-button { margin-left: auto; background: var(--green); color: white; border-color: var(--green); }
.calendar-wrap { background: white; border: 1px solid var(--line); overflow-x: auto; }
.calendar-weekdays, .calendar-grid { min-width: 960px; display: grid; grid-template-columns: repeat(7, 1fr); }
.calendar-weekdays { border-bottom: 1px solid var(--line); }
.calendar-weekdays span { padding: 10px; text-align: center; color: var(--muted); font-size: 10px; border-right: 1px solid var(--line); }
.calendar-day { min-height: 145px; padding: 8px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); background: #fff; }
.calendar-day.outside { background: #fafaf7; color: #b5bcba; }
.calendar-day.today { box-shadow: inset 0 0 0 2px var(--coral); }
.day-number { display: block; text-align: right; font-size: 10px; margin-bottom: 6px; }
.day-number small { display: none; }
.shift-group { margin-bottom: 5px; border-left: 2px solid; padding-left: 4px; min-height: 18px; }
.shift-group.morning { border-color: var(--gold); } .shift-group.lunch { border-color: var(--green-2); } .shift-group.night { border-color: var(--blue); }
.shift-group-title { display: flex; justify-content: space-between; font-size: 7px; color: var(--muted); margin-bottom: 2px; }
.shift-chip {
  padding: 3px 4px 3px 5px; border-radius: 4px; background: #f4f1e8; font-size: 8px;
  margin: 2px 0; cursor: grab; display: flex; align-items: center; gap: 4px;
  user-select: none; -webkit-user-select: none; touch-action: pan-y;
}
.shift-chip-name { min-width: 0; flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.shift-delete {
  border: 0; background: transparent; color: #9b8279; padding: 0; width: 15px; height: 15px;
  border-radius: 50%; cursor: pointer; display: grid; place-items: center; font-size: 11px; line-height: 1;
}
.shift-delete:hover { background: rgba(223,109,89,.16); color: var(--coral); }
.shift-group.lunch .shift-chip { background: var(--mint); }
.shift-group.night .shift-chip { background: var(--blue-soft); }
.calendar-day.drag-over { background: #f3f9f6; box-shadow: inset 0 0 0 2px var(--green-2); }
.shift-group.drag-target { outline: 2px solid var(--green-2); outline-offset: 2px; background: #f3faf7; }
.shift-group.drag-invalid { outline: 2px solid var(--coral); outline-offset: 2px; }
.shift-chip.long-press-dragging { opacity: .42; transform: scale(.97); }
.shift-trash {
  position: fixed; left: 50%; bottom: 20px; transform: translate(-50%, 120px);
  z-index: 80; min-width: 220px; padding: 13px 20px; border-radius: 28px;
  background: #713c35; color: white; display: flex; justify-content: center; align-items: center;
  gap: 9px; box-shadow: 0 14px 35px rgba(57,28,24,.28); opacity: 0; pointer-events: none;
  transition: .2s;
}
.shift-trash span { font-size: 19px; }
.shift-trash strong { font-size: 11px; }
body.shift-dragging .shift-trash { transform: translate(-50%, 0); opacity: 1; pointer-events: auto; }
.shift-trash.drag-target { background: var(--coral); transform: translate(-50%, -5px) scale(1.04) !important; }

.request-summary { background: var(--green); color: white; padding: 22px 28px; border-radius: 11px; display: flex; align-items: center; gap: 24px; margin-bottom: 18px; }
.summary-big strong { font: 700 26px "Noto Serif JP"; }
.summary-big span { font-size: 11px; opacity: .7; }
.summary-bar { height: 7px; background: rgba(255,255,255,.16); border-radius: 20px; flex: 1; overflow: hidden; }
.summary-bar i { display: block; height: 100%; background: #d6bd81; border-radius: inherit; }
.request-summary > span { font-size: 10px; opacity: .7; }
.table-panel { padding: 0; overflow: hidden; }
table { width: 100%; border-collapse: collapse; }
th, td { padding: 15px 20px; text-align: left; border-bottom: 1px solid var(--line); font-size: 11px; }
th { color: var(--muted); font-size: 9px; background: #fafaf7; letter-spacing: .06em; }
.person-cell { display: flex; align-items: center; gap: 10px; }
.person-cell .activity-avatar { width: 30px; height: 30px; font-size: 10px; }
.tag { display: inline-block; padding: 4px 7px; border-radius: 4px; background: var(--mint); color: var(--green-2); margin-right: 4px; font-size: 8px; }
.status { display: inline-flex; align-items: center; gap: 5px; font-size: 9px; }
.status::before { content:""; width: 6px; height: 6px; border-radius: 50%; background: var(--green-2); }
.status.pending { color: var(--coral); }
.status.pending::before { background: var(--coral); }
.remind-button { border: 1px solid var(--line); background: white; border-radius: 5px; padding: 5px 9px; cursor: pointer; font-size: 8px; }

.member-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.member-card { padding: 22px; background: white; border: 1px solid var(--line); border-radius: 11px; }
.member-card-head { display: flex; align-items: center; gap: 11px; margin-bottom: 17px; }
.member-card-head .activity-avatar { width: 42px; height: 42px; }
.member-card h3 { margin: 0 0 3px; font: 700 14px "Noto Serif JP"; }
.member-card small { color: var(--muted); font-size: 9px; }
.member-menu { margin-left: auto; border: 0; background: transparent; color: var(--muted); cursor: pointer; }
.member-meta { display: flex; justify-content: space-between; border-top: 1px solid var(--line); padding-top: 14px; margin-top: 14px; font-size: 10px; }
.member-meta span { color: var(--muted); }

.settings-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 18px; }
.settings-grid .panel { display: grid; gap: 17px; }
.form-field { display: grid; gap: 7px; }
.form-field > span, fieldset legend { color: var(--muted); font-size: 10px; font-weight: 600; }
input, select, textarea { width: 100%; border: 1px solid #d9ddd9; background: #fff; border-radius: 7px; padding: 10px 11px; color: var(--ink); outline: none; }
input:focus, select:focus, textarea:focus { border-color: var(--green-2); box-shadow: 0 0 0 3px var(--mint); }
textarea { min-height: 75px; resize: vertical; }
.inline-inputs { display: flex; align-items: center; gap: 8px; }
.shift-setting-row { display: grid; grid-template-columns: 10px 50px 1fr auto; align-items: center; gap: 10px; border-bottom: 1px solid var(--line); padding: 12px 0; }
.shift-color { width: 8px; height: 28px; border-radius: 5px; }
.shift-color.morning { background: var(--gold); } .shift-color.lunch { background: var(--green-2); } .shift-color.night { background: var(--blue); }
.shift-setting-row input { width: 55px; padding: 6px; }
.setting-note { padding: 10px; background: var(--blue-soft); color: var(--blue); border-radius: 6px; font-size: 9px; }
.integration-card { grid-column: 1/-1; grid-template-columns: auto 1fr auto !important; align-items: center; }
.integration-logo { width: 45px; height: 45px; display: grid; place-items: center; border-radius: 9px; border: 1px solid var(--line); font-size: 21px; font-weight: 700; color: #4285f4; }
.integration-card p { margin: 4px 0 0; color: var(--muted); font-size: 10px; }

.modal { width: min(580px, calc(100% - 30px)); border: 0; border-radius: 15px; padding: 0; color: var(--ink); box-shadow: 0 24px 80px rgba(8,34,30,.28); }
.modal::backdrop { background: rgba(8,34,30,.6); backdrop-filter: blur(4px); }
.modal form { padding: 27px; display: grid; gap: 19px; }
.modal-head { display: flex; justify-content: space-between; }
.modal-head h2 { margin: 0; font: 700 22px "Noto Serif JP"; }
.modal-head p { color: var(--muted); margin: 5px 0 0; font-size: 10px; }
.close-button { width: 32px; height: 32px; border: 0; background: #f2f2ee; border-radius: 50%; cursor: pointer; font-size: 18px; }
.modal-actions { display: flex; justify-content: flex-end; gap: 9px; }
fieldset { border: 0; padding: 0; margin: 0; display: grid; gap: 9px; }
.checkbox-row { display: flex; gap: 9px; }
.checkbox-row label { border: 1px solid var(--line); padding: 9px 12px; border-radius: 7px; }
.checkbox-row input { width: auto; }
.answer-tools { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.answer-guide { display: flex; gap: 7px; flex-wrap: wrap; }
.answer-hint { margin: -10px 0 0; color: var(--muted); font-size: 9px; line-height: 1.6; }
.choice { padding: 5px 8px; border-radius: 5px; font-size: 9px; }
.choice.yes { background: var(--mint); color: var(--green-2); }
.choice.maybe { background: #f6f0dd; color: #9a762f; }
.choice.no { background: var(--coral-soft); color: var(--coral); }
.bulk-toggle {
  flex: 0 0 auto; border: 1px solid #d5ddd9; background: white; border-radius: 7px;
  padding: 6px 10px; cursor: pointer; text-align: left; transition: .15s;
}
.bulk-toggle:hover { border-color: var(--green-2); background: #fafcfb; }
.bulk-toggle span, .bulk-toggle strong { display: block; }
.bulk-toggle span { color: var(--muted); font-size: 7px; }
.bulk-toggle strong { color: var(--green-2); font-size: 9px; margin-top: 2px; }
.staff-calendar { display: grid; gap: 6px; max-height: 330px; overflow-y: auto; padding-right: 4px; }
.staff-day-row {
  display: grid; grid-template-columns: 58px repeat(3, 1fr); gap: 5px;
  align-items: stretch; border-bottom: 1px solid #eeece6; padding-bottom: 6px;
}
.staff-date {
  border-radius: 7px; background: #f5f5f1; display: grid; place-items: center;
  align-content: center; min-height: 48px;
}
.staff-date small { color: var(--muted); font-size: 8px; }
.staff-date strong { font: 700 15px "Noto Serif JP"; }
.staff-date.sunday { background: var(--coral-soft); color: var(--coral); }
.staff-date.saturday { background: var(--blue-soft); color: var(--blue); }
.availability-shift {
  border: 1px solid var(--line); border-radius: 7px; padding: 5px 4px;
  display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 3px;
  background: white; cursor: pointer; text-align: left;
}
.availability-shift:hover { border-color: #b8c9c4; }
.availability-shift .shift-label strong, .availability-shift .shift-label small { display: block; }
.availability-shift .shift-label strong { font-size: 9px; }
.availability-shift .shift-label small { color: var(--muted); font-size: 6px; margin-top: 2px; }
.availability-mark {
  width: 25px; height: 25px; border-radius: 50%; display: grid; place-items: center;
  background: var(--mint); color: var(--green-2); font-weight: 700;
}
.availability-shift[data-state="maybe"] .availability-mark { background: #f6f0dd; color: #9a762f; }
.availability-shift[data-state="no"] .availability-mark { background: var(--coral-soft); color: var(--coral); }
.availability-shift.unavailable { background: #f5f5f2; cursor: default; opacity: .55; }
.availability-shift.unavailable .availability-mark { width: auto; background: transparent; color: var(--muted); font-size: 7px; }
.availability-shift.closed { visibility: hidden; pointer-events: none; }

.toast { position: fixed; right: 25px; bottom: 25px; background: var(--green); color: white; padding: 12px 17px; border-radius: 8px; box-shadow: var(--shadow); z-index: 100; opacity: 0; transform: translateY(12px); pointer-events: none; transition: .25s; }
.toast.show { opacity: 1; transform: none; }

@media (max-width: 1050px) {
  .sidebar { width: 80px; padding: 27px 12px; }
  .brand > div:last-child, .nav-item span:not(.nav-icon):not(.nav-badge), .shop-link > span:last-child { display: none; }
  .brand { padding-left: 4px; }
  .nav-item { justify-content: center; }
  .nav-badge { position: absolute; transform: translate(13px,-10px); }
  .shop-link { justify-content: center; }
  .main-content { margin-left: 80px; width: calc(100% - 80px); }
  .content-grid { grid-template-columns: 1fr; }
  .quick-actions { grid-template-columns: 1fr; }
  .quick-action { border-right: 0; border-bottom: 1px solid var(--line); padding: 12px 0; }
  .progress-ring-wrap { margin-right: 10px; }
  .member-grid { grid-template-columns: repeat(2,1fr); }
}

@media (max-width: 720px) {
  .sidebar { transform: translateX(-100%); width: 230px; transition: transform .25s; }
  .sidebar.open { transform: none; }
  .sidebar .brand > div:last-child, .sidebar .nav-item span:not(.nav-icon):not(.nav-badge), .sidebar .shop-link > span:last-child { display: block; }
  .sidebar .nav-item { justify-content: flex-start; }
  .main-content { margin-left: 0; width: 100%; }
  .topbar { height: 80px; padding: 0 17px; }
  .mobile-menu { display: block; }
  .topbar-title p, .manager-chip > span:not(.avatar) { display: none; }
  .topbar-title h1 { font-size: 16px; }
  .view { padding: 22px 15px 40px; }
  .deadline-card { padding: 27px 23px; grid-template-columns: 1fr; }
  .deadline-card h2 { font-size: 23px; }
  .progress-ring-wrap { margin: 27px 0 0; justify-content: flex-start; }
  .stats-grid { grid-template-columns: 1fr; }
  .content-grid { grid-template-columns: 1fr; }
  .section-toolbar { align-items: flex-start; gap: 18px; flex-direction: column; }
  #calendarView .section-toolbar { margin-bottom: 14px; }
  #calendarView .section-toolbar h2 { font-size: 23px; }
  .desktop-calendar-help { display: none; }
  .mobile-calendar-help { display: block; font-size: 11px; line-height: 1.7; }
  .toolbar-actions { width: 100%; flex-wrap: wrap; }
  #calendarView .toolbar-actions .button { flex: 1; padding: 9px 8px; font-size: 10px; }
  .member-grid, .settings-grid { grid-template-columns: 1fr; }
  .integration-card { grid-column: auto; grid-template-columns: auto 1fr !important; }
  .integration-card .button { grid-column: 1/-1; }
  .calendar-controls {
    position: sticky; top: 80px; z-index: 8; flex-wrap: wrap; border: 1px solid var(--line);
    border-radius: 10px; margin-bottom: 11px; padding: 9px 10px; box-shadow: 0 7px 18px rgba(25,52,47,.06);
  }
  .calendar-controls .icon-button { width: 34px; height: 34px; }
  .calendar-controls h3 { min-width: 110px; font-size: 14px; }
  .calendar-legend { order: 2; width: 100%; margin-left: 0; overflow-x: auto; }
  .auto-button { margin-left: auto; }
  .calendar-wrap { border: 0; background: transparent; overflow: visible; }
  .calendar-weekdays { display: none; }
  .calendar-grid { min-width: 0; display: grid; grid-template-columns: 1fr; gap: 10px; }
  .calendar-day.outside { display: none; }
  .calendar-day {
    min-height: 0; padding: 0; display: grid; grid-template-columns: 57px 1fr;
    border: 1px solid var(--line); border-radius: 11px; overflow: hidden;
    box-shadow: 0 5px 16px rgba(25,52,47,.05);
  }
  .day-number {
    margin: 0; padding: 12px 6px; text-align: center; background: #f2f3ef;
    font: 700 19px "Noto Serif JP"; display: flex; flex-direction: column; align-items: center;
    justify-content: flex-start; gap: 2px;
  }
  .day-number small { display: block; color: var(--muted); font: 500 8px "Noto Sans JP"; }
  .calendar-day.sunday .day-number { background: var(--coral-soft); color: var(--coral); }
  .calendar-day.saturday .day-number { background: var(--blue-soft); color: var(--blue); }
  .calendar-day > .shift-group { grid-column: 2; }
  .calendar-day > .day-number + .shift-group { grid-row: 1; }
  .shift-group {
    margin: 0; min-height: 50px; padding: 7px 8px 7px 10px; border-left-width: 3px;
    border-bottom: 1px solid #ecebe6;
  }
  .shift-group:last-child { border-bottom: 0; }
  .shift-group-title { font-size: 9px; margin-bottom: 5px; }
  .shift-group-title span:first-child::after { content: "  " attr(data-time); color: var(--muted); font-size: 7px; }
  .shift-chip {
    display: inline-flex; width: auto; min-width: 92px; max-width: 145px;
    margin: 2px 4px 2px 0; padding: 7px 7px 7px 9px; border-radius: 7px; font-size: 11px;
    box-shadow: inset 0 0 0 1px rgba(20,55,51,.04);
  }
  .shift-delete { width: 20px; height: 20px; font-size: 14px; }
  body.shift-dragging .shift-group { min-height: 58px; }
  .shift-trash { bottom: 17px; min-width: 230px; }
  .table-panel { overflow-x: auto; }
  table { min-width: 670px; }
  .staff-day-row { grid-template-columns: 44px repeat(3, minmax(82px, 1fr)); }
  .staff-calendar { overflow-x: auto; }
  .staff-day-row { min-width: 330px; }
  .answer-tools { align-items: flex-start; flex-direction: column; }
  .bulk-toggle { width: 100%; text-align: center; }
  .availability-shift { grid-template-columns: 1fr; text-align: center; justify-items: center; }
  .availability-shift .shift-label small { display: none; }
}
