/* ────────────────────────────────────────────────
   Bate Cadastro · UP Health design language
   Light, modern, low-chrome
   ──────────────────────────────────────────────── */

@font-face{font-family:'Ubuntu';src:url('../fonts/Ubuntu-Light.ttf') format('truetype');font-weight:300;font-display:swap}
@font-face{font-family:'Ubuntu';src:url('../fonts/Ubuntu-Regular.ttf') format('truetype');font-weight:400;font-display:swap}
@font-face{font-family:'Ubuntu';src:url('../fonts/Ubuntu-Medium.ttf') format('truetype');font-weight:500;font-display:swap}
@font-face{font-family:'Ubuntu';src:url('../fonts/Ubuntu-Bold.ttf') format('truetype');font-weight:700;font-display:swap}
@font-face{font-family:'UbuntuMono';src:url('../fonts/UbuntuMono-R.ttf') format('truetype');font-weight:400;font-display:swap}
@font-face{font-family:'Nevis';src:url('../fonts/nevis.ttf') format('truetype');font-weight:700;font-display:swap}

:root{
  /* Brand */
  --pu:#562A99;        /* Pantone Roxo */
  --pu-d:#3F1E72;
  --pu2:#F3EEFA;       /* roxo 10% */
  --pu3:#E1D2F1;       /* roxo 40% */
  --go:#F3B632;        /* Pantone Amarelo */
  --go-d:#D69A1A;
  --go2:#FEF5DF;

  /* Ink + neutrals */
  --ink:#0F0E17;
  --ink2:#3A3A4A;
  --ink3:#6F6E7E;
  --ink4:#A5A3B0;
  --ln:#EEEDF1;
  --ln2:#F6F5F8;
  --bg:#FAFAFB;
  --card:#FFFFFF;

  /* Semantic */
  --ok:#0E7C4A;  --ok2:#E7F3EC;
  --wn:#B56A00;  --wn2:#FBF0DC;
  --cr:#B42318;  --cr2:#FBECE9;

  --r:10px;
  --r-sm:8px;
  --r-lg:14px;

  --shadow-sm: 0 1px 2px rgba(15,14,23,.04);
  --shadow-md: 0 4px 16px -8px rgba(15,14,23,.10);
  --shadow-lg: 0 24px 48px -24px rgba(86,42,153,.18);
}

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

html,body{
  font-family:'Ubuntu',system-ui,-apple-system,sans-serif;
  background:var(--bg);
  color:var(--ink);
  font-size:14px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

a{color:var(--pu);text-decoration:none}
a:hover{text-decoration:underline}
button{font-family:inherit}

/* ── Header / topbar ─────────────────────────── */
.header{
  background:var(--card);
  border-bottom:1px solid var(--ln);
  padding:0 32px;
  height:64px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  position:sticky;
  top:0;
  z-index:30;
  backdrop-filter:saturate(180%) blur(8px);
}

.header-brand{display:flex;align-items:center;gap:12px}
.header-brand .bmark{
  width:34px;height:34px;border-radius:10px;
  background:linear-gradient(135deg,var(--pu) 0%,#7B3FCB 100%);
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:13px;letter-spacing:-.02em;
  box-shadow:0 2px 6px -2px rgba(86,42,153,.5), inset 0 1px 0 rgba(255,255,255,.2);
  position:relative;
}
.header-brand .bmark{
  width:34px; height:34px; border-radius:10px;
  background:linear-gradient(135deg,var(--pu) 0%,#7B3FCB 100%);
  color:transparent; font-size:0;
  display:flex; align-items:center; justify-content:center;
  font-weight:700; letter-spacing:-.02em;
  box-shadow:0 2px 6px -2px rgba(86,42,153,.5), inset 0 1px 0 rgba(255,255,255,.2);
  position:relative;
  overflow:hidden; /* garante que nada saia do border-radius */
}

/* Imagem proporcional sobreposta */
.header-brand .bmark::after{
  content:"";
  position:absolute;
  width:22px;      /* ajuste conforme necessário (20~26px) */
  height:22px;
  background:url("favicon.ico") center/contain no-repeat;
}
.header-brand h1{
  font-size:15px;font-weight:500;letter-spacing:-.01em;color:var(--ink);
}
.header-brand h1 small{
  display:block;font-size:11px;color:var(--ink4);font-weight:400;
  letter-spacing:.04em;text-transform:uppercase;margin-top:1px;
}

.header-nav{display:flex;gap:2px;align-items:center}
.nav-link{
  display:inline-flex;align-items:center;gap:7px;
  padding:8px 14px;border-radius:8px;
  font-size:13px;font-weight:500;color:var(--ink3);
  text-decoration:none;transition:background .15s,color .15s;
}
.nav-link:hover{background:var(--ln2);color:var(--ink);text-decoration:none}
.nav-link.active{background:var(--pu2);color:var(--pu)}
.nav-link svg{width:15px;height:15px;flex-shrink:0;opacity:.85}

.header-user{display:flex;align-items:center;gap:10px}
.header-user #userName{
  font-size:13px;color:var(--ink2);font-weight:500;
  display:inline-flex;align-items:center;gap:8px;
  padding-right:4px;
}
.header-user #userName::before{
  content: ""; /* remove as iniciais */
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background-color: #f3b632; /* mantém o fundo amarelo ou remova se a imagem já tiver fundo */
  background-image: url("imagem_conta.ico");
  background-size: 16px; /* ajuste conforme o tamanho do ícone */
  background-repeat: no-repeat;
  background-position: center;
  display: inline-flex;
  vertical-align: middle;
  margin-right: 8px; /* espaço entre o ícone e o texto do #userName */
}
/* ── Layout ─────────────────────────────────── */
.container{
  max-width:1100px;
  margin:0 auto;
  padding:32px 32px 80px;
}

.page-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:22px;gap:24px;flex-wrap:wrap;
}
.page-head h2{
  font-size:24px;font-weight:500;letter-spacing:-.02em;color:var(--ink);
  margin:0;
}
.page-head .page-sub{
  font-size:13px;color:var(--ink3);margin-top:4px;
}
.page-head .eyebrow{
  font-size:10.5px;color:var(--pu);letter-spacing:.1em;
  text-transform:uppercase;font-weight:500;margin-bottom:6px;
}

/* ── Card ───────────────────────────────────── */
.card{
  background:var(--card);
  border:1px solid var(--ln);
  border-radius:var(--r-lg);
  padding:26px 28px;
  margin-bottom:18px;
  box-shadow:var(--shadow-sm);
}
.card h2{
  font-size:16px;font-weight:500;letter-spacing:-.01em;
  color:var(--ink);margin-bottom:4px;
}
.card > h2 + .section-description{margin-bottom:20px}

.section-description{
  color:var(--ink3);font-size:13px;margin-bottom:16px;line-height:1.55;
}

/* ── Login ──────────────────────────────────── */
.login-container{
  min-height:100vh;
  display:grid;
  grid-template-columns:1fr 1fr;
  background:var(--bg);
}
.login-hero{
  position:relative;
  background:
    radial-gradient(circle at 80% 20%, rgba(243,182,50,.18), transparent 50%),
    radial-gradient(circle at 20% 80%, rgba(243,182,50,.08), transparent 40%),
    linear-gradient(155deg,#3F1E72 0%, #562A99 50%, #6E36C0 100%);
  color:#fff;
  padding:48px 56px;
  display:flex;flex-direction:column;justify-content:space-between;
  overflow:hidden;
}
.login-hero::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px);
  background-size:22px 22px;
  pointer-events:none;
}
.login-hero-brand{
  display:flex;align-items:center;gap:14px;position:relative;z-index:1;
}
.login-hero-brand .bmark{
  width:46px;height:46px;border-radius:14px;
  background:;color:var(--pu);
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:16px;letter-spacing:-.02em;
  box-shadow:0 8px 24px -8px rgba(0,0,0,.4);
  position:relative;
}
.login-hero-brand .bmark::after{
  content:'';position:absolute;right:-3px;bottom:-3px;
  width:14px;height:14px;border-radius:50%;background:var(--go);
  border:3px solid var(--pu);
}
.login-hero-brand h2{font-size:18px;font-weight:500;letter-spacing:-.01em;line-height:1.2}
.login-hero-brand h2 small{
  display:block;font-size:11px;letter-spacing:.1em;
  color:rgba(255,255,255,.65);text-transform:uppercase;margin-top:2px;font-weight:400;
}
.login-hero-content{position:relative;z-index:1}
.login-hero-content .pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:5px 12px;border-radius:999px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.18);
  font-size:11px;font-weight:500;letter-spacing:.04em;
  color:rgba(255,255,255,.85);
}
.login-hero-content .pill .d{
  width:6px;height:6px;border-radius:50%;background:var(--go);
  box-shadow:0 0 0 3px rgba(243,182,50,.25);
}
.login-hero-content h1{
  font-size:42px;font-weight:500;letter-spacing:-.03em;line-height:1.08;
  margin:18px 0 16px;color:#fff;
  font-family:'Nevis','Ubuntu',sans-serif;
}
.login-hero-content h1 em{
  font-style:normal;color:var(--go);
}
.login-hero-content p{
  font-size:15px;color:rgba(255,255,255,.78);max-width:380px;line-height:1.55;
}
.login-hero-foot{position:relative;z-index:1;display:flex;gap:32px}
.login-hero-foot .stat{font-size:12px;color:rgba(255,255,255,.7)}
.login-hero-foot .stat b{
  display:block;font-size:22px;color:#fff;font-weight:500;
  letter-spacing:-.02em;margin-bottom:2px;
}

.login-form-side{
  display:flex;align-items:center;justify-content:center;
  padding:48px 32px;
}
.login-container .card{
  width:100%;max-width:380px;padding:36px 36px 30px;
  margin:0;border:1px solid var(--ln);
  box-shadow:var(--shadow-md);
}
.logo{margin-bottom:26px}
.logo-icon{
  width:48px;height:48px;border-radius:14px;
  background:linear-gradient(135deg,var(--pu) 0%,100%);
  color:;display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:700;letter-spacing:-.01em;
  margin-bottom:18px;
  box-shadow:0 6px 14px -6px rgba(86,42,153,.5);
  position:relative;
}
.logo-icon::after{
  content:'';position:absolute;right:-3px;bottom:-3px;
  width:12px;height:12px;border-radius:50%;background:var(--go);
  border:2px solid var(--card);
}
.logo h1{
  font-size:22px;font-weight:500;letter-spacing:-.02em;color:var(--ink);
  margin-bottom:3px;
}
.logo-subtitle{
  color:var(--ink3);font-size:13px;
}

/* ── Forms ──────────────────────────────────── */
.form-group{margin-bottom:16px;text-align:left}
.form-row{display:flex;gap:14px}
.form-row .form-group{flex:1;margin-bottom:16px}
.form-row-inline{align-items:flex-end}
.form-group-btn{flex:0 0 auto}
.form-group-btn label{visibility:hidden}

label{
  display:block;
  margin-bottom:6px;
  font-weight:500;
  font-size:12px;
  color:var(--ink2);
  letter-spacing:.005em;
}

input[type="text"],
input[type="password"],
input[type="email"],
select{
  width:100%;
  padding:11px 13px;
  border:1px solid var(--ln);
  border-radius:var(--r-sm);
  font-size:13.5px;
  font-family:inherit;
  background:var(--card);
  color:var(--ink);
  transition:border-color .15s,box-shadow .15s,background .15s;
}
input::placeholder{color:var(--ink4)}
input[type="text"]:focus,
input[type="password"]:focus,
input[type="email"]:focus,
select:focus{
  outline:none;
  border-color:var(--pu);
  box-shadow:0 0 0 3px rgba(86,42,153,.12);
}
select{cursor:pointer;background:var(--card)}

/* File input — friendly drop zone */
input[type="file"]{
  width:100%;
  font-family:inherit;font-size:12.5px;
  color:var(--ink2);
  padding:14px;
  border:1.5px dashed var(--ln);
  border-radius:var(--r-sm);
  background:var(--ln2);
  cursor:pointer;
  transition:border-color .15s,background .15s;
}
input[type="file"]:hover{border-color:var(--pu3);background:var(--pu2)}
input[type="file"]:focus{outline:none;border-color:var(--pu);background:var(--pu2)}
input[type="file"]::file-selector-button{
  font-family:inherit;font-size:12px;font-weight:500;
  padding:6px 12px;margin-right:12px;
  border:1px solid var(--ln);
  border-radius:6px;
  background:var(--card);color:var(--ink2);
  cursor:pointer;
}
input[type="file"]::file-selector-button:hover{
  background:var(--pu);color:#fff;border-color:var(--pu);
}

code{
  background:var(--ln2);
  padding:2px 6px;
  border-radius:4px;
  font-family:'UbuntuMono',monospace;
  font-size:.92em;color:var(--pu);
}

/* Checkbox */
.checkbox-group{margin-top:4px}
.checkbox-label{
  display:flex;align-items:center;gap:10px;
  font-weight:400;font-size:13px;cursor:pointer;color:var(--ink2);
}
.checkbox-label input[type="checkbox"]{
  width:17px;height:17px;accent-color:var(--pu);cursor:pointer;
}

.help-text{
  display:block;color:var(--ink4);
  font-size:12px;margin-top:5px;
  line-height:1.45;
}
.checkbox-group .help-text{margin-left:27px}

/* ── Buttons ────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  padding:10px 18px;
  border:1px solid transparent;
  border-radius:var(--r-sm);
  font-family:inherit;font-size:13px;font-weight:500;
  cursor:pointer;
  text-decoration:none;
  transition:background .15s,border-color .15s,color .15s,transform .05s, box-shadow .15s;
  white-space:nowrap;
  letter-spacing:.005em;
}
.btn:active{transform:translateY(0.5px)}

.btn-primary{
  background:var(--pu);color:#fff;
  box-shadow:0 1px 2px rgba(15,14,23,.08), inset 0 1px 0 rgba(255,255,255,.12);
}
.btn-primary:hover{background:var(--pu-d)}

.btn-secondary{
  background:var(--card);color:var(--ink2);border-color:var(--ln);
}
.btn-secondary:hover{background:var(--ln2);color:var(--ink)}

.btn-success{
  background:var(--ok);color:#fff;
}
.btn-success:hover{background:#0a6940}

.btn-danger{background:var(--cr);color:#fff}
.btn-danger:hover{background:#8e1c12}

.btn-ghost{
  background:transparent;color:var(--ink3);border-color:transparent;
  padding:8px 12px;
}
.btn-ghost:hover{background:var(--ln2);color:var(--ink)}

.btn-block{width:100%}

.btn-sm{padding:7px 12px;font-size:12px}

/* ── Alerts ─────────────────────────────────── */
.alert{
  padding:13px 16px;border-radius:var(--r-sm);
  margin-bottom:16px;font-size:13px;line-height:1.5;
  border:1px solid transparent;display:flex;gap:10px;align-items:flex-start;
}
.alert::before{
  content:'';flex-shrink:0;width:18px;height:18px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  font-weight:700;font-size:11px;color:#fff;margin-top:1px;
}
.alert-success{background:var(--ok2);color:#0a6940;border-color:rgba(14,124,74,.2)}
.alert-success::before{content:'✓';background:var(--ok)}
.alert-danger{background:var(--cr2);color:#8e1c12;border-color:rgba(180,35,24,.2)}
.alert-danger::before{content:'!';background:var(--cr)}
.alert-warning{background:var(--wn2);color:#7a4900;border-color:rgba(181,106,0,.2)}
.alert-warning::before{content:'!';background:var(--wn)}
.alert-info{background:var(--pu2);color:var(--pu);border-color:rgba(86,42,153,.16)}
.alert-info::before{content:'i';background:var(--pu)}

/* ── Hidden / utility ──────────────────────── */
.hidden{display:none !important}

.error-message{
  color:var(--cr);font-size:12.5px;margin-top:10px;min-height:1.2em;
  font-weight:500;
}

/* ── Progress steps ─────────────────────────── */
.progress-area{padding:24px 0 8px}
.steps-container{
  display:flex;flex-direction:column;gap:6px;
  max-width:440px;margin:0 auto;position:relative;
}
.steps-container::before{
  content:'';position:absolute;left:23px;top:24px;bottom:24px;
  width:2px;background:var(--ln);z-index:0;border-radius:2px;
}
.step{
  display:flex;align-items:center;gap:14px;
  padding:10px 14px;border-radius:var(--r-sm);
  font-size:13px;
  transition:all .25s;
  position:relative;z-index:1;
  background:var(--card);
}
.step-icon{
  width:30px;height:30px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;font-size:13px;font-weight:600;
  background:var(--card);border:2px solid var(--ln);color:var(--ink4);
  transition:all .25s;
}
.step-pending{color:var(--ink4)}
.step-active{color:var(--pu);font-weight:500}
.step-active .step-icon{
  background:var(--pu);border-color:var(--pu);color:#fff;
  animation:pulse 1.6s ease-in-out infinite;
}
.step-active .step-icon::before{content:'';width:8px;height:8px;border-radius:50%;background:#fff}
.step-active .step-icon > *{display:none}
.step-done{color:var(--ok)}
.step-done .step-icon{background:var(--ok);border-color:var(--ok);color:#fff}
.step-done .step-icon::before{content:'✓';font-size:14px}
.step-done .step-icon > *{display:none}
.step-error{color:var(--cr)}
.step-error .step-icon{background:var(--cr);border-color:var(--cr);color:#fff}
.step-error .step-icon::before{content:'×';font-size:18px;line-height:1}
.step-error .step-icon > *{display:none}

@keyframes pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(86,42,153,.4)}
  50%{box-shadow:0 0 0 6px rgba(86,42,153,0)}
}

/* Spinner */
.spinner{
  width:36px;height:36px;
  border:3px solid var(--ln);
  border-top-color:var(--pu);
  border-radius:50%;
  animation:spin 1s linear infinite;
  margin-bottom:12px;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Tabs ───────────────────────────────────── */
.depara-tabs{
  display:flex;gap:2px;
  margin-bottom:22px;
  background:var(--ln2);
  padding:4px;border-radius:10px;
  width:fit-content;
}
.tab-btn{
  padding:8px 18px;
  border:none;background:transparent;
  font-size:13px;font-weight:500;
  color:var(--ink3);
  cursor:pointer;
  border-radius:7px;
  transition:all .15s;
}
.tab-btn:hover{color:var(--ink)}
.tab-btn.active{
  background:var(--card);color:var(--pu);
  box-shadow:0 1px 3px rgba(15,14,23,.06);
}

.depara-form{
  margin-bottom:22px;
  padding:18px;
  background:var(--ln2);
  border-radius:10px;
  border:1px solid var(--ln);
}
.depara-form .form-row{margin-bottom:0}
.depara-form .form-group{margin-bottom:0}

/* ── Tables ─────────────────────────────────── */
.table{
  width:100%;border-collapse:collapse;
  margin-top:12px;font-size:13px;
}
.table th{
  background:transparent;
  font-weight:500;font-size:10.5px;
  text-transform:uppercase;letter-spacing:.08em;
  color:var(--ink4);
  padding:12px 14px;text-align:left;
  border-bottom:1px solid var(--ln);
}
.table td{
  padding:14px;
  border-bottom:1px solid var(--ln);
  color:var(--ink2);
  vertical-align:middle;
}
.table tbody tr:last-child td{border-bottom:0}
.table tbody tr{transition:background .12s}
.table tbody tr:hover td{background:var(--ln2)}
.table tbody tr:hover .empty-row{background:transparent}
.empty-row td{
  text-align:center;color:var(--ink4);
  padding:36px 14px;
  font-size:13px;
}
.empty-row td::before{
  content:'';display:block;
  width:42px;height:42px;margin:0 auto 10px;
  border-radius:12px;background:var(--ln2);
  background-image:radial-gradient(circle at 50% 50%, var(--ln) 30%, transparent 31%);
  background-size:8px 8px;
}

/* ── Badges ─────────────────────────────────── */
.badge{
  display:inline-flex;align-items:center;gap:5px;
  padding:3px 9px;border-radius:999px;
  font-size:10.5px;font-weight:500;
  text-transform:uppercase;letter-spacing:.06em;
  background:var(--ln2);color:var(--ink2);
}
.badge::before{
  content:'';width:5px;height:5px;border-radius:50%;background:currentColor;
}
.badge-completed{background:var(--ok2);color:var(--ok)}
.badge-processing{background:var(--pu2);color:var(--pu)}
.badge-pending{background:var(--go2);color:var(--wn)}
.badge-error{background:var(--cr2);color:var(--cr)}
.badge-type-samp{background:#E6F0FE;color:#1A5FB4}
.badge-type-up{background:var(--go2);color:var(--wn)}

/* Make processing badge feel alive */
.badge-processing::before{animation:pulse-dot 1.4s ease-in-out infinite}
@keyframes pulse-dot{
  0%,100%{opacity:1}50%{opacity:.35}
}

/* ── Mapping (Conferência IDs) ─────────────── */
.mapping-card .mapping-head{margin-bottom:18px}

.mapping{
  display:flex;flex-direction:column;gap:6px;
  background:var(--ln2);
  border:1px solid var(--ln);
  border-radius:12px;
  padding:14px;
}

.mapping-cols{
  display:grid;
  grid-template-columns:84px 1fr 110px 1fr;
  gap:14px;
  padding:4px 14px 10px;
  font-size:10.5px;font-weight:500;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink4);
}
.mapping-cols span:nth-child(2){grid-column:2}
.mapping-cols span:last-child{grid-column:4}

.mapping-row{
  display:grid;
  grid-template-columns:84px 1fr 110px 1fr;
  gap:14px;
  align-items:center;
  background:var(--card);
  border:1px solid var(--ln);
  border-radius:10px;
  padding:12px 14px;
  transition:border-color .15s, box-shadow .15s, transform .15s;
}
.mapping-row:hover{
  border-color:var(--pu3);
  box-shadow:0 6px 18px -10px rgba(86,42,153,.18);
}
.mapping-row.is-key{
  background:linear-gradient(180deg, #fff 0%, var(--pu2) 100%);
  border-color:var(--pu3);
}

.mapping-tag{display:flex;align-items:center}
.mapping-tag .badge{padding:4px 10px;font-size:10px}

.mapping-field code{
  display:inline-block;
  background:var(--card);
  border:1px solid var(--ln);
  color:var(--ink);
  padding:6px 12px;
  border-radius:7px;
  font-family:'UbuntuMono',monospace;
  font-size:12.5px;
  letter-spacing:.01em;
  font-weight:400;
  box-shadow:0 1px 0 rgba(15,14,23,.02);
}
.is-key .mapping-field code{
  background:#fff;
  border-color:var(--pu3);
  color:var(--pu);
  font-weight:500;
}

.mapping-op{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:1px;
}
.mapping-op span{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:42px;height:28px;
  border-radius:999px;
  background:var(--card);
  border:1px solid var(--ln);
  color:var(--ink3);
  font-size:14px;font-weight:500;
  line-height:1;
}
.mapping-op small{
  font-size:9.5px;color:var(--ink4);
  letter-spacing:.06em;text-transform:uppercase;
  margin-top:2px;
}
.mapping-op.op-key span{
  background:var(--pu);color:#fff;border-color:var(--pu);
  font-weight:600;
  box-shadow:0 4px 10px -4px rgba(86,42,153,.5);
}
.mapping-op.op-key small{color:var(--pu);font-weight:500}

@media (max-width:720px){
  .mapping-cols{display:none}
  .mapping-row{
    grid-template-columns:1fr;
    gap:8px;
    padding:14px;
  }
  .mapping-tag:empty{display:none}
  .mapping-op{flex-direction:row;gap:8px;justify-content:flex-start;padding:2px 0}
}

/* ── Result area download CTA ──────────────── */
.result-area{margin-top:18px}
.result-area .btn-success{margin-top:8px}

/* ── Role badges ───────────────────────────── */
.role-badge{
  font-size:10px;text-transform:uppercase;letter-spacing:.06em;
  padding:2px 8px;border-radius:6px;font-weight:600;
}
.role-admin{background:var(--pu2,#E8F0FE);color:var(--pu,#1a73e8)}
.role-usuario{background:var(--go2,#FEF7E0);color:var(--wn,#e37400)}

/* ── Warning button ────────────────────────── */
.btn-warning{background:var(--wn,#B56A00);color:#fff}
.btn-warning:hover{background:#9a5a00}

/* ── Actions cell ──────────────────────────── */
.actions-cell{display:flex;gap:6px;flex-wrap:wrap}

/* ── Modal overlay ─────────────────────────── */
.modal-overlay{
  position:fixed;inset:0;z-index:1000;
  background:rgba(15,14,23,.45);
  display:flex;align-items:center;justify-content:center;
  padding:20px;
}
.modal-card{
  width:100%;max-width:440px;
  animation:modalIn .2s ease;
}
@keyframes modalIn{
  from{opacity:0;transform:translateY(12px)}
  to{opacity:1;transform:translateY(0)}
}

/* ── Responsive ─────────────────────────────── */
@media (max-width:860px){
  .login-container{grid-template-columns:1fr}
  .login-hero{display:none}
}
@media (max-width:640px){
  .header{padding:0 18px;flex-wrap:wrap;height:auto;gap:8px;padding-top:12px;padding-bottom:12px}
  .header-nav{order:3;width:100%;overflow-x:auto;gap:0}
  .nav-link{padding:7px 12px;font-size:12.5px}
  .container{padding:20px 16px 60px}
  .card{padding:20px;border-radius:12px}
  .form-row{flex-direction:column;gap:0}
  .depara-tabs{width:100%}
  .tab-btn{flex:1;text-align:center;padding:8px 10px}
}
