@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@100..900&display=swap');

/* =========================================================
   THEME TOKENS / DESIGN SYSTEM
   - Mantém suas classes existentes
   - Adiciona VARIANTS por cor para QUALQUER botão
   - Mantém “pegada roxa” (purple bias) em todas as variantes
   ========================================================= */
:root {
  /* NEUTROS */
  --white: #FFFFFF;
  --black: #050315;
  --gray-900: #111827;
  --gray-700: #4B5563;
  --gray-500: #9CA3AF;
  --gray-300: #E5E7EB;
  --gray-100: #F9FAFB;

  /* PALETA ROXA (BASE) */
  --purple-900: #2B1764;
  --purple-700: #5D2DDF;
  --purple-600: #7744FF;  /* roxo principal */
  --purple-500: #B027FF;
  --purple-300: #B397FF;
  --purple-100: #F3ECFF;

  /* LARANJA (ACENTO) */
  --orange-600: #FF8A00;
  --orange-500: #FFAF03;
  --orange-300: #FFD27A;

  /* SEMÂNTICOS */
  --color-bg: var(--purple-100);
  --color-text-main: var(--purple-900);

  --color-brand: var(--purple-600);
  --color-brand-soft: var(--purple-100);
  --color-accent: var(--orange-500);
  --color-border-focus: var(--color-brand);

  /* compat legada */
  --base-color: var(--color-bg);
  --base-30: color-mix(in srgb, var(--base-color) 30%, transparent);
  --main-color: var(--color-text-main);
  --main-color-i: var(--white);
  --secondary-color: var(--color-border-focus);

  /* =====================================================
     GRADIENTS (LEGADO/ORIGINAIS)
     ===================================================== */
  --gradient-primary: linear-gradient(135deg, #1B1464, #6844F9);
  --gradient-primary-hover: linear-gradient(135deg, var(--purple-700), var(--purple-500));

  --gradient-cta: linear-gradient(135deg, var(--orange-600), var(--orange-500));
  --gradient-cta-hover: linear-gradient(135deg, var(--purple-700), var(--purple-500));

  --gradient-cta-accent: linear-gradient(135deg, var(--orange-500), var(--orange-600));

  --gradient-bg-soft: radial-gradient(
    circle at top left,
    var(--purple-300) 0,
    var(--purple-100) 40%,
    var(--purple-100) 100%
  );

  --gradient-bg-soft-50: radial-gradient(
    circle at top left,
    color-mix(in srgb, var(--purple-300) 50%, transparent) 0,
    color-mix(in srgb, var(--purple-100) 50%, transparent) 40%,
    color-mix(in srgb, var(--purple-100) 50%, transparent) 100%
  );

  --gradient-panel: radial-gradient(
    circle at top left,
    var(--purple-300) 0,
    var(--purple-600) 40%,
    var(--purple-700) 100%
  );

  --gradient-glass-card: linear-gradient(
    135deg,
    rgba(255, 255, 255, 0.18),
    rgba(255, 255, 255, 0.06)
  );

  /* sombras */
  --shadow-soft: 0 12px 30px rgba(45, 23, 100, 0.20);
  --shadow-strong: 0 40px 80px rgba(45, 23, 100, 0.28);

  /* font */
  --font-default: 400 0.875rem 'Roboto', sans-serif;
  --font-small: 500 0.75rem 'Roboto', sans-serif;
  --font-medium: 600 1rem 'Roboto', sans-serif;
  --font-large: 600 1.25rem 'Roboto', sans-serif;
  --font-xlarge: 600 1.5rem 'Roboto', sans-serif;
  --button-font: 600 0.875rem 'Roboto', sans-serif;

  /* spacing */
  --spacing-xs: 8px;
  --spacing-sm: 16px;
  --spacing-md: 32px;
  --spacing-lg: 48px;
  --spacing-xl: 64px;
  --spacing-xxl: 96px;

  /* radius */
  --radius-xs: 4px;
  --radius-sm: 8px;
  --radius-md: 16px;
  --radius-lg: 32px;
  --radius-xl: 48px;

  /* alias botões */
  --cta: var(--gradient-cta);
  --cta-hover: var(--gradient-cta-hover);
  --cta-accent: var(--gradient-cta-accent);
  --cta-i: #ffffff;

  /* =====================================================
     AUX VARIANTS (BASES) — UMA BASE POR COR
     (todo o resto é derivado via mix + purple bias)
     ===================================================== */
  --aux-purple-bias: 34%; /* mantém tudo na mesma “família roxa” */

  --aux-blue-base:   #3B82F6;
  --aux-green-base:  #22C55E;
  --aux-red-base:    #EF4444;
  --aux-orange-base: #F59E0B;
  --aux-yellow-base: #EAB308;
  --aux-cyan-base:   #06B6D4;
  --aux-pink-base:   #EC4899;
  --aux-teal-base:   #14B8A6;
  --aux-gray-base:   #64748B;
}

/* =========================================================
   UTILS
   ========================================================= */

.relative { position: relative; }

.w-full { width: 100%; }
.flex { display: flex; }
.flex-1 { flex: 1; }
.gap-2 { gap: 8px; }

.w-250 { width: 250px !important; }
.swal2-popup-custom { margin-top: 0 !important; }
.no-border-icon { border: none !important; background: none !important; }
.badge-compact { font-size: .72rem; padding: .2rem .45rem; line-height: 1; }

.input-icon-wrapper { position: relative; }
.input-icon-wrapper .input-icon {
  position: absolute;
  left: .75rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: .75rem;
  color: #9ca3af;
  pointer-events: none;
}
.input-icon-wrapper .form-control.with-icon-left { padding-left: 2rem; }

/* =========================================================
   BASE
   ========================================================= */
body {
  padding: 0;
  margin: 0;
  font: var(--font-default);
  color: var(--main-color);
  background: var(--color-bg);
}

p, span, label { font: var(--font-default); }

h2.title {
  font: var(--font-large);
  text-transform: uppercase;
}

.container-fluid {
  padding: var(--spacing-sm) var(--spacing-md);
  width: 100%;
}

.app-shell {
  background: var(--white);
  color: var(--main-color);
  font: var(--font-default);
}

/* =========================================================
   HEADER
   ========================================================= */
header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: var(--gradient-primary);
  box-shadow: 0 2px 4px rgba(0,0,0,0.08);
  padding: var(--spacing-sm) var(--spacing-md);
}
header .icons {
  display: flex;
  align-items: center;
  gap: 8px;
}

/* =========================================================
   BOTÕES (BASE)
   - Mantém .btn / .btn-primary / .btn-secondary / etc
   - Adiciona sistema de variantes para QUALQUER botão
   ========================================================= */

.btn .ms-1 { margin-left: 0; }

.btn {
  padding: var(--spacing-sm);
  text-transform: uppercase;
  font: var(--button-font);
  border: 0;
  border-radius: var(--radius-sm);
  text-align: center;
  cursor: pointer;

  transition:
    transform 0.12s ease,
    box-shadow 0.12s ease,
    opacity 0.12s ease,
    background 0.12s ease,
    border-color 0.12s ease,
    filter 0.12s ease;
}

.btn:hover:not(:disabled) { transform: translateY(-1px); }
.btn:active:not(:disabled) { transform: translateY(0); }
.btn:disabled, .btn.disabled { opacity: 0.65; cursor: default; }

.btn.btn-sm {
  padding: 0 var(--spacing-sm);
  height: 32px;
}

/* Botões tradicionais (mantidos) */
.btn.btn-primary {
  background: var(--gradient-primary);
  color: var(--cta-i);
}
.btn.btn-primary:hover:not(:disabled) {
  background: var(--gradient-primary-hover);
}

.btn.btn-secondary {
  background: var(--gradient-primary);
  color: var(--cta-i) !important;
}
.btn.btn-secondary:hover:not(:disabled) {
  background: var(--gradient-primary-hover);
}

.btn.btn-cta {
  background: var(--gradient-cta);
  color: var(--cta-i) !important;
}
.btn.btn-cta:hover:not(:disabled) {
  background: var(--gradient-cta-hover);
}

.btn.btn-danger {
  background: #dc2626;
  color: var(--cta-i) !important;
}

/* Ghost mantido */
.btn.btn-ghost {
  position: relative;
  border-radius: var(--radius-xs);
  background: var(--gradient-glass-card);
  box-shadow: 0 26px 60px rgba(21, 10, 71, 0.58);
  border: 1px solid rgba(255, 255, 255, 0.35);
  backdrop-filter: blur(16px);
  color: var(--white);
}

/* =========================================================
   SISTEMA DE VARIANTS POR COR (para QUALQUER botão)
   Como usar:
   - class="btn is-blue" (botão normal)
   - class="btn btn-sm is-green"
   - class="btn icon-btn is-red"
   - class="btn btn-outline is-orange" (outline)
   - class="btn btn-soft is-cyan" (soft)
   ========================================================= */

/* Base do sistema */
.btn {
  /* fallback */
  --aux-base: var(--aux-gray-base);

  /* Ajustes globais */
  --aux-a-mix: 18%;    /* topo mais claro */
  --aux-b-mix: 32%;    /* base um pouco mais escura */
  --aux-border-mix: 55%;
  --aux-fg-mix: 86%;   /* ícone/texto */
  --aux-shadow: rgba(45, 23, 100, 0.14);

  /* tonaliza com roxo pra padronizar “saturação do tema” */
  --aux-toned: color-mix(
    in srgb,
    var(--aux-base) calc(100% - var(--aux-purple-bias)),
    var(--purple-600)
  );

  /* stops do gradient */
  --aux-a: color-mix(in srgb, var(--aux-toned) var(--aux-a-mix), var(--white));
  --aux-b: color-mix(in srgb, var(--aux-toned) var(--aux-b-mix), var(--white));

  /* borda e texto */
  --aux-border: color-mix(in srgb, var(--aux-toned) var(--aux-border-mix), transparent);
  --aux-fg: color-mix(in srgb, var(--aux-toned) var(--aux-fg-mix), var(--purple-900));

  /* gradiente pronto */
  --aux-gradient: linear-gradient(135deg, var(--aux-a), var(--aux-b));
  --aux-gradient-hover: linear-gradient(
    135deg,
    color-mix(in srgb, var(--aux-a) 70%, var(--white)),
    color-mix(in srgb, var(--aux-b) 70%, var(--white))
  );
}

/* Filled (default do variant) */
.btn.is-blue,
.btn.is-green,
.btn.is-red,
.btn.is-orange,
.btn.is-yellow,
.btn.is-cyan,
.btn.is-pink,
.btn.is-teal,
.btn.is-gray {
  background: var(--aux-gradient) !important;
  border: 1px solid var(--aux-border) !important;
  color: var(--aux-fg) !important;

  box-shadow:
    0 14px 28px rgba(45, 23, 100, 0.12),
    inset 0 0 0 1px color-mix(in srgb, var(--aux-toned) 14%, transparent);
}

.btn.is-blue:hover:not(:disabled),
.btn.is-green:hover:not(:disabled),
.btn.is-red:hover:not(:disabled),
.btn.is-orange:hover:not(:disabled),
.btn.is-yellow:hover:not(:disabled),
.btn.is-cyan:hover:not(:disabled),
.btn.is-pink:hover:not(:disabled),
.btn.is-teal:hover:not(:disabled),
.btn.is-gray:hover:not(:disabled) {
  background: var(--aux-gradient-hover) !important;
  filter: saturate(1.05);
}

/* Outline variant (mantém colorido, sem fill) */
.btn.btn-outline.is-blue,
.btn.btn-outline.is-green,
.btn.btn-outline.is-red,
.btn.btn-outline.is-orange,
.btn.btn-outline.is-yellow,
.btn.btn-outline.is-cyan,
.btn.btn-outline.is-pink,
.btn.btn-outline.is-teal,
.btn.btn-outline.is-gray {
  background: transparent !important;
  border: 1px solid color-mix(in srgb, var(--aux-toned) 55%, transparent) !important;
  color: color-mix(in srgb, var(--aux-toned) 70%, var(--purple-900)) !important;
  box-shadow: none;
}

.btn.btn-outline.is-blue:hover:not(:disabled),
.btn.btn-outline.is-green:hover:not(:disabled),
.btn.btn-outline.is-red:hover:not(:disabled),
.btn.btn-outline.is-orange:hover:not(:disabled),
.btn.btn-outline.is-yellow:hover:not(:disabled),
.btn.btn-outline.is-cyan:hover:not(:disabled),
.btn.btn-outline.is-pink:hover:not(:disabled),
.btn.btn-outline.is-teal:hover:not(:disabled),
.btn.btn-outline.is-gray:hover:not(:disabled) {
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--aux-toned) 10%, var(--white)),
    color-mix(in srgb, var(--aux-toned) 14%, var(--white))
  ) !important;
}

/* Soft variant (chips, ações leves) */
.btn.btn-soft.is-blue,
.btn.btn-soft.is-green,
.btn.btn-soft.is-red,
.btn.btn-soft.is-orange,
.btn.btn-soft.is-yellow,
.btn.btn-soft.is-cyan,
.btn.btn-soft.is-pink,
.btn.btn-soft.is-teal,
.btn.btn-soft.is-gray {
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--aux-toned) 10%, var(--white)),
    color-mix(in srgb, var(--aux-toned) 14%, var(--white))
  ) !important;

  border: 1px solid color-mix(in srgb, var(--aux-toned) 30%, transparent) !important;
  color: color-mix(in srgb, var(--aux-toned) 78%, var(--purple-900)) !important;
  box-shadow: none;
}

.btn.btn-soft.is-blue:hover:not(:disabled),
.btn.btn-soft.is-green:hover:not(:disabled),
.btn.btn-soft.is-red:hover:not(:disabled),
.btn.btn-soft.is-orange:hover:not(:disabled),
.btn.btn-soft.is-yellow:hover:not(:disabled),
.btn.btn-soft.is-cyan:hover:not(:disabled),
.btn.btn-soft.is-pink:hover:not(:disabled),
.btn.btn-soft.is-teal:hover:not(:disabled),
.btn.btn-soft.is-gray:hover:not(:disabled) {
  filter: saturate(1.05);
}

/* =========================================================
   Mapeamento das bases (uma cor por variante)
   ========================================================= */
.btn.is-blue,   .btn.btn-outline.is-blue,   .btn.btn-soft.is-blue   { --aux-base: var(--aux-blue-base); }
.btn.is-green,  .btn.btn-outline.is-green,  .btn.btn-soft.is-green  { --aux-base: var(--aux-green-base); }
.btn.is-red,    .btn.btn-outline.is-red,    .btn.btn-soft.is-red    { --aux-base: var(--aux-red-base); }
.btn.is-orange, .btn.btn-outline.is-orange, .btn.btn-soft.is-orange { --aux-base: var(--aux-orange-base); }
.btn.is-yellow, .btn.btn-outline.is-yellow, .btn.btn-soft.is-yellow { --aux-base: var(--aux-yellow-base); }
.btn.is-cyan,   .btn.btn-outline.is-cyan,   .btn.btn-soft.is-cyan   { --aux-base: var(--aux-cyan-base); }
.btn.is-pink,   .btn.btn-outline.is-pink,   .btn.btn-soft.is-pink   { --aux-base: var(--aux-pink-base); }
.btn.is-teal,   .btn.btn-outline.is-teal,   .btn.btn-soft.is-teal   { --aux-base: var(--aux-teal-base); }
.btn.is-gray,   .btn.btn-outline.is-gray,   .btn.btn-soft.is-gray   { --aux-base: var(--aux-gray-base); }

/* =========================================================
   Botão pequeno com ícone (mantido)
   + agora funciona com variants (is-blue etc)
   ========================================================= */
.btn.icon-btn {
  width: 32px;
  height: 32px;
  padding: 0;

  display: flex;
  align-items: center;
  justify-content: center;

  border-radius: 10px;
}

/* Corrige desalinhamento de ícones (font icons) */
.btn.icon-btn i,
.btn.icon-btn svg {
  line-height: 1;
  display: block;
}

/* input-group icon-btn */
.input-group .btn.icon-btn {
  height: 43px;
  width: 43px;
  border-radius: 12px;
}

/* =========================================================
   Botão refresh (mantido)
   ========================================================= */
.module-refresh-btn {
  background-color: var(--purple-900);
  color: var(--orange-300);
  border: 1px solid color-mix(in srgb, var(--orange-500) 35%, var(--purple-900));
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  padding: .25rem .5rem;
  min-width: 96px;
  height: 32px;
}
.module-refresh-btn:hover {
  background-color: var(--purple-700);
  color: var(--orange-300);
}

/* =========================================================
   Ações (mantido)
   ========================================================= */
.actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
}

.actions .btn-action {
  background: var(--cta);
  border: 0;
  color: var(--cta-i) !important;
  padding: var(--spacing-xs);
  border-radius: var(--radius-xs);
  cursor: pointer;
  transition:
    transform 0.12s ease,
    box-shadow 0.12s ease,
    opacity 0.12s ease,
    background 0.12s ease;
}

/* =========================================================
   FORM / INPUTS GENÉRICOS
   ========================================================= */
label,
.form-label {
  display: flex;
  align-items: center;
  width: 100%;
  font-weight: 600;
  margin-bottom: 5px;
  font-size: 0.8rem;
  color: var(--gray-700);
}

input.form-control,
select.form-control,
select.form-select {
  width: 100%;
  background-color: #F4F3F7;
  border: 1px solid #D1D0E0;
  border-radius: var(--radius-sm);
  padding: 10px 16px;
  font-size: 0.875rem;
  font-family: inherit;
  color: var(--main-color);
  outline: none;
  transition:
    border-color 0.12s ease,
    box-shadow 0.12s ease,
    background-color 0.12s ease,
    transform 0.12s ease;
}

textarea.form-control {
  width: 100%;
  background-color: #F4F3F7;
  border: 1px solid #D1D0E0;
  border-radius: var(--radius-md);
  padding: 10px 14px;
  font-size: 0.875rem;
  font-family: inherit;
  color: var(--main-color);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-brand) 6%, transparent);
  outline: none;
  resize: vertical;
  min-height: 90px;
  transition:
    border-color 0.12s ease,
    box-shadow 0.12s ease,
    background-color 0.12s ease,
    transform 0.12s ease;
}

input.form-control::placeholder,
textarea.form-control::placeholder,
select.form-control::placeholder {
  color: var(--main-color);
  opacity: .5;
}

input.form-control:focus,
select.form-control:focus,
select.form-select:focus,
textarea.form-control:focus {
  border-color: var(--color-border-focus);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--color-brand) 40%, transparent),
    0 0 0 3px color-mix(in srgb, var(--color-brand) 12%, transparent);
  background-color: color-mix(in srgb, var(--color-brand-soft) 80%, #ffffff);
}

input.form-control.is-invalid,
select.form-control.is-invalid,
textarea.form-control.is-invalid {
  border-color: #dc2626;
  box-shadow:
    0 0 0 1px rgba(220, 38, 38, 0.7),
    0 0 0 3px rgba(220, 38, 38, 0.16);
}

.input-icon { position: relative; }
.input-icon i {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--gray-500);
  font-size: 0.9rem;
}
.input-icon input.form-control { padding-left: 2.6rem; }

/* =========================================================
   LOGIN PAGE
   ========================================================= */
.login-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px 16px;
  background: var(--gradient-bg-soft);
  box-sizing: border-box;
}

.login-card {
  width: 100%;
  max-width: 1100px;
  min-height: 520px;
  background: var(--white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-strong);
  display: flex;
  overflow: hidden;
  position: relative;
}

.login-left {
  flex: 1 1 50%;
  padding: 40px 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--white);
}

.login-left-inner {
  width: 100%;
  max-width: 360px;
}

.logo-tenant { margin-bottom: 32px; }

.login-title {
  margin: 0 0 8px;
  font-size: 24px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--main-color);
}

.login-subtitle {
  margin: 0 0 32px;
  font-size: 13px;
  color: var(--gray-700);
}

.login-form {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.login-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.login-label {
  font-size: 12px;
  font-weight: 500;
  color: var(--gray-700);
}

.login-input-wrap {
  background: var(--color-brand-soft);
  border-radius: var(--radius-sm);
  padding: 10px 18px;
  display: flex;
  align-items: center;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-brand) 8%, transparent);
}

.login-input {
  border: none;
  outline: none;
  flex: 1;
  background: transparent;
  font-size: 13px;
  color: var(--main-color);
}

.login-input::placeholder { color: var(--purple-300); }

.login-button {
  margin-top: 4px;
  width: 100%;
  border: none;
  outline: none;
  cursor: pointer;
  padding: 12px 20px;
  border-radius: var(--radius-sm);
  font: var(--button-font);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--cta-i);
  background: var(--gradient-cta);
  box-shadow: 0 12px 30px rgba(120, 65, 255, 0.35);
  transition:
    transform 0.12s ease,
    box-shadow 0.12s ease,
    opacity 0.12s ease,
    background 0.12s ease;
}

.login-button:hover:not(:disabled) {
  transform: translateY(-1px);
  background: var(--gradient-cta-hover);
  box-shadow: 0 15px 36px rgba(120, 65, 255, 0.45);
}

.login-button:active:not(:disabled) {
  transform: translateY(0);
  box-shadow: 0 8px 20px rgba(120, 65, 255, 0.35);
}

.login-button:disabled { opacity: 0.7; cursor: default; }

.login-forgot { margin-top: 10px; text-align: right; }

.login-link {
  font-size: 12px;
  color: var(--color-brand);
  text-decoration: none;
}
.login-link:hover { text-decoration: underline; }

.login-error {
  margin-top: 8px;
  padding: 8px 12px;
  border-radius: 8px;
  font-size: 12px;
  background: rgba(255, 87, 87, 0.08);
  color: #d53030;
}

/* LOGIN RIGHT */
.login-right {
  flex: 1 1 50%;
  background: var(--gradient-panel);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.login-right::before {
  content: "";
  position: absolute;
  inset: -20%;
  background-image:
    radial-gradient(circle at 0 0, rgba(255, 255, 255, 0.11) 0, transparent 55%),
    radial-gradient(circle at 100% 100%, rgba(255, 255, 255, 0.08) 0, transparent 55%);
  opacity: 0.65;
  pointer-events: none;
}

.login-right-inner {
  position: relative;
  width: 80%;
  max-width: 380px;
}

.login-right-card {
  position: relative;
  border-radius: var(--radius-lg);
  background: var(--gradient-glass-card);
  box-shadow: 0 26px 60px rgba(21, 10, 71, 0.58);
  padding: 32px 32px 0;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.35);
  backdrop-filter: blur(16px);
  min-height: 340px;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}

.login-right-image {
  max-height: 320px;
  width: auto;
  display: block;
}

.login-right-badge {
  position: absolute;
  left: 26px;
  bottom: 50%;
  transform: translateY(50%);
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  box-shadow: 0 18px 40px rgba(21, 10, 71, 0.35);
  color: var(--color-accent);
}

/* =========================================================
   RESPONSIVO
   ========================================================= */
@media (max-width: 900px) {
  .login-card {
    flex-direction: column;
    max-width: 480px;
    min-height: auto;
  }
  .login-left { padding: 32px 24px 24px; }
  .login-right { order: -1; min-height: 260px; }
  .login-right-inner { width: 85%; }
  .login-right-card { padding: 24px 24px 0; min-height: 260px; }
  .login-right-image { max-height: 260px; }
}

@media (max-width: 480px) {
  .login-page { padding: 16px; }
  .login-left-inner { max-width: 100%; }
}

/* =========================================================
   LISTA / CARD / TABELA
   ========================================================= */
.table-empty-cell {
  padding: 0 !important;
  background-color: transparent !important;
}
.table-empty {
  border-radius: var(--radius-md);
  background: var(--gray-100) !important;
  padding: var(--spacing-md);
  text-align: center;
  margin-top: var(--spacing-xs) !important;
}

.filter-table {
  display: flex;
  gap: 12px;
  padding: var(--spacing-sm);
  background-color: var(--white);
  box-shadow: var(--shadow-soft);
  border-radius: var(--radius-md);
  margin-bottom: var(--spacing-md);
}

.card {
  background: var(--white);
  border-radius: var(--radius-md);
  box-sizing: border-box;
  box-shadow: var(--shadow-soft);
  border: 1px solid rgba(15, 23, 42, 0.04);
  overflow: hidden;
  margin-bottom: var(--spacing-md);
  padding: var(--spacing-sm);
}

.card-body { padding: 0; }

.list-group {
  border: 1px solid var(--gray-300);
  border-radius: var(--radius-sm);
}

.list-group-item {
  border: 0;
  border-bottom: 1px solid var(--gray-300);
  padding: var(--spacing-sm);
}

.list-group-item:last-child { border-bottom: none; }

.card-header {
  padding: 14px 20px;
  border-bottom: 1px solid rgba(15, 23, 42, 0.06);
  background: var(--white);
  font: var(--font-medium);
  color: var(--gray-900);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.card .table-responsive { margin: 0; padding: 0; }

.card .table {
  margin-bottom: 0;
  font-size: 0.8125rem;
  color: var(--gray-900);
}

.card .table thead { background: #F3F4F6; }

.card .table thead th {
  border-bottom: 0;
  padding: var(--spacing-sm) var(--spacing-xs);
  font: var(--font-small);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--gray-500);
  white-space: nowrap;
}

.card .table tbody td {
  padding: var(--spacing-sm) var(--spacing-xs);
  border-top: 1px solid var(--gray-300);
  border-bottom: 0;
  vertical-align: middle;
  font: var(--font-default);
  color: var(--main-color);
}

.table-hover > tbody > tr:hover > * { 
    --bs-table-color-state: unset !important;
    --bs-table-bg-state: unset !important; 
    background-color: transparent;
}
.table-hover > tbody > tr:hover { background: var(--gray-100) !important; }

.card .table tbody td.text-nowrap {
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

.card .badge.rounded-pill {
  font-size: 0.7rem;
  padding: 0.25rem 0.6rem;
}

.card .badge.bg-success {
  background-color: rgba(22, 163, 74, 0.12) !important;
  color: #166534;
}

/* Botão link (mantido) */
.card .btn.btn-link {
  border-radius: var(--radius-sm);
  width: 32px;
  height: 32px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  border: 0;
  background: transparent;
  transition: background 0.12s ease, transform 0.12s ease, box-shadow 0.12s ease;
}

.card .btn.btn-link i { font-size: 1rem; }

.card .btn.btn-link:hover {
  background: rgba(148, 163, 184, 0.16);
  transform: translateY(-1px);
  box-shadow: 0 4px 10px rgba(15, 23, 42, 0.12);
}

.card .btn.btn-link:disabled {
  opacity: 0.4;
  box-shadow: none;
  transform: none;
}

/* Paginação */
.card-pagination {
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: var(--main-color);
}

.card-pagination .pagination {
  background: var(--purple-100);
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid var(--purple-300);
}

.card-pagination .page-item button {
  background: var(--gradient-glass-card);
  outline: 1px solid var(--purple-300);
  border: 1px solid rgba(255, 255, 255, 0.35);
  backdrop-filter: blur(16px);
  color: var(--main-color);
}

.card-pagination .page-item.active button { background: rgba(0,0,0,.1); }

/* =====================================================
   PRODUCT VIEW
   ===================================================== */
.product-view-layout { display: flex; gap: 1.5rem; }

.product-view-sidebar {
  position: sticky;
  top: 50px;
  align-self: flex-start;
  width: 260px;
  display: flex;
  flex-direction: column;
}

.product-view-nav {
  border-radius: 1rem;
  background: #ffffff;
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.06);
  max-height: calc(100vh - 120px);
  padding: 1rem;
  margin-bottom: var(--spacing-sm);
}

.product-view-sidebar-header { margin-bottom: 1rem; }

.product-view-sidebar-header .product-code {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: #818cf8;
}

.product-view-sidebar-header .product-name {
  font-size: 0.875rem;
  font-weight: 600;
}

.product-view-nav .nav-link {
  border-radius: .5rem;
  padding: .4rem .75rem;
  font-size: .85rem;
  text-align: left;
  color: #4b5563;
}

.product-view-nav .nav-link.active {
  background: #eef2ff;
  color: #4f46e5;
  font-weight: 600;
}

.product-view-nav .nav-link:disabled { opacity: .4; cursor: not-allowed; }

.product-view-sidebar-footer {
  margin-top: var(--spacing-xs);
}

.product-view-content { flex: 1; }

.product-section { margin-bottom: 2rem; }
.product-section-title { margin-bottom: 1rem; }
.product-view-full { max-width: 100%; }

/* =====================================================
   OVERLAY (mantido)
   ===================================================== */
.product-full-overlay {
  position: fixed;
  inset: 0;
  z-index: 1100;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 16px;
}

.product-full-overlay-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.55);
  backdrop-filter: blur(2px);
}

.product-full-overlay-panel {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 100%;
  max-height: none;
  background: #ffffff;
  border-radius: 12px;
  box-shadow: 0 22px 45px rgba(15, 23, 42, 0.25);
  padding: 16px 20px 20px;
}

.product-full-overlay-close { position: absolute !important; top: 10px; right: 10px; z-index: 2; }

.product-full-overlay-panel .card { max-height: none; overflow: visible; }

.product-full-overlay-panel { max-width: 100%; padding: 16px 20px; }

.product-full-overlay-panel .page-header { margin-bottom: 8px; }
.product-full-overlay-panel .page-header-title { font-size: 20px; }
.product-full-overlay-panel .page-header-subtitle { font-size: 12px; }

.product-full-scale {
  transform: scale(0.7);
  transform-origin: top left;
  width: calc(100% / 0.7);
}

.product-full-layout {
  display: flex;
  gap: 8px;
}

.product-full-layout ::deep .d-flex.justify-content-between > div h2,
.product-full-layout ::deep .d-flex.justify-content-between > div .text-muted {
  display: none;
}


.product-full-layout .card {
  padding: 0;
  border-radius: 0;
  box-shadow: none;
  background-color: transparent;
  margin: 0;
}

.product-full-section--basic {
  display: grid;
  grid-template-columns: 1fr;
  grid-auto-rows: minmax(0, auto);
  column-gap: 12px;
  row-gap: 8px;
}

.product-full-section--basic > .form-section { margin-bottom: 0; }

.product-full-section--basic > .form-section:nth-of-type(1) {
  grid-column: 1;
  grid-row: 1 / span 2;
}

.product-full-section--basic > .form-section:nth-of-type(2) {
  grid-column: 2;
  grid-row: 1;
}

.product-full-section--basic > .form-section:nth-of-type(3) {
  grid-column: 2;
  grid-row: 2;
}

.product-full-section--basic > .form-section:nth-of-type(n + 4) {
  grid-column: 1 / -1;
}

/* =====================================================
   FIXED HOVER (mantido)
   ===================================================== */
.btn-hover-fixed {
  background-color: #6c757d !important;
  color: #fff !important;
  border-color: #6c757d !important;
}
.btn-hover-fixed:hover,
.btn-hover-fixed:focus,
.btn-hover-fixed:active {
  background-color: #6c757d !important;
  color: #fff !important;
  border-color: #6c757d !important;
}
.btn-hover-fixed:disabled,
.btn-hover-fixed.disabled { opacity: .65; }

/* =====================================================
   app-toggle-edit-panel / cards
   ===================================================== */
.app-toggle-edit-header {
    border-bottom: 1px solid var(--gray-300);
    margin-bottom: var(--spacing-sm);
    padding-bottom: var(--spacing-xs);
}

.app-toggle-edit-panel .row {
    margin-right: calc(-.5 * var(--bs-gutter-x)) !important;
    margin-left: calc(-.5 * var(--bs-gutter-x)) !important;
}

.app-toggle-edit-panel .list-group {
    width: 100%;
    border-radius: var(--radius-sm);
    max-height: 200px;
    overflow-y: auto;
    position: absolute;
    z-index: 2;
}
.app-toggle-edit-panel .list-group button {
    border-color: var(--gray-300);
}

.app-toggle-edit-panel,
.card .ui-data-table .card {
  position: relative;
  border: 1px solid var(--gray-300);
  border-radius: var(--radius-sm);
  margin-top: var(--spacing-sm);
  padding: var(--spacing-sm);
}

.card .card {
    margin: 0;
  padding: 0;
  box-shadow: none;
  border: 0;
  border-radius: 0;
}

/* =====================================================
   DROPZONE
   ===================================================== */

.dropzone {
  position: relative;
  border: 1px dashed var(--purple-300);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--purple-100) 65%, white);
  padding: 16px;
  min-height: 110px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: border-color .12s ease, box-shadow .12s ease, transform .12s ease, background .12s ease;
}

.dropzone-content {
  text-align: center;
  color: var(--gray-700);
  display: grid;
  gap: 4px;
}

.dropzone-content i {
  font-size: 26px;
  color: var(--purple-600);
}

.dropzone-title {
  font-weight: 700;
  color: var(--purple-900);
}

.dropzone-subtitle {
  font-size: .85rem;
  color: var(--gray-700);
}

.dropzone-hint {
  font-size: .75rem;
  color: var(--gray-500);
}

.dropzone.is-dragover {
  border-color: var(--purple-600);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--purple-600) 18%, transparent);
  transform: translateY(-1px);
  background: color-mix(in srgb, var(--purple-100) 85%, white);
}

.dropzone.is-filled {
  border-style: solid;
  background: color-mix(in srgb, var(--purple-100) 55%, white);
}

.dropzone-input {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}

/* =========================================================
   PREVIEW CARD PRODUCT
   ========================================================= */

  .pv-card{
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:12px;
  overflow:hidden;
  margin-bottom:14px;
  box-shadow:0 6px 16px rgba(0,0,0,.06);
}

.pv-media{
  aspect-ratio: 1 / 1;
  background:#f6f7f9;
  display:flex;
  align-items:center;
  justify-content:center;
}

.pv-media img{
  width:100%;
  height:100%;
  object-fit: contain;
  display:block;
}

.pv-placeholder{
  color:#9aa4b2;
  font-size:2rem;
}

.pv-body{ padding:12px; }

.pv-title{
  font-weight:700;
  font-size:.95rem;
  line-height:1.2;
  margin-bottom:6px;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

.pv-subtitle{ font-size:.8rem; margin-bottom:10px; }

.pv-badges{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-bottom:10px;
}

.pv-variants{
  border-top:1px dashed rgba(0,0,0,.10);
  padding-top:10px;
}

.pv-variants-title{
  font-size:.75rem;
  margin-bottom:6px;
}

.pv-variant-item{
  font-size:.8rem;
  line-height:1.3;
  padding:2px 0;
}

/* =========================================================
   TABS
   ========================================================= */

   .nav-link {
    color: var(--main-color);
   }

/* =====================================================
   UI CHECKBOX
   ===================================================== */

.ui-checkbox{
  /* base do variant (mesmo mapping is-*) */
  --aux-base: var(--aux-gray-base);

  /* tonalização roxa (igual seu design system) */
  --aux-toned: color-mix(
    in srgb,
    var(--aux-base) calc(100% - var(--aux-purple-bias)),
    var(--purple-600)
  );

  /* gradiente do estado ON */
  --aux-a: color-mix(in srgb, var(--aux-toned) 18%, var(--white));
  --aux-b: color-mix(in srgb, var(--aux-toned) 32%, var(--white));
  --aux-border: color-mix(in srgb, var(--aux-toned) 55%, transparent);

  --aux-gradient: linear-gradient(135deg, var(--aux-a), var(--aux-b));
  --aux-gradient-hover: linear-gradient(
    135deg,
    color-mix(in srgb, var(--aux-a) 70%, var(--white)),
    color-mix(in srgb, var(--aux-b) 70%, var(--white))
  );

  display: inline-flex;
  align-items: flex-end;
  height: 100%;
  padding-bottom: 7px;
}

.ui-checkbox input {
  display: none;
}

/* label clicável */
.ui-checkbox .ui-chk{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  user-select: none;
}

/* =====================================================
   BOX (OFF por padrão) - branco
   ===================================================== */
.ui-checkbox .ui-chk__box{
  width: 20px;
  height: 20px;
  border-radius: 4px;

  background: var(--white);
  border: 1px solid var(--gray-500);

  box-shadow:
    0 6px 14px rgba(45, 23, 100, 0.10),
    inset 0 0 0 1px rgba(255,255,255,0.65);

  display: grid;
  place-items: center;

  transition:
    transform .12s ease,
    box-shadow .12s ease,
    background .12s ease,
    border-color .12s ease,
    filter .12s ease;
}

/* hover leve no OFF */
.ui-checkbox .ui-chk:hover .ui-chk__box{
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--aux-toned) 25%, var(--gray-300));
  box-shadow:
    0 8px 16px rgba(45, 23, 100, 0.12),
    inset 0 0 0 1px rgba(255,255,255,0.65);
}

/* =====================================================
   CHECK (cor derivada do variant ativo)
   ===================================================== */
.ui-checkbox .ui-chk__box::after{
  content: "";
  width: 8px;
  height: 5px;
  border-left: 2.5px solid var(--aux-base);
  border-bottom: 2.5px solid var(--aux-base);
  transform: rotate(-45deg) scale(0);
  transform-origin: center;
  opacity: 0;
  transition: transform .12s ease, opacity .12s ease;
}

/* =====================================================
   ON (checked) - aplica cor escolhida
   ===================================================== */
.ui-checkbox .ui-chk__native:checked + .ui-chk .ui-chk__box{
  background: var(--aux-gradient);
  border-color: var(--aux-border);

  box-shadow:
    0 10px 22px rgba(45, 23, 100, 0.14),
    inset 0 0 0 1px color-mix(in srgb, var(--aux-toned) 16%, transparent);
}

/* hover no ON */
.ui-checkbox .ui-chk__native:checked + .ui-chk:hover .ui-chk__box{
  background: var(--aux-gradient-hover);
  filter: saturate(1.05);
}

/* mostra check */
.ui-checkbox .ui-chk__native:checked + .ui-chk .ui-chk__box::after{
  transform: rotate(-45deg) scale(1);
  opacity: 1;
}

/* focus ring */
.ui-checkbox .ui-chk__native:focus-visible + .ui-chk .ui-chk__box{
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--aux-toned) 55%, transparent),
    0 0 0 4px color-mix(in srgb, var(--aux-toned) 18%, transparent),
    0 10px 22px rgba(45, 23, 100, 0.12);
}

/* disabled */
.ui-checkbox .ui-chk__native:disabled + .ui-chk{
  opacity: .55;
  cursor: not-allowed;
}
.ui-checkbox .ui-chk__native:disabled + .ui-chk .ui-chk__box{
  transform: none;
  filter: grayscale(.15);
  box-shadow: none;
}

/* =====================================================
   Variants (igual botões) - mapeia base
   ===================================================== */
.ui-checkbox.is-purple { --aux-base: var(--purple-600); }
.ui-checkbox.is-blue   { --aux-base: var(--aux-blue-base); }
.ui-checkbox.is-green  { --aux-base: var(--aux-green-base); }
.ui-checkbox.is-red    { --aux-base: var(--aux-red-base); }
.ui-checkbox.is-orange { --aux-base: var(--aux-orange-base); }
.ui-checkbox.is-yellow { --aux-base: var(--aux-yellow-base); }
.ui-checkbox.is-cyan   { --aux-base: var(--aux-cyan-base); }
.ui-checkbox.is-pink   { --aux-base: var(--aux-pink-base); }
.ui-checkbox.is-teal   { --aux-base: var(--aux-teal-base); }
.ui-checkbox.is-gray   { --aux-base: var(--aux-gray-base); }
.btn-hover-fixed.disabled {
    opacity: .65;
}

/* Hover bem leve (cinza suave) */
.sb-row:hover > td {
    background-color: rgba(0, 0, 0, 0.035);
}

/* Deixa a transição suave ao entrar/sair */
.sb-row > td {
    transition: background-color 120ms ease-in-out;
}
