/**
 * Domino's Pizza — identidade visual AnyFood Backoffice
 * Cores oficiais: #0090E2 (azul), #FF0000 (vermelho), #FFFFFF (branco)
 */
:root {
  --dominos-blue: #0090E2;
  --dominos-blue-dark: #0074B5;
  --dominos-blue-darker: #005A8F;
  --dominos-blue-nav-active: #005A8F;
  --dominos-red: #FF0000;
  --dominos-red-dark: #CC0000;
  --dominos-white: #FFFFFF;

  --color-primary: var(--dominos-blue);
  --color-primary-dark: var(--dominos-blue-dark);
  --color-primary-darker: var(--dominos-blue-darker);
  --color-accent: var(--dominos-red);
  --color-primary-contrast: var(--dominos-white);
  --color-primary-rgb: 0, 144, 226;
  --color-accent-rgb: 255, 0, 0;

  --font-family-app: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

/* Tipografia do shell (header + sidebar + conteúdo) — alinhada ao dashboard moderno */
body,
#wrapper,
.sidebar,
.topbar,
#accordionSidebar {
  font-family: var(--font-family-app) !important;
}

.min-h-100vh {
  min-height: 100vh !important;
}

.invalid-form,
.invalid-image {
  border: 1px solid var(--dominos-red);
}

.bg-filtrando {
  background-color: rgba(0, 144, 226, 0.12);
  background-image: linear-gradient(180deg, rgba(0, 144, 226, 0.08) 10%, rgba(0, 90, 143, 0.12) 100%);
}

.nav-tabs {
  border-bottom: 0;
}

#pager {
  display: flex;
  width: 100%;
  justify-content: flex-end;
  gap: 4px;
}

#pager .stepper-before,
#pager .stepper-next,
#pager .stepper {
  display: inline-block;
  font-weight: 400;
  text-align: center;
  padding: 0.25rem 0.5rem;
  font-size: 0.875rem;
  line-height: 1.5;
  border-radius: 0.2rem;
  color: var(--color-primary);
  border: 1px solid var(--color-primary);
  cursor: pointer;
}

#pager .stepper-before:hover,
#pager .stepper-next:hover,
#pager .stepper:hover,
#pager .stepper-active {
  color: var(--color-primary-contrast);
  background-color: var(--color-primary);
}

/* ========== Login / Auth ========== */
body.bg-onboard {
  position: relative;
  background: linear-gradient(145deg, var(--dominos-blue-darker) 0%, var(--dominos-blue) 45%, #0b4f7a 100%);
  background-size: cover;
  min-height: 100vh;
}

body.bg-onboard::before {
  content: '';
  position: fixed;
  inset: 0;
  background: url('/img/dominos-backgorund.svg') center / cover no-repeat;
  opacity: 0.10;
  z-index: 0;
  pointer-events: none;
}

body.bg-onboard::after {
  content: '';
  position: fixed;
  top: -20%;
  right: -10%;
  width: 50vmin;
  height: 50vmin;
  background: radial-gradient(circle, rgba(255, 0, 0, 0.18) 0%, transparent 70%);
  z-index: 0;
  pointer-events: none;
}

.auth-layout {
  position: relative;
  z-index: 1;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 2rem 1.25rem;
  gap: 2rem;
}

.auth-card {
  width: 100%;
  max-width: 26rem;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 1.5rem;
  box-shadow: 0 25px 50px rgba(15, 23, 42, 0.18);
  overflow: hidden;
}

.auth-card-accent {
  height: 4px;
  background: linear-gradient(90deg, var(--dominos-blue) 0%, var(--dominos-blue) 55%, var(--dominos-red) 55%, var(--dominos-red) 100%);
}

.auth-card-body {
  padding: 2rem 2rem 1.75rem;
}

.auth-brand {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  margin-bottom: 1.75rem;
}

.auth-logo-wrap {
  width: 100%;
  max-width: 16rem;
  margin: 0 auto 1.25rem;
  padding: 0;
  background: transparent;
  box-shadow: none;
  display: block;
  transform: none;
}

.auth-logo-wrap img,
.auth-logo-wrap svg {
  width: 100%;
  height: auto;
  display: block;
}

.auth-brand h1 {
  font-size: 1.375rem;
  font-weight: 900;
  color: #0f172a;
  letter-spacing: -0.02em;
  margin: 0 0 0.35rem;
}

.auth-brand p {
  font-size: 0.875rem;
  color: #64748b;
  margin: 0;
  line-height: 1.45;
}

.auth-field {
  position: relative;
  margin-bottom: 1rem;
}

.auth-field-icon {
  position: absolute;
  left: 1rem;
  top: 50%;
  transform: translateY(-50%);
  color: #94a3b8;
  font-size: 0.9rem;
  pointer-events: none;
  z-index: 2;
}

.auth-input {
  width: 100%;
  padding: 0.8rem 1rem 0.8rem 2.75rem;
  font-size: 0.9rem;
  color: #1e293b;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 0.75rem;
  transition: border-color 0.15s, box-shadow 0.15s, background 0.15s;
}

.auth-input:focus {
  outline: none;
  background: #fff;
  border-color: var(--dominos-blue);
  box-shadow: 0 0 0 3px rgba(0, 144, 226, 0.15);
}

.auth-field-password .auth-input {
  padding-right: 2.75rem;
}

.auth-toggle-password {
  position: absolute;
  right: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  border: none;
  background: transparent;
  color: #94a3b8;
  padding: 0.35rem;
  line-height: 1;
  cursor: pointer;
  border-radius: 0.375rem;
  transition: color 0.15s, background 0.15s;
}

.auth-toggle-password:hover {
  color: var(--dominos-blue);
  background: rgba(0, 144, 226, 0.08);
}

.auth-btn-primary {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  width: 100%;
  padding: 0.85rem 1.25rem;
  font-size: 0.9rem;
  font-weight: 700;
  color: #fff;
  background: var(--dominos-blue);
  border: none;
  border-radius: 0.75rem;
  box-shadow: 0 4px 14px rgba(0, 144, 226, 0.35);
  transition: background 0.15s, transform 0.1s, box-shadow 0.15s;
  cursor: pointer;
  text-decoration: none !important;
}

.auth-btn-primary:hover {
  background: var(--dominos-blue-dark);
  color: #fff;
  box-shadow: 0 6px 18px rgba(0, 144, 226, 0.4);
}

.auth-btn-primary:active {
  transform: scale(0.99);
}

.auth-divider {
  border: none;
  border-top: 1px solid #f1f5f9;
  margin: 1.25rem 0;
}

.auth-links {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}

.auth-link {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--dominos-blue);
  text-decoration: none !important;
  transition: color 0.15s;
}

.auth-link:hover {
  color: var(--dominos-red);
}

.auth-link-muted {
  color: #64748b;
}

.auth-link-muted:hover {
  color: var(--dominos-blue);
}

.auth-footer {
  text-align: center;
}

.auth-footer p {
  color: rgba(255, 255, 255, 0.75);
  font-size: 0.75rem;
  margin: 0;
  font-weight: 500;
}

.auth-badge {
  display: inline-block;
  font-size: 0.625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #64748b;
  background: #f1f5f9;
  padding: 0.2rem 0.5rem;
  border-radius: 0.375rem;
  margin-bottom: 0.5rem;
}

/* Modal — validar código (esqueci senha) */
.auth-codigo-modal.swal2-popup {
  position: relative;
  width: 100%;
  max-width: 22rem;
  padding: 0;
  border-radius: 1.25rem;
  border: 1px solid #e2e8f0;
  box-shadow: 0 25px 50px rgba(15, 23, 42, 0.22);
  overflow: hidden;
}

.auth-codigo-modal.swal2-popup::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--dominos-blue) 0%, var(--dominos-blue) 55%, var(--dominos-red) 55%, var(--dominos-red) 100%);
  z-index: 1;
}

.auth-codigo-modal .auth-codigo-modal__title.swal2-title {
  padding: 1.5rem 1.5rem 0;
  margin: 0;
  font-size: 1.125rem;
  font-weight: 800;
  color: #0f172a;
  letter-spacing: -0.02em;
}

.auth-codigo-modal .auth-codigo-modal__content.swal2-html-container {
  margin: 0;
  padding: 0.75rem 1.5rem 0;
  font-size: inherit;
  color: inherit;
  overflow: visible;
}

.auth-codigo-modal__hero {
  display: flex;
  justify-content: center;
  margin-bottom: 0.75rem;
}

.auth-codigo-modal__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.25rem;
  height: 3.25rem;
  border-radius: 50%;
  background: rgba(0, 144, 226, 0.1);
  color: var(--dominos-blue);
  font-size: 1.2rem;
}

.auth-codigo-modal__desc {
  margin: 0;
  font-size: 0.875rem;
  line-height: 1.45;
  color: #64748b;
  text-align: center;
}

.auth-codigo-modal__email {
  margin: 0.5rem 0 0;
  font-size: 0.8125rem;
  color: #94a3b8;
  text-align: center;
}

.auth-codigo-modal__email strong {
  display: block;
  margin-top: 0.15rem;
  font-weight: 600;
  color: #334155;
  word-break: break-all;
}

.auth-codigo-modal .swal2-input.auth-codigo-modal__input {
  width: calc(100% - 3rem) !important;
  height: auto;
  margin: 1rem 1.5rem 0 !important;
  padding: 0.85rem 1rem !important;
  font-size: 1.5rem !important;
  font-weight: 700;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  letter-spacing: 0.4em;
  text-align: center;
  color: #0f172a;
  background: #f8fafc;
  border: 1px solid #e2e8f0 !important;
  border-radius: 0.75rem !important;
  box-shadow: none !important;
}

.auth-codigo-modal .swal2-input.auth-codigo-modal__input::placeholder {
  color: #cbd5e1;
  letter-spacing: 0.25em;
  font-weight: 500;
}

.auth-codigo-modal .swal2-input.auth-codigo-modal__input:focus {
  outline: none;
  background: #fff;
  border-color: var(--dominos-blue) !important;
  box-shadow: 0 0 0 3px rgba(0, 144, 226, 0.15) !important;
}

.auth-codigo-modal .auth-codigo-modal__validation.swal2-validation-message {
  margin: 0.75rem 1.5rem 0;
  padding: 0.5rem 0.75rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--dominos-red);
  background: #fef2f2;
  border: 1px solid #fecaca;
  border-radius: 0.5rem;
  width: calc(100% - 3rem);
}

.auth-codigo-modal .auth-codigo-modal__actions.swal2-actions {
  flex-direction: column-reverse;
  align-items: stretch;
  gap: 0.5rem;
  width: 100%;
  margin: 0;
  padding: 1rem 1.5rem 1.5rem;
}

.auth-codigo-modal__btn {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 100% !important;
  margin: 0 !important;
  padding: 0.75rem 1rem !important;
  font-size: 0.875rem !important;
  font-weight: 700 !important;
  border-radius: 0.75rem !important;
  border: none !important;
  box-shadow: none !important;
  transition: background 0.15s, color 0.15s, box-shadow 0.15s, transform 0.1s;
}

.auth-codigo-modal__btn--primary {
  color: #fff !important;
  background: var(--dominos-blue) !important;
  box-shadow: 0 4px 14px rgba(0, 144, 226, 0.35) !important;
}

.auth-codigo-modal__btn--primary:hover {
  background: var(--dominos-blue-dark) !important;
}

.auth-codigo-modal__btn--primary:active {
  transform: scale(0.99);
}

.auth-codigo-modal__btn--ghost {
  color: #64748b !important;
  background: #fff !important;
  border: 1px solid #e2e8f0 !important;
}

.auth-codigo-modal__btn--ghost:hover {
  color: var(--dominos-blue) !important;
  border-color: rgba(0, 144, 226, 0.35) !important;
  background: rgba(0, 144, 226, 0.06) !important;
}

body.bg-onboard .swal2-container {
  backdrop-filter: blur(4px);
}

body.bg-onboard .swal2-container.swal2-backdrop-show {
  background: rgba(15, 23, 42, 0.45);
}

/* Legado — compatibilidade */
.login-card {
  background: #fff;
  border-radius: 1.5rem;
  box-shadow: 0 25px 50px rgba(15, 23, 42, 0.18);
  border: 1px solid #e2e8f0;
  overflow: hidden;
}

#olho-senha {
  display: none;
}

/* ========== Sidebar ========== */
#accordionSidebar.bg-gradient-primary,
#accordionSidebar.sidebar.bg-gradient-primary,
ul#accordionSidebar.bg-gradient-primary,
.navbar-nav#accordionSidebar.bg-gradient-primary,
.sidebar.bg-gradient-primary#accordionSidebar {
  background-color: var(--dominos-blue) !important;
  background-image: linear-gradient(180deg, var(--dominos-blue) 0%, var(--dominos-blue-darker) 100%) !important;
  background-size: cover !important;
  position: relative;
  font-family: var(--font-family-app) !important;
}

#accordionSidebar.bg-gradient-primary::after,
#accordionSidebar.sidebar.bg-gradient-primary::after,
ul#accordionSidebar.bg-gradient-primary::after,
.navbar-nav#accordionSidebar.bg-gradient-primary::after,
.sidebar.bg-gradient-primary#accordionSidebar::after {
  content: '';
  position: absolute;
  top: 64px;
  right: 0;
  bottom: 0;
  width: 3px;
  background-color: var(--dominos-red);
  z-index: 1;
}

#accordionSidebar.sidebar-dark .nav-item .nav-link,
#accordionSidebar.sidebar-dark .nav-item .nav-link i,
#accordionSidebar.sidebar-dark .nav-item .nav-link span {
  color: var(--dominos-white) !important;
}

#accordionSidebar.sidebar-dark .nav-item .nav-link:hover {
  background-color: rgba(255, 255, 255, 0.08) !important;
}

#accordionSidebar.sidebar-dark .nav-item.active .nav-link {
  color: var(--dominos-white) !important;
  font-weight: 700 !important;
  background-color: var(--dominos-blue-nav-active) !important;
  border-left: 4px solid rgba(255, 0, 0, 0.85) !important;
}

#accordionSidebar.sidebar-dark .nav-item.active .nav-link i,
#accordionSidebar.sidebar-dark .nav-item.active .nav-link span {
  color: var(--dominos-white) !important;
}

#accordionSidebar.sidebar-dark .sidebar-brand,
#accordionSidebar .sidebar-brand-toggle {
  color: var(--dominos-white) !important;
}

#accordionSidebar .sidebar-brand-toggle {
  width: 100%;
  border: none;
  background: transparent;
  cursor: pointer;
  padding: 1rem;
  text-transform: none;
  letter-spacing: normal;
}

#accordionSidebar .sidebar-brand-toggle:hover,
#accordionSidebar .sidebar-brand-toggle:focus {
  background-color: rgba(255, 255, 255, 0.08) !important;
  outline: none;
}

#accordionSidebar .sidebar-brand-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
}

#accordionSidebar .sidebar-brand-logo {
  display: block;
  object-fit: contain;
}

/* Recolhida: só o símbolo */
#accordionSidebar .sidebar-brand-logo--compact {
  width: 3rem;
  height: 3rem;
  max-width: 3rem;
}

#accordionSidebar .sidebar-brand-logo--full {
  display: none;
  width: auto;
  max-width: 11.5rem;
  height: auto;
  max-height: 2.35rem;
}

#accordionSidebar:not(.toggled) .sidebar-brand-logo--compact {
  display: none;
}

#accordionSidebar:not(.toggled) .sidebar-brand-logo--full {
  display: block;
}

#accordionSidebar.toggled .sidebar-brand-logo--compact {
  display: block;
}

#accordionSidebar.toggled .sidebar-brand-logo--full {
  display: none;
}

#accordionSidebar.sidebar-dark hr.sidebar-divider {
  border-top-color: rgba(255, 255, 255, 0.2) !important;
}

#accordionSidebar.sidebar-dark #sidebarToggle {
  background-color: rgba(255, 255, 255, 0.12) !important;
}

#accordionSidebar.sidebar-dark #sidebarToggle::after {
  color: var(--dominos-white) !important;
}

/* ========== Topbar ========== */
.topbar {
  background-color: var(--dominos-blue) !important;
  background-image: none !important;
  border-bottom: 3px solid var(--dominos-red) !important;
  font-family: var(--font-family-app) !important;
}

.topbar .nav-link,
.topbar .text-gray-600,
.topbar .nav-item.dropdown.no-arrow .nav-link span {
  color: var(--dominos-white) !important;
}

.topbar .nav-link i,
.topbar #sidebarToggleTop {
  color: var(--dominos-white) !important;
}

.topbar #sidebarToggleTop:hover,
.topbar #sidebarToggleTop:focus {
  background-color: rgba(255, 255, 255, 0.12) !important;
  color: var(--dominos-white) !important;
}

.topbar .nav-link:hover,
.topbar .nav-link:focus {
  color: rgba(255, 255, 255, 0.9) !important;
}

.topbar .nav-item.dropdown.no-arrow .nav-link,
#userDropdown {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

.topbar .nav-item.dropdown.no-arrow .nav-link .img-profile {
  height: 2rem;
  width: 2rem;
  object-fit: cover;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  filter: brightness(0) invert(1);
}

.topbar .dropdown-menu {
  border-top: 2px solid var(--dominos-red);
  font-family: var(--font-family-app);
}

.topbar .dropdown-item {
  color: var(--dominos-blue-darker);
}

.topbar .dropdown-item:hover,
.topbar .dropdown-item:focus {
  background-color: var(--dominos-blue);
  color: var(--dominos-white);
}

.topbar .topbar-divider {
  border-right-color: rgba(255, 255, 255, 0.25) !important;
}

/* ========== Botões e links ========== */
.btn-primary {
  background-color: var(--dominos-blue) !important;
  border-color: var(--dominos-blue) !important;
  color: var(--dominos-white) !important;
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary:not(:disabled):not(.disabled):active {
  background-color: var(--dominos-blue-dark) !important;
  border-color: var(--dominos-blue-dark) !important;
  color: var(--dominos-white) !important;
}

.btn-primary:focus {
  box-shadow: 0 0 0 0.2rem rgba(0, 144, 226, 0.45) !important;
}

.btn-danger,
.btn-dominos-red {
  background-color: var(--dominos-red) !important;
  border-color: var(--dominos-red) !important;
  color: var(--dominos-white) !important;
}

.btn-danger:hover {
  background-color: var(--dominos-red-dark) !important;
  border-color: var(--dominos-red-dark) !important;
}

.btn-outline-primary {
  color: var(--dominos-blue);
  border-color: var(--dominos-blue);
}

.btn-outline-primary:hover {
  background-color: var(--dominos-blue);
  border-color: var(--dominos-blue);
  color: var(--dominos-white);
}

.text-primary {
  color: var(--dominos-blue) !important;
}

.border-left-primary {
  border-left: 0.25rem solid var(--dominos-blue) !important;
}

.border-left-danger,
.border-left-dominos {
  border-left: 0.25rem solid var(--dominos-red) !important;
}

.bg-primary {
  background-color: var(--dominos-blue) !important;
}

.badge-primary {
  background-color: var(--dominos-blue) !important;
}

.badge-danger,
.badge-dominos-online {
  background-color: var(--dominos-red) !important;
  color: var(--dominos-white) !important;
}

a {
  color: var(--dominos-blue);
}

a:hover {
  color: var(--dominos-blue-dark);
}

.form-control:focus,
.custom-select:focus {
  border-color: var(--dominos-blue);
  box-shadow: 0 0 0 0.2rem rgba(0, 144, 226, 0.2);
}

.custom-control-input:checked ~ .custom-control-label::before,
.custom-switch .custom-control-input:checked ~ .custom-control-label::before {
  background-color: var(--dominos-blue);
  border-color: var(--dominos-blue);
}

.page-item.active .page-link {
  background-color: var(--dominos-blue);
  border-color: var(--dominos-blue);
}

.page-link {
  color: var(--dominos-blue);
}

.page-link:hover {
  color: var(--dominos-blue-dark);
}

.nav-tabs .nav-link.active {
  color: var(--dominos-blue) !important;
  border-color: var(--dominos-blue) var(--dominos-blue) #fff;
}

.dropdown-item.active,
.dropdown-item:active {
  background-color: var(--dominos-blue) !important;
}

.progress-bar {
  background-color: var(--dominos-blue);
}

.list-group-item.active {
  background-color: var(--dominos-blue);
  border-color: var(--dominos-blue);
}

.scroll-to-top {
  background: var(--dominos-blue);
}

.scroll-to-top:hover {
  background: var(--dominos-red);
}

.icon-circle.bg-primary {
  background-color: var(--dominos-blue) !important;
}

.icon-circle.bg-primary i {
  color: var(--dominos-white) !important;
}

/* Footer interno */
.sticky-footer.bg-gradient-light {
  background: #f8f9fc;
  border-top: 1px solid rgba(0, 144, 226, 0.15);
}

.sticky-footer .copyright {
  color: #6c757d;
  font-size: 0.85rem;
}

/* ========== Módulo Lojas iFood ========== */
.ifood-module {
  --ifood-slate-50: #f8fafc;
  --ifood-slate-100: #f1f5f9;
  --ifood-slate-200: #e2e8f0;
  --ifood-slate-400: #94a3b8;
  --ifood-slate-500: #64748b;
  --ifood-slate-700: #334155;
  --ifood-slate-800: #1e293b;
  --ifood-slate-900: #0f172a;
  max-width: 64rem;
  margin: 0 auto;
  padding-bottom: 2rem;
}

#ifood-list-page.ifood-module {
  max-width: none;
  width: 100%;
  padding: 1.25rem 1.5rem 2rem;
}

#ifood-list-page .ifood-table tbody td .text-truncate {
  max-width: none;
}

#ifood-list-page .ifood-table-card .table-responsive {
  min-height: 24rem;
}

#ifood-list-page .ifood-table thead th,
#ifood-list-page .ifood-table tbody td {
  padding-top: 1rem;
  padding-bottom: 1rem;
}

#ifood-list-page .ifood-table .ifood-table-placeholder {
  height: 20rem;
  vertical-align: middle;
}

#store-page.ifood-module {
  max-width: none;
  width: 100%;
  padding: 1.25rem 1.5rem 2rem;
}

#store-page #store-loading.ifood-card {
  min-height: 20rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

#store-page #interruptions-list {
  min-height: 12rem;
}

.ifood-module .ifood-page-hero {
  background: #fff;
  border: 1px solid var(--ifood-slate-200);
  border-radius: 1.5rem;
  padding: 1.5rem 2rem;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.05);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 1.25rem;
  margin-bottom: 1.5rem;
}

.ifood-module .ifood-page-hero h1 {
  font-size: 1.5rem;
  font-weight: 900;
  color: var(--ifood-slate-900);
  margin: 0;
  letter-spacing: -0.02em;
}

.ifood-module .ifood-page-hero .ifood-badge-muted {
  font-size: 0.75rem;
  font-weight: 600;
  background: var(--ifood-slate-100);
  color: var(--ifood-slate-500);
  padding: 0.15rem 0.5rem;
  border-radius: 0.375rem;
  vertical-align: middle;
  margin-left: 0.5rem;
}

.ifood-module .ifood-page-hero p {
  color: var(--ifood-slate-500);
  font-size: 0.875rem;
  margin: 0.25rem 0 0;
}

.ifood-module .ifood-card {
  background: #fff;
  border: 1px solid var(--ifood-slate-200);
  border-radius: 1rem;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.05);
}

.ifood-module .ifood-search-bar {
  padding: 1.25rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-bottom: 1.5rem;
}

.ifood-module .ifood-search-wrap {
  position: relative;
  flex: 1;
  min-width: 200px;
}

.ifood-module .ifood-search-wrap .fas {
  position: absolute;
  left: 1rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--ifood-slate-400);
}

.ifood-module .ifood-search-input {
  width: 100%;
  padding: 0.75rem 1rem 0.75rem 2.75rem;
  background: var(--ifood-slate-50);
  border: 1px solid var(--ifood-slate-200);
  border-radius: 0.75rem;
  font-size: 0.875rem;
  transition: border-color 0.15s, box-shadow 0.15s, background 0.15s;
}

.ifood-module .ifood-search-input:focus {
  outline: none;
  border-color: var(--dominos-blue);
  box-shadow: 0 0 0 3px rgba(0, 144, 226, 0.15);
  background: #fff;
}

.ifood-module .ifood-btn-ghost {
  padding: 0.75rem 1.25rem;
  background: var(--ifood-slate-100);
  border: none;
  border-radius: 0.75rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--ifood-slate-700);
  transition: background 0.15s;
}

.ifood-module .ifood-btn-ghost:hover {
  background: var(--ifood-slate-200);
}

.ifood-module .ifood-btn-icon {
  padding: 0.625rem;
  background: var(--ifood-slate-50);
  border: 1px solid var(--ifood-slate-200);
  border-radius: 0.75rem;
  color: var(--ifood-slate-500);
  line-height: 1;
  transition: background 0.15s, color 0.15s;
}

.ifood-module .ifood-btn-icon:hover {
  background: var(--ifood-slate-100);
  color: var(--ifood-slate-800);
}

.ifood-module .ifood-table-card {
  overflow: hidden;
}

.ifood-module .ifood-table-head {
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--ifood-slate-100);
  background: rgba(248, 250, 252, 0.8);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.ifood-module .ifood-table-head h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--ifood-slate-900);
  margin: 0;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.ifood-module .ifood-dot {
  width: 0.625rem;
  height: 0.625rem;
  border-radius: 50%;
  background: var(--dominos-blue);
  display: inline-block;
}

.ifood-module .ifood-count-pill {
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--ifood-slate-500);
  background: var(--ifood-slate-100);
  padding: 0.25rem 0.75rem;
  border-radius: 9999px;
}

.ifood-module .ifood-table {
  width: 100%;
  border-collapse: collapse;
  margin: 0;
}

.ifood-module .ifood-table thead th {
  padding: 1rem 1.5rem;
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--ifood-slate-400);
  background: rgba(248, 250, 252, 0.5);
  border-bottom: 1px solid var(--ifood-slate-100);
}

.ifood-module .ifood-table tbody td {
  padding: 1rem 1.5rem;
  border-bottom: 1px solid var(--ifood-slate-100);
  vertical-align: middle;
}

.ifood-module .ifood-table tbody tr {
  cursor: pointer;
  transition: background 0.15s;
}

.ifood-module .ifood-table tbody tr:hover {
  background: rgba(248, 250, 252, 0.9);
}

.ifood-module .ifood-table tbody tr:hover .ifood-store-name {
  color: var(--dominos-blue);
}

.ifood-module .ifood-store-name {
  font-weight: 700;
  color: var(--ifood-slate-900);
  transition: color 0.15s;
}

.ifood-module .ifood-merchant-chip {
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 0.75rem;
  background: var(--ifood-slate-100);
  color: var(--ifood-slate-700);
  padding: 0.25rem 0.625rem;
  border-radius: 0.375rem;
  border: 1px solid var(--ifood-slate-200);
}

.ifood-module .ifood-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.25rem 0.625rem;
  border-radius: 9999px;
  font-size: 0.75rem;
  font-weight: 700;
}

.ifood-module .ifood-status-badge .ifood-status-dot {
  width: 0.375rem;
  height: 0.375rem;
  border-radius: 50%;
}

.ifood-module .ifood-status-available {
  background: rgba(0, 144, 226, 0.1);
  color: var(--dominos-blue);
}

.ifood-module .ifood-status-available .ifood-status-dot {
  background: var(--dominos-blue);
}

.ifood-module .ifood-status-partial {
  background: #fffbeb;
  color: #d97706;
  border: 1px solid #fde68a;
}

.ifood-module .ifood-status-partial .ifood-status-dot {
  background: #f59e0b;
}

.ifood-module .ifood-status-offline {
  background: rgba(255, 0, 0, 0.1);
  color: var(--dominos-red);
}

.ifood-module .ifood-status-offline .ifood-status-dot {
  background: var(--dominos-red);
}

.ifood-module .ifood-status-loading {
  background: var(--ifood-slate-100);
  color: var(--ifood-slate-400);
}

.ifood-module .ifood-action-btn {
  padding: 0.5rem;
  background: var(--ifood-slate-100);
  border: none;
  border-radius: 0.5rem;
  color: var(--ifood-slate-500);
  transition: background 0.15s, color 0.15s;
}

.ifood-module .ifood-table tbody tr:hover .ifood-action-btn {
  background: var(--dominos-blue);
  color: #fff;
}

.ifood-module .ifood-table-footer {
  padding: 1rem 1.5rem;
  border-top: 1px solid var(--ifood-slate-100);
  background: rgba(248, 250, 252, 0.5);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  font-size: 0.75rem;
  color: var(--ifood-slate-400);
}

.ifood-module .ifood-empty {
  text-align: center;
  padding: 3rem 1.5rem;
}

.ifood-module .ifood-empty i {
  font-size: 3rem;
  color: var(--ifood-slate-200);
  margin-bottom: 0.75rem;
}

.ifood-module .ifood-back-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
  padding: 1rem 1.25rem;
  margin-bottom: 1.5rem;
}

.ifood-module .ifood-btn-back {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--ifood-slate-600);
  background: var(--ifood-slate-50);
  border: 1px solid var(--ifood-slate-200);
  border-radius: 0.75rem;
  padding: 0.625rem 1rem;
  text-decoration: none !important;
  transition: color 0.15s, background 0.15s;
}

.ifood-module .ifood-btn-back:hover {
  color: var(--dominos-blue);
  background: var(--ifood-slate-100);
}

.ifood-module .ifood-store-banner {
  background: var(--ifood-slate-900);
  color: #fff;
  border-radius: 1.5rem;
  padding: 1.5rem 2rem;
  border: 1px solid #1e293b;
  position: relative;
  overflow: hidden;
  margin-bottom: 1.5rem;
}

.ifood-module .ifood-store-banner::before {
  content: '\f54e';
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
  position: absolute;
  right: -1rem;
  top: -2rem;
  font-size: 15rem;
  opacity: 0.04;
  pointer-events: none;
}

.ifood-module .ifood-banner-main {
  position: relative;
  z-index: 1;
}

.ifood-module .ifood-banner-title-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem 1.25rem;
  margin-bottom: 0.875rem;
}

.ifood-module .ifood-store-banner h2 {
  font-size: 1.75rem;
  font-weight: 900;
  margin: 0;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.ifood-module .ifood-banner-meta {
  text-align: left;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
}

.ifood-module .ifood-ticket-box--banner {
  margin: 1rem 0 0;
  text-align: left;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.25rem;
  min-width: 11rem;
  width: auto;
  max-width: 100%;
}

.ifood-module .ifood-ticket-box--banner .label {
  margin: 0;
}

.ifood-module .ifood-ticket-box--banner .value {
  margin: 0;
  white-space: nowrap;
}

.ifood-module .ifood-banner-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.25rem 0.75rem;
  border-radius: 9999px;
  font-size: 0.625rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ifood-module .ifood-banner-badge-online {
  background: var(--dominos-blue);
  color: #fff;
}

.ifood-module .ifood-banner-badge-partial {
  background: #f59e0b;
  color: var(--ifood-slate-900);
}

.ifood-module .ifood-banner-badge-offline {
  background: var(--dominos-red);
  color: #fff;
}

.ifood-module .ifood-banner-badge .pulse-dot {
  width: 0.375rem;
  height: 0.375rem;
  border-radius: 50%;
  background: currentColor;
  animation: ifood-pulse 1.5s ease-in-out infinite;
}

.ifood-module .ifood-banner-badge-online .pulse-dot,
.ifood-module .ifood-banner-badge-partial .pulse-dot {
  background: #fff;
}

@keyframes ifood-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.4; }
}

.ifood-module .ifood-merchant-id-chip {
  font-family: ui-monospace, monospace;
  font-size: 0.75rem;
  background: rgba(15, 23, 42, 0.6);
  border: 1px solid #334155;
  padding: 0.375rem 0.75rem;
  border-radius: 0.375rem;
  color: #94a3b8;
  display: inline-block;
  margin-top: 0;
}

.ifood-module .ifood-merchant-id-chip strong {
  color: #34d399;
}

.ifood-module .ifood-ticket-box {
  background: rgba(15, 23, 42, 0.7);
  border: 1px solid #334155;
  border-radius: 0.75rem;
  padding: 1rem;
  text-align: center;
  min-width: 130px;
}

.ifood-module .ifood-ticket-box .label {
  font-size: 0.625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ifood-slate-400);
}

.ifood-module .ifood-ticket-box .value {
  font-size: 1.25rem;
  font-weight: 900;
  color: var(--dominos-blue);
  margin-top: 0.125rem;
}

.ifood-module .ifood-section-title {
  font-weight: 800;
  color: var(--ifood-slate-900);
  border-bottom: 1px solid var(--ifood-slate-100);
  padding-bottom: 0.75rem;
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.ifood-module .ifood-section-title i {
  color: var(--dominos-blue);
}

.ifood-module .ifood-section-title.danger i {
  color: var(--dominos-red);
}

.ifood-module .ifood-info-label {
  font-size: 0.625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ifood-slate-400);
  display: block;
  margin-bottom: 0.125rem;
}

.ifood-module .ifood-info-value {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--ifood-slate-800);
}

.ifood-module .ifood-store-card-head {
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--ifood-slate-100);
}

.ifood-module .ifood-store-info-layout {
  margin-left: -0.5rem;
  margin-right: -0.5rem;
}

.ifood-module .ifood-store-info-col {
  padding-left: 0.5rem;
  padding-right: 0.5rem;
}

@media (max-width: 767.98px) {
  .ifood-module .ifood-store-info-col:first-child {
    margin-bottom: 0.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--ifood-slate-100);
  }
}

@media (min-width: 768px) {
  .ifood-module .ifood-store-info-col:first-child {
    border-right: 1px solid var(--ifood-slate-100);
    padding-right: 1.25rem;
  }

  .ifood-module .ifood-store-info-col:last-child {
    padding-left: 1.25rem;
  }
}

.ifood-module .ifood-store-info-item {
  margin-bottom: 1rem;
}

.ifood-module .ifood-store-info-item:last-child {
  margin-bottom: 0;
}

.ifood-module .ifood-store-info-item .ifood-info-value {
  word-break: break-word;
}

.ifood-module .ifood-store-name-title {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.625rem 1rem;
  margin: 0;
  padding: 0;
  border: none;
  font-size: 1.375rem;
  font-weight: 800;
  color: var(--ifood-slate-900);
  letter-spacing: -0.02em;
  line-height: 1.3;
  width: 100%;
  max-width: 100%;
}

.ifood-module .ifood-store-name-title > .fas {
  color: var(--dominos-blue);
  font-size: 1.125rem;
  flex-shrink: 0;
}

.ifood-module .ifood-store-name-title #store-section-title {
  word-break: break-word;
}

.ifood-module .ifood-store-name-title #store-status-badge {
  flex-shrink: 0;
  margin: 0;
  vertical-align: middle;
}

.ifood-module .ifood-info-value-highlight {
  font-size: 1.125rem;
  font-weight: 800;
  color: var(--dominos-blue);
}

.ifood-module .ifood-toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem;
  background: var(--ifood-slate-50);
  border: 1px solid var(--ifood-slate-100);
  border-radius: 0.75rem;
  margin-bottom: 0.75rem;
}

.ifood-module .ifood-toggle {
  width: 2.75rem;
  height: 1.5rem;
  border-radius: 9999px;
  padding: 0.125rem;
  border: none;
  background: #cbd5e1;
  position: relative;
  transition: background 0.2s;
  flex-shrink: 0;
}

.ifood-module .ifood-toggle.on {
  background: var(--dominos-blue);
}

.ifood-module .ifood-toggle::after {
  content: '';
  display: block;
  width: 1.125rem;
  height: 1.125rem;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.15);
  transition: transform 0.2s;
}

.ifood-module .ifood-toggle.on::after {
  transform: translateX(1.25rem);
}

.ifood-module .ifood-toggle[aria-disabled='true'] {
  opacity: 0.85;
  cursor: default;
}

.ifood-module .ifood-section-head {
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--ifood-slate-100);
  background: rgba(248, 250, 252, 0.8);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
}

.ifood-module .ifood-section-head p {
  font-size: 0.75rem;
  color: var(--ifood-slate-500);
  margin: 0.25rem 0 0;
}

.ifood-module .ifood-btn-red {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--dominos-red);
  color: #fff;
  font-size: 0.75rem;
  font-weight: 700;
  border: none;
  border-radius: 0.75rem;
  padding: 0.625rem 1rem;
  box-shadow: 0 4px 12px rgba(255, 0, 0, 0.15);
  transition: background 0.15s;
}

.ifood-module .ifood-btn-red:hover {
  background: var(--dominos-red-dark);
  color: #fff;
}

.ifood-module .ifood-btn-outline {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  background: var(--ifood-slate-100);
  color: var(--ifood-slate-700);
  font-size: 0.75rem;
  font-weight: 700;
  border: 1px solid var(--ifood-slate-200);
  border-radius: 0.75rem;
  padding: 0.625rem 1rem;
  transition: background 0.15s, color 0.15s;
}

.ifood-module .ifood-btn-outline:hover {
  background: rgba(0, 144, 226, 0.08);
  color: var(--dominos-blue);
}

.ifood-module .ifood-pause-body {
  gap: 1rem;
}

.ifood-module .ifood-pause-card {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  padding: 1.25rem;
  border-radius: 0.75rem;
  border: 1px solid;
  margin-bottom: 1rem;
}

.ifood-module .ifood-pause-card.active {
  background: rgba(255, 0, 0, 0.04);
  border-color: #fecaca;
}

.ifood-module .ifood-pause-card.scheduled {
  background: rgba(245, 158, 11, 0.08);
  border-color: #fde68a;
}

.ifood-module .ifood-pause-card.finished {
  background: #f8fafc;
  border-color: #e2e8f0;
  opacity: 0.92;
}

.ifood-module .ifood-pause-empty {
  background: #f8fafc !important;
  border-color: #e2e8f0 !important;
}

.ifood-module .ifood-pause-icon {
  width: 3rem;
  height: 3rem;
  border-radius: 0.75rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.ifood-module .ifood-pause-card.active .ifood-pause-icon {
  background: rgba(255, 0, 0, 0.1);
  color: var(--dominos-red);
}

.ifood-module .ifood-pause-card.scheduled .ifood-pause-icon {
  background: #fef3c7;
  color: #b45309;
}

.ifood-module .ifood-pause-card.finished .ifood-pause-icon {
  background: #e2e8f0;
  color: #64748b;
}

.ifood-module .ifood-pause-hint strong {
  color: #334155;
}

.ifood-module .ifood-pause-card.finished .ifood-pause-hint {
  color: #94a3b8;
}

.ifood-module .ifood-pause-tag {
  font-size: 0.5625rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 0.125rem 0.5rem;
  border-radius: 9999px;
}

.ifood-module .ifood-pause-tag.active {
  background: var(--dominos-red);
  color: #fff;
}

.ifood-module .ifood-pause-tag.scheduled {
  background: #f59e0b;
  color: var(--ifood-slate-900);
}

.ifood-module .ifood-pause-tag.finished {
  background: #e2e8f0;
  color: #64748b;
}

.ifood-module .ifood-btn-delete-pause {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.625rem;
  background: #fff;
  border: 1px solid var(--ifood-slate-200);
  border-radius: 0.75rem;
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--ifood-slate-500);
  transition: color 0.15s, border-color 0.15s, background 0.15s;
}

.ifood-module .ifood-btn-delete-pause:hover {
  color: var(--dominos-red);
  border-color: #fecaca;
  background: #fff5f5;
}

.ifood-module .ifood-hours-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 1rem;
  justify-items: stretch;
  width: 100%;
}

@media (max-width: 991.98px) {
  .ifood-module .ifood-hours-grid {
    grid-template-columns: repeat(auto-fill, minmax(7.5rem, 1fr));
    justify-items: center;
  }
}

.ifood-module .ifood-hour-day {
  background: var(--ifood-slate-50);
  border: 1px solid var(--ifood-slate-200);
  border-radius: 0.75rem;
  padding: 1rem 0.75rem;
  width: 100%;
  max-width: 10rem;
  margin: 0 auto;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  transition: border-color 0.15s;
}

@media (min-width: 992px) {
  .ifood-module .ifood-hours-grid .ifood-hour-day {
    max-width: none;
    margin: 0;
  }
}

.ifood-module .ifood-hour-day:hover {
  border-color: var(--dominos-blue);
}

.ifood-module .ifood-hour-day .day {
  font-size: 0.625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ifood-slate-400);
}

.ifood-module .ifood-hour-day .day,
.ifood-module .ifood-hour-day .time,
.ifood-module .ifood-hour-day .tag {
  width: 100%;
  text-align: center;
}

.ifood-module .ifood-hour-day .time {
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--ifood-slate-700);
  margin: 0.5rem 0;
  line-height: 1.35;
}

.ifood-module .ifood-hour-day .tag {
  font-size: 0.5rem;
  font-weight: 700;
  background: #ecfdf5;
  color: #047857;
  padding: 0.125rem 0.5rem;
  border-radius: 9999px;
}

.ifood-module .ifood-hour-day.empty-day {
  opacity: 0.7;
}

.ifood-module .ifood-hour-day.empty-day .tag {
  background: var(--ifood-slate-100);
  color: var(--ifood-slate-400);
}

.ifood-module .ifood-loading-overlay {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.6);
  backdrop-filter: blur(4px);
  z-index: 1050;
  display: flex;
  align-items: center;
  justify-content: center;
}

.ifood-module .ifood-loading-box {
  background: #fff;
  padding: 2rem;
  border-radius: 1rem;
  text-align: center;
  max-width: 20rem;
  border: 1px solid var(--ifood-slate-100);
  box-shadow: 0 25px 50px rgba(0, 0, 0, 0.15);
}

.ifood-module .ifood-spinner-wrap {
  position: relative;
  width: 4rem;
  height: 4rem;
  margin: 0 auto 1rem;
}

.ifood-module .ifood-spinner-wrap .spinner-border {
  width: 4rem;
  height: 4rem;
  border-width: 4px;
  color: var(--dominos-blue) !important;
}

.ifood-module .ifood-spinner-wrap .fas {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: var(--dominos-blue);
}

.ifood-modal {
  --ifood-slate-50: #f8fafc;
  --ifood-slate-100: #f1f5f9;
  --ifood-slate-200: #e2e8f0;
  --ifood-slate-400: #94a3b8;
  --ifood-slate-500: #64748b;
  --ifood-slate-700: #334155;
  --ifood-slate-800: #1e293b;
  --ifood-slate-900: #0f172a;
}

.ifood-modal .ifood-search-wrap {
  position: relative;
}

.ifood-modal .ifood-search-wrap .fas {
  position: absolute;
  left: 1rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--ifood-slate-400);
  z-index: 1;
}

.ifood-modal .ifood-search-input {
  width: 100%;
  padding: 0.75rem 1rem 0.75rem 2.75rem;
  background: var(--ifood-slate-50);
  border: 1px solid var(--ifood-slate-200);
  border-radius: 0.75rem;
  font-size: 0.875rem;
}

.ifood-modal .ifood-search-input:focus {
  outline: none;
  border-color: var(--dominos-blue);
  box-shadow: 0 0 0 3px rgba(0, 144, 226, 0.15);
  background: #fff;
}

/* Bootstrap: backdrop abaixo da modal (evita tela escura sem clique) */
.modal-backdrop.show {
  z-index: 1040;
}

.modal.show {
  display: block;
  z-index: 1055;
}

.ifood-modal.show {
  display: block;
  z-index: 1055;
}

.usuarios-lojas-modal.show {
  display: block;
  z-index: 1055;
}

.ifood-module .ifood-btn-primary:disabled,
.ifood-module .ifood-btn-outline:disabled {
  opacity: 0.55;
  cursor: not-allowed;
  box-shadow: none;
}

.ifood-modal .modal-content {
  border: none;
  border-radius: 1.5rem;
  overflow: hidden;
  box-shadow: 0 25px 50px rgba(0, 0, 0, 0.2);
}

.ifood-modal .modal-header-dark {
  background: var(--ifood-slate-900);
  color: #fff;
  border: none;
  padding: 1.25rem 1.5rem;
}

.ifood-modal .modal-header-primary {
  background: var(--dominos-blue);
  color: #fff;
  border: none;
  padding: 1.25rem 1.5rem;
}

.ifood-modal .modal-header-dark .close,
.ifood-modal .modal-header-primary .close {
  color: rgba(255, 255, 255, 0.7);
  opacity: 1;
  text-shadow: none;
}

.ifood-modal .modal-header-dark .close:hover,
.ifood-modal .modal-header-primary .close:hover {
  color: #fff;
}

.ifood-modal .ifood-form-label {
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--ifood-slate-700);
}

.ifood-modal .ifood-form-control {
  padding: 0.75rem 1rem;
  background: var(--ifood-slate-50);
  border: 1px solid var(--ifood-slate-200);
  border-radius: 0.75rem;
  font-size: 0.875rem;
}

.ifood-modal .ifood-form-control:focus {
  background: #fff;
  border-color: var(--dominos-blue);
  box-shadow: 0 0 0 3px rgba(0, 144, 226, 0.15);
}

.ifood-modal .ifood-alert-warn {
  background: #fff1f2;
  border: 1px solid #fecaca;
  border-radius: 0.75rem;
  padding: 0.75rem;
  font-size: 0.75rem;
  color: #9f1239;
}

.ifood-modal .modal-footer-light {
  background: var(--ifood-slate-50);
  border-top: 1px solid var(--ifood-slate-100);
}

.ifood-modal .shift-row {
  background: var(--ifood-slate-50);
  border: 1px solid var(--ifood-slate-100);
  border-radius: 0.75rem;
}

/* Modal: horários de funcionamento */
.ifood-hours-modal .modal-dialog {
  max-width: 48rem;
  width: calc(100% - 2rem);
  margin: 1rem auto;
}

.ifood-hours-modal .modal-content {
  max-height: 85vh;
  display: flex;
  flex-direction: column;
}

.ifood-hours-modal .modal-header-hours {
  background: linear-gradient(90deg, var(--dominos-blue-darker) 0%, var(--dominos-blue) 100%);
  color: #fff;
  border: none;
  padding: 1.25rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
}

.ifood-hours-modal .modal-header-hours-inner {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.ifood-hours-modal .modal-header-hours-icon {
  padding: 0.625rem;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 0.75rem;
  line-height: 1;
}

.ifood-hours-modal .modal-header-hours-icon i {
  font-size: 1.25rem;
}

.ifood-hours-modal .modal-header-hours .modal-title {
  font-size: 1.125rem;
  font-weight: 900;
  letter-spacing: -0.02em;
  color: #fff;
}

.ifood-hours-modal .modal-header-hours-sub {
  font-size: 0.6875rem;
  color: rgba(255, 255, 255, 0.85);
  font-weight: 500;
  margin-top: 0.125rem;
}

.ifood-hours-modal .modal-header-hours .close {
  color: rgba(255, 255, 255, 0.8);
  opacity: 1;
  text-shadow: none;
  padding: 0.5rem;
  margin: -0.5rem -0.5rem -0.5rem 0;
}

.ifood-hours-modal .modal-header-hours .close:hover {
  color: #fff;
}

.ifood-hours-modal .hours-modal-body {
  flex: 1;
  overflow-y: auto;
  padding: 1.5rem;
}

.ifood-hours-modal .hours-info-banner {
  background: rgba(0, 144, 226, 0.1);
  border: 1px solid rgba(0, 144, 226, 0.2);
  border-radius: 1rem;
  padding: 1rem;
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  font-size: 0.75rem;
  line-height: 1.5;
  color: #334155;
  margin-bottom: 1.25rem;
}

.ifood-hours-modal .hours-info-banner i {
  color: var(--dominos-blue);
  font-size: 1.125rem;
  margin-top: 0.125rem;
  flex-shrink: 0;
}

.ifood-hours-modal .hours-info-title {
  display: block;
  font-weight: 700;
  color: #0f172a;
  margin-bottom: 0.125rem;
}

.ifood-hours-modal .hours-days-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.ifood-hours-modal .hours-day-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 1rem;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
  transition: border-color 0.15s;
}

.ifood-hours-modal .hours-day-row:hover {
  border-color: #cbd5e1;
}

.ifood-hours-modal .hours-day-name {
  min-width: 8.75rem;
}

.ifood-hours-modal .hours-day-name h4 {
  font-size: 0.9375rem;
  font-weight: 800;
  color: #1e293b;
  margin: 0;
}

.ifood-hours-modal .hours-day-tag {
  font-size: 0.625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--dominos-blue);
  display: block;
  margin-top: 0.125rem;
}

.ifood-hours-modal .hours-day-times {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.ifood-hours-modal .hours-time-chip {
  display: inline-flex;
  align-items: center;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 0.75rem;
  padding: 0.5rem 0.75rem;
  font-size: 0.75rem;
}

.ifood-hours-modal .hours-time-label {
  font-size: 0.625rem;
  font-weight: 700;
  text-transform: uppercase;
  color: #94a3b8;
  margin-right: 0.5rem;
}

.ifood-hours-modal .hours-time-chip input[type="time"] {
  border: none;
  background: transparent;
  font-weight: 700;
  color: #334155;
  outline: none;
  width: 5.5rem;
  padding: 0;
  font-size: 0.8125rem;
}

.ifood-hours-modal .hours-time-chip input[type="time"]:focus {
  color: var(--dominos-blue);
}

.ifood-hours-modal .hours-time-sep {
  font-size: 0.75rem;
  font-weight: 700;
  color: #94a3b8;
}

.ifood-hours-modal .btn-copy-hours {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 0.6875rem;
  font-weight: 800;
  color: #64748b;
  background: #f1f5f9;
  border: 1px solid #e2e8f0;
  border-radius: 0.75rem;
  padding: 0.625rem 0.875rem;
  cursor: pointer;
  transition: color 0.15s, background 0.15s, border-color 0.15s;
  flex-shrink: 0;
}

.ifood-hours-modal .btn-copy-hours:hover {
  color: var(--dominos-blue);
  background: rgba(0, 144, 226, 0.08);
  border-color: rgba(0, 144, 226, 0.25);
}

.ifood-hours-modal .hours-modal-footer {
  background: #f8fafc;
  border-top: 1px solid #f1f5f9;
  padding: 1.25rem 1.5rem;
  flex-shrink: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.ifood-hours-modal .hours-footer-warning {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.75rem;
  font-weight: 600;
  color: #64748b;
}

.ifood-hours-modal .hours-footer-warning i {
  color: var(--dominos-red);
  font-size: 1.125rem;
}

.ifood-hours-modal .hours-footer-actions {
  display: flex;
  gap: 0.75rem;
  width: 100%;
}

@media (min-width: 576px) {
  .ifood-hours-modal .hours-footer-actions {
    width: auto;
  }
}

.ifood-hours-modal .hours-btn-cancel {
  flex: 1;
  padding: 0.75rem 1.5rem;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.75rem;
  font-size: 0.75rem;
  font-weight: 800;
  color: #334155;
  cursor: pointer;
  transition: background 0.15s;
}

.ifood-hours-modal .hours-btn-cancel:hover {
  background: #f1f5f9;
}

.ifood-hours-modal .hours-btn-save {
  flex: 1;
  padding: 0.75rem 2rem;
  background: var(--dominos-blue);
  border: none;
  border-radius: 0.75rem;
  font-size: 0.75rem;
  font-weight: 800;
  color: #fff;
  box-shadow: 0 4px 12px rgba(0, 144, 226, 0.25);
  cursor: pointer;
  transition: background 0.15s;
}

.ifood-hours-modal .hours-btn-save:hover {
  background: var(--dominos-blue-dark);
}

@media (min-width: 576px) {
  .ifood-hours-modal .hours-btn-cancel,
  .ifood-hours-modal .hours-btn-save {
    flex: initial;
  }
}

@media (max-width: 575.98px) {
  .ifood-hours-modal .hours-day-row {
    flex-direction: column;
    align-items: stretch;
  }

  .ifood-hours-modal .hours-day-times {
    justify-content: flex-start;
  }

  .ifood-hours-modal .btn-copy-hours {
    width: 100%;
    justify-content: center;
  }
}

/* ========== Módulo Usuários ========== */
#usuarios-page.ifood-module,
#usuarios-form-page.ifood-module {
  max-width: none;
  width: 100%;
  padding: 1.25rem 1.5rem 2rem;
}

.ifood-module .ifood-btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.75rem 1.25rem;
  background: var(--dominos-blue);
  color: #fff !important;
  font-size: 0.875rem;
  font-weight: 700;
  border: none;
  border-radius: 0.75rem;
  box-shadow: 0 4px 14px rgba(0, 144, 226, 0.35);
  text-decoration: none !important;
  transition: background 0.15s, box-shadow 0.15s, transform 0.1s;
  cursor: pointer;
}

.ifood-module .ifood-btn-primary:hover {
  background: var(--dominos-blue-dark);
  color: #fff !important;
}

.ifood-module .ifood-btn-primary--sm {
  padding: 0.625rem 1rem;
  font-size: 0.8125rem;
}

.ifood-module .ifood-filter-bar {
  padding: 1.25rem;
  margin-bottom: 1.5rem;
}

.ifood-module .ifood-filter-form {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 1rem;
}

.ifood-module .ifood-filter-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(14rem, 1fr));
  gap: 0.75rem;
  flex: 1;
  min-width: min(100%, 20rem);
}

.ifood-module .ifood-filter-select {
  width: 100%;
  padding: 0.75rem 1rem;
  height: auto;
}

.ifood-module .ifood-filter-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
}

#usuarios-page .ifood-filter-actions .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  padding: 0.625rem 1rem;
  background: var(--ifood-slate-100);
  border: none;
  border-radius: 0.75rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--ifood-slate-700);
  text-decoration: none !important;
}

#usuarios-page .ifood-filter-actions .btn:hover {
  background: var(--ifood-slate-200);
  color: var(--ifood-slate-800);
}

.ifood-module .ifood-profile-pill {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--ifood-slate-700);
  background: var(--ifood-slate-100);
  padding: 0.25rem 0.625rem;
  border-radius: 9999px;
  border: 1px solid var(--ifood-slate-200);
}

#usuarios-page .ifood-table tbody tr {
  cursor: default;
}

#usuarios-page .ifood-table tbody tr:hover .ifood-store-name {
  color: inherit;
}

#usuarios-page .ifood-action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  padding: 0;
  background: var(--ifood-slate-100);
  border: none;
  border-radius: 0.5rem;
  color: var(--ifood-slate-500);
  text-decoration: none !important;
  transition: background 0.15s, color 0.15s;
}

#usuarios-page .ifood-table tbody tr:hover .ifood-action-btn {
  background: var(--dominos-blue);
  color: #fff;
}

.ifood-module .ifood-table-footer--paginate {
  flex-direction: column;
  align-items: stretch;
  gap: 0.75rem;
}

@media (min-width: 768px) {
  .ifood-module .ifood-table-footer--paginate {
    flex-direction: row;
    align-items: center;
  }
}

.ifood-module .ifood-pagination-wrap .pagination {
  margin: 0;
  justify-content: flex-end;
}

.ifood-module .ifood-form-badge {
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--ifood-slate-500);
  background: var(--ifood-slate-100);
  padding: 0.35rem 0.75rem;
  border-radius: 9999px;
}

.ifood-module .ifood-tabs {
  border: none;
  margin-bottom: 0;
  gap: 0.5rem;
  display: flex;
  flex-wrap: wrap;
}

.ifood-module .ifood-tabs .nav-link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.25rem;
  font-size: 0.8125rem;
  font-weight: 700;
  color: var(--ifood-slate-500);
  background: #fff;
  border: 1px solid var(--ifood-slate-200) !important;
  border-radius: 0.75rem 0.75rem 0 0 !important;
  margin-bottom: -1px;
  transition: color 0.15s, background 0.15s, border-color 0.15s;
}

.ifood-module .ifood-tabs .nav-link:hover {
  color: var(--dominos-blue);
  background: var(--ifood-slate-50);
}

.ifood-module .ifood-tabs .nav-link.active {
  color: var(--dominos-blue);
  background: #fff;
  border-color: var(--ifood-slate-200) !important;
  border-bottom-color: #fff !important;
  box-shadow: inset 0 3px 0 var(--dominos-blue);
}

.ifood-module .ifood-form-card {
  position: relative;
  margin-top: 0;
  border-radius: 0 1rem 1rem 1rem;
}

.ifood-module .ifood-form-card-body {
  padding: 1.5rem;
}

.ifood-module .ifood-form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(14rem, 1fr));
  gap: 1rem 1.25rem;
}

.ifood-module .ifood-form-group {
  margin-bottom: 0;
}

.ifood-module .ifood-form-label {
  display: block;
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--ifood-slate-700);
  margin-bottom: 0.35rem;
}

.ifood-module .ifood-form-control,
.ifood-module select.ifood-form-control {
  padding: 0.75rem 1rem;
  background: var(--ifood-slate-50);
  border: 1px solid var(--ifood-slate-200);
  border-radius: 0.75rem;
  font-size: 0.875rem;
  color: var(--ifood-slate-800);
  height: auto;
}

.ifood-module .ifood-form-control:focus,
.ifood-module select.ifood-form-control:focus {
  background: #fff;
  border-color: var(--dominos-blue);
  box-shadow: 0 0 0 3px rgba(0, 144, 226, 0.15);
}

.ifood-module .ifood-form-control:disabled,
.ifood-module select.ifood-form-control:disabled {
  background: var(--ifood-slate-100);
  opacity: 0.85;
  cursor: not-allowed;
}

.ifood-module .ifood-field-hint {
  display: block;
  margin-top: 0.35rem;
  font-size: 0.75rem;
  color: var(--ifood-slate-400);
}

.ifood-module .ifood-section-hint {
  font-size: 0.8125rem;
  color: var(--ifood-slate-500);
  margin: 0;
}

.ifood-module .ifood-section-hint--warn {
  color: #b45309;
  background: #fffbeb;
  border: 1px solid #fde68a;
  border-radius: 0.5rem;
  padding: 0.5rem 0.75rem;
  margin-top: 0.5rem;
}

.ifood-module .ifood-form-card-footer {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.5rem;
  padding: 1rem 1.5rem;
  border-top: 1px solid var(--ifood-slate-100);
  background: rgba(248, 250, 252, 0.8);
}

/* Bloco de lojas no formulário de usuários */
#usuarios-form-page .usuarios-lojas-block {
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--ifood-slate-100);
}

#usuarios-form-page .usuarios-lojas-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}

#usuarios-form-page .usuarios-lojas-count {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--ifood-slate-500);
}

.ifood-module .ifood-permissions-wrap {
  border: 1px solid var(--ifood-slate-100);
  border-radius: 0.75rem;
  overflow: hidden;
}

.ifood-module .ifood-permissions-table thead th {
  text-align: center;
}

.ifood-module .ifood-permissions-table thead th:first-child,
.ifood-module .ifood-permissions-table tbody td:first-child {
  text-align: left;
}

.ifood-module .ifood-permissions-table tbody td {
  vertical-align: middle;
}

.ifood-module .ifood-permissions-table tbody tr.disabled-row {
  opacity: 0.55;
}

.ifood-module .ifood-permission-module {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 600;
  color: var(--ifood-slate-800);
}

.ifood-module .ifood-permission-module i {
  color: var(--dominos-blue);
  width: 1.125rem;
  text-align: center;
}

.ifood-module .ifood-permission-check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

.ifood-module .ifood-permission-input {
  width: 1.125rem;
  height: 1.125rem;
  accent-color: var(--dominos-blue);
  cursor: pointer;
}

.ifood-module .ifood-permission-label {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--ifood-slate-600);
  margin: 0;
  cursor: pointer;
}

.ifood-module .ifood-empty--compact {
  padding: 2rem 1rem;
}

.ifood-module .ifood-empty--compact i {
  font-size: 1.5rem;
  color: var(--dominos-blue);
  margin-bottom: 0.5rem;
}

.ifood-module .ifood-btn-ghost--sm,
.ifood-module .ifood-btn-outline--sm {
  padding: 0.5rem 0.875rem;
  font-size: 0.75rem;
}

/* Modal de lojas — módulo Usuários (não é iFood) */
.usuarios-lojas-modal {
  --usuarios-slate-50: #f8fafc;
  --usuarios-slate-100: #f1f5f9;
  --usuarios-slate-200: #e2e8f0;
  --usuarios-slate-400: #94a3b8;
  --usuarios-slate-500: #64748b;
  --usuarios-slate-700: #334155;
  --usuarios-slate-800: #1e293b;
  --usuarios-slate-900: #0f172a;
}

.usuarios-lojas-modal__content {
  border: none;
  border-radius: 1.25rem;
  overflow: hidden;
  box-shadow: 0 25px 50px rgba(15, 23, 42, 0.2);
}

.usuarios-lojas-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.25rem 1.5rem;
  background: var(--dominos-blue);
  color: #fff;
  border: none;
}

.usuarios-lojas-modal__title {
  margin: 0;
  font-size: 1.0625rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.usuarios-lojas-modal__close {
  border: none;
  background: rgba(255, 255, 255, 0.15);
  color: #fff;
  width: 2rem;
  height: 2rem;
  border-radius: 0.5rem;
  font-size: 1.25rem;
  line-height: 1;
  cursor: pointer;
  transition: background 0.15s;
}

.usuarios-lojas-modal__close:hover {
  background: rgba(255, 255, 255, 0.25);
  color: #fff;
}

.usuarios-lojas-modal__body {
  padding: 1.25rem 1.5rem;
  background: #fff;
}

.usuarios-lojas-modal__search {
  position: relative;
  margin-bottom: 1rem;
}

.usuarios-lojas-modal__search .fas {
  position: absolute;
  left: 1rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--usuarios-slate-400);
  pointer-events: none;
}

.usuarios-lojas-modal__search-input {
  width: 100%;
  padding: 0.75rem 1rem 0.75rem 2.75rem;
  font-size: 0.875rem;
  color: var(--usuarios-slate-800);
  background: var(--usuarios-slate-50);
  border: 1px solid var(--usuarios-slate-200);
  border-radius: 0.75rem;
  transition: border-color 0.15s, box-shadow 0.15s, background 0.15s;
}

.usuarios-lojas-modal__search-input:focus {
  outline: none;
  background: #fff;
  border-color: var(--dominos-blue);
  box-shadow: 0 0 0 3px rgba(0, 144, 226, 0.15);
}

.usuarios-lojas-modal__toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}

.usuarios-lojas-modal__count {
  margin-left: auto;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--usuarios-slate-500);
}

.usuarios-lojas-modal__list {
  max-height: 22rem;
  overflow-y: auto;
  border: 1px solid var(--usuarios-slate-200);
  border-radius: 0.75rem;
  padding: 0.75rem;
  background: var(--usuarios-slate-50);
}

.usuarios-lojas-modal__loading {
  text-align: center;
  padding: 2rem 1rem;
  color: var(--usuarios-slate-500);
}

.usuarios-lojas-modal__loading i {
  font-size: 1.5rem;
  color: var(--dominos-blue);
  margin-bottom: 0.5rem;
}

.usuarios-lojas-modal__loading p {
  margin: 0;
  font-size: 0.875rem;
}

.usuarios-lojas-item {
  display: flex;
  align-items: center;
  padding: 0.75rem 1rem;
  border: 1px solid var(--usuarios-slate-200);
  border-radius: 0.75rem;
  margin-bottom: 0.5rem;
  cursor: pointer;
  background: #fff;
  transition: border-color 0.15s, background 0.15s;
}

.usuarios-lojas-item:last-child {
  margin-bottom: 0;
}

.usuarios-lojas-item:hover {
  background: var(--usuarios-slate-50);
  border-color: rgba(0, 144, 226, 0.35);
}

.usuarios-lojas-item.is-selected {
  background: rgba(0, 144, 226, 0.08);
  border-color: var(--dominos-blue);
}

.usuarios-lojas-item input[type="checkbox"] {
  margin: 0 0.75rem 0 0;
  accent-color: var(--dominos-blue);
  cursor: pointer;
  flex-shrink: 0;
}

.usuarios-lojas-item__name {
  flex: 1;
  margin: 0;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--usuarios-slate-800);
  cursor: pointer;
}

.usuarios-lojas-modal__footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.5rem;
  padding: 1rem 1.5rem;
  background: var(--usuarios-slate-50);
  border-top: 1px solid var(--usuarios-slate-100);
}

.usuarios-lojas-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  font-family: inherit;
  line-height: 1.25;
  cursor: pointer;
  text-decoration: none;
  border-radius: 0.75rem;
  transition: background 0.15s, color 0.15s, border-color 0.15s, box-shadow 0.15s;
  -webkit-appearance: none;
  appearance: none;
}

.usuarios-lojas-btn--primary {
  padding: 0.75rem 1.25rem;
  font-size: 0.875rem;
  font-weight: 700;
  color: #fff;
  background: var(--dominos-blue);
  border: none;
  box-shadow: 0 4px 14px rgba(0, 144, 226, 0.3);
}

.usuarios-lojas-btn--primary:hover {
  background: var(--dominos-blue-dark);
  color: #fff;
}

.usuarios-lojas-btn--outline {
  padding: 0.625rem 1rem;
  font-size: 0.8125rem;
  font-weight: 700;
  color: var(--usuarios-slate-700);
  background: #fff;
  border: 1px solid var(--usuarios-slate-200);
}

.usuarios-lojas-btn--outline:hover {
  color: var(--dominos-blue);
  background: rgba(0, 144, 226, 0.06);
  border-color: rgba(0, 144, 226, 0.35);
}

.usuarios-lojas-btn--ghost {
  padding: 0.75rem 1.125rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--usuarios-slate-600);
  background: #fff;
  border: 1px solid var(--usuarios-slate-200);
}

.usuarios-lojas-btn--ghost:hover {
  color: var(--dominos-blue);
  background: var(--usuarios-slate-50);
  border-color: rgba(0, 144, 226, 0.25);
}

.usuarios-lojas-btn--sm {
  padding: 0.5rem 0.875rem;
  font-size: 0.75rem;
}

.usuarios-lojas-btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
  box-shadow: none;
}
