:root{
  --bg:#050505;
  --bg-soft:#0c0c0d;
  --panel:#101112;
  --panel-2:#151617;
  --text:#f7f2e2;
  --muted:#b6ab92;
  --gold:#d4af37;
  --gold-soft:#f3db87;
  --gold-deep:#8a6c1f;
  --line:rgba(212,175,55,.16);
  --line-strong:rgba(212,175,55,.34);
  --white-line:rgba(255,255,255,.06);
  --ok:#37d27e;
  --warn:#f0b84b;
  --late:#ff6b6b;
  --radius-xl:30px;
  --radius-lg:24px;
  --radius-md:18px;
  --shadow:0 20px 60px rgba(0,0,0,.42);
}

*{
  margin:0;
  padding:0;
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
}

body{
  min-height:100vh;
  font-family:'Inter',sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at 10% 10%, rgba(212,175,55,.10), transparent 22%),
    radial-gradient(circle at 90% 0%, rgba(212,175,55,.07), transparent 20%),
    linear-gradient(180deg, #040404 0%, #0a0a0b 100%);
}

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

button,
input,
textarea,
select{
  font:inherit;
}

.glass{
  background:linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.015));
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  backdrop-filter:blur(18px);
}

.btn{
  border:none;
  border-radius:14px;
  padding:13px 18px;
  cursor:pointer;
  font-weight:700;
  transition:.25s ease;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}

.btn:hover{
  transform:translateY(-2px);
}

.btnGold{
  background:linear-gradient(135deg,var(--gold-soft),var(--gold));
  color:#1a1507;
  box-shadow:0 10px 28px rgba(212,175,55,.22);
}

.btnGhost{
  background:rgba(255,255,255,.03);
  color:var(--text);
  border:1px solid var(--line-strong);
}

.fullWidth{
  width:100%;
}

/* =========================
   AUTH
========================= */

.authBody{
  position:relative;
  overflow:hidden;
}

.authNoise{
  position:fixed;
  inset:0;
  pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.02) 1px, transparent 1px);
  background-size:32px 32px;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.55), transparent 90%);
  opacity:.25;
}

.authGlow{
  position:fixed;
  width:420px;
  height:420px;
  border-radius:50%;
  filter:blur(60px);
  pointer-events:none;
  opacity:.18;
}

.authGlowOne{
  top:-120px;
  left:-100px;
  background:var(--gold);
}

.authGlowTwo{
  right:-120px;
  bottom:-140px;
  background:#7d6118;
}

.authLayout{
  width:min(1240px, calc(100% - 32px));
  min-height:100vh;
  margin:0 auto;
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:28px;
  align-items:center;
  padding:30px 0;
  position:relative;
  z-index:1;
}

.authLeft{
  padding:14px 6px;
}

.eyebrowBadge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(212,175,55,.10);
  border:1px solid var(--line-strong);
  color:var(--gold-soft);
  font-size:.86rem;
  font-weight:700;
  margin-bottom:22px;
}

.authTitle{
  font-size:clamp(2.2rem,4vw,4.3rem);
  line-height:1.02;
  max-width:760px;
  margin-bottom:18px;
  letter-spacing:-0.03em;
}

.authDescription{
  color:var(--muted);
  line-height:1.85;
  max-width:700px;
  font-size:1rem;
  margin-bottom:30px;
}

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

.authFeatureCard{
  display:flex;
  gap:14px;
  align-items:flex-start;
  padding:18px;
  border-radius:20px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--white-line);
  transition:.25s ease;
}

.authFeatureCard:hover{
  transform:translateY(-4px);
  border-color:var(--line-strong);
}

.featureIcon{
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border-radius:14px;
  background:rgba(212,175,55,.10);
  border:1px solid rgba(212,175,55,.18);
  color:var(--gold-soft);
  flex-shrink:0;
}

.authFeatureCard strong{
  display:block;
  margin-bottom:6px;
  font-size:.97rem;
}

.authFeatureCard p{
  color:var(--muted);
  font-size:.9rem;
  line-height:1.55;
}

.authRight{
  padding:30px;
  border-radius:32px;
  position:relative;
  overflow:hidden;
}

.authRight::before{
  content:"";
  position:absolute;
  inset:-1px;
  background:linear-gradient(135deg, rgba(212,175,55,.18), transparent 35%, transparent 65%, rgba(212,175,55,.06));
  opacity:.55;
  pointer-events:none;
}

.loginBrand{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:28px;
  position:relative;
  z-index:1;
}

.brandMark{
  width:56px;
  height:56px;
  display:grid;
  place-items:center;
  border-radius:18px;
  background:linear-gradient(135deg,var(--gold-soft),var(--gold));
  color:#171205;
  font-weight:800;
  font-size:1.02rem;
  box-shadow:0 12px 32px rgba(212,175,55,.22);
}

.loginBrand h2{
  font-size:1.18rem;
  margin-bottom:4px;
}

.loginBrand p{
  color:var(--muted);
}

.loginForm{
  display:grid;
  gap:14px;
  position:relative;
  z-index:1;
}

.fieldGroup{
  display:grid;
  gap:8px;
}

.fieldGroup label{
  font-size:.92rem;
  color:#ebdfbb;
}

.fieldGroup input,
.fieldGroup textarea,
.fieldGroup select,
.searchInput{
  width:100%;
  padding:14px 16px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  color:var(--text);
  outline:none;
}

.fieldGroup textarea{
  resize:vertical;
  min-height:100px;
}

.fieldGroup input:focus,
.fieldGroup textarea:focus,
.fieldGroup select:focus,
.searchInput:focus{
  border-color:var(--line-strong);
  box-shadow:0 0 0 4px rgba(212,175,55,.06);
}

.loginBottomNote{
  position:relative;
  z-index:1;
  margin-top:18px;
  display:flex;
  align-items:center;
  gap:10px;
}

.loginBottomNote span{
  flex:1;
  height:1px;
  background:linear-gradient(90deg, rgba(212,175,55,.28), transparent);
}

.loginBottomNote p{
  font-size:.82rem;
  color:var(--muted);
}

/* =========================
   APP LAYOUT
========================= */

.appLayout{
  min-height:100vh;
  display:grid;
  grid-template-columns:290px 1fr;
}

.sidebar{
  padding:22px;
  border-right:1px solid var(--line);
  background:linear-gradient(180deg, rgba(10,10,10,.92), rgba(9,9,10,.82));
}

.sidebarTop{
  padding:16px;
  border-radius:24px;
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:20px;
}

.sidebarTop strong{
  display:block;
  font-size:1rem;
}

.sidebarTop span{
  display:block;
  color:var(--muted);
  font-size:.88rem;
  margin-top:3px;
}

.sidebarMenu{
  display:grid;
  gap:10px;
  margin-bottom:20px;
}

.menuItem{
  display:flex;
  align-items:center;
  gap:12px;
  padding:14px 16px;
  border-radius:18px;
  border:1px solid transparent;
  color:#ecdcb8;
  transition:.25s ease;
  position:relative;
  overflow:hidden;
}

.menuItem::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(212,175,55,.11), transparent 70%);
  opacity:0;
  transition:.25s ease;
}

.menuItem:hover,
.menuItem.active{
  border-color:var(--line-strong);
  background:rgba(212,175,55,.08);
  transform:translateX(3px);
}

.menuItem:hover::before,
.menuItem.active::before{
  opacity:1;
}

.menuIcon{
  width:30px;
  height:30px;
  border-radius:10px;
  display:grid;
  place-items:center;
  background:rgba(212,175,55,.10);
  border:1px solid rgba(212,175,55,.16);
  color:var(--gold-soft);
  flex-shrink:0;
}

.sidebarInfo{
  padding:20px;
  border-radius:24px;
}

.sidebarInfo small{
  display:block;
  color:var(--gold-soft);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:.72rem;
  margin-bottom:8px;
}

.sidebarInfo h3{
  margin-bottom:8px;
  font-size:1.15rem;
}

.sidebarInfo p{
  color:var(--muted);
  line-height:1.65;
  margin-bottom:14px;
}

.mainContent{
  padding:24px;
  display:grid;
  gap:18px;
}

.topbar{
  border-radius:26px;
  padding:20px 24px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:18px;
}

.sectionEyebrow{
  color:var(--gold-soft);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:.75rem;
  margin-bottom:6px;
}

.topbar h1{
  font-size:1.8rem;
  margin-bottom:4px;
}

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

.topbarRight{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:320px;
}

.heroCard{
  border-radius:30px;
  padding:28px;
  display:grid;
  grid-template-columns:1.18fr .82fr;
  gap:20px;
  position:relative;
  overflow:hidden;
}

.heroCard::after{
  content:"";
  position:absolute;
  width:280px;
  height:280px;
  border-radius:50%;
  right:-80px;
  bottom:-90px;
  background:radial-gradient(circle, rgba(212,175,55,.15), transparent 68%);
  pointer-events:none;
}

.heroPill{
  display:inline-flex;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(212,175,55,.08);
  border:1px solid var(--line-strong);
  color:var(--gold-soft);
  font-size:.84rem;
  font-weight:700;
  margin-bottom:16px;
}

.heroText h2{
  font-size:clamp(2rem,3vw,3.2rem);
  line-height:1.03;
  margin-bottom:14px;
  max-width:760px;
  letter-spacing:-0.03em;
}

.heroText p{
  color:var(--muted);
  line-height:1.8;
  max-width:720px;
  margin-bottom:20px;
}

.heroActions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

.heroStats{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  align-self:end;
}

.miniStat{
  padding:18px;
  border-radius:20px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--white-line);
}

.miniStat span{
  display:block;
  color:var(--muted);
  margin-bottom:10px;
  font-size:.88rem;
}

.miniStat strong{
  font-size:1.5rem;
}

.kpiGrid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}

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

.kpiCard{
  padding:22px;
  border-radius:24px;
  position:relative;
  overflow:hidden;
}

.kpiCard::before{
  content:"";
  position:absolute;
  width:140px;
  height:140px;
  right:-50px;
  top:-50px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(212,175,55,.14), transparent 70%);
}

.kpiCard span{
  display:block;
  color:var(--muted);
  margin-bottom:10px;
}

.kpiCard strong{
  display:block;
  font-size:2rem;
  margin-bottom:8px;
}

.kpiCard small{
  color:#dcc984;
}

.dashboardRow{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}

.panel,
.formPanel{
  padding:22px;
  border-radius:26px;
}

.panelHeader{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:16px;
}

.panelHeader h3{
  margin-bottom:4px;
}

.panelHeader p{
  color:var(--muted);
  font-size:.92rem;
}

.tag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 12px;
  border-radius:999px;
  font-size:.75rem;
  font-weight:800;
  text-transform:uppercase;
  background:rgba(212,175,55,.08);
  color:var(--gold-soft);
  border:1px solid var(--line-strong);
}

.chartCard{
  padding-top:6px;
}

.chartBars{
  height:280px;
  display:flex;
  align-items:flex-end;
  gap:12px;
}

.barCol{
  flex:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:12px;
}

.barTrack{
  width:100%;
  height:230px;
  padding:10px;
  display:flex;
  align-items:flex-end;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.05));
  border:1px solid rgba(255,255,255,.05);
}

.barFill{
  width:100%;
  border-radius:14px;
  background:linear-gradient(180deg,var(--gold-soft),var(--gold));
  box-shadow:0 10px 24px rgba(212,175,55,.22);
}

.h54{height:54%}
.h70{height:70%}
.h62{height:62%}
.h88{height:88%}
.h76{height:76%}

.barCol span{
  color:var(--muted);
  font-size:.84rem;
}

.listGroup{
  display:grid;
  gap:12px;
}

.listItem{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:14px 16px;
  border-radius:18px;
  background:rgba(255,255,255,.025);
  border:1px solid rgba(255,255,255,.05);
}

.listItem small{
  display:block;
  margin-top:6px;
  color:var(--muted);
}

.documentCard{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:16px;
  padding:16px;
  border-radius:18px;
  background:rgba(255,255,255,.025);
  border:1px solid rgba(255,255,255,.05);
}

.documentCard p{
  color:var(--muted);
  margin-top:6px;
  line-height:1.55;
  font-size:.92rem;
}

.documentMeta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:10px;
}

.metaPill{
  padding:7px 10px;
  border-radius:999px;
  background:rgba(212,175,55,.08);
  border:1px solid rgba(212,175,55,.16);
  color:var(--gold-soft);
  font-size:.76rem;
  font-weight:700;
}

.status{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 12px;
  border-radius:999px;
  font-size:.75rem;
  font-weight:800;
  text-transform:uppercase;
  white-space:nowrap;
}

.status.ok{
  color:#b8f6d1;
  background:rgba(55,210,126,.12);
  border:1px solid rgba(55,210,126,.2);
}

.status.warn{
  color:#ffe3a6;
  background:rgba(240,184,75,.12);
  border:1px solid rgba(240,184,75,.2);
}

.status.late{
  color:#ffcaca;
  background:rgba(255,107,107,.12);
  border:1px solid rgba(255,107,107,.2);
}

.tableWrap{
  overflow:auto;
}

table{
  width:100%;
  border-collapse:collapse;
}

th,
td{
  padding:14px 10px;
  text-align:left;
  border-bottom:1px solid rgba(255,255,255,.06);
}

th{
  font-size:.8rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:#dccb8f;
}

td{
  color:#f5edd7;
}

.tableEmpty,
.emptyStateSmall{
  color:var(--muted);
  text-align:center;
  padding:18px 10px;
}

.gridForm{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:16px;
}

.fieldSpan2{
  grid-column:span 2;
}

.formActions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

.toast{
  position:fixed;
  right:20px;
  bottom:20px;
  background:linear-gradient(180deg, rgba(18,18,18,.95), rgba(10,10,10,.95));
  color:var(--text);
  border:1px solid var(--line-strong);
  padding:14px 16px;
  border-radius:16px;
  box-shadow:var(--shadow);
  z-index:9999;
  min-width:260px;
}

/* =========================
   RESPONSIVO
========================= */

@media (max-width: 1160px){
  .authLayout,
  .heroCard,
  .dashboardRow{
    grid-template-columns:1fr;
  }

  .authFeatureGrid,
  .heroStats{
    grid-template-columns:1fr;
  }

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

@media (max-width: 920px){
  .appLayout{
    grid-template-columns:1fr;
  }

  .sidebar{
    border-right:none;
    border-bottom:1px solid var(--line);
  }

  .topbar{
    flex-direction:column;
    align-items:flex-start;
  }

  .topbarRight{
    width:100%;
    min-width:0;
    flex-direction:column;
    align-items:stretch;
  }

  .gridForm{
    grid-template-columns:1fr;
  }

  .fieldSpan2{
    grid-column:span 1;
  }
}

@media (max-width: 640px){
  .authLayout{
    width:min(100% - 20px, 1240px);
  }

  .authRight,
  .mainContent,
  .sidebar{
    padding:18px;
  }

  .kpiGrid,
  .kpiGrid.twoCols{
    grid-template-columns:1fr;
  }

  .chartBars{
    gap:8px;
  }

  .barTrack{
    height:200px;
  }

  .formActions{
    flex-direction:column;
  }
}

.hidden{
  display:none !important;
}

.authTabs{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-bottom:18px;
}

.authTab{
  border:none;
  padding:12px 14px;
  border-radius:14px;
  background:rgba(255,255,255,.03);
  color:var(--text);
  border:1px solid rgba(255,255,255,.08);
  cursor:pointer;
  transition:.25s ease;
  font-weight:700;
}

.authTab.active{
  background:rgba(212,175,55,.10);
  border-color:var(--line-strong);
  color:var(--gold-soft);
}

.authFeedback{
  position:relative;
  z-index:1;
  min-height:22px;
  margin-top:14px;
  font-size:.92rem;
  color:#d8c987;
}
.hidden{
  display:none !important;
}

.filtersBar{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:12px;
  margin-bottom:16px;
}

.rowActions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

.actionBtn{
  border:none;
  border-radius:12px;
  padding:8px 12px;
  cursor:pointer;
  font-weight:700;
  transition:.2s ease;
}

.actionBtn.edit{
  background:rgba(212,175,55,.12);
  color:var(--gold-soft);
  border:1px solid rgba(212,175,55,.24);
}

.actionBtn.delete{
  background:rgba(255,107,107,.10);
  color:#ffb5b5;
  border:1px solid rgba(255,107,107,.18);
}

.actionBtn:hover{
  transform:translateY(-1px);
}

.docActions{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:10px;
}

@media (max-width: 920px){
  .filtersBar{
    grid-template-columns:1fr;
  }

  .docActions{
    align-items:flex-start;
  }

  .documentCard{
    flex-direction:column;
  }
}
.roleBadge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(212,175,55,.10);
  border:1px solid rgba(212,175,55,.22);
  color:var(--gold-soft);
  font-weight:800;
  text-transform:uppercase;
  font-size:.78rem;
  letter-spacing:.04em;
}

.profileGrid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}

.profileCard{
  padding:18px;
  border-radius:18px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.05);
}

.profileCard span{
  display:block;
  color:var(--muted);
  margin-bottom:8px;
  font-size:.88rem;
}

.profileCard strong{
  font-size:1.05rem;
}

@media (max-width: 920px){
  .profileGrid{
    grid-template-columns:1fr;
  }
}

.roleSelect{
  width:100%;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(212,175,55,.20);
  background:rgba(255,255,255,.04);
  color:var(--text);
  outline:none;
}

.roleSelect:focus{
  border-color:var(--line-strong);
  box-shadow:0 0 0 4px rgba(212,175,55,.06);
}

.mutedText{
  color:var(--muted);
  font-size:.9rem;
}
/* =========================
   USERS PREMIUM V6.1
========================= */

.usersHero{
  border-radius:30px;
  padding:28px;
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:20px;
  position:relative;
  overflow:hidden;
}

.usersHero::after{
  content:"";
  position:absolute;
  right:-80px;
  bottom:-80px;
  width:260px;
  height:260px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(212,175,55,.16), transparent 68%);
  pointer-events:none;
}

.usersHeroContent h2{
  font-size:clamp(1.8rem, 3vw, 3rem);
  line-height:1.05;
  margin-bottom:14px;
  max-width:760px;
  letter-spacing:-0.03em;
}

.usersHeroContent p{
  color:var(--muted);
  line-height:1.8;
  max-width:760px;
}

.usersHeroMiniStats{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  align-self:end;
}

.usersMiniStat{
  padding:18px;
  border-radius:20px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.05);
}

.usersMiniStat span{
  display:block;
  color:var(--muted);
  margin-bottom:10px;
  font-size:.88rem;
}

.usersMiniStat strong{
  font-size:1.25rem;
}

.usersInfoGrid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}

.profilePanel,
.permissionsPanel,
.usersTablePanel{
  padding:22px;
  border-radius:26px;
}

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

.premiumProfileCard{
  position:relative;
  overflow:hidden;
}

.premiumProfileCard::before{
  content:"";
  position:absolute;
  width:120px;
  height:120px;
  right:-40px;
  top:-40px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(212,175,55,.12), transparent 70%);
}

.permissionLegend{
  display:grid;
  gap:12px;
}

.permissionItem{
  display:flex;
  gap:14px;
  align-items:flex-start;
  padding:14px 16px;
  border-radius:18px;
  background:rgba(255,255,255,.025);
  border:1px solid rgba(255,255,255,.05);
}

.permissionItem strong{
  display:block;
  margin-bottom:5px;
}

.permissionItem p{
  color:var(--muted);
  line-height:1.55;
  font-size:.92rem;
}

.permissionDot{
  width:14px;
  height:14px;
  border-radius:999px;
  margin-top:4px;
  flex-shrink:0;
}

.adminDot{ background:linear-gradient(135deg,#f3db87,#d4af37); }
.fiscalDot{ background:#37d27e; }
.atendimentoDot{ background:#5aa9ff; }
.financeiroDot{ background:#b07bff; }
.clienteDot{ background:#8b8b8b; }

.usersTableHead{
  align-items:center;
}

.usersToolbar{
  min-width:280px;
}

.usersCardsWrap{
  display:none;
  gap:12px;
}

.userCard{
  padding:16px;
  border-radius:20px;
  background:rgba(255,255,255,.025);
  border:1px solid rgba(255,255,255,.05);
  display:grid;
  gap:12px;
}

.userCardTop strong{
  display:block;
  margin-bottom:5px;
}

.userCardTop p{
  color:var(--muted);
  font-size:.92rem;
  line-height:1.5;
  word-break:break-word;
}

.userCardMeta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}

.userRoleBadge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(212,175,55,.09);
  border:1px solid rgba(212,175,55,.2);
  color:var(--gold-soft);
  font-weight:800;
  font-size:.75rem;
  text-transform:uppercase;
}

.usersDesktopTable{
  margin-top:10px;
}

.roleSelect{
  width:100%;
  min-width:160px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(212,175,55,.20);
  background:rgba(255,255,255,.04);
  color:var(--text);
  outline:none;
}

.roleSelect:focus{
  border-color:var(--line-strong);
  box-shadow:0 0 0 4px rgba(212,175,55,.06);
}

.mutedText{
  color:var(--muted);
  font-size:.9rem;
}

@media (max-width: 1160px){
  .usersHero,
  .usersInfoGrid{
    grid-template-columns:1fr;
  }

  .profileGridUsers{
    grid-template-columns:1fr;
  }
}

@media (max-width: 860px){
  .usersCardsWrap{
    display:grid;
  }

  .usersDesktopTable{
    display:none;
  }

  .usersToolbar{
    width:100%;
    min-width:0;
  }
}
/* =========================
   XML TO EXCEL
========================= */

.xmlHero{
  border-radius:30px;
  padding:28px;
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:20px;
  position:relative;
  overflow:hidden;
}

.xmlHero::after{
  content:"";
  position:absolute;
  right:-80px;
  bottom:-80px;
  width:260px;
  height:260px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(212,175,55,.16), transparent 68%);
  pointer-events:none;
}

.xmlHeroContent h2{
  font-size:clamp(1.8rem, 3vw, 3rem);
  line-height:1.05;
  margin-bottom:14px;
  max-width:760px;
  letter-spacing:-0.03em;
}

.xmlHeroContent p{
  color:var(--muted);
  line-height:1.8;
  max-width:760px;
}

.xmlHeroStats{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  align-self:end;
}

.xmlToolsGrid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}

.topSpace16{
  margin-top:16px;
}

@media (max-width: 1160px){
  .xmlHero{
    grid-template-columns:1fr;
  }
}

@media (max-width: 920px){
  .xmlToolsGrid{
    grid-template-columns:1fr;
  }
}
/* =========================
   TOOLS PAGES
========================= */

.toolHero{
  border-radius:30px;
  padding:28px;
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:20px;
  position:relative;
  overflow:hidden;
}

.toolHero::after{
  content:"";
  position:absolute;
  right:-80px;
  bottom:-80px;
  width:260px;
  height:260px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(212,175,55,.16), transparent 68%);
  pointer-events:none;
}

.toolHeroContent h2{
  font-size:clamp(1.8rem, 3vw, 3rem);
  line-height:1.05;
  margin-bottom:14px;
  max-width:760px;
  letter-spacing:-0.03em;
}

.toolHeroContent p{
  color:var(--muted);
  line-height:1.8;
  max-width:760px;
}

.toolHeroStats{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  align-self:end;
}

.toolGrid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}

.topSpace16{
  margin-top:16px;
}

.txtPreviewArea{
  width:100%;
  min-height:340px;
  resize:vertical;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  color:var(--text);
  padding:16px;
  outline:none;
  line-height:1.6;
  font-family:monospace;
}

@media (max-width: 1160px){
  .toolHero{
    grid-template-columns:1fr;
  }
}

@media (max-width: 920px){
  .toolGrid{
    grid-template-columns:1fr;
  }
}
/* =========================
   XML EVOLUCAO FISCAL
========================= */

.kpiGrid .kpiCard strong{
  font-size:1.45rem;
}

.listGroup .listItem small{
  color:var(--muted);
}

.panel .tag{
  white-space:nowrap;
}

/* =========================
   LOTE XML ZIP
========================= */

.kpiGrid .kpiCard strong{
  font-size:1.45rem;
}

.listGroup .listItem small{
  color:var(--muted);
}

.panel .tag{
  white-space:nowrap;
}

/* =========================
   CONTRACHEQUE
========================= */

.contrachequeSheet{
  background:#fff;
  color:#111;
  border-radius:24px;
  padding:28px;
  box-shadow:0 20px 60px rgba(0,0,0,.18);
}

.ccHeader{
  display:flex;
  justify-content:space-between;
  gap:20px;
  align-items:flex-start;
  border-bottom:1px solid rgba(0,0,0,.12);
  padding-bottom:16px;
  margin-bottom:18px;
}

.ccHeader h2{
  margin:0 0 6px 0;
  font-size:1.35rem;
}

.ccHeader p,
.ccHeader span{
  margin:0;
  color:#444;
}

.ccHeaderRight{
  text-align:right;
  display:flex;
  flex-direction:column;
  gap:6px;
}

.ccInfoGrid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-bottom:18px;
  font-size:.95rem;
}

.ccTableWrap{
  overflow:auto;
}

.ccTable{
  width:100%;
  border-collapse:collapse;
  margin-bottom:18px;
}

.ccTable th,
.ccTable td{
  border:1px solid rgba(0,0,0,.12);
  padding:10px 12px;
  text-align:left;
  font-size:.92rem;
}

.ccTable th{
  background:#f6f6f6;
}

.ccTotals{
  display:grid;
  gap:8px;
  justify-content:end;
  margin-bottom:22px;
}

.ccLiquido{
  font-size:1.08rem;
}

.ccFooter{
  border-top:1px solid rgba(0,0,0,.12);
  padding-top:16px;
}

.ccSignatures{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
  margin-top:28px;
}

.ccSignature{
  border-top:1px solid rgba(0,0,0,.28);
  padding-top:8px;
  text-align:center;
  color:#444;
  font-size:.9rem;
}

@media (max-width: 920px){
  .ccInfoGrid,
  .ccSignatures{
    grid-template-columns:1fr;
  }

  .ccHeader{
    flex-direction:column;
  }

  .ccHeaderRight{
    text-align:left;
  }
}

@media print {
  body *{
    visibility:hidden;
  }

  .contrachequePrintPanel,
  .contrachequePrintPanel *{
    visibility:visible;
  }

  .contrachequePrintPanel{
    position:absolute;
    inset:0;
    width:100%;
    margin:0;
    padding:0;
    background:#fff !important;
  }

  .noPrint{
    display:none !important;
  }

  .contrachequeSheet{
    box-shadow:none;
    border-radius:0;
    padding:20px;
  }
}
/* =========================
   CONTRACHEQUE PREMIUM
========================= */

.ccSummaryGrid{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}

.ccSummaryCard{
  border-radius:22px;
  padding:18px;
  border:1px solid rgba(255,255,255,.06);
  background:rgba(255,255,255,.025);
}

.ccSummaryCard span{
  display:block;
  color:var(--muted);
  margin-bottom:8px;
  font-size:.88rem;
}

.ccSummaryCard strong{
  display:block;
  font-size:1.35rem;
  margin-bottom:4px;
}

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

.ccSummaryPositive strong{
  color:#caa24f;
}

.ccSummaryNegative strong{
  color:#ff8b8b;
}

.ccSummaryLiquid strong{
  color:#7de2a8;
}

.contrachequeSheetPro{
  background:linear-gradient(180deg,#ffffff 0%,#fafafa 100%);
  color:#141414;
  border-radius:28px;
  padding:30px;
  box-shadow:0 30px 80px rgba(0,0,0,.18);
}

.ccProTop{
  display:flex;
  justify-content:space-between;
  gap:24px;
  align-items:flex-start;
  padding-bottom:18px;
  border-bottom:1px solid rgba(0,0,0,.08);
  margin-bottom:22px;
}

.ccProBrand{
  display:flex;
  gap:16px;
  align-items:center;
}

.ccProLogo{
  width:58px;
  height:58px;
  border-radius:18px;
  background:linear-gradient(135deg,#111,#2c2c2c);
  color:#d4af37;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.25rem;
  font-weight:800;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}

.ccProBrand h2{
  margin:0 0 5px 0;
  font-size:1.3rem;
}

.ccProBrand p{
  margin:0;
  color:#666;
}

.ccProDocTitle{
  text-align:right;
  display:flex;
  flex-direction:column;
  gap:8px;
}

.ccProDocTitle strong{
  font-size:1rem;
  letter-spacing:.08em;
  color:#111;
}

.ccProDocTitle span{
  color:#666;
}

.ccProMeta{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin-bottom:22px;
}

.ccMetaItem{
  background:#f6f6f6;
  border:1px solid rgba(0,0,0,.06);
  border-radius:18px;
  padding:14px;
}

.ccMetaItem span{
  display:block;
  font-size:.82rem;
  color:#777;
  margin-bottom:6px;
}

.ccMetaItem strong{
  font-size:.95rem;
  color:#111;
}

.ccProBody{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  margin-bottom:22px;
}

.ccProColumn{
  border:1px solid rgba(0,0,0,.08);
  border-radius:22px;
  overflow:hidden;
  background:#fff;
}

.ccBlockTitle{
  padding:14px 16px;
  background:#121212;
  color:#d4af37;
  font-weight:700;
  letter-spacing:.03em;
}

.ccLines{
  padding:10px 14px;
  display:grid;
  gap:10px;
}

.ccLine{
  display:flex;
  justify-content:space-between;
  gap:14px;
  align-items:flex-start;
  padding:12px 0;
  border-bottom:1px solid rgba(0,0,0,.06);
}

.ccLine:last-child{
  border-bottom:none;
}

.ccLine strong{
  display:block;
  font-size:.94rem;
  margin-bottom:4px;
}

.ccLine small{
  color:#777;
}

.ccLine span{
  font-weight:700;
  color:#111;
  white-space:nowrap;
}

.ccLine.empty{
  color:#777;
  display:block;
}

.ccProTotals{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  margin-bottom:22px;
}

.ccProTotalCard{
  background:#f6f6f6;
  border:1px solid rgba(0,0,0,.06);
  border-radius:20px;
  padding:16px;
}

.ccProTotalCard span{
  display:block;
  font-size:.84rem;
  color:#777;
  margin-bottom:8px;
}

.ccProTotalCard strong{
  font-size:1.2rem;
  color:#111;
}

.ccProTotalCard.liquid{
  background:linear-gradient(135deg,#111,#1b1b1b);
  border-color:#111;
}

.ccProTotalCard.liquid span,
.ccProTotalCard.liquid strong{
  color:#fff;
}

.ccProObs{
  border:1px solid rgba(0,0,0,.08);
  border-radius:20px;
  padding:16px;
  background:#fff;
  margin-bottom:24px;
}

.ccProObs strong{
  display:block;
  margin-bottom:8px;
}

.ccProObs p{
  margin:0;
  color:#555;
  line-height:1.6;
}

.ccProSignatures{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  margin-top:26px;
}

.ccProSignature{
  border-top:1px solid rgba(0,0,0,.22);
  padding-top:10px;
  text-align:center;
  color:#666;
  font-size:.9rem;
}

@media (max-width: 1100px){
  .ccProMeta,
  .ccProTotals{
    grid-template-columns:1fr 1fr;
  }

  .ccProBody{
    grid-template-columns:1fr;
  }
}

@media (max-width: 760px){
  .ccProTop,
  .ccProSignatures,
  .ccProMeta,
  .ccProTotals{
    grid-template-columns:1fr;
    flex-direction:column;
  }

  .ccProDocTitle{
    text-align:left;
  }
}

@media print {
  body *{
    visibility:hidden;
  }

  .contrachequePrintPanel,
  .contrachequePrintPanel *{
    visibility:visible;
  }

  .contrachequePrintPanel{
    position:absolute;
    inset:0;
    width:100%;
    margin:0;
    padding:0;
    background:#fff !important;
  }

  .noPrint{
    display:none !important;
  }

  .contrachequeSheetPro{
    box-shadow:none;
    border-radius:0;
    padding:18px;
  }
}
/* =========================
   CONTRACHEQUE CLASSICO PDF
========================= */

.classicPayslipWrap{
  margin-top:18px;
}

.classicPayslip{
  display:grid;
  grid-template-columns: 1fr 165px;
  background:#fff;
  color:#111;
  border:2px solid #111;
  min-height:760px;
  font-family:Arial, Helvetica, sans-serif;
}

.cpMain{
  display:flex;
  flex-direction:column;
  min-height:100%;
}

.cpTopHeader{
  display:grid;
  grid-template-columns: 1fr 1fr;
  border-bottom:2px solid #111;
}

.cpCompanyBlock,
.cpTitleBlock{
  padding:8px 10px;
  font-size:13px;
  line-height:1.35;
}

.cpTitleBlock{
  text-align:center;
}

.cpTitle{
  font-size:16px;
  font-weight:700;
  margin-bottom:6px;
}

.cpEmployeeHeader{
  display:grid;
  grid-template-columns: 90px 1.4fr 1fr 1fr 1fr;
  border-bottom:2px solid #111;
  border-top:1px solid #111;
}

.cpCol{
  border-right:1px solid #111;
  min-height:68px;
}

.cpCol:last-child{
  border-right:none;
}

.cpLabel{
  font-size:11px;
  text-align:center;
  padding:4px 6px 2px;
}

.cpValue{
  font-size:13px;
  text-align:center;
  padding:6px 6px 8px;
}

.cpValue.strong{
  font-weight:700;
  font-size:15px;
}

.cpTableArea{
  flex:1;
  border-bottom:2px solid #111;
}

.cpTable{
  width:100%;
  border-collapse:collapse;
  font-size:12px;
}

.cpTable thead th{
  border-bottom:1px solid #111;
  border-right:1px solid #111;
  padding:4px 6px;
  font-weight:700;
  text-align:center;
}

.cpTable thead th:last-child{
  border-right:none;
}

.cpTable td{
  border-right:1px solid #111;
  padding:4px 6px;
  vertical-align:top;
}

.cpTable td:last-child{
  border-right:none;
}

.cpTable tbody tr{
  height:28px;
}

.cpTable .codigo{
  width:70px;
}

.cpTable .descricao{
  width:auto;
}

.cpTable .referencia{
  width:110px;
}

.cpTable .vencimentos,
.cpTable .descontos{
  width:140px;
}

.cpTable tbody td:nth-child(1),
.cpTable tbody td:nth-child(3){
  text-align:center;
}

.cpTable tbody td:nth-child(4),
.cpTable tbody td:nth-child(5){
  text-align:right;
}

.cpTotalsBox{
  border-bottom:2px solid #111;
}

.cpTotalsRow{
  display:grid;
  grid-template-columns: 1fr 1fr;
  margin-left:auto;
  width:46%;
  border-bottom:1px solid #111;
}

.cpTotalsLabel{
  text-align:center;
  padding:4px 6px;
  font-size:11px;
  border-left:1px solid #111;
}

.cpTotalsValues{
  display:grid;
  grid-template-columns: 1fr 1fr;
  margin-left:auto;
  width:46%;
  border-bottom:1px solid #111;
}

.cpTotalsValues div{
  text-align:right;
  padding:6px 10px;
  font-size:14px;
  border-left:1px solid #111;
}

.cpLiquidoRow{
  display:grid;
  grid-template-columns: 1.2fr 55px 40px 1fr;
  margin-left:auto;
  width:46%;
  align-items:center;
}

.cpLiquidoLabel{
  padding:8px 10px;
  font-weight:700;
  border-left:1px solid #111;
  font-size:13px;
}

.cpLiquidoCurrency{
  padding:8px 6px;
  text-align:center;
  font-weight:700;
  border-left:1px solid #111;
}

.cpLiquidoArrow{
  padding:8px 6px;
  text-align:center;
  font-weight:700;
  border-left:1px solid #111;
  font-size:18px;
}

.cpLiquidoValue{
  padding:8px 10px;
  text-align:right;
  font-size:18px;
  font-weight:700;
  border-left:1px solid #111;
}

.cpBottomGrid{
  display:grid;
  grid-template-columns: repeat(5, 1fr);
}

.cpBottomCell{
  border-right:1px solid #111;
  padding:6px 8px 10px;
  min-height:58px;
}

.cpBottomCell:last-child{
  border-right:none;
}

.cpBottomLabel{
  font-size:11px;
  text-align:center;
  margin-bottom:8px;
}

.cpBottomValue{
  font-size:13px;
  text-align:center;
}

.cpSideReceipt{
  border-left:2px solid #111;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  align-items:center;
  padding:10px 6px;
}

.cpSideText{
  writing-mode:vertical-rl;
  transform:rotate(180deg);
  text-align:center;
  font-size:12px;
  font-weight:500;
  letter-spacing:.02em;
}

.cpSignatureArea,
.cpDateArea{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
}

.cpSignatureLine{
  width:1px;
  height:150px;
  background:#111;
}

.cpDateLine{
  width:1px;
  height:110px;
  background:#111;
}

.cpSignatureLabel,
.cpDateLabel{
  writing-mode:vertical-rl;
  transform:rotate(180deg);
  font-size:12px;
}

@media (max-width: 1200px){
  .classicPayslip{
    transform:scale(.9);
    transform-origin:top left;
    width:111%;
  }
}

@media (max-width: 960px){
  .classicPayslipWrap{
    overflow:auto;
  }

  .classicPayslip{
    min-width:1100px;
    transform:none;
    width:auto;
  }
}

@media print {
  html,
  body{
    width:210mm !important;
    height:297mm !important;
    margin:0 !important;
    padding:0 !important;
    background:#fff !important;
    overflow:visible !important;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }

  body{
    font-family: Arial, Helvetica, sans-serif !important;
    color:#000 !important;
  }

  body *{
    visibility:hidden !important;
    box-shadow:none !important;
    text-shadow:none !important;
  }

  #contrachequePreviewPanel,
  #contrachequePreviewPanel *{
    visibility:visible !important;
  }

  #contrachequePreviewPanel{
    position:absolute !important;
    top:8mm !important;
    left:10mm !important;
    width:190mm !important;
    margin:0 !important;
    padding:0 !important;
    background:#fff !important;
    overflow:visible !important;
    break-inside:avoid !important;
    page-break-inside:avoid !important;
  }

  .classicPayslipWrap{
    margin:0 !important;
    padding:0 !important;
    overflow:visible !important;
  }

  .classicPayslip{
    width:190mm !important;
    min-height:160mm !important;
    max-height:160mm !important;
    display:grid !important;
    grid-template-columns: 1fr 30mm !important;
    background:#fff !important;
    color:#000 !important;
    border:1.4px solid #000 !important;
    box-shadow:none !important;
    overflow:hidden !important;
    transform:none !important;
    page-break-inside:avoid !important;
    break-inside:avoid !important;
  }

  .cpMain,
  .cpTopHeader,
  .cpEmployeeHeader,
  .cpTableArea,
  .cpTotalsBox,
  .cpBottomGrid,
  .cpSideReceipt{
    background:#fff !important;
    color:#000 !important;
  }

  .cpTopHeader{
    display:grid !important;
    grid-template-columns: 1fr 1fr !important;
    border-bottom:1.4px solid #000 !important;
  }

  .cpCompanyBlock,
  .cpTitleBlock{
    padding:4mm 4mm !important;
    font-size:11px !important;
    line-height:1.25 !important;
    color:#000 !important;
  }

  .cpTitle{
    font-size:15px !important;
    font-weight:700 !important;
    margin-bottom:2mm !important;
    color:#000 !important;
  }

  .cpEmployeeHeader{
    display:grid !important;
    grid-template-columns: 20mm 1.5fr 26mm 24mm 30mm !important;
    border-top:1px solid #000 !important;
    border-bottom:1.4px solid #000 !important;
  }

  .cpCol{
    border-right:1px solid #000 !important;
    min-height:24mm !important;
    background:#fff !important;
  }

  .cpCol:last-child{
    border-right:none !important;
  }

  .cpLabel{
    font-size:9px !important;
    color:#000 !important;
    text-align:center !important;
    padding:1.5mm 1.2mm 0.8mm !important;
  }

  .cpValue{
    font-size:10px !important;
    color:#000 !important;
    text-align:center !important;
    padding:2.5mm 1.2mm 2.8mm !important;
    white-space:normal !important;
    overflow:visible !important;
  }

  .cpValue.strong{
    font-size:12px !important;
    font-weight:700 !important;
  }

  .cpTableArea{
    border-bottom:1.4px solid #000 !important;
    overflow:visible !important;
  }

  .cpTable{
    width:100% !important;
    border-collapse:collapse !important;
    table-layout:fixed !important;
    font-size:10px !important;
    color:#000 !important;
    background:#fff !important;
  }

  .cpTable thead{
    display:table-header-group !important;
  }

  .cpTable thead th{
    background:#fff !important;
    color:#000 !important;
    border-bottom:1px solid #000 !important;
    border-right:1px solid #000 !important;
    padding:1.5mm 1.8mm !important;
    font-size:9.5px !important;
    font-weight:700 !important;
    text-align:center !important;
  }

  .cpTable thead th:last-child{
    border-right:none !important;
  }

  .cpTable tbody td{
    background:#fff !important;
    color:#000 !important;
    border-right:1px solid #000 !important;
    padding:1.3mm 1.8mm !important;
    font-size:9.5px !important;
    line-height:1.15 !important;
    vertical-align:middle !important;
    white-space:normal !important;
    overflow:visible !important;
    text-overflow:clip !important;
  }

  .cpTable tbody td:last-child{
    border-right:none !important;
  }

  .cpTable tbody tr{
    height:8.5mm !important;
    break-inside:avoid !important;
    page-break-inside:avoid !important;
  }

  .cpTable tbody td:nth-child(1),
  .cpTable tbody td:nth-child(3){
    text-align:center !important;
  }

  .cpTable tbody td:nth-child(4),
  .cpTable tbody td:nth-child(5){
    text-align:right !important;
    font-weight:700 !important;
  }

  .cpTotalsBox{
    border-bottom:1.4px solid #000 !important;
    background:#fff !important;
    color:#000 !important;
  }

  .cpTotalsRow,
  .cpTotalsValues,
  .cpLiquidoRow{
    width:48% !important;
    margin-left:auto !important;
  }

  .cpTotalsRow{
    display:grid !important;
    grid-template-columns:1fr 1fr !important;
    border-bottom:1px solid #000 !important;
  }

  .cpTotalsLabel{
    border-left:1px solid #000 !important;
    padding:1.5mm 1.2mm !important;
    font-size:8.5px !important;
    text-align:center !important;
    color:#000 !important;
    background:#fff !important;
  }

  .cpTotalsValues{
    display:grid !important;
    grid-template-columns:1fr 1fr !important;
    border-bottom:1px solid #000 !important;
  }

  .cpTotalsValues div{
    border-left:1px solid #000 !important;
    padding:2mm 2.5mm !important;
    font-size:11px !important;
    font-weight:700 !important;
    text-align:right !important;
    color:#000 !important;
    background:#fff !important;
  }

  .cpLiquidoRow{
    display:grid !important;
    grid-template-columns: 1.2fr 55px 40px 1fr !important;
    align-items:center !important;
    background:#fff !important;
    color:#000 !important;
  }

  .cpLiquidoLabel,
  .cpLiquidoCurrency,
  .cpLiquidoArrow,
  .cpLiquidoValue{
    border-left:1px solid #000 !important;
    padding-top:2.4mm !important;
    padding-bottom:2.4mm !important;
    background:#fff !important;
    color:#000 !important;
  }

  .cpLiquidoLabel{
    font-size:10px !important;
    font-weight:700 !important;
    padding-left:2.5mm !important;
  }

  .cpLiquidoCurrency{
    font-size:11px !important;
    font-weight:700 !important;
    text-align:center !important;
  }

  .cpLiquidoArrow{
    font-size:17px !important;
    font-weight:700 !important;
    text-align:center !important;
  }

  .cpLiquidoValue{
    font-size:18px !important;
    font-weight:700 !important;
    text-align:right !important;
    padding-right:2.5mm !important;
  }

  .cpBottomGrid{
    display:grid !important;
    grid-template-columns: repeat(5, 1fr) !important;
    background:#fff !important;
    color:#000 !important;
  }

  .cpBottomCell{
    border-right:1px solid #000 !important;
    min-height:18mm !important;
    padding:2mm 2mm 2.5mm !important;
    background:#fff !important;
    color:#000 !important;
  }

  .cpBottomCell:last-child{
    border-right:none !important;
  }

  .cpBottomLabel{
    font-size:8px !important;
    color:#000 !important;
    text-align:center !important;
    margin-bottom:2mm !important;
  }

  .cpBottomValue{
    font-size:10px !important;
    color:#000 !important;
    text-align:center !important;
    font-weight:700 !important;
  }

  .cpSideReceipt{
    border-left:1.4px solid #000 !important;
    display:flex !important;
    flex-direction:column !important;
    justify-content:space-between !important;
    align-items:center !important;
    padding:3mm 1.5mm !important;
    background:#fff !important;
    color:#000 !important;
  }

  .cpSideText,
  .cpSignatureLabel,
  .cpDateLabel{
    font-size:9px !important;
    color:#000 !important;
    writing-mode:vertical-rl !important;
    transform:rotate(180deg) !important;
  }

  .cpSignatureLine{
    width:1px !important;
    height:62mm !important;
    background:#000 !important;
  }

  .cpDateLine{
    width:1px !important;
    height:34mm !important;
    background:#000 !important;
  }

  .tableEmpty{
    color:#000 !important;
    text-align:center !important;
    font-size:10px !important;
  }

  .noPrint,
  .sidebar,
  .topbar,
  .toolHero,
  .dashboardRow{
    display:none !important;
  }

  @page{
    size:A4 portrait;
    margin:0;
  }
}

/* =========================
   CONTRACHEQUE PDF PREMIUM
========================= */

.premiumSlipPrintWrap{
  margin-top:18px;
}

.premiumSlipPrint{
  background:#fff;
}

.slipOuter{
  width:100%;
  border-collapse:collapse;
  table-layout:fixed;
  background:#fff;
  color:#111;
  font-family:Arial, Helvetica, sans-serif;
  border:2px solid #111;
}

.slipOuter td{
  vertical-align:top;
}

.slipMainCell{
  width:auto;
}

.slipReceiptCell{
  width:38mm;
  border-left:2px solid #111;
  padding:0;
}

.slipReceiptInner{
  height:100%;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  align-items:center;
  padding:10px 4px;
}

.slipHeaderTable,
.slipEmployeeTable,
.slipRubricaTable,
.slipTotalsTable,
.slipLiquidoTable,
.slipBaseTable{
  width:100%;
  border-collapse:collapse;
  table-layout:fixed;
}

.slipHeaderTable{
  border-bottom:2px solid #111;
}

.slipHeaderCompany,
.slipHeaderTitle{
  padding:10px 12px;
}

.slipHeaderCompany{
  border-right:1px solid #111;
}

.slipCompanyName{
  font-size:15px;
  font-weight:700;
  margin-bottom:4px;
}

.slipCompanyLine{
  font-size:12px;
  margin-bottom:3px;
}

.slipHeaderTitle{
  text-align:center;
}

.slipDocTitle{
  font-size:18px;
  font-weight:700;
  margin-bottom:6px;
}

.slipDocSub{
  font-size:13px;
}

.slipEmployeeTable{
  border-bottom:2px solid #111;
}

.slipEmployeeTable td{
  border-right:1px solid #111;
  padding:6px 8px 8px;
}

.slipEmployeeTable td:last-child{
  border-right:none;
}

.employeeNameCell{
  width:38%;
}

.slipMiniLabel{
  font-size:11px;
  text-align:center;
  margin-bottom:8px;
}

.slipMiniValue{
  font-size:13px;
  text-align:center;
}

.slipMiniValue.strong{
  font-size:15px;
  font-weight:700;
}

.slipRubricaTable thead th{
  border-bottom:1px solid #111;
  border-right:1px solid #111;
  padding:5px 6px;
  font-size:12px;
  text-align:center;
}

.slipRubricaTable thead th:last-child{
  border-right:none;
}

.slipRubricaTable tbody td{
  border-right:1px solid #111;
  border-bottom:1px solid #d6d6d6;
  padding:4px 6px;
  font-size:12px;
  height:26px;
}

.slipRubricaTable tbody td:last-child{
  border-right:none;
}

.slipRubricaTable tbody td:nth-child(1),
.slipRubricaTable tbody td:nth-child(3){
  text-align:center;
}

.slipRubricaTable tbody td:nth-child(4),
.slipRubricaTable tbody td:nth-child(5){
  text-align:right;
  font-weight:700;
}

.codeCol{
  width:11%;
}

.descCol{
  width:43%;
}

.refCol{
  width:14%;
}

.moneyCol{
  width:16%;
}

.slipTotalsTable{
  width:48%;
  margin-left:auto;
  border-top:2px solid #111;
}

.slipTotalsTable td{
  border-left:1px solid #111;
  border-bottom:1px solid #111;
  padding:6px 8px;
  text-align:center;
}

.slipTotalHead{
  font-size:11px;
  font-weight:600;
}

.slipTotalValue{
  font-size:15px;
  font-weight:700;
  text-align:right !important;
  padding-right:12px !important;
}

.slipLiquidoTable{
  width:48%;
  margin-left:auto;
}

.slipLiquidoTable td{
  border-left:1px solid #111;
  border-bottom:2px solid #111;
  padding:7px 8px;
}

.liqLabel{
  font-size:12px;
  font-weight:700;
}

.liqCurrency{
  width:40px;
  text-align:center;
  font-weight:700;
}

.liqArrow{
  width:32px;
  text-align:center;
  font-size:18px;
  font-weight:700;
}

.liqValue{
  font-size:19px;
  font-weight:700;
  text-align:right;
  padding-right:12px !important;
}

.slipBaseTable td{
  border-right:1px solid #111;
  padding:7px 6px 9px;
}

.slipBaseTable td:last-child{
  border-right:none;
}

.slipReceiptText{
  writing-mode:vertical-rl;
  transform:rotate(180deg);
  font-size:12px;
  text-align:center;
  font-weight:600;
  display:flex;
  align-items:center;
  justify-content:center;
  flex:1;
}

.slipReceiptSignature,
.slipReceiptDate{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
}

.slipReceiptLine{
  width:1px;
  height:88px;
  background:#111;
}

.slipReceiptLine.small{
  height:46px;
}

.slipReceiptLabel{
  writing-mode:vertical-rl;
  transform:rotate(180deg);
  font-size:11px;
}

@media print {
  html,
  body{
    width:210mm !important;
    height:297mm !important;
    margin:0 !important;
    padding:0 !important;
    background:#fff !important;
    overflow:visible !important;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }

  body *{
    visibility:hidden !important;
    box-shadow:none !important;
    text-shadow:none !important;
  }

  #contrachequePreviewPanel,
  #contrachequePreviewPanel *{
    visibility:visible !important;
  }

  #contrachequePreviewPanel{
    position:absolute !important;
    top:8mm !important;
    left:10mm !important;
    width:190mm !important;
    margin:0 !important;
    padding:0 !important;
    background:#fff !important;
  }

  .premiumSlipPrintWrap{
    margin:0 !important;
    padding:0 !important;
  }

  .premiumSlipPrint{
    width:190mm !important;
    height:148mm !important;
    overflow:hidden !important;
    background:#fff !important;
  }

  .slipOuter{
    width:190mm !important;
    height:148mm !important;
    border:1.3px solid #000 !important;
    border-collapse:collapse !important;
    table-layout:fixed !important;
    background:#fff !important;
    color:#000 !important;
    font-family:Arial, Helvetica, sans-serif !important;
  }

  .slipReceiptCell{
    width:26mm !important;
    border-left:1.3px solid #000 !important;
  }

  .slipReceiptInner{
    height:148mm !important;
    padding:2mm 1.5mm !important;
  }

  .slipHeaderTable{
    border-bottom:1.3px solid #000 !important;
  }

  .slipHeaderCompany,
  .slipHeaderTitle{
    padding:3mm 3mm !important;
  }

  .slipHeaderCompany{
    border-right:1px solid #000 !important;
  }

  .slipCompanyName{
    font-size:11px !important;
    font-weight:700 !important;
    margin-bottom:1.2mm !important;
  }

  .slipCompanyLine{
    font-size:8.3px !important;
    margin-bottom:0.7mm !important;
  }

  .slipDocTitle{
    font-size:12px !important;
    font-weight:700 !important;
    margin-bottom:1.2mm !important;
  }

  .slipDocSub{
    font-size:8.6px !important;
  }

  .slipEmployeeTable{
    border-bottom:1.3px solid #000 !important;
  }

  .slipEmployeeTable td{
    border-right:1px solid #000 !important;
    padding:1.2mm 1.2mm 1.5mm !important;
  }

  .slipMiniLabel{
    font-size:7.2px !important;
    margin-bottom:1mm !important;
  }

  .slipMiniValue{
    font-size:8.2px !important;
  }

  .slipMiniValue.strong{
    font-size:9px !important;
  }

  .slipRubricaTable thead th{
    border-bottom:1px solid #000 !important;
    border-right:1px solid #000 !important;
    padding:1mm 1.2mm !important;
    font-size:7.4px !important;
    text-align:center !important;
    color:#000 !important;
    background:#fff !important;
  }

  .slipRubricaTable tbody td{
    border-right:1px solid #000 !important;
    border-bottom:0.6px solid #cfcfcf !important;
    padding:0.8mm 1.2mm !important;
    font-size:7.4px !important;
    height:5.2mm !important;
    color:#000 !important;
    background:#fff !important;
    white-space:nowrap !important;
    overflow:hidden !important;
  }

  .slipRubricaTable tbody td:nth-child(4),
  .slipRubricaTable tbody td:nth-child(5){
    text-align:right !important;
    font-weight:700 !important;
  }

  .slipTotalsTable{
    width:50% !important;
    margin-left:auto !important;
    border-top:1.3px solid #000 !important;
  }

  .slipTotalsTable td{
    border-left:1px solid #000 !important;
    border-bottom:1px solid #000 !important;
    padding:1.2mm 1.5mm !important;
  }

  .slipTotalHead{
    font-size:6.9px !important;
  }

  .slipTotalValue{
    font-size:9px !important;
    font-weight:700 !important;
    text-align:right !important;
    padding-right:2mm !important;
  }

  .slipLiquidoTable{
    width:50% !important;
    margin-left:auto !important;
  }

  .slipLiquidoTable td{
    border-left:1px solid #000 !important;
    border-bottom:1.3px solid #000 !important;
    padding:1.3mm 1.2mm !important;
  }

  .liqLabel{
    font-size:7.4px !important;
    font-weight:700 !important;
  }

  .liqCurrency{
    width:8mm !important;
    text-align:center !important;
    font-size:7.8px !important;
  }

  .liqArrow{
    width:6mm !important;
    text-align:center !important;
    font-size:10px !important;
  }

  .liqValue{
    font-size:11px !important;
    font-weight:700 !important;
    text-align:right !important;
    padding-right:2mm !important;
  }

  .slipBaseTable td{
    border-right:1px solid #000 !important;
    padding:1.2mm 0.8mm 1.5mm !important;
  }

  .slipReceiptText{
    font-size:7px !important;
    line-height:1.1 !important;
  }

  .slipReceiptLine{
    height:32mm !important;
    background:#000 !important;
  }

  .slipReceiptLine.small{
    height:18mm !important;
  }

  .slipReceiptLabel{
    font-size:7px !important;
    color:#000 !important;
  }

  .tableEmpty{
    text-align:center !important;
    font-size:7.4px !important;
    color:#000 !important;
  }

  .noPrint,
  .sidebar,
  .topbar,
  .toolHero,
  .dashboardRow{
    display:none !important;
  }

  @page{
    size:A4 portrait;
    margin:0;
  }
}