@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=Noto+Sans:wght@400;500;600;700;800;900&family=Material+Symbols+Rounded:opsz,wght,FILL,GRAD@20..48,500..700,0..1,-25..200&display=swap');

:root {
  --green-950: #172217;
  --green-900: #243426;
  --green-800: #344a36;
  --green-700: #435d45;
  --green-100: #edf3ed;
  --paper: #f8f7f2;
  --white: #fff;
  --ink: #172019;
  --muted: #69736b;
  --line: rgba(23, 32, 25, .13);
  --gold: #c8a85b;
  --red: #a64545;
  --blue: #365c7d;
  --radius: 8px;
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100%;
  color: var(--ink);
  font-family: "Segoe UI", Arial, sans-serif;
  letter-spacing: 0;
}

body {
  background: linear-gradient(145deg, #f7f5ee 0%, #e8eee6 46%, #dfe8dc 100%);
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input,
select {
  font: inherit;
}

.login-page {
  min-height: 100vh;
  display: grid;
  grid-template-columns: minmax(360px, .46fr) minmax(420px, .54fr);
}

.login-campaign {
  min-height: 100vh;
  padding: 56px;
  color: var(--white);
  background: linear-gradient(160deg, #405a42 0%, #243426 58%, #172217 100%);
  display: grid;
  align-content: center;
  gap: 16px;
}

.login-campaign img {
  width: 92px;
  height: 92px;
  border-radius: 50%;
  margin-bottom: 56px;
  box-shadow: 0 18px 48px rgba(0, 0, 0, .24);
}

.login-campaign span {
  color: rgba(255,255,255,.72);
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
}

.login-campaign h1 {
  margin: 0;
  max-width: 560px;
  font-size: 54px;
  line-height: 1;
}

.login-campaign p {
  max-width: 520px;
  margin: 0;
  color: rgba(255,255,255,.84);
  font-size: 18px;
  line-height: 1.5;
}

.login-panel {
  min-height: 100vh;
  padding: 58px;
  display: grid;
  align-content: center;
  gap: 18px;
  background: rgba(255,255,255,.88);
}

.installer-panel {
  align-content: start;
}

.login-heading {
  display: flex;
  align-items: center;
  gap: 12px;
}

.login-heading img,
.brand-mini img {
  width: 48px;
  height: 48px;
  border-radius: 50%;
}

.login-heading strong,
.brand-mini strong {
  display: block;
  color: var(--green-950);
  font-size: 18px;
}

.login-heading small,
.brand-mini small {
  display: block;
  color: var(--muted);
  margin-top: 2px;
}

.segmented {
  display: grid;
  grid-template-columns: 1.15fr 1fr .9fr;
  gap: 6px;
  padding: 5px;
  background: var(--green-100);
  border-radius: var(--radius);
}

.segmented button {
  min-height: 38px;
  border: 0;
  border-radius: 7px;
  background: transparent;
  color: var(--green-900);
  cursor: pointer;
  font-size: 12px;
  font-weight: 800;
}

.segmented button.active {
  background: var(--green-900);
  color: #fff;
}

.form-grid {
  display: grid;
  gap: 12px;
}

.split {
  display: grid;
  grid-template-columns: 1fr 120px;
  gap: 12px;
}

label {
  display: grid;
  gap: 6px;
  color: var(--green-950);
  font-size: 13px;
  font-weight: 800;
}

input,
select,
textarea {
  min-height: 44px;
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 7px;
  background: #fff;
  color: var(--ink);
  padding: 10px 12px;
  font-weight: 500;
}

textarea {
  min-height: 112px;
  resize: vertical;
}

hr {
  width: 100%;
  border: 0;
  border-top: 1px solid var(--line);
}

.button,
.inline-form button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  border: 0;
  border-radius: 7px;
  background: var(--green-900);
  color: #fff;
  cursor: pointer;
  font-size: 13px;
  font-weight: 900;
  padding: 10px 14px;
}

.button.secondary {
  background: #fff;
  color: var(--green-900);
  border: 1px solid var(--line);
}

.inline-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
}

.muted {
  color: var(--muted);
  line-height: 1.5;
}

.alert {
  border-radius: var(--radius);
  padding: 12px 14px;
  font-size: 13px;
  line-height: 1.45;
}

.alert.error {
  background: #fae8e8;
  color: var(--red);
}

.alert.success {
  background: var(--green-100);
  color: var(--green-800);
}

.card.highlight {
  border-color: rgba(200, 168, 91, .45);
  background: #fffaf0;
}

.secret-box {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  border-radius: 7px;
  background: var(--green-950);
  color: #fff;
  font-family: Consolas, "Courier New", monospace;
  font-size: 17px;
  font-weight: 900;
  letter-spacing: 0;
  padding: 8px 12px;
  margin: 4px 0 8px;
}

.app-shell {
  display: grid;
  grid-template-columns: 240px 1fr;
  min-height: 100vh;
}

.sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  background: #fcfbf7;
  border-right: 1px solid var(--line);
  padding: 22px 16px;
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.brand-mini {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--line);
}

.nav-list {
  display: grid;
  gap: 6px;
}

.nav-list a {
  display: grid;
  grid-template-columns: 26px 1fr;
  align-items: center;
  gap: 9px;
  min-height: 42px;
  border-radius: 7px;
  color: #354139;
  font-size: 14px;
  font-weight: 800;
  padding: 8px;
}

.nav-list a.active {
  background: var(--green-900);
  color: #fff;
}

.nav-list i {
  width: 24px;
  height: 24px;
  border-radius: 6px;
  display: grid;
  place-items: center;
  background: rgba(67, 93, 69, .12);
  color: var(--green-800);
  font-style: normal;
  font-size: 12px;
}

.nav-list a.active i {
  background: rgba(255, 255, 255, .14);
  color: var(--gold);
}

.sidebar-footer {
  margin-top: auto;
  display: grid;
  gap: 4px;
  color: var(--green-950);
  font-weight: 800;
  font-size: 13px;
}

.sidebar-footer small {
  color: var(--muted);
}

.sidebar-footer a {
  margin-top: 8px;
  color: var(--red);
}

.main-content {
  padding: 32px;
}

.page-header {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  align-items: flex-start;
  margin-bottom: 22px;
}

.page-header h1 {
  margin: 0;
  color: var(--green-950);
  font-size: 34px;
  line-height: 1.05;
}

.page-header p {
  margin: 8px 0 0;
  color: var(--muted);
}

.actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 18px;
}

.metrics article,
.card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255,255,255,.88);
  padding: 18px;
}

.metrics article {
  min-height: 122px;
  display: grid;
  align-content: space-between;
}

.metrics span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.metrics strong {
  display: block;
  color: var(--green-950);
  font-size: 34px;
  line-height: 1;
}

.metrics small {
  color: var(--green-700);
  font-weight: 800;
}

.grid-2,
.grid-3 {
  display: grid;
  gap: 16px;
  margin-bottom: 18px;
}

.grid-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.grid-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.card h2 {
  margin: 0 0 10px;
  color: var(--green-950);
  font-size: 20px;
}

.card p,
.card small {
  color: var(--muted);
  line-height: 1.5;
}

.badge-row {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 12px;
}

.badge-row span,
.pill {
  border-radius: 999px;
  background: var(--green-100);
  color: var(--green-800);
  font-size: 12px;
  font-weight: 900;
  padding: 6px 10px;
}

.table-wrap {
  overflow-x: auto;
}

table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}

th,
td {
  border-bottom: 1px solid var(--line);
  padding: 12px;
  text-align: left;
  vertical-align: top;
}

th {
  color: var(--green-950);
  font-size: 12px;
  text-transform: uppercase;
}

.mail-list {
  display: grid;
  gap: 10px;
}

.mail-list div {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 4px 12px;
  border: 1px solid var(--line);
  border-radius: 7px;
  padding: 12px;
}

.mail-list b {
  color: var(--green-950);
}

.mail-list span {
  color: var(--muted);
}

.mail-list small {
  grid-row: 1 / span 2;
  grid-column: 2;
  align-self: center;
  color: var(--blue);
  font-weight: 900;
}

.table-link {
  color: var(--blue);
  font-weight: 900;
}

.compact-form {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}

.timeline {
  display: grid;
  gap: 10px;
}

.timeline div {
  border: 1px solid var(--line);
  border-radius: 7px;
  background: #fff;
  padding: 12px;
  display: grid;
  gap: 4px;
}

.timeline b {
  color: var(--green-950);
}

.timeline span {
  color: #3b473f;
  line-height: 1.45;
}

.timeline small {
  color: var(--muted);
  font-weight: 800;
}

.money {
  color: var(--green-950);
  font-size: 26px;
  font-weight: 900;
  margin: 0;
}

code {
  color: var(--green-950);
  font-family: Consolas, "Courier New", monospace;
  font-size: 12px;
  word-break: break-all;
}

.checkbox-line {
  display: flex;
  grid-template-columns: none;
  align-items: center;
  gap: 10px;
  color: var(--green-950);
  font-weight: 800;
}

.checkbox-line input {
  width: 18px;
  min-height: 18px;
}

.integration-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-bottom: 18px;
}

.integration-card {
  display: grid;
  align-content: start;
}

.integration-title {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
}

.integration-title h2 {
  margin-bottom: 6px;
}

.form-actions {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.json-preview {
  max-height: 420px;
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 7px;
  background: #111912;
  color: #f6f8f5;
  padding: 14px;
  white-space: pre-wrap;
  word-break: break-word;
}

.status-ok {
  background: #e4f4e8 !important;
  color: #25613a !important;
}

.status-warn {
  background: #fff3d7 !important;
  color: #7b5716 !important;
}

.status-error {
  background: #f8dddd !important;
  color: #8f2f2f !important;
}

.field-help {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

.diagnostic-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

@media (max-width: 900px) {
  .login-page,
  .app-shell,
  .grid-2,
  .grid-3,
  .metrics,
  .integration-grid,
  .diagnostic-summary {
    grid-template-columns: 1fr;
  }

  .login-campaign,
  .login-panel {
    min-height: auto;
    padding: 32px;
  }

  .sidebar {
    position: static;
    height: auto;
  }

  .page-header {
    flex-direction: column;
  }
}

/* Pack 0.6.1 - Login A3 com Gabo Assinador */
.a3-login-card {
  display: grid;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(237, 243, 237, .52);
  padding: 14px;
}

.a3-login-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.a3-login-head strong {
  display: block;
  color: var(--green-950);
  font-size: 15px;
}

.a3-login-head small {
  display: block;
  color: var(--muted);
  margin-top: 3px;
  line-height: 1.35;
}

.a3-status-box {
  min-height: 44px;
  border: 1px solid rgba(23, 32, 25, .10);
  border-radius: 7px;
  background: rgba(255, 255, 255, .74);
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
  padding: 10px;
}

.a3-status-box.ok {
  background: #eef7ef;
  color: var(--green-800);
  border-color: rgba(67, 93, 69, .22);
}

.a3-status-box.warn {
  background: #fbf2d6;
  color: #7d6720;
  border-color: rgba(200, 168, 91, .34);
}

.a3-status-box.error {
  background: #fae8e8;
  color: var(--red);
  border-color: rgba(166, 69, 69, .24);
}

.a3-cert-box {
  display: grid;
  gap: 6px;
}

.a3-login-actions {
  display: grid;
  grid-template-columns: .95fr 1.05fr;
  gap: 10px;
  align-items: stretch;
}

.a3-login-actions form {
  display: grid;
}

.status-pill {
  flex: 0 0 auto;
  border-radius: 999px;
  padding: 6px 9px;
  background: #eef0ea;
  color: var(--green-900);
  font-size: 11px;
  font-weight: 800;
  white-space: nowrap;
}

.status-pill.status-ok {
  background: #e5f2e8;
  color: var(--green-800);
}

.status-pill.status-warn {
  background: #fbf2d6;
  color: #7d6720;
}

.status-pill.status-error {
  background: #fae8e8 !important;
  color: var(--red) !important;
}

@media (max-width: 640px) {
  .a3-login-actions {
    grid-template-columns: 1fr;
  }

  .a3-login-head {
    flex-direction: column;
  }
}


/* Pack 0.6.2.1 - Efeitos, fontes e iconologia Gabo One UI
   Recompilado com alterações reais de CSS/JS/views. */
:root {
  --font-ui: "Inter", "Noto Sans", "Segoe UI", Arial, sans-serif;
  --font-mono: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
  --surface-glass: rgba(255,255,255,.72);
  --shadow-soft: 0 18px 60px rgba(23, 32, 25, .12);
  --shadow-card: 0 14px 34px rgba(23, 32, 25, .09);
  --shadow-hover: 0 18px 40px rgba(23, 32, 25, .14);
  --focus-ring: 0 0 0 4px rgba(67, 93, 69, .18);
  --motion: cubic-bezier(.2,.8,.2,1);
}

html, body, button, input, select, textarea {
  font-family: var(--font-ui);
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.material-symbols-rounded,
.nav-list i[data-gabo-icon="1"],
[data-icon]::before {
  font-family: "Material Symbols Rounded";
  font-weight: normal;
  font-style: normal;
  font-size: 20px;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  display: inline-flex;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  font-feature-settings: "liga";
  -webkit-font-feature-settings: "liga";
  -webkit-font-smoothing: antialiased;
  font-variation-settings: "FILL" 0, "wght" 650, "GRAD" 0, "opsz" 24;
}

body {
  background:
    radial-gradient(circle at 12% 8%, rgba(200, 168, 91, .13), transparent 28%),
    radial-gradient(circle at 92% 14%, rgba(67, 93, 69, .11), transparent 26%),
    linear-gradient(145deg, #f7f5ee 0%, #e8eee6 46%, #dfe8dc 100%);
}

.login-page {
  position: relative;
  overflow-x: hidden;
}

.login-page::before,
.app-shell::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 28% 18%, rgba(255,255,255,.38), transparent 19%),
    radial-gradient(circle at 82% 92%, rgba(200,168,91,.10), transparent 26%);
  opacity: .9;
  z-index: -1;
}

.login-campaign {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background:
    radial-gradient(circle at 14% 18%, rgba(255,255,255,.12), transparent 24%),
    linear-gradient(160deg, #405a42 0%, #243426 58%, #172217 100%);
}

.login-campaign::before,
.login-campaign::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
  z-index: -1;
}

.login-campaign::before {
  width: 320px;
  height: 320px;
  right: -110px;
  bottom: -120px;
  border: 1px solid rgba(255,255,255,.13);
}

.login-campaign::after {
  width: 180px;
  height: 180px;
  left: 52px;
  top: 96px;
  background: radial-gradient(circle, rgba(255,255,255,.11), transparent 62%);
  filter: blur(.2px);
}

.login-campaign img,
.login-heading img,
.brand-mini img {
  object-fit: contain;
  transform: translateZ(0);
}

.login-campaign img {
  animation: gaboLogoPulse 6.5s var(--motion) infinite;
}

.login-campaign h1,
.page-header h1 {
  letter-spacing: -0.045em;
}

.login-panel,
.main-content {
  backdrop-filter: blur(12px);
}

.login-trust-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.login-trust-list span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 34px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  background: rgba(255,255,255,.09);
  color: rgba(255,255,255,.88);
  font-size: 12px;
  font-weight: 800;
  padding: 7px 10px;
}

.segmented,
.a3-login-card,
.card,
.metrics article,
.integration-card,
.login-panel,
.table-wrap,
.alert,
.mail-list div,
.timeline div {
  box-shadow: var(--shadow-card);
}

.segmented,
.a3-login-card,
.card,
.metrics article,
.integration-card,
.login-panel,
.table-wrap,
.alert,
.mail-list div,
.timeline div,
.button,
.inline-form button,
input,
select,
textarea,
.nav-list a {
  transition:
    transform .22s var(--motion),
    box-shadow .22s var(--motion),
    border-color .22s var(--motion),
    background-color .22s var(--motion),
    color .22s var(--motion),
    opacity .22s var(--motion);
}

.card:hover,
.metrics article:hover,
.integration-card:hover,
.mail-list div:hover,
.timeline div:hover,
.a3-login-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-hover);
  border-color: rgba(67, 93, 69, .24);
}

.button:hover,
.inline-form button:hover,
.segmented button:hover,
.nav-list a:hover {
  transform: translateY(-1px);
}

.button:active,
.inline-form button:active,
.segmented button:active,
.nav-list a:active {
  transform: translateY(0) scale(.985);
}

.button:focus-visible,
.inline-form button:focus-visible,
.segmented button:focus-visible,
.nav-list a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 0;
  box-shadow: var(--focus-ring);
  border-color: rgba(67, 93, 69, .42);
}

input:focus,
select:focus,
textarea:focus {
  border-color: rgba(67, 93, 69, .42);
  box-shadow: var(--focus-ring);
}

.button,
.inline-form button {
  position: relative;
  overflow: hidden;
}

.button::after,
.inline-form button::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent, rgba(255,255,255,.18), transparent);
  transform: translateX(-120%);
  transition: transform .55s var(--motion);
}

.button:hover::after,
.inline-form button:hover::after {
  transform: translateX(120%);
}

.nav-list a {
  position: relative;
  overflow: hidden;
}

.nav-list a.active {
  box-shadow: 0 10px 28px rgba(23, 34, 23, .18);
}

.nav-list a::after {
  content: "";
  position: absolute;
  inset: 8px auto 8px 0;
  width: 3px;
  border-radius: 999px;
  background: var(--gold);
  opacity: 0;
  transform: scaleY(.4);
  transition: opacity .2s var(--motion), transform .2s var(--motion);
}

.nav-list a.active::after,
.nav-list a:hover::after {
  opacity: 1;
  transform: scaleY(1);
}

.nav-list i {
  font-style: normal;
  font-weight: 900;
}

.nav-list i[data-gabo-icon="1"] {
  font-size: 18px;
}

.brand-mini,
.login-heading {
  min-width: 0;
}

.brand-mini span,
.login-heading div {
  min-width: 0;
}

.status-pill,
.badge-row span,
.pill {
  box-shadow: 0 7px 18px rgba(23,32,25,.07);
}

.metrics article strong,
.money {
  letter-spacing: -.035em;
}

.table-wrap {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface-glass);
}

.table-wrap table {
  background: transparent;
}

th {
  letter-spacing: .02em;
}

tr:hover td {
  background: rgba(237, 243, 237, .48);
}

.a3-status-box {
  position: relative;
  overflow: hidden;
}

.a3-status-box.warn::before,
.a3-status-box.ok::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: var(--gold);
}

.a3-status-box.ok::before {
  background: var(--green-700);
}

[data-reveal] {
  opacity: 0;
  transform: translateY(8px);
}

[data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
  transition: opacity .36s var(--motion), transform .36s var(--motion);
}

.gabo-toast-stack {
  position: fixed;
  right: 18px;
  bottom: 18px;
  display: grid;
  gap: 10px;
  z-index: 1000;
  pointer-events: none;
}

.gabo-toast {
  max-width: 360px;
  border: 1px solid rgba(67,93,69,.18);
  border-radius: 8px;
  background: rgba(255,255,255,.94);
  box-shadow: 0 18px 44px rgba(23,32,25,.16);
  color: var(--green-950);
  padding: 12px 14px;
  font-size: 13px;
  line-height: 1.45;
  pointer-events: auto;
  animation: gaboToastIn .26s var(--motion) both;
}

.gabo-toast strong {
  display: block;
  margin-bottom: 2px;
}

@keyframes gaboLogoPulse {
  0%, 100% { transform: translateY(0) scale(1); box-shadow: 0 18px 48px rgba(0,0,0,.24); }
  50% { transform: translateY(-3px) scale(1.02); box-shadow: 0 28px 70px rgba(0,0,0,.28); }
}

@keyframes gaboToastIn {
  from { opacity: 0; transform: translateY(8px) scale(.98); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

@media (max-width: 900px) {
  .login-page {
    background: linear-gradient(145deg, #f7f5ee 0%, #e8eee6 46%, #dfe8dc 100%);
  }

  .login-campaign {
    min-height: 360px;
  }

  .login-campaign img {
    margin-bottom: 18px;
  }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: .01ms !important;
  }
}


/* Pack 0.6.2.2 - Gabo One UI Icon Kit
   Iconologia própria em SVG inline, com tratamento visual inspirado em One UI moderna.
   Não usa assets proprietários Samsung; preserva Material Symbols apenas como fallback. */
:root {
  --oneui-bg: #f6f8f5;
  --oneui-surface: rgba(255,255,255,.86);
  --oneui-surface-strong: #ffffff;
  --oneui-border: rgba(24, 39, 26, .10);
  --oneui-shadow-sm: 0 8px 22px rgba(18, 31, 20, .08);
  --oneui-shadow-md: 0 18px 46px rgba(18, 31, 20, .13);
  --oneui-shadow-lg: 0 28px 78px rgba(18, 31, 20, .17);
  --oneui-ease: cubic-bezier(.16, 1, .3, 1);
  --oneui-radius: 8px;
  --oneui-icon-green-a: #e6f2e7;
  --oneui-icon-green-b: #cfe5d1;
  --oneui-icon-gold-a: #fff5dc;
  --oneui-icon-gold-b: #ecd38e;
  --oneui-icon-blue-a: #e7f0f7;
  --oneui-icon-blue-b: #c8dcec;
  --oneui-icon-red-a: #fbeaea;
  --oneui-icon-red-b: #efc3c3;
}

html, body, button, input, select, textarea {
  font-family: "Inter", "Noto Sans", "Segoe UI", Arial, sans-serif;
}

body.gabo-oneui-v0622,
.gabo-oneui-v0622 {
  background:
    radial-gradient(circle at 14% 12%, rgba(200,168,91,.14), transparent 28%),
    radial-gradient(circle at 88% 8%, rgba(67,93,69,.12), transparent 24%),
    linear-gradient(145deg, #f8f7f2 0%, #edf3ec 44%, #e1eadf 100%);
}

.gabo-oneui-v0622 .sidebar {
  background: rgba(252,251,247,.94);
  backdrop-filter: blur(18px) saturate(135%);
  -webkit-backdrop-filter: blur(18px) saturate(135%);
  box-shadow: 10px 0 38px rgba(23,32,25,.06);
}

.gabo-oneui-v0622 .brand-mini img,
.gabo-oneui-v0622 .login-heading img,
.gabo-oneui-v0622 .login-campaign img {
  object-fit: contain;
  background: rgba(255,255,255,.74);
  border: 1px solid rgba(255,255,255,.64);
}

.gabo-oneui-v0622 .nav-list a {
  position: relative;
  min-height: 44px;
  border-radius: var(--oneui-radius);
  overflow: hidden;
  transition: transform .22s var(--oneui-ease), background .22s var(--oneui-ease), box-shadow .22s var(--oneui-ease), color .22s var(--oneui-ease);
}

.gabo-oneui-v0622 .nav-list a::before {
  content: "";
  position: absolute;
  inset: 5px auto 5px 0;
  width: 3px;
  border-radius: 999px;
  background: transparent;
  transition: background .22s var(--oneui-ease);
}

.gabo-oneui-v0622 .nav-list a:hover {
  background: rgba(67,93,69,.08);
  transform: translateX(2px);
}

.gabo-oneui-v0622 .nav-list a.active {
  background: linear-gradient(135deg, #213322, #405a42);
  box-shadow: var(--oneui-shadow-sm);
}

.gabo-oneui-v0622 .nav-list a.active::before {
  background: var(--gold);
}

.gabo-oneui-v0622 .nav-list i,
.gabo-oneui-icon {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  display: inline-grid;
  place-items: center;
  overflow: hidden;
  flex: 0 0 auto;
  color: #243426;
  background: linear-gradient(145deg, var(--oneui-icon-green-a), var(--oneui-icon-green-b));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.72), 0 8px 18px rgba(23,32,25,.08);
}

.gabo-oneui-v0622 .nav-list a.active i,
.gabo-oneui-v0622 .nav-list a.active .gabo-oneui-icon {
  color: #fff;
  background: linear-gradient(145deg, rgba(255,255,255,.22), rgba(255,255,255,.08));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18), 0 10px 20px rgba(0,0,0,.12);
}

.gabo-icon-svg {
  width: 18px;
  height: 18px;
  display: block;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.15;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.gabo-oneui-v0622 .login-page,
body.login-page.gabo-oneui-v0622 {
  min-height: 100vh;
  background:
    radial-gradient(circle at 13% 14%, rgba(200,168,91,.14), transparent 26%),
    linear-gradient(145deg, #f7f5ee 0%, #e8eee6 46%, #dfe8dc 100%);
}

body.login-page.gabo-oneui-v0622 {
  display: grid;
  grid-template-columns: minmax(420px, .48fr) minmax(480px, .52fr);
}

.gabo-oneui-v0622 .login-campaign {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 18% 18%, rgba(255,255,255,.12), transparent 26%),
    radial-gradient(circle at 92% 88%, rgba(200,168,91,.16), transparent 32%),
    linear-gradient(160deg, #435d45 0%, #243426 58%, #172217 100%);
}

.gabo-oneui-v0622 .login-campaign::after {
  content: "";
  position: absolute;
  right: -90px;
  bottom: -90px;
  width: 320px;
  height: 320px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.13);
}

.gabo-oneui-v0622 .login-panel {
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(18px) saturate(145%);
  -webkit-backdrop-filter: blur(18px) saturate(145%);
}

.gabo-oneui-v0622 .login-trust-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 22px;
}

.gabo-oneui-v0622 .login-trust-list span {
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  color: rgba(255,255,255,.86);
  padding: 7px 12px 7px 8px;
  font-size: 12px;
  font-weight: 800;
  text-transform: none;
  backdrop-filter: blur(8px);
}

.gabo-oneui-v0622 .login-trust-list i {
  width: 26px;
  height: 26px;
  border-radius: 8px;
  display: inline-grid;
  place-items: center;
  color: #243426;
  background: linear-gradient(145deg, #fff8e7, #e5cf91);
}

.gabo-oneui-v0622 .segmented,
.gabo-oneui-v0622 .a3-login-card,
.gabo-oneui-v0622 .card,
.gabo-oneui-v0622 .metrics article,
.gabo-oneui-v0622 .table-wrap {
  border: 1px solid var(--oneui-border);
  border-radius: var(--oneui-radius);
  background: var(--oneui-surface);
  box-shadow: var(--oneui-shadow-sm);
}

.gabo-oneui-v0622 .a3-login-card,
.gabo-oneui-v0622 .card,
.gabo-oneui-v0622 .metrics article {
  transition: transform .22s var(--oneui-ease), box-shadow .22s var(--oneui-ease), border-color .22s var(--oneui-ease);
}

.gabo-oneui-v0622 .a3-login-card:hover,
.gabo-oneui-v0622 .card:hover,
.gabo-oneui-v0622 .metrics article:hover {
  transform: translateY(-2px);
  box-shadow: var(--oneui-shadow-md);
  border-color: rgba(67,93,69,.16);
}

.gabo-oneui-v0622 .button,
.gabo-oneui-v0622 .inline-form button,
.gabo-oneui-v0622 .segmented button {
  border-radius: var(--oneui-radius);
  transition: transform .18s var(--oneui-ease), box-shadow .18s var(--oneui-ease), background .18s var(--oneui-ease), color .18s var(--oneui-ease);
}

.gabo-oneui-v0622 .button:not(.secondary),
.gabo-oneui-v0622 .inline-form button {
  background: linear-gradient(135deg, #243426, #435d45);
  box-shadow: 0 12px 24px rgba(36,52,38,.18);
}

.gabo-oneui-v0622 .button:hover,
.gabo-oneui-v0622 .inline-form button:hover,
.gabo-oneui-v0622 .segmented button:hover {
  transform: translateY(-1px);
}

.gabo-oneui-v0622 input,
.gabo-oneui-v0622 select,
.gabo-oneui-v0622 textarea {
  border-radius: var(--oneui-radius);
  background: rgba(255,255,255,.96);
  transition: border-color .18s var(--oneui-ease), box-shadow .18s var(--oneui-ease), background .18s var(--oneui-ease);
}

.gabo-oneui-v0622 input:focus,
.gabo-oneui-v0622 select:focus,
.gabo-oneui-v0622 textarea:focus {
  outline: 0;
  border-color: rgba(67,93,69,.48);
  box-shadow: 0 0 0 4px rgba(67,93,69,.14);
  background: #fff;
}

.gabo-oneui-v0622 .metrics article:nth-child(4n+1) { background: linear-gradient(145deg, rgba(255,255,255,.92), rgba(230,242,231,.72)); }
.gabo-oneui-v0622 .metrics article:nth-child(4n+2) { background: linear-gradient(145deg, rgba(255,255,255,.92), rgba(255,245,220,.72)); }
.gabo-oneui-v0622 .metrics article:nth-child(4n+3) { background: linear-gradient(145deg, rgba(255,255,255,.92), rgba(231,240,247,.72)); }
.gabo-oneui-v0622 .metrics article:nth-child(4n+4) { background: linear-gradient(145deg, rgba(255,255,255,.92), rgba(251,234,234,.58)); }

.gabo-oneui-v0622 .status-pill,
.gabo-oneui-v0622 .pill,
.gabo-oneui-v0622 .badge-row span {
  border: 1px solid rgba(67,93,69,.12);
}

@media (max-width: 900px) {
  body.login-page.gabo-oneui-v0622 {
    grid-template-columns: 1fr;
  }
}

/* Pack 0.6.2.3 - Sidebar fixa com rolagem própria e logout na navegação. */
:root {
  --gabo-sidebar-width: 240px;
}

body.gabo-sidebar-v0623.app-shell {
  display: block;
  min-height: 100dvh;
}

.gabo-sidebar-v0623 .sidebar {
  position: fixed;
  inset: 0 auto 0 0;
  z-index: 40;
  width: var(--gabo-sidebar-width);
  height: 100dvh;
  max-height: 100dvh;
  overflow: hidden;
  padding: 18px 14px;
  gap: 14px;
}

.gabo-sidebar-v0623 .brand-mini {
  flex: 0 0 auto;
  align-items: flex-start;
  min-width: 0;
  padding: 4px 6px 16px;
}

.gabo-sidebar-v0623 .brand-mini img {
  flex: 0 0 auto;
  width: 44px;
  height: 44px;
  object-fit: contain;
}

.gabo-sidebar-v0623 .brand-mini span {
  display: grid;
  gap: 2px;
  min-width: 0;
  line-height: 1.18;
}

.gabo-sidebar-v0623 .brand-mini strong {
  font-size: 15px;
  line-height: 1.15;
}

.gabo-sidebar-v0623 .sidebar-user-name {
  display: block;
  color: #26362a;
  font-size: 12px;
  font-weight: 800;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.gabo-sidebar-v0623 .sidebar-user-matricula {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  line-height: 1.2;
  letter-spacing: .01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.gabo-sidebar-v0623 .nav-list {
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 0 4px 4px 0;
  scrollbar-width: thin;
  scrollbar-color: rgba(67, 93, 69, .35) transparent;
}

.gabo-sidebar-v0623 .nav-list::-webkit-scrollbar {
  width: 8px;
}

.gabo-sidebar-v0623 .nav-list::-webkit-scrollbar-track {
  background: transparent;
}

.gabo-sidebar-v0623 .nav-list::-webkit-scrollbar-thumb {
  background: rgba(67, 93, 69, .28);
  border-radius: 999px;
}

.gabo-sidebar-v0623 .nav-list a {
  flex: 0 0 auto;
  width: 100%;
}

.gabo-sidebar-v0623 .nav-list .logout-link {
  margin-top: auto;
  color: var(--red);
  background: rgba(166, 69, 69, .07);
  border: 1px solid rgba(166, 69, 69, .11);
}

.gabo-sidebar-v0623 .nav-list .logout-link:hover {
  color: #8d3030;
  background: rgba(166, 69, 69, .12);
}

.gabo-sidebar-v0623 .nav-list .logout-link i,
.gabo-sidebar-v0623 .nav-list .logout-link .gabo-oneui-icon {
  color: #8d3030;
  background: linear-gradient(145deg, #fff5f3, #f3d2cc);
}

.gabo-sidebar-v0623 .main-content {
  margin-left: var(--gabo-sidebar-width);
  min-height: 100dvh;
  padding: 32px;
}

.gabo-sidebar-v0623 .sidebar-footer {
  display: none !important;
}

@media (max-width: 860px) {
  body.gabo-sidebar-v0623.app-shell {
    display: grid;
    grid-template-columns: 1fr;
  }

  .gabo-sidebar-v0623 .sidebar {
    position: sticky;
    top: 0;
    width: 100%;
    height: auto;
    max-height: 72vh;
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .gabo-sidebar-v0623 .nav-list {
    max-height: 44vh;
  }

  .gabo-sidebar-v0623 .main-content {
    margin-left: 0;
    padding: 20px;
  }
}

/* SisGabo 0.9.1 — Cobertura do checklist */
.coverage-header .eyebrow {
  margin: 0 0 4px;
  color: var(--green-700);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.coverage-actions {
  align-items: center;
}

.coverage-summary article strong {
  letter-spacing: -.04em;
}

.coverage-legend {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 18px;
}

.coverage-legend-item {
  display: grid;
  grid-template-columns: 14px 1fr;
  column-gap: 10px;
  align-items: start;
  min-height: 58px;
}

.coverage-legend-item b {
  display: block;
  color: var(--green-950);
  font-size: 13px;
}

.coverage-legend-item small {
  grid-column: 2;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.coverage-dot {
  width: 12px;
  height: 12px;
  border-radius: 999px;
  margin-top: 3px;
  box-shadow: 0 0 0 4px rgba(67, 93, 69, .08);
}

.status-presente { background: #2f7d52; }
.status-parcial { background: #c8a85b; }
.status-pendente { background: #5d6f82; }
.status-nao_encontrado { background: #a64545; }

.coverage-department {
  margin-bottom: 18px;
  overflow: hidden;
}

.coverage-department-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
  margin-bottom: 14px;
}

.coverage-department-head h2 {
  margin: 0;
  color: var(--green-950);
  font-size: 20px;
  line-height: 1.2;
}

.coverage-department-head p {
  margin: 5px 0 0;
  max-width: 880px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.coverage-department-head > span {
  flex: 0 0 auto;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255,255,255,.78);
  color: var(--green-800);
  font-size: 12px;
  font-weight: 900;
  padding: 7px 10px;
}

.coverage-table-wrap {
  width: 100%;
  overflow-x: auto;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
}

.coverage-table {
  width: 100%;
  min-width: 980px;
  border-collapse: collapse;
}

.coverage-table th,
.coverage-table td {
  padding: 12px;
  border-bottom: 1px solid rgba(23, 32, 25, .08);
  text-align: left;
  vertical-align: top;
  font-size: 13px;
}

.coverage-table th {
  color: var(--green-900);
  background: rgba(237, 243, 237, .62);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .02em;
}

.coverage-table tbody tr:last-child td {
  border-bottom: 0;
}

.coverage-table td strong {
  display: block;
  color: var(--green-950);
  font-size: 14px;
  line-height: 1.25;
}

.coverage-table td small {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  line-height: 1.35;
}

.coverage-table code {
  display: inline-block;
  margin-top: 7px;
  border-radius: 6px;
  background: rgba(23, 32, 25, .055);
  color: var(--green-800);
  font-size: 11px;
  padding: 4px 6px;
}

.coverage-status,
.coverage-priority {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 900;
  padding: 5px 8px;
  white-space: nowrap;
}

.coverage-status-presente { background: #e3f2e9; color: #1f6b43; }
.coverage-status-parcial { background: #fbf2d6; color: #80661d; }
.coverage-status-pendente { background: #edf1f5; color: #40566c; }
.coverage-status-nao_encontrado { background: #fae8e8; color: #9b3636; }
.coverage-priority { background: rgba(67, 93, 69, .1); color: var(--green-800); }

.coverage-checks {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.coverage-check {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
  line-height: 1.2;
  padding: 5px 7px;
}

.coverage-check.ok {
  background: #e9f4ed;
  color: #1f6b43;
}

.coverage-check.fail {
  background: #f3f1ea;
  color: #7b7466;
}

.coverage-notes ul {
  margin: 8px 0 0;
  padding-left: 20px;
  color: var(--muted);
  line-height: 1.55;
}

@media (max-width: 900px) {
  .coverage-legend {
    grid-template-columns: 1fr 1fr;
  }

  .coverage-department-head {
    flex-direction: column;
  }
}

@media (max-width: 640px) {
  .coverage-legend {
    grid-template-columns: 1fr;
  }
}

/* Pack 0.9.2 - calendário moderno, login por abas, cadastro público e botões de integração. */
.gabo-v092 .nav-list a[href="/agenda"] i::after { content: ""; }
.gabo-v092 .nav-list a { scroll-margin: 10px; }

.button i,
.inline-form button i,
.integration-button-row i,
.integration-local-actions i,
.login-password-form .button i,
.public-register-form .button i,
.a3-login-actions i,
.page-header .button i {
  width: 18px;
  height: 18px;
  display: inline-grid;
  place-items: center;
  flex: 0 0 auto;
}

.button,
.inline-form button,
.form-actions button,
.page-header .button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
}

.login-v092 .login-panel-v092 {
  max-width: 520px;
}

.login-v092 .login-tabs {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
  margin-bottom: 14px;
}

.login-v092 .login-tabs button {
  min-height: 42px;
  white-space: normal;
}

.login-tab-pane {
  display: block;
}

.login-tab-pane[hidden],
.login-extra-panel[hidden],
.conditional-fields[hidden] {
  display: none !important;
}

.login-utility-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin: 10px 0 4px;
}

.link-button {
  background: transparent;
  border: 0;
  color: var(--green-800);
  font-weight: 800;
  cursor: pointer;
  padding: 4px 0;
}

.link-button:hover {
  color: var(--green-950);
  text-decoration: underline;
}

.login-extra-panel {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}

.login-extra-panel h2 {
  margin: 0 0 10px;
  font-size: 17px;
  color: var(--green-950);
}

.a3-inline {
  border: 1px solid var(--line);
  background: rgba(255,255,255,.74);
  border-radius: var(--radius);
  padding: 14px;
}

.inline-actions,
.integration-button-row,
.integration-local-actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
}

.integration-button-row {
  grid-column: 1 / -1;
  justify-content: flex-start;
  margin-top: 2px;
}

.integration-local-actions {
  margin: 10px 0 8px;
}

.integration-local-actions .mini,
.button.mini {
  min-height: 34px;
  padding: 7px 9px;
  font-size: 12px;
  border-radius: 7px;
}

.integration-config-form .form-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.integration-actions-top {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.integration-inline-form {
  gap: 6px;
}

.integration-inline-form button {
  white-space: nowrap;
}

.integration-native-card {
  border-color: rgba(67,93,69,.24);
  box-shadow: 0 14px 38px rgba(23,32,25,.07);
}

.input-action-wrap {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 6px;
  align-items: center;
}

.mini-button {
  border: 1px solid var(--line);
  background: var(--green-900);
  color: #fff;
  border-radius: 7px;
  font-weight: 800;
  min-height: 40px;
  padding: 8px 10px;
  cursor: pointer;
}

.field-ok {
  border-color: rgba(31,107,67,.42) !important;
  box-shadow: 0 0 0 3px rgba(31,107,67,.08);
}

.field-error {
  border-color: rgba(166,69,69,.48) !important;
  box-shadow: 0 0 0 3px rgba(166,69,69,.08);
}

.calendar-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(320px, .75fr);
  gap: 16px;
  align-items: start;
}

.calendar-card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255,255,255,.86);
  padding: 18px;
  box-shadow: 0 18px 48px rgba(23,32,25,.08);
}

.calendar-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
  margin-bottom: 14px;
}

.calendar-head h2 {
  margin: 0;
  color: var(--green-950);
  font-size: 20px;
}

.calendar-head p {
  margin: 4px 0 0;
  color: var(--muted);
  line-height: 1.45;
}

.calendar-controls {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 14px;
}

.calendar-slots {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(92px, 1fr));
  gap: 8px;
}

.calendar-slot {
  min-height: 42px;
  border: 1px solid rgba(67,93,69,.16);
  border-radius: 7px;
  background: #fff;
  color: var(--green-900);
  font-weight: 800;
  cursor: pointer;
  transition: transform .16s ease, box-shadow .16s ease, background .16s ease;
}

.calendar-slot:hover:not(:disabled),
.calendar-slot.active {
  transform: translateY(-1px);
  background: var(--green-900);
  color: #fff;
  box-shadow: 0 10px 24px rgba(23,32,25,.16);
}

.calendar-slot:disabled {
  cursor: not-allowed;
  opacity: .45;
  background: #f3f1ea;
}

.calendar-selected {
  grid-column: 1 / -1;
  border: 1px dashed rgba(67,93,69,.28);
  border-radius: 7px;
  padding: 10px;
  color: var(--muted);
  background: rgba(237,243,237,.44);
}

@media (max-width: 980px) {
  .calendar-shell {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .login-v092 .login-tabs,
  .calendar-controls {
    grid-template-columns: 1fr;
  }
  .integration-local-actions,
  .integration-button-row,
  .login-utility-row {
    flex-direction: column;
    align-items: stretch;
  }
  .integration-local-actions .button,
  .integration-button-row .button,
  .login-utility-row .link-button {
    width: 100%;
  }
}

/* Pack 0.9.3 - refinamentos de login, Assinador, Integrações, Atualizador e Central de e-mails. */
body.login-page.login-v093 {
  grid-template-columns: minmax(420px, 46vw) minmax(0, 1fr);
  align-items: stretch;
  overflow-x: hidden;
}

.login-v093 .login-panel-v093 {
  width: 100%;
  max-width: none;
  background:
    radial-gradient(circle at 72% 28%, rgba(200,168,91,.12), transparent 28%),
    linear-gradient(145deg, rgba(248,247,242,.82), rgba(237,243,237,.74));
  padding: clamp(32px, 5vw, 72px);
  align-content: center;
}

.login-v093 .login-heading,
.login-v093 .login-tabs,
.login-v093 .login-tab-pane,
.login-v093 .login-extra-panel,
.login-v093 .alert {
  width: min(760px, 100%);
  margin-left: auto;
  margin-right: auto;
}

.login-v093 .login-tab-pane,
.login-v093 .login-extra-panel {
  border: 1px solid rgba(23,32,25,.10);
  background: rgba(255,255,255,.82);
  border-radius: 8px;
  padding: 18px;
  box-shadow: 0 18px 52px rgba(23,32,25,.09);
}

.login-v093 .login-extra-panel {
  margin-top: 12px;
}

.login-v093 .login-tabs-v093 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  padding: 6px;
  gap: 6px;
  margin-top: 18px;
  margin-bottom: 14px;
}

.login-v093 .login-pane-title {
  margin: 0 0 12px;
  color: var(--green-950);
  font-size: 18px;
}

.login-v093 .a3-inline {
  border: 0;
  background: transparent;
  padding: 0;
  box-shadow: none;
}

.a3-status-box.error,
.a3-status-box.status-error {
  border-color: rgba(166,69,69,.24);
  background: #fff2f2;
  color: #9a3d3d;
}

.integration-grid-v093 .integration-card {
  display: grid;
  align-content: start;
  gap: 10px;
}

.integration-card-actions,
.integration-local-actions,
.integration-button-row,
.inline-mini-form {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  margin: 0;
}

.integration-card-actions {
  padding: 8px 0 4px;
}

.integration-card-actions .button,
.integration-local-actions .button,
.integration-button-row .button {
  min-height: 34px;
  padding: 7px 9px;
  border-radius: 7px;
  white-space: nowrap;
}

.integration-config-form[hidden] {
  display: none !important;
}

.update-summary-card {
  border-color: rgba(67,93,69,.18);
  background: linear-gradient(145deg, rgba(255,255,255,.92), rgba(237,243,237,.7));
}

.update-summary-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
}

.update-summary-head h2 {
  margin: 0 0 6px;
}

.update-summary-head p {
  margin: 0;
  color: var(--muted);
  line-height: 1.5;
}

.update-summary-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1.1fr;
  gap: 14px;
}

.chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}

.chip {
  border-radius: 999px;
  background: rgba(67,93,69,.10);
  color: var(--green-900);
  font-weight: 800;
  font-size: 12px;
  padding: 6px 9px;
}

.compact-list {
  margin: 8px 0 0;
  padding-left: 18px;
  color: var(--muted);
}

.mail-outlook-shell {
  display: grid;
  grid-template-columns: 210px minmax(0, 1fr) minmax(320px, .42fr);
  gap: 14px;
  align-items: start;
}

.mail-folders,
.mail-config,
.mail-outlook-list {
  min-height: 420px;
}

.mail-folder-button {
  width: 100%;
  min-height: 40px;
  border: 0;
  background: transparent;
  color: var(--green-900);
  font-weight: 850;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  border-radius: 7px;
  padding: 8px;
  cursor: pointer;
}

.mail-folder-button:hover,
.mail-folder-button.active {
  background: var(--green-900);
  color: #fff;
}

.mail-list-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 10px;
}

.mail-list-head h2 {
  margin: 0;
}

.outlook-message-list {
  display: grid;
  gap: 8px;
}

.outlook-message-row {
  border: 1px solid rgba(23,32,25,.08);
  border-radius: 8px;
  background: rgba(255,255,255,.88);
  padding: 10px 12px;
  display: grid;
  gap: 4px;
}

.outlook-message-row div {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}

.outlook-message-row strong {
  color: var(--green-950);
  font-size: 13px;
}

.outlook-message-row span {
  color: var(--green-900);
  font-weight: 800;
  text-align: right;
}

.outlook-message-row p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.4;
}

.outlook-message-row small {
  color: var(--muted);
  font-weight: 700;
}

.compact-inline-form {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

@media (max-width: 1180px) {
  .mail-outlook-shell,
  .update-summary-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  body.login-page.login-v093 {
    grid-template-columns: 1fr;
  }
  .login-v093 .login-campaign {
    min-height: 320px;
  }
  .login-v093 .login-panel-v093 {
    min-height: auto;
  }
}

@media (max-width: 640px) {
  .login-v093 .login-tabs-v093 {
    grid-template-columns: 1fr 1fr;
  }
  .outlook-message-row div {
    display: grid;
  }
  .outlook-message-row span {
    text-align: left;
  }
}

/* Pack 0.9.4 - cadastro inteligente */
.login-v094 .login-panel-v094 {
  width: min(680px, calc(100vw - 32px));
  max-width: 680px;
}
.login-v094 .login-tabs-v093 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.register-kind-buttons {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  padding: 6px;
  border: 1px solid rgba(23, 32, 25, .09);
  border-radius: 12px;
  background: rgba(237, 243, 237, .74);
}
.register-kind-option {
  min-height: 42px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border-radius: 9px;
  padding: 10px 12px;
  font-weight: 800;
  font-size: 12px;
  color: var(--green-900, #243426);
  cursor: pointer;
  border: 1px solid transparent;
  text-align: center;
}
.register-kind-option input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.register-kind-option.is-selected,
.register-kind-option:has(input:checked) {
  color: #fff;
  background: var(--green-900, #243426);
  box-shadow: 0 10px 22px rgba(23, 32, 25, .16);
}
.register-diagnostic {
  grid-column: 1 / -1;
  border-radius: 10px;
  padding: 10px 12px;
  font-size: 12px;
  font-weight: 700;
  border: 1px solid rgba(23, 32, 25, .1);
  background: rgba(255,255,255,.8);
}
.register-diagnostic.success {
  background: #edf8ef;
  color: #275b32;
  border-color: rgba(39, 91, 50, .18);
}
.register-diagnostic.error {
  background: #fff0f0;
  color: #9a3f3f;
  border-color: rgba(154, 63, 63, .18);
}
.register-diagnostic.info {
  background: #f7f5ec;
  color: #6d5d26;
  border-color: rgba(200, 168, 91, .2);
}
.public-register-form-v094 .conditional-fields {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  padding: 12px;
  border-radius: 12px;
  border: 1px solid rgba(67, 93, 69, .13);
  background: rgba(237, 243, 237, .42);
}
.public-register-form-v094 .conditional-fields[hidden] {
  display: none !important;
}
.public-register-form-v094 .field-help {
  grid-column: 1 / -1;
  margin: -2px 0 0;
  color: var(--muted, #6d756d);
  font-size: 12px;
}
.public-register-form-v094 input[readonly] {
  background: rgba(237, 243, 237, .72);
  color: var(--green-900, #243426);
  font-weight: 700;
}
@media (max-width: 760px) {
  .login-v094 .login-tabs-v093,
  .register-kind-buttons,
  .public-register-form-v094 .conditional-fields {
    grid-template-columns: 1fr;
  }
}


/* Pack 0.9.4.1 - limpeza da tela de login/cadastro. */
body.login-page.login-v0941 {
  grid-template-columns: minmax(420px, .48fr) minmax(520px, .52fr);
  background:
    radial-gradient(circle at 85% 18%, rgba(67, 93, 69, .12), transparent 28%),
    linear-gradient(145deg, #f7f5ee 0%, #e8eee6 46%, #dfe8dc 100%);
}

.login-v0941 .login-panel,
body.login-page.login-v0941 .login-panel,
body.login-page.login-v0941.gabo-oneui-v0622 .login-panel {
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  max-width: 620px;
  width: 100%;
  justify-self: center;
}

.login-v0941 .login-heading,
.login-v0941 .segmented,
.login-v0941 .login-tab-pane,
.login-v0941 .login-extra-panel {
  max-width: 540px;
  width: 100%;
}

.login-v0941 .login-tab-pane {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255,255,255,.86);
  padding: 16px;
  box-shadow: 0 18px 48px rgba(23,32,25,.08);
}

.login-v0941 .login-tab-pane[data-login-pane="novo_cadastro"] {
  padding: 18px;
}

.login-v0941 .login-extra-panel {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255,255,255,.86);
  margin-top: 12px;
  padding: 16px;
  box-shadow: 0 18px 48px rgba(23,32,25,.08);
}

.login-v0941 .login-company-name {
  max-width: 560px;
  margin: 0;
  color: #fff;
  font-size: clamp(32px, 4.2vw, 54px);
  line-height: 1;
  font-weight: 900;
  letter-spacing: -0.045em;
}

.login-v0941 .login-campaign h1 {
  margin-bottom: 4px;
}

.login-v0941 .public-register-form .muted,
.login-v0941 [data-login-pane="novo_cadastro"] > .muted {
  display: none !important;
}

@media (max-width: 1180px) {
  body.login-page.login-v0941 {
    grid-template-columns: minmax(360px, .42fr) minmax(460px, .58fr);
  }
}

@media (max-width: 900px) {
  body.login-page.login-v0941 {
    display: block;
  }
  .login-v0941 .login-campaign {
    min-height: auto;
    padding: 34px 22px;
  }
  .login-v0941 .login-campaign img {
    margin-bottom: 20px;
  }
  .login-v0941 .login-panel {
    min-height: auto;
    padding: 22px;
    max-width: none;
  }
  .login-v0941 .login-heading,
  .login-v0941 .segmented,
  .login-v0941 .login-tab-pane,
  .login-v0941 .login-extra-panel {
    max-width: none;
  }
}


/* Pack 0.9.4.2 - máscaras BR, login responsivo ampliado e refinamento de cadastro. */
body.login-page.login-v0942 {
  grid-template-columns: minmax(390px, .46fr) minmax(620px, .54fr);
}

body.login-page.login-v0942 .login-panel,
body.login-page.login-v0942.gabo-oneui-v0622 .login-panel {
  width: 80%;
  max-width: 860px;
  min-width: 520px;
  justify-self: center;
}

.login-v0942 .login-heading,
.login-v0942 .segmented,
.login-v0942 .login-tab-pane,
.login-v0942 .login-extra-panel {
  max-width: none;
  width: 100%;
}

.login-v0942 .login-company-name {
  font-size: clamp(22px, 3vw, 40px);
  line-height: 1.08;
  letter-spacing: -0.025em;
  max-width: 100%;
  overflow-wrap: anywhere;
}

.login-v0942 .public-register-form-v094 .conditional-fields[data-register-orgao] {
  order: -1;
  margin-top: 2px;
}

.login-v0942 .public-register-form-v094 label[data-name-field] input::placeholder {
  color: rgba(105, 115, 107, .72);
}

input[data-mask],
input[data-br-mask] {
  font-variant-numeric: tabular-nums;
}

.sisgabo-date-time-note,
[data-brasilia-timezone-note] {
  color: var(--muted, #69736b);
  font-size: 12px;
  line-height: 1.35;
}

@media (max-width: 1180px) {
  body.login-page.login-v0942 {
    grid-template-columns: minmax(340px, .40fr) minmax(520px, .60fr);
  }
  body.login-page.login-v0942 .login-panel,
  body.login-page.login-v0942.gabo-oneui-v0622 .login-panel {
    width: 88%;
    min-width: 0;
  }
}

@media (max-width: 900px) {
  body.login-page.login-v0942 {
    display: block;
  }
  body.login-page.login-v0942 .login-panel,
  body.login-page.login-v0942.gabo-oneui-v0622 .login-panel {
    width: 100%;
    max-width: none;
    min-width: 0;
  }
  .login-v0942 .login-company-name {
    font-size: clamp(20px, 7vw, 34px);
  }
}

@media (max-width: 560px) {
  .login-v0942 .login-tabs-v093,
  .login-v0942 .register-kind-buttons {
    grid-template-columns: 1fr;
  }
  .login-v0942 .login-tab-pane,
  .login-v0942 .login-extra-panel {
    padding: 14px;
  }
}


/* SisGabo 0.9.4.3 - Agentes locais Gabo 2.0.0 sem quebrar visual vigente */
.integration-grid-v0943 .agent-native-card {
  border-color: rgba(31, 92, 54, .18);
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(246,250,247,.92));
}
.agent-endpoint code,
.agent-card-endpoint code {
  display: inline-flex;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  background: rgba(28, 82, 48, .08);
  border: 1px solid rgba(28, 82, 48, .12);
  border-radius: 8px;
  padding: 5px 8px;
  color: #183b27;
}
.lighthouse-actions,
.gabo-local-actions,
.integration-button-row,
.integration-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}
.lighthouse-actions .button,
.gabo-local-actions .button,
.integration-card-actions .button,
.integration-card-actions .inline-mini-form button {
  min-height: 34px;
  padding: 8px 10px;
  white-space: nowrap;
}
.local-agent-result-inline,
[data-local-agent-result] {
  min-height: 18px;
}
.agent-native-card .integration-title h2 {
  letter-spacing: -.01em;
}
.agent-card-summary {
  display: grid;
  gap: 8px;
}
@media (max-width: 860px) {
  .lighthouse-actions,
  .gabo-local-actions,
  .integration-card-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .lighthouse-actions .button,
  .gabo-local-actions .button,
  .integration-card-actions .button,
  .integration-card-actions .inline-mini-form button {
    width: 100%;
    justify-content: center;
  }
}
@media (max-width: 520px) {
  .lighthouse-actions,
  .gabo-local-actions,
  .integration-card-actions {
    grid-template-columns: 1fr;
  }
}

/* SisGabo 0.9.5 - Órgãos públicos, licitações, contratos e empenhos */
.gabo-module-head .breadcrumb { margin: 0 0 6px; color: var(--muted, #6b756d); font-weight: 800; font-size: 12px; text-transform: uppercase; letter-spacing: .04em; }
.gabo-compact-metrics { margin-bottom: 18px; }
.gabo-compact-metrics article strong { font-size: clamp(20px, 2vw, 30px); }
.gabo-admin-grid { align-items: start; gap: 16px; }
.gabo-form-tight { gap: 12px; }
.gabo-form-tight label { min-width: 0; }
.gabo-form-tight input,
.gabo-form-tight select,
.gabo-form-tight textarea { width: 100%; }
.gabo-form-tight .span-2 { grid-column: 1 / -1; }
.compact-actions { gap: 8px; flex-wrap: wrap; }
.gabo-btn-ico { display: inline-grid; place-items: center; min-width: 22px; height: 22px; margin-right: 6px; border-radius: 7px; background: rgba(255,255,255,.18); font-size: 10px; font-weight: 900; line-height: 1; }
.gabo-inline-result { grid-column: 1 / -1; padding: 10px 12px; border: 1px solid rgba(23,32,25,.12); border-radius: 8px; background: rgba(255,255,255,.72); color: #26382a; font-weight: 700; min-height: 40px; }
.gabo-inline-result.is-error { background: #fff1f1; border-color: rgba(166,69,69,.24); color: #a64545; }
.gabo-inline-result.is-ok { background: #f0f7ed; border-color: rgba(67,93,69,.24); color: #344a36; }
.badge.status-ativo,
.badge.status-ativa,
.badge.status-homologada,
.badge.status-em_atendimento { background: #edf6ed; color: #29452e; border-color: rgba(67,93,69,.18); }
.badge.status-finalizado,
.badge.status-encerrada { background: #eef2f7; color: #35455c; border-color: rgba(54,92,125,.18); }
.badge.status-cancelado,
.badge.status-bloqueado { background: #fae8e8; color: #a64545; border-color: rgba(166,69,69,.18); }
@media (max-width: 980px) { .gabo-admin-grid.two-cols, .grid.two-cols.gabo-admin-grid { grid-template-columns: 1fr; } }

/* Pack 0.9.6.1 - Tabela Mestre por abas, importador V5/V12/SSL e login/cadastro 95%. */
body.login-page.login-v0942 .login-panel,
body.login-page.login-v0942.gabo-oneui-v0622 .login-panel,
body.login-page .login-panel-v093,
body.login-page .login-panel-v094,
body.login-page .login-panel-v0941,
body.login-page .login-panel-v0942 {
  width: 95%;
  max-width: 980px;
  min-width: 0;
  justify-self: center;
}

@media (max-width: 1180px) {
  body.login-page.login-v0942 .login-panel,
  body.login-page.login-v0942.gabo-oneui-v0622 .login-panel,
  body.login-page .login-panel-v093,
  body.login-page .login-panel-v094,
  body.login-page .login-panel-v0941,
  body.login-page .login-panel-v0942 {
    width: 95%;
    max-width: none;
    min-width: 0;
  }
}

.tabela-mestre-header-v0961 .actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}

.tabela-mestre-metrics-v0961 {
  margin-bottom: 16px;
}

.master-tabs-v0961 {
  display: flex;
  gap: 8px;
  align-items: center;
  overflow-x: auto;
  padding: 10px;
  margin: 0 0 16px;
  border: 1px solid rgba(35, 82, 53, .10);
  border-radius: 22px;
  background: rgba(255, 255, 255, .72);
  box-shadow: 0 18px 42px rgba(30, 70, 45, .06);
  backdrop-filter: blur(14px);
}

.master-tabs-v0961 a {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 16px;
  border: 1px solid transparent;
  border-radius: 999px;
  color: #2d4f39;
  text-decoration: none;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: -.01em;
  white-space: nowrap;
}

.master-tabs-v0961 a:hover {
  background: rgba(35, 117, 70, .08);
}

.master-tabs-v0961 a.active {
  color: #fff;
  background: linear-gradient(135deg, #18492c, #2d8e56);
  box-shadow: 0 12px 28px rgba(25, 89, 48, .22);
}

.master-tab-panel-v0961 {
  display: none;
  margin-bottom: 16px;
}

.master-tab-panel-v0961.active {
  display: block;
}

.master-product-form-v0961 {
  grid-template-columns: repeat(4, minmax(150px, 1fr));
}

.master-product-form-v0961 label.span-2,
.master-product-form-v0961 .span-2 {
  grid-column: span 4;
}

.catalog-preview-v0961 {
  padding: 16px;
  border: 1px solid rgba(35, 82, 53, .12);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(248, 252, 249, .96), rgba(255, 255, 255, .92));
}

.catalog-preview-v0961 > strong {
  display: block;
  margin-bottom: 10px;
  color: #183b27;
  font-size: 14px;
}

.catalog-preview-grid-v0961 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.catalog-preview-grid-v0961 article {
  min-height: 116px;
  padding: 14px;
  border: 1px solid rgba(35, 82, 53, .11);
  border-radius: 18px;
  background: #fff;
}

.catalog-preview-grid-v0961 article.is-selected {
  border-color: rgba(38, 142, 80, .45);
  box-shadow: 0 12px 28px rgba(38, 142, 80, .12);
}

.catalog-preview-grid-v0961 b,
.catalog-preview-grid-v0961 span,
.catalog-preview-grid-v0961 small {
  display: block;
}

.catalog-preview-grid-v0961 b {
  color: #183b27;
  font-size: 14px;
}

.catalog-preview-grid-v0961 span {
  margin-top: 5px;
  color: #2d8e56;
  font-weight: 800;
  font-size: 12px;
}

.catalog-preview-grid-v0961 small {
  margin-top: 8px;
  color: var(--muted, #69736b);
  line-height: 1.35;
}

.master-products-table-v0961 table,
.master-table-light-v0961 table {
  min-width: 980px;
}

.master-products-table-v0961 code {
  display: inline-flex;
  max-width: 180px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  padding: 4px 7px;
  border-radius: 8px;
  background: rgba(25, 89, 48, .08);
  color: #183b27;
}

@media (max-width: 1100px) {
  .master-product-form-v0961 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .master-product-form-v0961 label.span-2,
  .master-product-form-v0961 .span-2 {
    grid-column: span 2;
  }
  .catalog-preview-grid-v0961 {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 680px) {
  .master-tabs-v0961 {
    border-radius: 18px;
    padding: 8px;
  }
  .master-tabs-v0961 a {
    min-height: 38px;
    padding: 0 12px;
    font-size: 12px;
  }
  .master-product-form-v0961 {
    grid-template-columns: 1fr;
  }
  .master-product-form-v0961 label.span-2,
  .master-product-form-v0961 .span-2 {
    grid-column: span 1;
  }
}


/* Pack 0.9.6.2 - Tabela Mestre condicional, hierarquia AC/AR e restauração visual Gabo. */
input[type="checkbox"],
input[type="radio"] {
  width: auto;
  min-height: 16px;
  padding: 0;
  accent-color: var(--green-900, #243426);
}

.master-tabs-v0962 {
  border-radius: var(--radius, 8px);
  background: rgba(255, 255, 255, .88);
  box-shadow: none;
  backdrop-filter: none;
  border-color: var(--line, rgba(23,32,25,.13));
}

.master-tabs-v0962 a {
  border-radius: 7px;
  color: var(--green-900, #243426);
}

.master-tabs-v0962 a.active {
  background: var(--green-900, #243426);
  color: #fff;
  box-shadow: none;
}

.master-tab-panel-v0962.card,
.master-fieldset,
.catalog-preview-v0962,
.catalog-preview-grid-v0962 article {
  border-radius: var(--radius, 8px);
}

.master-product-form-v0962 {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

.master-fieldset {
  border: 1px solid var(--line, rgba(23,32,25,.13));
  background: rgba(255,255,255,.68);
  padding: 16px;
  margin: 0;
}

.master-fieldset legend {
  color: var(--green-950, #172217);
  font-size: 14px;
  font-weight: 900;
  padding: 0 8px;
}

.master-field-grid {
  display: grid;
  gap: 12px;
}

.master-field-grid.cols-4 {
  grid-template-columns: repeat(4, minmax(160px, 1fr));
}

.span-full {
  grid-column: 1 / -1;
}

.master-switch-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(130px, 1fr));
  gap: 10px;
}

.gabo-switch-field {
  display: inline-flex;
  grid-template-columns: none;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  min-height: 42px;
  padding: 10px 12px;
  border: 1px solid var(--line, rgba(23,32,25,.13));
  border-radius: 7px;
  background: #fff;
  color: var(--green-950, #172217);
  font-size: 13px;
  font-weight: 800;
  cursor: pointer;
}

.gabo-switch-input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.gabo-switch-ui {
  position: relative;
  display: inline-block;
  width: 38px;
  min-width: 38px;
  height: 22px;
  border-radius: 999px;
  background: #dfe8dc;
  border: 1px solid rgba(23,32,25,.12);
  transition: background .16s ease, border-color .16s ease;
}

.gabo-switch-ui::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 2px 6px rgba(23,32,25,.18);
  transition: transform .16s ease;
}

.gabo-switch-input:checked + .gabo-switch-ui {
  background: var(--green-900, #243426);
  border-color: var(--green-900, #243426);
}

.gabo-switch-input:checked + .gabo-switch-ui::after {
  transform: translateX(16px);
}

.gabo-switch-input:focus-visible + .gabo-switch-ui {
  outline: 3px solid rgba(200,168,91,.38);
  outline-offset: 2px;
}

[data-product-context][hidden],
.is-hidden-by-context {
  display: none !important;
}

.field-help {
  margin: 10px 0 0;
  color: var(--muted, #69736b);
  font-size: 12px;
  line-height: 1.45;
}

.master-table-light-v0962 table,
.master-products-table-v0962 table {
  min-width: 1120px;
}

.master-products-table-v0962 small {
  color: var(--muted, #69736b);
}

.catalog-preview-v0962 {
  background: rgba(255,255,255,.72);
  box-shadow: none;
}

.catalog-preview-grid-v0962 article.is-selected {
  border-color: rgba(67, 93, 69, .42);
  box-shadow: none;
}

@media (max-width: 1180px) {
  .master-field-grid.cols-4,
  .master-switch-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px) {
  .master-field-grid.cols-4,
  .master-switch-grid {
    grid-template-columns: 1fr;
  }
  .gabo-switch-field {
    width: 100%;
  }
}


/* SisGabo 0.9.6.3 - ICP pública, CNAE e NFS-e */
.master-conditional-box {
  border: 1px solid rgba(23,32,25,.10);
  border-radius: 8px;
  background: rgba(255,255,255,.62);
  padding: 14px;
}
.master-subsection {
  border-top: 1px solid rgba(23,32,25,.10);
  margin-top: 18px;
  padding-top: 16px;
}
.master-subsection h3 {
  margin: 0 0 12px;
  font-size: 15px;
  color: var(--green-950, #172217);
}
[data-nfse-municipal][hidden],
[data-nfse-nacional][hidden],
[data-ac-commerce-section][hidden] {
  display: none !important;
}
.master-field-grid.cols-4,
.compact-form.form-grid {
  align-items: end;
}
.compact-form .field-help,
.field-help {
  color: var(--muted, #6d756d);
  font-size: 12px;
  line-height: 1.4;
}


/* SisGabo 0.9.6.4 - Tabela Mestre: cards no padrão Órgãos Públicos, subtabs internas e checks compactos. */
.tabela-mestre-header-v0962 {
  margin-bottom: 18px;
}
.tabela-mestre-metrics-v0964 {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin: 0 0 18px !important;
}
.tabela-mestre-metrics-v0964 article,
.tabela-mestre-metrics-v0964 .metric-card {
  display: grid;
  align-content: space-between;
  min-height: 92px;
  padding: 14px 16px;
  border: 1px solid var(--line, rgba(23,32,25,.13));
  border-radius: var(--radius, 8px);
  background: rgba(255,255,255,.88);
  box-shadow: 0 10px 24px rgba(23,32,25,.045);
}
.tabela-mestre-metrics-v0964 article span,
.tabela-mestre-metrics-v0964 .metric-card span {
  color: var(--muted, #6d756d);
  font-size: 12px;
  font-weight: 800;
}
.tabela-mestre-metrics-v0964 article strong,
.tabela-mestre-metrics-v0964 .metric-card strong {
  display: block;
  color: var(--green-950, #172217);
  font-size: clamp(22px, 2vw, 30px);
  line-height: 1;
  margin-top: 8px;
}
.tabela-mestre-metrics-v0964 article small,
.tabela-mestre-metrics-v0964 .metric-card small {
  color: var(--green-700, #435d45);
  font-size: 11px;
  font-weight: 800;
}
.master-product-subtabs-v0964 {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  padding: 8px;
  margin: 0 0 2px;
  border: 1px solid var(--line, rgba(23,32,25,.13));
  border-radius: var(--radius, 8px);
  background: rgba(255,255,255,.82);
}
.master-product-subtabs-v0964 button {
  appearance: none;
  border: 1px solid transparent;
  border-radius: 999px;
  background: transparent;
  color: var(--green-900, #243426);
  cursor: pointer;
  font-size: 12px;
  font-weight: 900;
  min-height: 34px;
  padding: 0 12px;
  white-space: nowrap;
}
.master-product-subtabs-v0964 button:hover {
  background: rgba(67, 93, 69, .08);
}
.master-product-subtabs-v0964 button.active {
  background: var(--green-900, #243426);
  border-color: var(--green-900, #243426);
  color: #fff;
}
.master-product-subtabs-v0964 button[hidden] {
  display: none !important;
}
.master-product-form-v0962 [data-product-subpanel][hidden] {
  display: none !important;
}
.master-product-form-v0962 .master-fieldset {
  padding: 14px;
}
.master-product-form-v0962 .master-fieldset legend {
  font-size: 13px;
}
.master-product-actions-v0964 {
  display: flex;
  justify-content: flex-end;
  margin-top: 2px;
}
.master-switch-grid {
  display: flex !important;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.gabo-switch-field {
  width: auto;
  min-width: 0;
  min-height: 30px !important;
  padding: 5px 9px !important;
  gap: 7px !important;
  border-radius: 999px !important;
  font-size: 12px !important;
  line-height: 1.2;
  box-shadow: none !important;
}
.gabo-switch-field .gabo-switch-input,
.master-product-form-v0962 .gabo-switch-input,
input.gabo-switch-input[type="checkbox"] {
  position: absolute !important;
  opacity: 0 !important;
  pointer-events: none !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  width: 1px !important;
  min-width: 1px !important;
  max-width: 1px !important;
  height: 1px !important;
  min-height: 1px !important;
  margin: 0 !important;
  padding: 0 !important;
}
.gabo-switch-ui {
  width: 30px !important;
  min-width: 30px !important;
  height: 18px !important;
}
.gabo-switch-ui::after {
  top: 1px !important;
  left: 1px !important;
  width: 14px !important;
  height: 14px !important;
}
.gabo-switch-input:checked + .gabo-switch-ui::after {
  transform: translateX(12px) !important;
}
.master-product-form-v0962 input[type="checkbox"]:not(.gabo-switch-input) {
  width: 16px !important;
  min-width: 16px !important;
  height: 16px !important;
  min-height: 16px !important;
  padding: 0 !important;
}
.master-field-grid.cols-4 {
  grid-template-columns: repeat(4, minmax(150px, 1fr));
}
.master-tab-panel-v0962.card {
  padding: 18px;
}
@media (max-width: 1100px) {
  .tabela-mestre-metrics-v0964 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 680px) {
  .tabela-mestre-metrics-v0964 {
    grid-template-columns: 1fr;
  }
  .master-product-subtabs-v0964 {
    overflow-x: auto;
    flex-wrap: nowrap;
  }
  .master-product-subtabs-v0964 button {
    flex: 0 0 auto;
  }
}


/* SisGabo 0.9.6.5 - restauração da Tabela Mestre conforme identidade aprovada e padrão Órgãos Públicos. */
.tabela-mestre-metrics-v0965 {
  margin-bottom: 18px !important;
}
.tabela-mestre-metrics-v0965 article {
  min-height: 96px;
  border-radius: var(--radius, 8px) !important;
  box-shadow: none !important;
}
.master-tabs-v0965 {
  border-radius: var(--radius, 8px) !important;
  margin-bottom: 16px !important;
  background: rgba(255,255,255,.88) !important;
}
.master-tabs-v0965 a {
  border-radius: 7px !important;
  box-shadow: none !important;
}
.master-tabs-v0965 a.active {
  background: var(--green-900, #243426) !important;
  color: #fff !important;
  box-shadow: none !important;
}
.master-tab-panel-v0965 {
  border-radius: var(--radius, 8px) !important;
  box-shadow: none !important;
}
.master-product-form-v0965 {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
.master-product-form-v0965 .master-fieldset {
  border-radius: var(--radius, 8px) !important;
  background: rgba(255,255,255,.72) !important;
}
.master-product-form-v0965 .master-fieldset legend {
  padding: 0 8px;
  margin: 0;
  line-height: 1.2;
}
.master-product-form-v0965 .master-switch-grid {
  display: flex !important;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.master-product-form-v0965 .gabo-switch-field,
.gabo-switch-field {
  width: auto !important;
  min-width: 0 !important;
  min-height: 30px !important;
  padding: 5px 9px !important;
  gap: 7px !important;
  border-radius: 999px !important;
  font-size: 12px !important;
  line-height: 1.2 !important;
  box-shadow: none !important;
}
.master-product-form-v0965 .gabo-switch-input,
input.gabo-switch-input[type="checkbox"] {
  position: absolute !important;
  opacity: 0 !important;
  pointer-events: none !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  width: 1px !important;
  min-width: 1px !important;
  max-width: 1px !important;
  height: 1px !important;
  min-height: 1px !important;
  margin: 0 !important;
  padding: 0 !important;
}
.master-product-form-v0965 .gabo-switch-ui,
.gabo-switch-ui {
  width: 30px !important;
  min-width: 30px !important;
  height: 18px !important;
}
.master-product-form-v0965 .gabo-switch-ui::after,
.gabo-switch-ui::after {
  top: 1px !important;
  left: 1px !important;
  width: 14px !important;
  height: 14px !important;
}
.master-product-form-v0965 .gabo-switch-input:checked + .gabo-switch-ui::after,
.gabo-switch-input:checked + .gabo-switch-ui::after {
  transform: translateX(12px) !important;
}
.master-product-form-v0965 input[type="checkbox"]:not(.gabo-switch-input) {
  width: 16px !important;
  min-width: 16px !important;
  height: 16px !important;
  min-height: 16px !important;
  padding: 0 !important;
}
/* Fallback: se o JS ainda não carregar, o hash da URL exibe a aba correta no Chrome atual. */
.master-tab-panel-v0965:target {
  display: block !important;
}
body:has(.master-tab-panel-v0965:target) .master-tab-panel-v0965.active:not(:target) {
  display: none !important;
}
@media (max-width: 1100px) {
  .tabela-mestre-metrics-v0965 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 680px) {
  .tabela-mestre-metrics-v0965 { grid-template-columns: 1fr; }
}


/* SisGabo 0.9.7 - Voucher AR e ajuste crítico do login A3 sem alterar identidade visual. */
.voucher-metrics-v097 { margin-bottom: 18px; }
.voucher-form-card-v097 { border-radius: var(--radius, 8px); }
.voucher-detail-grid-v097 { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(320px, .9fr); gap: 16px; align-items: start; }
.detail-list-v097 { display: grid; grid-template-columns: 150px 1fr; gap: 10px 14px; margin: 0; }
.detail-list-v097 dt { color: var(--muted, #6d756d); font-weight: 800; font-size: 12px; }
.detail-list-v097 dd { margin: 0; min-width: 0; }
.detail-list-v097 code { white-space: normal; word-break: break-all; font-size: 11px; }
.timeline-v097 { display: grid; gap: 10px; }
.timeline-v097 article { border: 1px solid var(--line, rgba(23,32,25,.11)); border-radius: var(--radius, 8px); padding: 12px; background: rgba(255,255,255,.72); }
.timeline-v097 article strong { display: block; color: var(--green-950, #172217); }
.timeline-v097 article span { display: block; color: var(--muted, #6d756d); font-size: 12px; margin-top: 2px; }
.timeline-v097 article p { margin: 8px 0 0; color: var(--ink, #172019); }
.voucher-status-emitido { background: #e7f3ea !important; color: #2f6d3b !important; }
.voucher-status-pendente_cliente, .voucher-status-aguardando_pagamento { background: #fbf2d6 !important; color: #7d6720 !important; }
.voucher-status-cancelado, .voucher-status-revogado { background: #fae8e8 !important; color: #a64545 !important; }
.a3-status-box.ok, .status-pill.ok { border-color: rgba(67,93,69,.28); color: var(--green-800, #344a36); }
.a3-status-box.error, .status-pill.error { border-color: rgba(166,69,69,.34); color: #a64545; }
.a3-status-box.warn, .status-pill.warn { border-color: rgba(200,168,91,.42); color: #7d6720; }
@media (max-width: 900px) { .voucher-detail-grid-v097 { grid-template-columns: 1fr; } .detail-list-v097 { grid-template-columns: 1fr; } }


/* SisGabo 0.9.7.1 — RESGATE COMERCIAL GABO ONE UI
   Objetivo: restaurar o login/cadastro aprovado e conter regressões visuais de layout sem mexer em banco ou regras de negócio. */
body.login-page.login-v0942 {
  grid-template-columns: minmax(390px, .46fr) minmax(620px, .54fr) !important;
  background:
    radial-gradient(circle at 85% 18%, rgba(67, 93, 69, .12), transparent 28%),
    linear-gradient(145deg, #f7f5ee 0%, #e8eee6 46%, #dfe8dc 100%) !important;
}

body.login-page.login-v0942 .login-panel,
body.login-page.login-v0942.gabo-oneui-v0622 .login-panel {
  width: min(95%, 860px) !important;
  max-width: 860px !important;
  min-width: 520px;
  justify-self: center !important;
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

body.login-page.login-v0942 .login-heading,
body.login-page.login-v0942 .segmented,
body.login-page.login-v0942 .login-tab-pane,
body.login-page.login-v0942 .login-extra-panel {
  max-width: none !important;
  width: 100% !important;
}

body.login-page.login-v0942 .login-tab-pane,
body.login-page.login-v0942 .login-extra-panel {
  border: 1px solid var(--line, rgba(23,32,25,.11)) !important;
  border-radius: var(--radius, 8px) !important;
  background: rgba(255,255,255,.88) !important;
  box-shadow: 0 18px 48px rgba(23,32,25,.08) !important;
}

body.login-page.login-v0942 .login-company-name {
  font-size: clamp(22px, 3vw, 40px) !important;
  line-height: 1.08 !important;
  letter-spacing: -0.025em !important;
  max-width: 100% !important;
  overflow-wrap: anywhere !important;
}

body.login-page.login-v0942 .public-register-form-v094 {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 12px !important;
}

body.login-page.login-v0942 .public-register-form-v094 .register-kind-buttons,
body.login-page.login-v0942 .public-register-form-v094 .conditional-fields,
body.login-page.login-v0942 .public-register-form-v094 .register-diagnostic,
body.login-page.login-v0942 .public-register-form-v094 button[type="submit"] {
  grid-column: 1 / -1 !important;
}

body.login-page.login-v0942 .public-register-form-v094 label,
body.login-page.login-v0942 .login-password-form label,
body.login-page.login-v0942 .recover-form {
  min-width: 0 !important;
}

body.login-page.login-v0942 input,
body.login-page.login-v0942 select,
body.login-page.login-v0942 textarea {
  width: 100% !important;
  min-height: 42px;
}

/* Resgate geral de UX: formulários, cards e tabelas não podem ficar espremidos ou com ações gigantes. */
.main-content .card,
.main-content .panel,
.main-content .mini-card,
.main-content .metric,
.main-content .master-tab-panel-v0965,
.main-content .master-tab-panel-v0962 {
  border-radius: 8px !important;
  border: 1px solid rgba(23,32,25,.11) !important;
}

.form-grid,
.master-product-form-v0965,
.master-product-form-v0962,
.master-field-grid,
.master-field-grid.cols-4 {
  align-items: start !important;
}

.form-grid label,
.master-product-form-v0965 label,
.master-product-form-v0962 label,
.master-field-grid label {
  min-width: 0 !important;
}

.form-grid input,
.form-grid select,
.form-grid textarea,
.master-product-form-v0965 input,
.master-product-form-v0965 select,
.master-product-form-v0965 textarea,
.master-product-form-v0962 input,
.master-product-form-v0962 select,
.master-product-form-v0962 textarea {
  max-width: 100% !important;
}

.master-product-form-v0965 .master-switch-grid,
.master-switch-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)) !important;
  gap: 8px !important;
}

.master-product-form-v0965 .gabo-switch-field,
.master-product-form-v0962 .gabo-switch-field,
.gabo-switch-field {
  min-height: 42px !important;
  padding: 8px 10px !important;
  border-radius: 8px !important;
  display: grid !important;
  grid-template-columns: auto 1fr !important;
  align-items: center !important;
  gap: 10px !important;
  font-size: 12px !important;
  line-height: 1.25 !important;
}

.master-product-form-v0965 .gabo-switch-ui,
.master-product-form-v0962 .gabo-switch-ui,
.gabo-switch-ui {
  width: 40px !important;
  height: 22px !important;
  min-width: 40px !important;
}

.master-product-form-v0965 .gabo-switch-ui::after,
.master-product-form-v0962 .gabo-switch-ui::after,
.gabo-switch-ui::after {
  width: 18px !important;
  height: 18px !important;
  top: 2px !important;
  left: 2px !important;
}

.master-product-form-v0965 .gabo-switch-input:checked + .gabo-switch-ui::after,
.master-product-form-v0962 .gabo-switch-input:checked + .gabo-switch-ui::after,
.gabo-switch-input:checked + .gabo-switch-ui::after {
  transform: translateX(18px) !important;
}

.master-product-form-v0965 input[type="checkbox"]:not(.gabo-switch-input),
.master-product-form-v0962 input[type="checkbox"]:not(.gabo-switch-input),
.form-grid input[type="checkbox"]:not(.gabo-switch-input) {
  width: 18px !important;
  height: 18px !important;
  min-height: 18px !important;
  max-width: 18px !important;
  padding: 0 !important;
  flex: 0 0 18px !important;
}

.table-wrap,
.master-products-table-v0962,
.master-products-table-v0965,
.master-table-light-v0962 {
  overflow-x: auto !important;
  -webkit-overflow-scrolling: touch;
}

@media (max-width: 1180px) {
  body.login-page.login-v0942 {
    grid-template-columns: minmax(340px, .40fr) minmax(520px, .60fr) !important;
  }
  body.login-page.login-v0942 .login-panel,
  body.login-page.login-v0942.gabo-oneui-v0622 .login-panel {
    width: 95% !important;
    min-width: 0 !important;
  }
}

@media (max-width: 900px) {
  body.login-page.login-v0942 {
    display: block !important;
  }
  body.login-page.login-v0942 .login-panel,
  body.login-page.login-v0942.gabo-oneui-v0622 .login-panel {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
  }
  body.login-page.login-v0942 .public-register-form-v094 {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 560px) {
  body.login-page.login-v0942 .login-tabs-v093,
  body.login-page.login-v0942 .register-kind-buttons {
    grid-template-columns: 1fr !important;
  }
}

/* SisGabo 0.9.7.2 — restauração cirúrgica do login/cadastro aprovado.
   Escopo: respeitar identidade Gabo One UI, inspiração internet banking sem cópia literal,
   manter lado esquerdo fixo e liberar 100% da área útil direita para login/cadastro. */
body.login-page.login-v0972 {
  min-height: 100vh !important;
  height: 100vh !important;
  display: grid !important;
  grid-template-columns: minmax(390px, 44vw) minmax(0, 1fr) !important;
  overflow: hidden !important;
  background:
    radial-gradient(circle at 84% 14%, rgba(67, 93, 69, .10), transparent 26%),
    linear-gradient(145deg, #f7f5ee 0%, #e8eee6 46%, #dfe8dc 100%) !important;
}

body.login-page.login-v0972 .login-campaign {
  position: sticky !important;
  top: 0 !important;
  align-self: stretch !important;
  min-height: 100vh !important;
  height: 100vh !important;
  overflow: hidden !important;
  padding: clamp(34px, 5.2vw, 70px) clamp(26px, 5vw, 72px) !important;
}

body.login-page.login-v0972 .login-campaign h1 {
  margin-top: 10px !important;
  margin-bottom: 8px !important;
  white-space: nowrap !important;
  font-size: clamp(42px, 5.1vw, 74px) !important;
  line-height: .92 !important;
  letter-spacing: -.055em !important;
}

body.login-page.login-v0972 .login-company-name {
  display: block !important;
  max-width: min(94%, 720px) !important;
  white-space: nowrap !important;
  overflow: visible !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
  font-size: clamp(18px, 2.35vw, 38px) !important;
  line-height: 1.04 !important;
  letter-spacing: -.03em !important;
  text-transform: none !important;
}

body.login-page.login-v0972 .login-panel,
body.login-page.login-v0972.gabo-oneui-v0622 .login-panel {
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  height: 100vh !important;
  overflow-y: auto !important;
  justify-self: stretch !important;
  align-self: stretch !important;
  padding: clamp(28px, 4vw, 60px) clamp(24px, 4.4vw, 72px) !important;
  background: rgba(255,255,255,.48) !important;
  box-shadow: none !important;
  border-left: 1px solid rgba(23,32,25,.08) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
}

body.login-page.login-v0972 .login-heading-clean {
  display: block !important;
  padding: 0 !important;
  margin: 0 0 16px !important;
  max-width: none !important;
  width: 100% !important;
}

body.login-page.login-v0972 .login-heading-clean img {
  display: none !important;
}

body.login-page.login-v0972 .login-heading-clean strong {
  display: block !important;
  color: var(--green-950, #172217) !important;
  font-size: clamp(22px, 2.1vw, 34px) !important;
  line-height: 1.05 !important;
  letter-spacing: -.035em !important;
  font-weight: 900 !important;
}

body.login-page.login-v0972 .login-heading-clean small {
  display: block !important;
  max-width: 760px !important;
  margin-top: 8px !important;
  color: var(--muted, #69736b) !important;
  font-size: 13px !important;
  line-height: 1.45 !important;
}

body.login-page.login-v0972 .login-tabs-v0972 {
  max-width: none !important;
  width: 100% !important;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 8px !important;
  margin-bottom: 14px !important;
  padding: 8px !important;
  border-radius: 8px !important;
  background: rgba(255,255,255,.78) !important;
  border: 1px solid rgba(23,32,25,.10) !important;
  box-shadow: 0 12px 34px rgba(23,32,25,.06) !important;
}

body.login-page.login-v0972 .login-tabs-v0972 button {
  min-height: 44px !important;
  padding: 10px 12px !important;
  border-radius: 8px !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  color: var(--green-900, #243426) !important;
  white-space: nowrap !important;
}

body.login-page.login-v0972 .login-tabs-v0972 button.active {
  background: var(--green-900, #243426) !important;
  color: #fff !important;
  box-shadow: 0 12px 26px rgba(23,32,25,.16) !important;
}

body.login-page.login-v0972 .login-tab-pane,
body.login-page.login-v0972 .login-extra-panel,
body.login-page.login-v0972 .alert {
  max-width: none !important;
  width: 100% !important;
}

body.login-page.login-v0972 .login-tab-pane,
body.login-page.login-v0972 .login-extra-panel {
  padding: clamp(16px, 2vw, 26px) !important;
  border-radius: 8px !important;
  background: rgba(255,255,255,.90) !important;
  border: 1px solid rgba(23,32,25,.10) !important;
  box-shadow: 0 20px 52px rgba(23,32,25,.08) !important;
}

body.login-page.login-v0972 .login-password-form {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto !important;
  align-items: end !important;
  gap: 12px !important;
}

body.login-page.login-v0972 .login-password-form .button {
  min-height: 44px !important;
  padding-inline: 18px !important;
  white-space: nowrap !important;
}

body.login-page.login-v0972 .login-context-note {
  margin: -2px 0 2px !important;
  color: var(--muted, #69736b) !important;
  font-size: 12px !important;
  line-height: 1.35 !important;
}

body.login-page.login-v0972 .public-register-form-v094 {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 12px !important;
}

body.login-page.login-v0972 .public-register-form-v094 .register-kind-buttons,
body.login-page.login-v0972 .public-register-form-v094 .register-kind-note,
body.login-page.login-v0972 .public-register-form-v094 .conditional-fields,
body.login-page.login-v0972 .public-register-form-v094 .register-diagnostic,
body.login-page.login-v0972 .public-register-form-v094 button[type="submit"] {
  grid-column: 1 / -1 !important;
}

body.login-page.login-v0972 .public-register-form-v094 .conditional-fields[data-register-orgao],
body.login-page.login-v0972 .public-register-form-v094 .public-org-card-v0972 {
  order: initial !important;
  margin-top: 0 !important;
}

body.login-page.login-v0972 .public-org-card-v0972 {
  background: rgba(237,243,237,.72) !important;
  border-color: rgba(67,93,69,.18) !important;
}

body.login-page.login-v0972 .register-kind-buttons {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

body.login-page.login-v0972 .register-kind-option {
  min-height: 46px !important;
  border-radius: 8px !important;
  padding: 10px 12px !important;
}

body.login-page.login-v0972 .login-utility-row {
  margin-top: 12px !important;
  justify-content: flex-start !important;
}

body.login-page.login-v0972 .a3-inline {
  max-width: none !important;
}

@media (max-width: 1180px) {
  body.login-page.login-v0972 {
    grid-template-columns: minmax(330px, 40vw) minmax(0, 1fr) !important;
  }
  body.login-page.login-v0972 .login-campaign h1 {
    font-size: clamp(36px, 4.5vw, 58px) !important;
  }
  body.login-page.login-v0972 .login-company-name {
    font-size: clamp(16px, 2vw, 28px) !important;
  }
  body.login-page.login-v0972 .login-password-form {
    grid-template-columns: 1fr 1fr !important;
  }
  body.login-page.login-v0972 .login-password-form .button {
    grid-column: 1 / -1 !important;
    justify-self: start !important;
  }
}

@media (max-width: 900px) {
  body.login-page.login-v0972 {
    display: block !important;
    height: auto !important;
    min-height: 100vh !important;
    overflow: auto !important;
  }
  body.login-page.login-v0972 .login-campaign {
    position: relative !important;
    min-height: 280px !important;
    height: auto !important;
    padding: 32px 22px !important;
  }
  body.login-page.login-v0972 .login-campaign h1,
  body.login-page.login-v0972 .login-company-name {
    white-space: nowrap !important;
  }
  body.login-page.login-v0972 .login-company-name {
    font-size: clamp(15px, 4.4vw, 26px) !important;
  }
  body.login-page.login-v0972 .login-panel,
  body.login-page.login-v0972.gabo-oneui-v0622 .login-panel {
    height: auto !important;
    min-height: auto !important;
    overflow: visible !important;
    padding: 22px !important;
    border-left: 0 !important;
  }
}

@media (max-width: 680px) {
  body.login-page.login-v0972 .login-tabs-v0972,
  body.login-page.login-v0972 .register-kind-buttons,
  body.login-page.login-v0972 .login-password-form,
  body.login-page.login-v0972 .public-register-form-v094 {
    grid-template-columns: 1fr !important;
  }
  body.login-page.login-v0972 .login-tabs-v0972 button {
    justify-content: center !important;
  }
}


/* SisGabo 0.9.7.3 — ajuste fino solicitado no login.
   Mantém a estrutura 0.9.7.2, sem redesenhar, apenas polindo título e nomenclatura. */
body.login-page.login-v0973 .login-campaign h1 {
  font-size: clamp(40px, 4.8vw, 70px) !important;
  letter-spacing: -.045em !important;
}

body.login-page.login-v0973 .login-heading-clean {
  margin-bottom: 14px !important;
}

body.login-page.login-v0973 .login-heading-clean strong {
  font-size: clamp(13px, 1.05vw, 16px) !important;
  line-height: 1.2 !important;
  letter-spacing: .055em !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
}

body.login-page.login-v0973 .login-heading-clean small {
  display: none !important;
}


/* Pack 0.9.7.12 - Cadastro contador: card CFC full-width sem mensagem externa */
body.login-page.login-v09712 .contador-cfc-status-card {
  grid-column: 1 / -1 !important;
  width: 100% !important;
  display: block !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
}
body.login-page.login-v09712 .contador-cfc-status-card[hidden],
body.login-page.login-v09712 .contador-cfc-status[hidden] {
  display: none !important;
}
body.login-page.login-v09712 .contador-cfc-status {
  width: 100% !important;
  border: 1px solid rgba(67, 93, 69, .16) !important;
  border-radius: 8px !important;
  background: rgba(255, 255, 255, .86) !important;
  padding: 12px 14px !important;
  display: grid !important;
  gap: 4px !important;
  color: var(--green-900, #243426) !important;
}
body.login-page.login-v09712 .contador-cfc-status.success {
  background: rgba(237, 248, 239, .88) !important;
  border-color: rgba(39, 91, 50, .22) !important;
}
body.login-page.login-v09712 .contador-cfc-status.warning,
body.login-page.login-v09712 .contador-cfc-status.error {
  background: rgba(247, 245, 236, .92) !important;
  border-color: rgba(200, 168, 91, .26) !important;
}
body.login-page.login-v09712 .contador-cfc-status strong {
  font-size: 13px !important;
  line-height: 1.25 !important;
}
body.login-page.login-v09712 .contador-cfc-status span,
body.login-page.login-v09712 .contador-cfc-status small {
  font-size: 12px !important;
  line-height: 1.35 !important;
  color: var(--muted, #6d756d) !important;
}


/* Pack 0.9.7.13 - Cadastro contador: card CFC somente com texto em negrito e WhatsApp antes do CPF */
body.login-page.login-v09713 .contador-cfc-status-card {
  grid-column: 1 / -1 !important;
  width: 100% !important;
  display: block !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
}
body.login-page.login-v09713 .contador-cfc-status-card[hidden],
body.login-page.login-v09713 .contador-cfc-status[hidden] {
  display: none !important;
}
body.login-page.login-v09713 .contador-cfc-status {
  width: 100% !important;
  border: 1px solid rgba(67, 93, 69, .16) !important;
  border-radius: 8px !important;
  background: rgba(255, 255, 255, .86) !important;
  padding: 12px 14px !important;
  display: grid !important;
  gap: 0 !important;
  color: var(--green-900, #243426) !important;
}
body.login-page.login-v09713 .contador-cfc-status.success {
  background: rgba(237, 248, 239, .88) !important;
  border-color: rgba(39, 91, 50, .22) !important;
}
body.login-page.login-v09713 .contador-cfc-status.warning,
body.login-page.login-v09713 .contador-cfc-status.error {
  background: rgba(247, 245, 236, .92) !important;
  border-color: rgba(200, 168, 91, .26) !important;
}
body.login-page.login-v09713 .contador-cfc-status strong {
  font-size: 13px !important;
  line-height: 1.25 !important;
  font-weight: 800 !important;
}
body.login-page.login-v09713 .contador-cfc-status span,
body.login-page.login-v09713 .contador-cfc-status small {
  display: none !important;
}


/* Pack 0.9.7.14 - Cadastro contador: CFC somente para CPF e resultado em caixa alta */
body.login-page.login-v09714 .contador-cfc-status-card {
  grid-column: 1 / -1 !important;
  width: 100% !important;
  display: block !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
}
body.login-page.login-v09714 .contador-cfc-status-card[hidden],
body.login-page.login-v09714 .contador-cfc-status[hidden] {
  display: none !important;
}
body.login-page.login-v09714 .contador-cfc-status {
  width: 100% !important;
  border: 1px solid rgba(67, 93, 69, .16) !important;
  border-radius: 8px !important;
  background: rgba(255, 255, 255, .86) !important;
  padding: 12px 14px !important;
  display: grid !important;
  gap: 0 !important;
  color: var(--green-900, #243426) !important;
}
body.login-page.login-v09714 .contador-cfc-status.success {
  background: rgba(237, 248, 239, .88) !important;
  border-color: rgba(39, 91, 50, .22) !important;
}
body.login-page.login-v09714 .contador-cfc-status.warning,
body.login-page.login-v09714 .contador-cfc-status.error {
  background: rgba(247, 245, 236, .92) !important;
  border-color: rgba(200, 168, 91, .26) !important;
}
body.login-page.login-v09714 .contador-cfc-status strong {
  font-size: 13px !important;
  line-height: 1.25 !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: .02em !important;
}
body.login-page.login-v09714 .contador-cfc-status span,
body.login-page.login-v09714 .contador-cfc-status small {
  display: none !important;
}

/* SisGabo 0.9.8 - CRM Comercial: ajustes aditivos sem alterar login aprovado */
.gabo-crm-dashboard.three-cols { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.crm-list-mini { display: grid; gap: 8px; margin: 10px 0 14px; }
.crm-list-row { border: 1px solid var(--line); border-radius: var(--radius); padding: 10px; background: rgba(255,255,255,.72); }
.crm-list-row strong { display: block; color: var(--green-950); font-size: 13px; line-height: 1.25; }
.crm-list-row span { display: block; color: var(--muted); font-size: 12px; margin-top: 3px; }
.crm-card-action { width: 100%; justify-content: center; }
.crm-form-wide { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.crm-form-wide .span-2 { grid-column: span 2; }
.gabo-switch-line { display: flex; align-items: center; gap: 10px; min-height: 42px; }
.gabo-switch-line input { width: 18px; height: 18px; }
.status-prospect { background: #fbf2d6; color: #7d6720; }
.status-nao_localizado, .status-pendente { background: #fbf2d6; color: #7d6720; }
.status-inativo, .status-bloqueado { background: #fae8e8; color: var(--red); }
@media (max-width: 1100px) { .gabo-crm-dashboard.three-cols, .crm-form-wide { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 720px) { .gabo-crm-dashboard.three-cols, .crm-form-wide { grid-template-columns: 1fr; } .crm-form-wide .span-2 { grid-column: auto; } }
