:root {
  --bg: #f4f6f8;
  --surface: #ffffff;
  --surface-soft: #f8fafc;
  --surface-dark: #101828;
  --line: #e4e7ec;
  --line-strong: #d0d5dd;
  --text: #101828;
  --muted: #667085;
  --subtle: #98a2b3;
  --primary: #155eef;
  --primary-dark: #004eeb;
  --green: #067647;
  --amber: #b54708;
  --red: #b42318;
  --blue-soft: #eff4ff;
  --green-soft: #ecfdf3;
  --amber-soft: #fffaeb;
  --shadow: 0 10px 30px rgba(16, 24, 40, 0.06);
  --radius: 16px;
}

* { box-sizing: border-box; }
html, body { min-height: 100%; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, "Apple SD Gothic Neo", "Noto Sans KR", "Segoe UI", sans-serif;
  line-height: 1.5;
}
button, input, textarea, select { font: inherit; }
button { cursor: pointer; }

.app-shell { min-height: 100vh; display: grid; grid-template-columns: 260px minmax(0, 1fr); }
.sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  display: flex;
  flex-direction: column;
  padding: 22px 16px;
  background: var(--surface-dark);
  color: #fff;
  z-index: 30;
}
.brand { display: flex; align-items: center; gap: 12px; padding: 4px 8px 24px; }
.brand-mark {
  width: 42px; height: 42px; border-radius: 13px; display: grid; place-items: center;
  background: linear-gradient(135deg, #84adff, #155eef); font-size: 21px; font-weight: 900;
  box-shadow: 0 8px 22px rgba(21,94,239,.35);
}
.brand strong { display: block; font-size: 17px; }
.brand span { display: block; margin-top: 2px; color: #98a2b3; font-size: 12px; }
.main-nav { display: grid; gap: 5px; }
.nav-item {
  width: 100%; min-height: 44px; display: flex; align-items: center; gap: 11px;
  padding: 10px 12px; border: 1px solid transparent; border-radius: 11px;
  background: transparent; color: #d0d5dd; text-align: left; font-weight: 700;
}
.nav-item:hover { background: #1d2939; color: #fff; }
.nav-item.active { background: #fff; color: #101828; box-shadow: 0 8px 22px rgba(0,0,0,.16); }
.nav-icon { width: 24px; text-align: center; font-size: 17px; }
.sidebar-footer { margin-top: auto; padding: 18px 9px 0; border-top: 1px solid #344054; color: #d0d5dd; }
.sidebar-footer small { display: block; margin-top: 12px; color: #667085; }
.connection-row { display: flex; align-items: center; gap: 8px; margin-top: 8px; font-size: 12px; }
.dot { width: 8px; height: 8px; border-radius: 50%; flex: 0 0 auto; }
.dot-online { background: #32d583; box-shadow: 0 0 0 4px rgba(50,213,131,.12); }
.dot-idle { background: #98a2b3; }
.dot-error { background: #f04438; }

.app-main { min-width: 0; }
.topbar {
  position: sticky; top: 0; z-index: 20;
  height: 86px; display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 16px 28px; background: rgba(255,255,255,.9); border-bottom: 1px solid var(--line);
  backdrop-filter: blur(16px);
}
.topbar h1 { margin: 0; font-size: 24px; letter-spacing: -.02em; }
.eyebrow { margin: 0 0 2px; color: var(--muted); font-size: 12px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.topbar-actions { display: flex; align-items: center; gap: 10px; }
.today-pill { padding: 8px 12px; border: 1px solid var(--line); border-radius: 999px; background: #fff; color: #344054; font-size: 13px; font-weight: 700; }
.icon-button { width: 38px; height: 38px; display: grid; place-items: center; border: 1px solid var(--line); border-radius: 10px; background: #fff; color: #344054; font-weight: 800; }
.icon-button:hover { background: var(--surface-soft); }
.menu-toggle { display: none; }

.content { max-width: 1500px; margin: 0 auto; padding: 26px 28px 48px; }
.page { display: none; }
.page.active { display: block; animation: pageIn .18s ease; }
@keyframes pageIn { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }

.hero-card {
  display: flex; align-items: center; justify-content: space-between; gap: 28px;
  padding: 30px; border-radius: 22px; color: #fff;
  background: radial-gradient(circle at top right, rgba(132,173,255,.45), transparent 35%), linear-gradient(135deg, #101828 0%, #1d2939 62%, #344054 100%);
  box-shadow: 0 18px 45px rgba(16,24,40,.18);
}
.hero-card h2 { margin: 13px 0 8px; font-size: clamp(24px, 3vw, 36px); letter-spacing: -.035em; }
.hero-card p { max-width: 760px; margin: 0; color: #d0d5dd; }
.primary-action {
  flex: 0 0 auto; min-width: 230px; min-height: 58px; display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  border: 0; border-radius: 14px; background: #fff; color: #101828; font-weight: 900; box-shadow: 0 10px 25px rgba(0,0,0,.18);
}
.primary-action:disabled { opacity: .58; cursor: not-allowed; }

.badge { display: inline-flex; align-items: center; padding: 5px 9px; border-radius: 999px; font-size: 12px; font-weight: 900; }
.badge-blue { background: rgba(132,173,255,.18); color: #d1e0ff; border: 1px solid rgba(132,173,255,.35); }
.badge-green { background: var(--green-soft); color: var(--green); }
.badge-amber { background: var(--amber-soft); color: var(--amber); }

.notice { margin-top: 16px; padding: 13px 15px; border-radius: 12px; font-size: 13px; }
.notice-info { background: var(--blue-soft); border: 1px solid #c7d7fe; color: #3538cd; }
.notice-neutral { background: #f9fafb; border: 1px solid var(--line); color: var(--muted); }

.status-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 14px; margin-top: 18px; }
.status-card, .metric-card, .panel {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow);
}
.status-card { padding: 18px; }
.status-card-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; color: var(--muted); font-size: 12px; font-weight: 800; }
.status-card > strong { display: block; margin-top: 15px; font-size: 19px; }
.status-card p { margin: 5px 0 0; color: var(--muted); font-size: 12px; }
.status-chip { display: inline-flex; padding: 4px 8px; border-radius: 999px; font-size: 11px; font-weight: 900; }
.chip-idle { background: #f2f4f7; color: #475467; }
.chip-warn { background: var(--amber-soft); color: var(--amber); }
.chip-ok { background: var(--green-soft); color: var(--green); }

.section-grid { display: grid; gap: 16px; margin-top: 18px; }
.two-columns { grid-template-columns: repeat(2, minmax(0,1fr)); }
.three-columns { grid-template-columns: repeat(3, minmax(0,1fr)); }
.four-columns { grid-template-columns: repeat(4, minmax(0,1fr)); }
.panel { padding: 20px; }
.panel-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 16px; }
.panel-head h3 { margin: 1px 0 0; font-size: 18px; }
.section-kicker { margin: 0; color: var(--primary); font-size: 11px; font-weight: 900; letter-spacing: .12em; }

.workflow-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 14px; }
.workflow-list li { display: grid; grid-template-columns: 36px 1fr; gap: 12px; align-items: start; }
.workflow-list li > span { width: 34px; height: 34px; display: grid; place-items: center; border-radius: 10px; background: var(--blue-soft); color: var(--primary); font-weight: 900; }
.workflow-list strong { display: block; }
.workflow-list p { margin: 2px 0 0; color: var(--muted); font-size: 13px; }
.check-list { display: grid; gap: 12px; }
.check-list label { display: flex; align-items: center; gap: 9px; padding: 10px 12px; border: 1px solid var(--line); border-radius: 10px; color: #344054; font-size: 13px; }
.check-list input { width: 17px; height: 17px; }

.metric-card { padding: 18px; }
.metric-card span { color: var(--muted); font-size: 12px; font-weight: 800; }
.metric-card strong { display: block; margin: 9px 0 5px; font-size: 27px; }
.metric-card small { color: var(--subtle); }
.empty-state { margin-top: 18px; min-height: 340px; display: grid; place-items: center; align-content: center; text-align: center; }
.empty-state h3 { margin: 12px 0 6px; }
.empty-state p { max-width: 650px; margin: 0; color: var(--muted); }
.empty-icon { width: 58px; height: 58px; display: grid; place-items: center; border-radius: 18px; background: var(--blue-soft); color: var(--primary); font-size: 28px; font-weight: 900; }

.report-page { height: calc(100vh - 140px); min-height: 680px; }
.report-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 12px; }
.report-toolbar p { margin: 5px 0 0; color: var(--muted); font-size: 13px; }
.daily-report-frame { width: 100%; height: calc(100% - 58px); min-height: 620px; border: 1px solid var(--line); border-radius: 16px; background: #fff; box-shadow: var(--shadow); }

.mid-layout { display: grid; grid-template-columns: minmax(360px, .9fr) minmax(420px, 1.1fr); gap: 18px; align-items: start; }
.form-grid { display: grid; gap: 12px; }
.two-columns-form { grid-template-columns: repeat(2, minmax(0,1fr)); }
.field { display: grid; gap: 6px; }
.field span { color: #475467; font-size: 12px; font-weight: 800; }
.field input, .field textarea, .field select { width: 100%; min-height: 42px; padding: 9px 11px; border: 1px solid var(--line-strong); border-radius: 10px; background: #fff; color: var(--text); outline: none; }
.field input:focus, .field textarea:focus, .field select:focus { border-color: #84adff; box-shadow: 0 0 0 4px rgba(21,94,239,.10); }
.field input[type="number"] { text-align: right; }
.button-row { display: flex; gap: 9px; flex-wrap: wrap; margin-top: 16px; }
.button-primary, .button-secondary { min-height: 42px; padding: 9px 14px; border-radius: 10px; font-weight: 900; }
.button-primary { border: 1px solid var(--primary); background: var(--primary); color: #fff; }
.button-primary:hover { background: var(--primary-dark); }
.button-secondary { border: 1px solid var(--line-strong); background: #fff; color: #344054; }
.button-secondary:hover { background: #f9fafb; }
.save-state { color: var(--green); font-size: 12px; font-weight: 800; }
.preview-panel { text-align: center; }
#midReportCanvas { display: block; width: min(100%, 620px); height: auto; margin: 0 auto; border: 1px solid #101828; background: #fff; box-shadow: 0 10px 26px rgba(16,24,40,.09); }
.preview-panel .button-row { justify-content: center; }
.helper-text { color: var(--muted); font-size: 12px; }

.table-wrap { overflow: auto; border: 1px solid var(--line); border-radius: 12px; }
table { width: 100%; min-width: 800px; border-collapse: collapse; }
th, td { padding: 11px 12px; border-bottom: 1px solid var(--line); text-align: left; font-size: 13px; }
th { background: #f9fafb; color: #475467; font-weight: 900; }
.table-empty { height: 150px; text-align: center; color: var(--muted); }

.device-hero { display: flex; align-items: center; gap: 20px; padding: 26px; border: 1px solid #fedf89; border-radius: 18px; background: var(--amber-soft); }
.device-hero h2 { margin: 8px 0 5px; }
.device-hero p { margin: 0; color: #7a2e0e; }
.device-illustration { width: 74px; height: 74px; display: grid; place-items: center; flex: 0 0 auto; border-radius: 22px; background: #fff; color: var(--amber); font-size: 42px; box-shadow: var(--shadow); }
.plain-list { margin: 0; padding-left: 20px; color: #475467; }
.plain-list li { margin: 8px 0; }
.connection-table { display: grid; border: 1px solid var(--line); border-radius: 12px; overflow: hidden; }
.connection-table > div { display: flex; justify-content: space-between; gap: 14px; padding: 12px 14px; border-bottom: 1px solid var(--line); }
.connection-table > div:last-child { border-bottom: 0; }
.connection-table span { color: var(--muted); }
.text-ok { color: var(--green); }
.text-warn { color: var(--amber); }
.text-muted { color: var(--subtle); }

.settings-layout { display: grid; grid-template-columns: 220px minmax(0,1fr); gap: 18px; align-items: start; }
.settings-nav { position: sticky; top: 112px; display: grid; gap: 5px; padding: 9px; border: 1px solid var(--line); border-radius: 14px; background: #fff; box-shadow: var(--shadow); }
.settings-tab { width: 100%; padding: 10px 11px; border: 1px solid transparent; border-radius: 9px; background: transparent; color: #475467; text-align: left; font-weight: 800; }
.settings-tab:hover { background: #f9fafb; }
.settings-tab.active { background: var(--blue-soft); color: var(--primary); border-color: #c7d7fe; }
.settings-panels { min-width: 0; }
.settings-panel { display: none; padding: 22px; border: 1px solid var(--line); border-radius: var(--radius); background: #fff; box-shadow: var(--shadow); }
.settings-panel.active { display: block; }
.toggle-list { display: grid; gap: 10px; }
.toggle-row { display: flex; align-items: center; justify-content: space-between; gap: 15px; padding: 13px 14px; border: 1px solid var(--line); border-radius: 11px; }
.toggle-row strong { display: block; }
.toggle-row span { display: block; margin-top: 3px; color: var(--muted); font-size: 12px; }
.toggle-row input { width: 18px; height: 18px; }
.timeline { display: grid; gap: 12px; }
.timeline > div { padding: 14px 15px; border-left: 3px solid #84adff; background: #f9fafb; border-radius: 0 11px 11px 0; }
.timeline time { display: block; color: var(--primary); font-size: 11px; font-weight: 900; }
.timeline strong { display: block; margin-top: 3px; }
.timeline p { margin: 4px 0 0; color: var(--muted); font-size: 13px; }
.empty-inline { min-height: 220px; display: grid; place-items: center; border: 1px dashed var(--line-strong); border-radius: 12px; color: var(--muted); }


.status-popup-layer {
  position: fixed;
  inset: 0;
  z-index: 20000;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 22px 18px;
  background: rgba(16, 24, 40, .18);
  backdrop-filter: blur(2px);
}
.status-popup {
  width: min(560px, calc(100vw - 36px));
  display: grid;
  grid-template-columns: 42px minmax(0,1fr) 34px;
  align-items: center;
  gap: 13px;
  padding: 16px 16px 16px 18px;
  border: 2px solid #d0d5dd;
  border-radius: 16px;
  background: #fff;
  color: #101828;
  box-shadow: 0 24px 70px rgba(16,24,40,.35);
  animation: statusPopupIn .18s ease-out;
}
.status-popup-icon {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  font-size: 22px;
  font-weight: 1000;
}
.status-popup-content strong { display: block; margin-bottom: 3px; font-size: 15px; }
.status-popup-content p { margin: 0; color: #344054; font-size: 14px; font-weight: 700; line-height: 1.55; }
.status-popup-close {
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: 9px;
  background: #f2f4f7;
  color: #344054;
  font-size: 22px;
  line-height: 1;
}
.status-popup-close:hover { background: #e4e7ec; }
.status-popup-success { border-color: #6ce9a6; }
.status-popup-success .status-popup-icon { background: #ecfdf3; color: #027a48; }
.status-popup-error { border-color: #f97066; }
.status-popup-error .status-popup-icon { background: #fef3f2; color: #b42318; }
.status-popup-warn { border-color: #fdb022; }
.status-popup-warn .status-popup-icon { background: #fffaeb; color: #b54708; }
.status-popup-info { border-color: #84adff; }
.status-popup-info .status-popup-icon { background: #eff8ff; color: #175cd3; }
@keyframes statusPopupIn { from { opacity: 0; transform: translateY(-18px) scale(.98); } to { opacity: 1; transform: none; } }


@media (max-width: 1120px) {
  .status-grid, .four-columns { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .mid-layout { grid-template-columns: 1fr; }
}
@media (max-width: 860px) {
  .app-shell { grid-template-columns: 1fr; }
  .sidebar { position: fixed; left: 0; top: 0; transform: translateX(-102%); width: 280px; transition: .2s ease; box-shadow: 18px 0 35px rgba(16,24,40,.22); }
  .sidebar.open { transform: translateX(0); }
  .menu-toggle { display: grid; }
  .topbar { padding: 14px 18px; }
  .content { padding: 20px 16px 36px; }
  .topbar h1 { font-size: 21px; }
  .today-pill { display: none; }
  .hero-card { align-items: flex-start; flex-direction: column; }
  .primary-action { width: 100%; }
  .two-columns, .three-columns, .settings-layout { grid-template-columns: 1fr; }
  .settings-nav { position: static; display: flex; overflow-x: auto; }
  .settings-tab { width: auto; white-space: nowrap; }
  .report-page { height: auto; min-height: 0; }
  .daily-report-frame { height: 900px; }
}
@media (max-width: 560px) {
  .status-grid, .four-columns, .two-columns-form { grid-template-columns: 1fr; }
  .hero-card { padding: 22px; }
  .panel { padding: 16px; }
  .device-hero { align-items: flex-start; flex-direction: column; }
  .button-row { flex-direction: column; }
  .button-row button { width: 100%; }
}

.auth-button {
  min-height: 38px;
  white-space: nowrap;
}

.auth-modal {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: grid;
  place-items: center;
  padding: 20px;
  background: rgba(16, 24, 40, 0.55);
  backdrop-filter: blur(8px);
}

.auth-modal.is-hidden,
.is-hidden {
  display: none !important;
}

.auth-card {
  width: min(480px, 100%);
  padding: 24px;
  border: 1px solid var(--line, #e4e7ec);
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 28px 80px rgba(16, 24, 40, 0.22);
}

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

.auth-card-head h2 {
  margin: 2px 0 0;
}

.auth-help {
  margin: 0 0 18px;
  color: #667085;
  line-height: 1.65;
}

.auth-submit {
  width: 100%;
  justify-content: center;
  margin-top: 14px;
}

.auth-notice {
  margin-top: 16px;
}

.signed-in-box {
  display: grid;
  gap: 6px;
  padding: 16px;
  border: 1px solid #d0d5dd;
  border-radius: 12px;
  background: #f9fafb;
}

.signed-in-box span {
  color: #667085;
  font-size: 13px;
}

.signed-in-box strong {
  overflow-wrap: anywhere;
}

/* Auth v0.3: 이메일/비밀번호 + 마스터 승인 */
.auth-mode-tabs { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; margin-bottom: 18px; padding: 5px; border-radius: 12px; background: #f2f4f7; }
.auth-mode-tab { min-height: 39px; border: 0; border-radius: 9px; background: transparent; color: #667085; font-weight: 900; }
.auth-mode-tab.active { background: #fff; color: var(--primary); box-shadow: 0 2px 8px rgba(16,24,40,.08); }
.auth-form-stack { display: grid; gap: 12px; }
.auth-link-button { display: block; margin: 12px auto 0; border: 0; background: transparent; color: var(--primary); font-weight: 800; }
.signed-in-meta { display: flex; gap: 12px; flex-wrap: wrap; color: #667085; font-size: 12px; }
.signed-in-meta b { margin-left: 3px; color: #344054; }

.access-gate { position: fixed; inset: 0; z-index: 95; display: grid; place-items: center; padding: 20px; background: rgba(246,248,252,.96); backdrop-filter: blur(8px); }
.access-gate-card { width: min(540px,100%); padding: 38px; border: 1px solid #e4e7ec; border-radius: 22px; background: #fff; text-align: center; box-shadow: 0 30px 90px rgba(16,24,40,.18); }
.access-gate-icon { width: 72px; height: 72px; display: grid; place-items: center; margin: 22px auto 16px; border-radius: 50%; background: #eff8ff; color: var(--primary); font-size: 34px; font-weight: 900; }
.access-gate-card h2 { margin: 0 0 10px; }
.access-gate-card p { margin: 0 auto 24px; max-width: 430px; color: #667085; line-height: 1.7; }

.member-list { display: grid; gap: 10px; margin-top: 16px; }
.member-row { display: flex; align-items: center; justify-content: space-between; gap: 18px; padding: 14px 15px; border: 1px solid var(--line); border-radius: 12px; background: #fff; }
.member-main { min-width: 0; display: grid; gap: 3px; }
.member-main strong { color: #101828; }
.member-main span, .member-main small { color: #667085; overflow-wrap: anywhere; }
.member-main small { font-size: 11px; }
.member-review { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; justify-content: flex-end; }
.member-status { display: inline-flex; padding: 5px 9px; border-radius: 999px; font-size: 11px; font-weight: 900; }
.member-status-pending { background: #fffaeb; color: #b54708; }
.member-status-approved { background: #ecfdf3; color: #027a48; }
.member-status-rejected { background: #fef3f2; color: #b42318; }
.member-actions { display: flex; gap: 6px; }
.button-small { min-height: 34px; padding: 6px 10px; border-radius: 8px; font-weight: 900; }
.button-approve { border: 1px solid #abefc6; background: #ecfdf3; color: #027a48; }
.button-reject { border: 1px solid #fecdca; background: #fef3f2; color: #b42318; }
.member-master-label { color: var(--primary); font-size: 12px; font-weight: 900; }
@media (max-width: 640px) { .member-row { align-items: flex-start; flex-direction: column; } .member-review { justify-content: flex-start; } }


/* v0.5 회원가입·마스터 승인 비밀번호 재설정 */
.signup-honeypot { position: absolute !important; left: -10000px !important; width: 1px !important; height: 1px !important; overflow: hidden !important; }
.password-reset-step { display: grid; gap: 12px; padding: 15px; border: 1px solid var(--line); border-radius: 13px; background: #fff; }
.password-reset-step > strong { color: #344054; font-size: 13px; }
.password-reset-divider { display: flex; align-items: center; gap: 10px; margin: 16px 0; color: #98a2b3; font-size: 11px; font-weight: 800; }
.password-reset-divider::before, .password-reset-divider::after { content: ""; flex: 1; height: 1px; background: var(--line); }
.admin-subsection { display: grid; gap: 12px; padding: 16px; border: 1px solid var(--line); border-radius: 14px; background: #f9fafb; }
.admin-subsection + .admin-subsection { margin-top: 18px; }
.admin-subsection-head > div { display: grid; gap: 4px; }
.admin-subsection-head strong { color: #101828; }
.admin-subsection-head span { color: #667085; font-size: 12px; line-height: 1.55; }
.reset-code-box { display: grid; grid-template-columns: minmax(0,1fr) minmax(0,1fr) auto; align-items: center; gap: 12px; padding: 14px; border: 1px solid #84caff; border-radius: 13px; background: #eff8ff; }
.reset-code-box > div { display: grid; gap: 4px; }
.reset-code-box span, .reset-code-box small { color: #475467; font-size: 11px; }
.reset-code-box small { grid-column: 1 / -1; line-height: 1.5; }
.reset-code-value { letter-spacing: .12em; font-size: 20px; color: #175cd3; }
@media (max-width: 720px) { .reset-code-box { grid-template-columns: 1fr; } .reset-code-box small { grid-column: auto; } }


/* v0.6 회원 권한 및 로그인 화면 개선 */
.auth-required-nav.is-hidden { display: none !important; }
.member-name-line { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.role-badge { display: inline-flex; align-items: center; min-height: 24px; padding: 3px 8px; border-radius: 999px; font-size: 11px; font-weight: 1000; }
.role-badge-master { background: #eef4ff; color: #3538cd; border: 1px solid #c7d7fe; }
.role-badge-member { background: #f2f4f7; color: #475467; border: 1px solid #d0d5dd; }
.button-role-master { border: 1px solid #b2ccff; background: #eff8ff; color: #175cd3; }
.button-role-member { border: 1px solid #d0d5dd; background: #f9fafb; color: #344054; }
.member-current-label { display: inline-flex; padding: 6px 9px; border-radius: 8px; background: #f2f4f7; color: #667085; font-size: 11px; font-weight: 900; }
@media (max-width: 640px) {
  .status-popup-layer { padding-top: 12px; }
  .status-popup { grid-template-columns: 38px minmax(0,1fr) 30px; padding: 13px; }
  .status-popup-icon { width: 38px; height: 38px; }
}
