/* ============================================================
   Office — classes customizadas (extensão do office.css)
   ============================================================ */

/* ── Loading bar ─────────────────────────────────────────────── */

#loading-bar {
  position: fixed;
  top: 0; left: 0;
  width: 100%; height: 3px;
  background: var(--primary);
  z-index: 9999;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .3s ease;
}
#loading-bar.active {
  transform: scaleX(.7);
  transition: transform 8s ease;
}

/* ── Toast ───────────────────────────────────────────────────── */

#toast-container {
  position: fixed;
  top: 1rem; right: 1rem;
  z-index: 9998;
  display: flex;
  flex-direction: column;
  gap: .5rem;
}
.toast {
  padding: .625rem 1rem;
  border-radius: var(--r-md);
  font-size: .8125rem;
  font-weight: 600;
  background: var(--bg-card);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-md);
  opacity: 0;
  transform: translateX(1rem);
  transition: opacity .2s, transform .2s;
  cursor: pointer;
  max-width: 320px;
}
.toast.visible        { opacity: 1; transform: translateX(0); }
.toast-success { border-left: 3px solid var(--success); }
.toast-error   { border-left: 3px solid var(--error); }
.toast-info    { border-left: 3px solid var(--primary); }
.toast-warning { border-left: 3px solid var(--warning); }

/* ── Signin background ───────────────────────────────────────── */

.auth-page {
  background-image:
    radial-gradient(ellipse at 20% 50%, hsl(201 83% 94%) 0%, transparent 60%),
    radial-gradient(ellipse at 80% 80%, hsl(191 100% 92%) 0%, transparent 50%);
}
[data-theme="dark"] .auth-page {
  background-image: none;
}

/* ── Signin PIN input ────────────────────────────────────────── */

#step2-pin {
  letter-spacing: .5rem;
  font-size: 1.5rem;
  font-family: var(--font-heading);
  font-weight: 700;
  text-align: center;
  padding: .75rem 1rem;
}

/* ── Signin error ────────────────────────────────────────────── */

#signin-error {
  font-size: .8125rem;
  color: var(--error);
  background: var(--error-light);
  border-radius: var(--r-md);
  padding: .625rem .875rem;
  display: none;
  margin-bottom: .75rem;
}
#signin-error.visible { display: block; }

/* ── Step animation ──────────────────────────────────────────── */

.step { animation: step-in .2s ease; }
@keyframes step-in {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Update banner ───────────────────────────────────────────── */

.btn-update {
  background: var(--warning-light);
  color: var(--warning);
  border: 1px solid var(--warning);
  border-radius: var(--r-md);
  padding: .375rem .75rem;
  font-size: .75rem;
  font-weight: 700;
  cursor: pointer;
}

/* ── Merchant picker ─────────────────────────────────────────── */

#merchant-picker {
  display: none;
  position: fixed;
  inset: 0;
  background: var(--bg);
  z-index: 200;
  align-items: center;
  justify-content: center;
}
#merchant-picker.visible {
  display: flex;
}
.merchant-picker-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 2rem;
  width: 100%;
  max-width: 420px;
  box-shadow: var(--shadow-lg);
}
.merchant-picker-title {
  font-family: var(--font-heading);
  font-size: 1.125rem;
  font-weight: 700;
  margin-bottom: 1.25rem;
  color: var(--text-primary);
}
.merchant-picker-list {
  display: flex;
  flex-direction: column;
  gap: .5rem;
}
.merchant-picker-item {
  display: flex;
  align-items: center;
  gap: .875rem;
  padding: .75rem 1rem;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  cursor: pointer;
  transition: background .1s, border-color .1s;
  background: none;
  width: 100%;
  text-align: left;
}
.merchant-picker-item:hover {
  background: var(--grey-50);
  border-color: var(--primary);
}
.merchant-picker-logo {
  width: 36px;
  height: 36px;
  border-radius: var(--r-xs);
  object-fit: contain;
  background: var(--grey-100);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--text-muted);
  font-size: .875rem;
}
.merchant-picker-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  border-radius: var(--r-xs);
}
.merchant-picker-name {
  font-weight: 600;
  font-size: .9375rem;
  color: var(--text-primary);
}

/* ── Layout helpers ──────────────────────────────────────────── */

.page-header-left {
  display: flex;
  align-items: center;
  gap: .625rem;
}

/* ── Loading / Empty states ──────────────────────────────────── */

.loading-state {
  padding: 2.5rem 1rem;
  text-align: center;
  font-size: .875rem;
  color: var(--text-muted);
}
.empty-state {
  padding: 3rem 1rem;
  text-align: center;
  color: var(--text-muted);
}
.empty-icon {
  font-size: 2rem;
  margin-bottom: .75rem;
  opacity: .35;
}
.empty-state p { font-size: .875rem; margin: 0; }

/* ── Narrow (contentor de formulários) ───────────────────────── */

.narrow { max-width: 720px; }

/* ── Form section ────────────────────────────────────────────── */

.form-section { margin-bottom: 1.75rem; }
.form-section-title {
  font-size: .6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--text-muted);
  margin-bottom: .875rem;
  padding-bottom: .5rem;
  border-bottom: 1px solid var(--border);
}

/* ── Detail grid / form fields ───────────────────────────────── */

.detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 1rem;
}
.addr-grid {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
}
.addr-card {
  flex: 1 1 180px;
  max-width: 300px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: .25rem;
  padding: 1rem 1.25rem;
  border-radius: var(--r-lg);
  border: 1.5px solid var(--border);
  background: var(--bg-card);
  box-shadow: var(--shadow-sm);
  cursor: pointer;
  transition: border-color var(--transition);
}
.addr-icon {
  width: 36px; height: 36px;
  border-radius: var(--r-xs);
  background: var(--grey-100);
  color: var(--text-muted);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .875rem;
  margin-bottom: .375rem;
  flex-shrink: 0;
  transition: background var(--transition), color var(--transition);
}
.addr-card:hover { border-color: var(--primary); }
.addr-card.selected { border-left: 4px solid var(--success); }
.addr-card.selected .addr-icon { background: var(--success); color: #fff; }
.addr-card strong { font-size: .875rem; font-weight: 600; color: var(--text-primary); }
.addr-card span { font-size: .75rem; color: var(--text-secondary); }
.detail-field {
  display: flex;
  flex-direction: column;
  gap: .3125rem;
}
.detail-field > label {
  font-size: .75rem;
  font-weight: 600;
  color: var(--text-secondary);
}
.detail-field input,
.detail-field select,
.detail-field textarea {
  padding: .4375rem .75rem;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--bg-card);
  color: var(--text-primary);
  font-size: .875rem;
  font-family: var(--font-body);
  outline: none;
  transition: border-color .15s;
  width: 100%;
  box-sizing: border-box;
}
.detail-field input:focus,
.detail-field select:focus,
.detail-field textarea:focus {
  border-color: var(--primary);
}
.detail-field--wide    { grid-column: 1 / -1; }
.detail-field--invalid input,
.detail-field--invalid select,
.detail-field--invalid textarea { border-color: var(--error); }
.detail-field--check   { justify-content: flex-end; padding-bottom: .125rem; }
.check-label {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .875rem;
  color: var(--text-primary);
  cursor: pointer;
}
.req { color: var(--error); }
.detail-field input[readonly] {
  background: var(--grey-50);
  color: var(--text-secondary);
  cursor: default;
}

/* ── Row link (nome clicável na tabela) ──────────────────────── */

.row-link {
  font-weight: 600;
  color: var(--text-primary);
  background: none;
  border: none;
  padding: 0;
  font-family: inherit;
  font-size: inherit;
  text-align: left;
  cursor: pointer;
}
.row-link:hover { color: var(--primary); }

.td-actions { width: 40px; text-align: right; }

/* ── Table extras ────────────────────────────────────────────── */

.td-logo { width: 44px; }
.td-logo-img {
  width: 32px; height: 32px;
  object-fit: contain;
  border-radius: var(--r-xs);
  display: block;
}
.td-logo-placeholder {
  width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  border-radius: var(--r-xs);
  background: var(--grey-100);
  color: var(--text-muted);
}

/* ── Multi-select ────────────────────────────────────────────── */

.multi-select-box {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: .25rem;
  padding: .375rem;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  max-height: 180px;
  overflow-y: auto;
  transition: border-color var(--transition), box-shadow var(--transition);
}
.multi-select-box:focus-within {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px hsl(201 83% 57% / .12);
}
.multi-select-box--tree { grid-template-columns: 1fr; max-height: 300px; }
.multi-select-group {
  grid-column: 1 / -1;
  padding: .375rem .5rem .125rem;
  font-size: .6875rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .06em;
  color: var(--text-muted);
  border-bottom: 1px solid var(--border);
  margin-top: .25rem;
}
.multi-select-group:first-child { margin-top: 0; }
.multi-select-item {
  display: flex; align-items: center;
  padding: .375rem .625rem;
  border-radius: var(--r-sm);
  cursor: pointer;
  font-size: .8125rem;
  color: var(--text-primary);
  transition: background var(--transition), color var(--transition);
  user-select: none;
  border-left: 2px solid transparent;
}
.multi-select-item:hover { background: var(--grey-50); }
.multi-select-item:has(input:checked) {
  background: var(--primary-subtle);
  color: var(--primary);
  border-left-color: var(--primary);
}
.multi-select-item input[type=checkbox] { display: none; }
.multi-select-item--indent { margin-left: 1.25rem; }
.area-id { margin-left: .25rem; font-size: .6875rem; font-family: monospace; color: var(--text-muted); opacity: .7; }
.multi-select-legend {
  display: flex; gap: 1rem; margin-top: .375rem;
  font-size: .75rem; color: var(--text-muted);
}
.multi-select-legend i { margin-right: .25rem; }

/* ── Image upload ────────────────────────────────────────────── */

.image-upload-zone {
  position: relative;
  border: 2px dashed var(--border);
  border-radius: var(--r-sm);
  overflow: hidden; cursor: pointer;
  transition: border-color .15s;
}
.image-upload-zone:hover            { border-color: var(--primary); }
.image-upload-zone.drag-over        { border-color: var(--primary); background: var(--primary-subtle); }
.image-upload-zone--logo,
.image-upload-zone--default         { width: 120px; height: 120px; }
.image-upload-zone--banner          { width: 100%; height: 160px; }
.image-upload-img                   { width: 100%; height: 100%; object-fit: contain; }
.image-upload-overlay {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.45);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: .25rem; color: #fff; font-size: .75rem;
  opacity: 0; transition: opacity .15s;
}
.image-upload-zone:hover .image-upload-overlay { opacity: 1; }
.image-upload-placeholder {
  width: 100%; height: 100%;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: .5rem; color: var(--text-muted);
  font-size: .75rem; text-align: center;
  padding: .5rem; box-sizing: border-box;
}
.image-upload-placeholder i { font-size: 1.5rem; }
.img-delete-btn {
  position: absolute; top: .375rem; right: .375rem;
  width: 22px; height: 22px; border-radius: 50%;
  background: rgba(0,0,0,.5); border: none;
  color: #fff; font-size: .7rem; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  z-index: 2; padding: 0;
}
.img-delete-btn:hover { background: var(--error); }

/* ── Pagination ──────────────────────────────────────────────── */

.pagination { display: flex; align-items: center; gap: .25rem; padding: .625rem 1rem; }
.page-btn {
  min-width: 32px; height: 32px; padding: 0 .5rem;
  border: 1px solid var(--border); border-radius: var(--r-xs);
  background: var(--bg-card); color: var(--text-primary);
  font-size: .8125rem; font-family: var(--font-body); cursor: pointer;
  transition: background .1s, border-color .1s;
}
.page-btn:hover:not(:disabled) { background: var(--grey-100); border-color: var(--primary); }
.page-btn--active { background: var(--primary); color: var(--text-contrast); border-color: var(--primary); cursor: default; }
.page-btn:disabled { opacity: .4; cursor: not-allowed; }
.page-dots { color: var(--text-muted); font-size: .875rem; padding: 0 .125rem; }

/* ── Filter bar ──────────────────────────────────────────────── */

.filter-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: .75rem;
}
.filter-bar > .detail-field {
  flex: 1;
  min-width: 160px;
}

/* ── Areas tree ──────────────────────────────────────────────── */

.areas-tree { display: flex; flex-direction: column; gap: 1rem; }
.areas-group { border: 1px solid var(--border); border-radius: var(--r-sm); overflow: hidden; }
.areas-group-header {
  padding: .5rem .875rem;
  font-size: .6875rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .06em;
  color: var(--text-muted);
  background: var(--grey-50);
  border-bottom: 1px solid var(--border);
}
.areas-row {
  display: flex; align-items: center; gap: .75rem;
  padding: .625rem .875rem; cursor: pointer;
  transition: background .1s;
  border-bottom: 1px solid var(--border-subtle);
}
.areas-row:last-child        { border-bottom: none; }
.areas-row:hover             { background: var(--grey-50); }
.areas-row--child            { padding-left: 2.25rem; background: var(--grey-50); }
.areas-row--child:hover      { background: var(--grey-100); }
.areas-row-icon              { color: var(--text-muted); width: 16px; text-align: center; flex-shrink: 0; }
.areas-row-name              { flex: 1; font-size: .875rem; }
.areas-row-id                { font-size: .75rem; color: var(--text-muted); font-family: var(--font-mono); }
.areas-row-pub               { flex-shrink: 0; }
