/* ───────────────────────────────────────────────────────────
   EB · Nordeste RP — System styles (shell + UI primitives)
   ─────────────────────────────────────────────────────────── */

/* ── SHELL ─────────────────────────────────────────────── */
.shell { display: grid; grid-template-columns: 256px 1fr; min-height: 100vh; background: var(--bg); }
.shell-main { display: flex; flex-direction: column; min-width: 0; }
.shell-content { padding: 24px clamp(20px, 3vw, 40px) 60px; flex: 1; min-width: 0; }
@media (max-width: 880px) {
  .shell { grid-template-columns: 1fr; }
  .shell-sidebar { position: sticky; top: 0; z-index: 10; }
}

/* Sidebar */
.shell-sidebar {
  display: flex; flex-direction: column;
  border-right: 1px solid var(--line);
  background: linear-gradient(180deg, oklch(1 0 0 / .7), oklch(0.98 0.005 140 / .55));
  backdrop-filter: blur(10px);
  padding: 22px 14px;
  position: sticky; top: 0; height: 100vh;
}
.shell-sidebar__brand { display: flex; align-items: center; gap: 10px; padding: 6px 8px 22px; border-bottom: 1px dashed var(--line-strong); }
.shell-sidebar__brand-marks { display: flex; align-items: center; gap: 6px; }
.shell-sidebar__brand-marks img { height: 28px; width: auto; object-fit: contain; }
.shell-sidebar__brand-text { display: flex; flex-direction: column; min-width: 0; }
.shell-sidebar__brand-text > * { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.shell-nav { display: flex; flex-direction: column; gap: 2px; margin-top: 18px; }
.shell-nav__item {
  position: relative;
  display: flex; align-items: center; gap: 10px;
  padding: 9px 12px; border-radius: 10px;
  border: 1px solid transparent; background: transparent;
  color: var(--ink-2);
  font: 500 13px/1 'Manrope', sans-serif; letter-spacing: 0.01em;
  cursor: pointer; text-align: left;
  transition: background .2s, color .2s, border-color .2s;
}
.shell-nav__item:hover { background: oklch(0.96 0.005 140); color: var(--ink-1); }
.shell-nav__item.is-active { background: oklch(1 0 0); color: var(--ink-1); border-color: var(--line); box-shadow: 0 1px 0 oklch(1 0 0), 0 6px 18px -10px oklch(0.40 0.02 140 / .12); }
.shell-nav__icon { display: inline-flex; color: var(--ink-3); }
.shell-nav__item.is-active .shell-nav__icon { color: var(--accent); }
.shell-nav__rail { position: absolute; left: -1px; top: 6px; bottom: 6px; width: 2px; background: var(--accent); border-radius: 2px; }
.shell-sidebar__foot { margin-top: auto; display: flex; flex-direction: column; gap: 10px; padding: 14px 8px 4px; border-top: 1px dashed var(--line-strong); }

/* Topbar */
.shell-topbar {
  display: flex; align-items: center; gap: 16px;
  padding: 14px clamp(20px, 3vw, 40px);
  border-bottom: 1px solid var(--line);
  background: oklch(1 0 0 / .65);
  backdrop-filter: blur(10px);
  position: sticky; top: 0; z-index: 5;
}
.shell-topbar__breadcrumb { display: flex; align-items: center; gap: 4px; min-width: 0; }
.shell-topbar__center { display: none; align-items: center; gap: 8px; margin: 0 auto; }
@media (min-width: 880px) { .shell-topbar__center { display: flex; } }
.shell-topbar__right { margin-left: auto; display: flex; align-items: center; gap: 12px; }

.shell-iconbtn {
  position: relative;
  width: 32px; height: 32px; display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--line); background: var(--surface); border-radius: 999px;
  color: var(--ink-2); cursor: pointer; transition: all .2s;
}
.shell-iconbtn:hover { color: var(--ink-1); border-color: var(--ink-3); }
.shell-iconbtn--ghost { border: none; background: transparent; }
.shell-iconbtn__dot { position: absolute; top: 6px; right: 7px; width: 6px; height: 6px; background: var(--accent); border-radius: 50%; }

.shell-user { display: flex; align-items: center; gap: 10px; padding-left: 8px; border-left: 1px solid var(--line); }
.shell-user__meta { display: none; flex-direction: column; line-height: 1.1; }
@media (min-width: 720px) { .shell-user__meta { display: flex; } }
.shell-user__name { font: 600 13px/1.1 'Manrope', sans-serif; color: var(--ink-1); }
.shell-user__sub { font: 500 10px/1 'JetBrains Mono', monospace; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-3); margin-top: 3px; }

/* Welcome curtain (post-login transition) */
.welcome-curtain {
  position: fixed; inset: 0; z-index: 60;
  background: oklch(0.98 0.005 140 / .96);
  backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
}
.welcome-curtain__marks { display: flex; align-items: center; justify-content: center; gap: 18px; }
.welcome-curtain__marks img { height: 64px; }
.welcome-curtain__bar { width: 200px; height: 2px; background: oklch(0.92 0.005 140); margin: 18px auto 0; overflow: hidden; border-radius: 2px; }
.welcome-curtain__bar span { display: block; width: 40%; height: 100%; background: var(--accent); animation: curtain-bar 1.2s ease-in-out infinite; }
@keyframes curtain-bar { 0%{transform:translateX(-100%)}100%{transform:translateX(280%)} }

/* ── PAGE / PageHeader ─────────────────────────────────── */
.page { display: flex; flex-direction: column; gap: 20px; }
.page-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.page-head__eyebrow { font: 500 10px/1 'JetBrains Mono', monospace; letter-spacing: 0.28em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 8px; }
.page-head__title { font: 600 clamp(24px, 2.4vw, 32px)/1.15 'Manrope', sans-serif; letter-spacing: -0.01em; color: var(--ink-1); margin: 0; }
.page-head__sub { font: 500 14px/1.5 'Manrope', sans-serif; color: var(--ink-2); margin: 6px 0 0; max-width: 64ch; }
.page-head__actions { display: flex; align-items: center; gap: 10px; }

/* ── Cards & stats ─────────────────────────────────────── */
.ui-card {
  background: oklch(1 0 0 / .72);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 18px 20px;
  box-shadow: 0 1px 0 oklch(1 0 0), 0 18px 36px -28px oklch(0.40 0.02 140 / .18);
  backdrop-filter: blur(8px);
}
.stat-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 14px; }
.stat-grid--4 { grid-template-columns: repeat(2, 1fr); }
@media (min-width: 720px) { .stat-grid--4 { grid-template-columns: repeat(4, 1fr); } }
.ui-stat {
  background: oklch(1 0 0 / .72);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 14px 16px;
  display: flex; flex-direction: column; gap: 4px;
  transition: transform .2s, box-shadow .2s, border-color .2s;
}
.ui-stat:hover { transform: translateY(-2px); border-color: oklch(0.86 0.005 140); box-shadow: 0 14px 28px -22px oklch(0.40 0.02 140 / .25); }
.ui-stat__top { display: flex; align-items: center; justify-content: space-between; }
.ui-stat__label { font: 500 10px/1 'JetBrains Mono', monospace; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink-3); }
.ui-stat__icon { color: var(--ink-4); }
.ui-stat__value { font: 600 clamp(22px, 2vw, 28px)/1 'Manrope', sans-serif; color: var(--ink-1); letter-spacing: -0.01em; font-variant-numeric: tabular-nums; margin-top: 6px; }
.ui-stat__bottom { display: flex; align-items: center; gap: 8px; margin-top: 2px; min-height: 14px; }
.ui-stat__trend { font: 500 10px/1 'JetBrains Mono', monospace; letter-spacing: 0.12em; }
.ui-stat__trend.is-up { color: var(--accent); }
.ui-stat__trend.is-down { color: var(--warn); }
.ui-stat__hint { font: 500 10px/1 'JetBrains Mono', monospace; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-4); }

/* Dashboard cards */
.dash-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
@media (max-width: 880px) { .dash-grid { grid-template-columns: 1fr; } }
.dash-card { min-height: 280px; }
.dash-card__head { display: flex; align-items: center; justify-content: space-between; padding-bottom: 12px; border-bottom: 1px dashed var(--line-strong); margin-bottom: 12px; }
.dash-card__title { font: 600 14px/1.2 'Manrope', sans-serif; color: var(--ink-1); margin: 0; letter-spacing: 0.01em; }

.activity-list { display: flex; flex-direction: column; gap: 12px; }
.activity-item { display: flex; gap: 10px; align-items: flex-start; }
.activity-item__body { flex: 1; min-width: 0; }
.activity-item__line { font: 500 13px/1.4 'Manrope', sans-serif; color: var(--ink-2); }
.activity-item__line strong { color: var(--ink-1); font-weight: 600; }
.activity-item__time { font: 500 10px/1 'JetBrains Mono', monospace; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-4); margin-top: 4px; }

.bars { display: flex; flex-direction: column; gap: 10px; }
.bars__top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 4px; }
.bars__label { font: 500 12px/1 'Manrope', sans-serif; color: var(--ink-2); }
.bars__val { font: 600 12px/1 'JetBrains Mono', monospace; color: var(--ink-1); }
.bars__track { height: 6px; background: oklch(0.94 0.005 140); border-radius: 4px; overflow: hidden; }
.bars__fill { height: 100%; background: linear-gradient(90deg, oklch(0.45 0.05 145), oklch(0.55 0.04 160)); }

.sys-list { display: flex; flex-direction: column; gap: 8px; }
.sys-item { display: flex; align-items: center; justify-content: space-between; padding: 8px 0; border-bottom: 1px dashed oklch(0.94 0.005 140); }
.sys-item:last-child { border-bottom: none; }
.sys-item__l { font: 500 13px/1 'Manrope', sans-serif; color: var(--ink-2); }
.sys-item__r { display: flex; align-items: center; gap: 8px; font: 500 11px/1 'JetBrains Mono', monospace; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-1); }
.sys-item__meta { color: var(--ink-3); }

.ops-list { display: flex; flex-direction: column; gap: 10px; }
.ops-item { display: grid; grid-template-columns: 96px 1fr; gap: 12px; align-items: flex-start; }
.ops-item__time { font: 500 11px/1.3 'JetBrains Mono', monospace; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent); }
.ops-item__title { font: 600 13px/1.3 'Manrope', sans-serif; color: var(--ink-1); }
.ops-item__meta { display: flex; align-items: center; gap: 6px; margin-top: 4px; font: 500 11px/1 'JetBrains Mono', monospace; color: var(--ink-3); letter-spacing: 0.12em; text-transform: uppercase; }

/* ── Avatar / Badge / Button ───────────────────────────── */
.ui-avatar {
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 50%; background: oklch(0.94 0.005 140); color: var(--ink-2);
  font: 600 12px/1 'JetBrains Mono', monospace; letter-spacing: 0.06em;
  overflow: hidden; flex-shrink: 0;
  border: 1px solid oklch(0.92 0.005 140);
}
.ui-avatar img { width: 100%; height: 100%; object-fit: cover; }
.ui-avatar--dark { background: oklch(0.22 0.01 140); color: oklch(0.85 0.005 140); border-color: oklch(0.28 0.01 140); }

.ui-badge {
  display: inline-flex; align-items: center;
  padding: 4px 8px; border-radius: 999px;
  font: 600 10px/1 'JetBrains Mono', monospace;
  letter-spacing: 0.18em; text-transform: uppercase;
  border: 1px solid var(--line-strong); color: var(--ink-2); background: var(--surface);
}
.ui-badge--ok { color: var(--accent); background: var(--accent-soft); border-color: oklch(0.85 0.025 145); }
.ui-badge--warn { color: var(--warn); background: oklch(0.96 0.04 30); border-color: oklch(0.88 0.06 30); }
.ui-badge--accent { color: oklch(0.30 0.06 270); background: oklch(0.96 0.02 270); border-color: oklch(0.86 0.04 270); }

.ui-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 14px; border-radius: 10px; cursor: pointer;
  font: 600 12px/1 'Manrope', sans-serif; letter-spacing: 0.04em;
  border: 1px solid transparent;
  transition: transform .15s, box-shadow .2s, background .15s, color .15s, border-color .15s;
}
.ui-btn--primary { background: var(--ink-1); color: oklch(0.98 0 0); border-color: var(--ink-1); }
.ui-btn--primary:hover { transform: translateY(-1px); box-shadow: 0 10px 24px -14px oklch(0.22 0.01 140 / .55); }
.ui-btn--ghost { background: var(--surface); color: var(--ink-2); border-color: var(--line-strong); }
.ui-btn--ghost:hover { color: var(--ink-1); border-color: var(--ink-3); }
.ui-btn--sm { padding: 6px 10px; font-size: 11px; }
.ui-btn__icon { display: inline-flex; }

/* ── Form fields / inputs / select / textarea ─────────── */
.ui-field { display: flex; flex-direction: column; gap: 6px; }
.ui-field__label { font: 500 10px/1 'JetBrains Mono', monospace; letter-spacing: 0.24em; text-transform: uppercase; color: var(--ink-3); }
.ui-field__hint { font: 500 11px/1.3 'Manrope', sans-serif; color: var(--ink-3); }
.ui-field__hint.is-error { color: var(--warn); }
.ui-input {
  width: 100%;
  background: var(--surface);
  border: 1px solid var(--line-strong);
  border-radius: 10px;
  padding: 10px 12px;
  font: 500 14px/1.3 'Manrope', sans-serif;
  color: var(--ink-1);
  transition: border-color .2s, box-shadow .2s;
}
.ui-input:hover { border-color: oklch(0.80 0.005 140); }
.ui-input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 4px oklch(0.42 0.06 145 / .08); }
.ui-input--area { resize: vertical; min-height: 90px; font-family: 'Manrope', sans-serif; }
.ui-input--select { appearance: none; padding-right: 32px; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='none' stroke='%23777' stroke-width='1.4' d='M1 1l4 4 4-4'/%3E%3C/svg%3E"); background-position: right 12px center; background-repeat: no-repeat; }

.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 14px; }
.form-grid--2 { grid-template-columns: 1fr 1fr; }
.form-grid .span-2 { grid-column: 1 / -1; }
.form-grid__actions { grid-column: 1 / -1; display: flex; justify-content: flex-end; gap: 8px; padding-top: 8px; border-top: 1px dashed var(--line-strong); margin-top: 4px; }

/* Switch */
.ui-switch { display: inline-flex; align-items: center; gap: 10px; cursor: pointer; }
.ui-switch input { display: none; }
.ui-switch__track { width: 36px; height: 20px; background: oklch(0.92 0.005 140); border-radius: 999px; position: relative; transition: background .2s; }
.ui-switch__thumb { position: absolute; top: 2px; left: 2px; width: 16px; height: 16px; border-radius: 50%; background: var(--surface); box-shadow: 0 2px 5px oklch(0.40 0.02 140 / .25); transition: left .2s; }
.ui-switch input:checked + .ui-switch__track { background: var(--accent); }
.ui-switch input:checked + .ui-switch__track .ui-switch__thumb { left: 18px; }
.ui-switch__label { font: 500 13px/1.3 'Manrope', sans-serif; color: var(--ink-2); }

/* ── Modal ─────────────────────────────────────────────── */
.ui-modal {
  position: fixed; inset: 0; z-index: 100;
  background: oklch(0.30 0.01 140 / .35);
  backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  padding: 5vh 20px;
}
.ui-modal__panel {
  background: var(--surface);
  border-radius: 16px;
  border: 1px solid var(--line);
  box-shadow: 0 32px 80px -40px oklch(0.20 0.01 140 / .6), 0 4px 12px -6px oklch(0.20 0.01 140 / .12);
  width: min(100%, 720px);
  max-height: 90vh;
  display: flex; flex-direction: column;
  overflow: hidden;
}
.ui-modal__panel--sm { width: min(100%, 460px); }
.ui-modal__panel--md { width: min(100%, 640px); }
.ui-modal__panel--lg { width: min(100%, 820px); }
.ui-modal--dark .ui-modal__panel { background: oklch(0.16 0.01 250); border-color: oklch(0.26 0.01 250); color: oklch(0.92 0.005 140); }
.ui-modal__head { display: flex; align-items: flex-start; justify-content: space-between; padding: 18px 22px; border-bottom: 1px solid var(--line); gap: 12px; }
.ui-modal--dark .ui-modal__head { border-color: oklch(0.26 0.01 250); }
.ui-modal__sub { font: 500 10px/1 'JetBrains Mono', monospace; letter-spacing: 0.28em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 6px; }
.ui-modal--dark .ui-modal__sub { color: oklch(0.62 0.01 250); }
.ui-modal__title { font: 600 17px/1.3 'Manrope', sans-serif; color: var(--ink-1); margin: 0; }
.ui-modal--dark .ui-modal__title { color: oklch(0.94 0.005 140); }
.ui-modal__head-actions { display: flex; align-items: center; gap: 8px; }
.ui-modal__close { background: transparent; border: 1px solid var(--line-strong); width: 30px; height: 30px; border-radius: 8px; display: inline-flex; align-items: center; justify-content: center; color: var(--ink-2); cursor: pointer; }
.ui-modal__close:hover { color: var(--ink-1); }
.ui-modal--dark .ui-modal__close { border-color: oklch(0.30 0.01 250); color: oklch(0.75 0.01 250); }
.ui-modal__body { padding: 20px 22px 22px; overflow: auto; }

/* ── Table ─────────────────────────────────────────────── */
.ui-table-wrap { overflow: auto; margin: 4px -4px; }
.ui-table { width: 100%; border-collapse: separate; border-spacing: 0; }
.ui-table th { font: 500 10px/1 'JetBrains Mono', monospace; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink-3); text-align: left; padding: 10px 12px; border-bottom: 1px solid var(--line); }
.ui-table td { padding: 12px; border-bottom: 1px solid oklch(0.96 0.005 140); font: 500 13px/1.3 'Manrope', sans-serif; color: var(--ink-1); vertical-align: middle; }
.ui-table tr:last-child td { border-bottom: none; }
.ui-table tr.is-clickable { cursor: pointer; }
.ui-table tr.is-clickable:hover td { background: oklch(0.97 0.005 140); }
.ui-table__empty { text-align: center; padding: 36px 12px; color: var(--ink-3); font: 500 12px/1 'JetBrains Mono', monospace; letter-spacing: 0.18em; text-transform: uppercase; }

.row-actions { display: inline-flex; align-items: center; gap: 6px; flex-wrap: wrap; justify-content: flex-end; }
.row-actions__btn { background: transparent; border: 1px solid var(--line-strong); border-radius: 999px; padding: 5px 9px; font: 600 10px/1 'JetBrains Mono', monospace; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-2); cursor: pointer; transition: all .15s; }
.row-actions__btn:hover { color: var(--ink-1); border-color: var(--ink-3); }
.row-actions__btn.is-ok { color: var(--accent); border-color: oklch(0.85 0.025 145); }
.row-actions__btn.is-warn { color: var(--warn); border-color: oklch(0.88 0.06 30); }
.row-actions__btn.is-danger { color: var(--warn); }
.row-actions__btn.is-danger:hover { background: oklch(0.97 0.04 30); }

/* ── Toolbar / Search / Chip ────────────────────────────── */
.ui-toolbar { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; padding: 6px 4px 14px; border-bottom: 1px dashed var(--line-strong); margin-bottom: 12px; }
.ui-search { display: inline-flex; align-items: center; gap: 8px; background: var(--surface); border: 1px solid var(--line-strong); border-radius: 999px; padding: 7px 12px; color: var(--ink-3); min-width: 240px; }
.ui-search input { flex: 1; border: none; outline: none; background: transparent; font: 500 13px/1 'Manrope', sans-serif; color: var(--ink-1); }
.ui-chip {
  background: var(--surface); border: 1px solid var(--line-strong); border-radius: 999px;
  padding: 6px 11px; font: 600 10.5px/1 'JetBrains Mono', monospace; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-2); cursor: pointer; transition: all .15s;
}
.ui-chip:hover { color: var(--ink-1); border-color: var(--ink-3); }
.ui-chip.is-active { background: var(--ink-1); color: oklch(0.98 0 0); border-color: var(--ink-1); }

/* Empty state */
.ui-empty { display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 36px 16px; color: var(--ink-2); text-align: center; }
.ui-empty__mark { width: 48px; height: 48px; display: inline-flex; align-items: center; justify-content: center; border: 1px dashed var(--line-strong); border-radius: 12px; color: var(--ink-3); }
.ui-empty__title { font: 600 14px/1.3 'Manrope', sans-serif; color: var(--ink-1); }
.ui-empty__hint { font: 500 12px/1.4 'Manrope', sans-serif; color: var(--ink-3); max-width: 38ch; }

/* Card section head */
.card-section-head { display: flex; align-items: center; justify-content: space-between; padding-bottom: 12px; border-bottom: 1px dashed var(--line-strong); margin-bottom: 12px; }
.card-section-head h3 { font: 600 14px/1 'Manrope', sans-serif; color: var(--ink-1); margin: 0; }

/* ── GUARITA (Discord-like dark embed) ─────────────────── */
.guarita-embed {
  background: linear-gradient(180deg, oklch(0.20 0.012 250), oklch(0.16 0.012 250));
  color: oklch(0.90 0.005 140);
  border-radius: 12px;
  overflow: hidden;
  margin: -22px;
}
.ui-modal--dark .guarita-embed { margin: 0; border-radius: 0; }
.guarita-embed__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 22px;
  background: linear-gradient(180deg, oklch(0.24 0.012 250), oklch(0.20 0.012 250));
  border-bottom: 1px solid oklch(0.28 0.01 250);
}
.guarita-embed__crest { display: flex; align-items: center; gap: 12px; position: relative; padding-left: 12px; }
.guarita-embed__rail { position: absolute; left: 0; top: 4px; bottom: 4px; width: 3px; background: linear-gradient(180deg, #7cf0a8, #2c9e6f); border-radius: 3px; }
.guarita-embed__name { font: 600 15px/1.1 'Manrope', sans-serif; color: oklch(0.95 0.005 140); }
.guarita-embed__sub { display: flex; align-items: center; gap: 8px; font: 500 11px/1 'JetBrains Mono', monospace; letter-spacing: 0.14em; text-transform: uppercase; color: oklch(0.65 0.01 250); margin-top: 4px; }
.guarita-embed__id { text-align: right; display: flex; flex-direction: column; gap: 4px; }
.guarita-embed__body { padding: 20px 22px; display: flex; flex-direction: column; gap: 14px; }
.guarita-embed__row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 14px; }
.guarita-embed .ui-field__label { color: oklch(0.62 0.01 250); }
.guarita-embed .ui-input { background: oklch(0.14 0.01 250); border-color: oklch(0.28 0.01 250); color: oklch(0.94 0.005 140); }
.guarita-embed .ui-input:hover { border-color: oklch(0.36 0.01 250); }
.guarita-embed .ui-input:focus { border-color: #7cf0a8; box-shadow: 0 0 0 4px oklch(0.7 0.15 150 / .15); }
.guarita-embed .ui-input--select { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='none' stroke='%23aaa' stroke-width='1.4' d='M1 1l4 4 4-4'/%3E%3C/svg%3E"); }

.guarita-embed__upload {
  display: inline-flex; align-items: center; gap: 8px; padding: 10px 12px;
  background: oklch(0.14 0.01 250); border: 1px dashed oklch(0.36 0.01 250); color: oklch(0.78 0.005 140);
  border-radius: 10px; cursor: pointer; font: 500 12px/1 'JetBrains Mono', monospace; letter-spacing: 0.14em; text-transform: uppercase;
  transition: all .2s;
}
.guarita-embed__upload:hover { border-color: #7cf0a8; color: #7cf0a8; }
.guarita-embed__preview { position: relative; border-radius: 10px; overflow: hidden; border: 1px solid oklch(0.28 0.01 250); }
.guarita-embed__preview img { display: block; width: 100%; max-height: 280px; object-fit: cover; }
.guarita-embed__preview-x { position: absolute; top: 8px; right: 8px; background: oklch(0.16 0.01 250 / .85); color: oklch(0.92 0.005 140); border: 1px solid oklch(0.36 0.01 250); border-radius: 999px; padding: 5px 10px; font: 500 10px/1 'JetBrains Mono', monospace; letter-spacing: 0.18em; text-transform: uppercase; cursor: pointer; }
.guarita-embed__foot { display: flex; align-items: center; justify-content: space-between; padding-top: 12px; border-top: 1px dashed oklch(0.30 0.01 250); }
.guarita-embed__btn-ghost { background: transparent; border: 1px solid oklch(0.30 0.01 250); color: oklch(0.78 0.005 140); padding: 9px 14px; border-radius: 10px; font: 600 11px/1 'JetBrains Mono', monospace; letter-spacing: 0.2em; text-transform: uppercase; cursor: pointer; }
.guarita-embed__btn-primary { background: linear-gradient(180deg, #7cf0a8, #4cbb87); color: oklch(0.16 0.01 250); border: none; padding: 10px 16px; border-radius: 10px; font: 700 11px/1 'JetBrains Mono', monospace; letter-spacing: 0.2em; text-transform: uppercase; cursor: pointer; transition: transform .15s; }
.guarita-embed__btn-primary:hover { transform: translateY(-1px); }

.guarita-detail { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 24px; margin-bottom: 16px; }
.guarita-detail dt { font: 500 10px/1 'JetBrains Mono', monospace; letter-spacing: 0.24em; text-transform: uppercase; color: oklch(0.60 0.01 250); margin-bottom: 4px; }
.guarita-detail dd { margin: 0; font: 600 14px/1.3 'Manrope', sans-serif; color: oklch(0.95 0.005 140); }
.guarita-detail__obs { padding: 14px; background: oklch(0.14 0.01 250); border-radius: 10px; border-left: 3px solid #7cf0a8; }
.guarita-detail__obs p { margin: 6px 0 0; color: oklch(0.85 0.005 140); font: 500 14px/1.5 'Manrope', sans-serif; }
.guarita-detail__img { margin-top: 14px; border-radius: 10px; overflow: hidden; }
.guarita-detail__img img { display: block; width: 100%; }

/* Guarita grid of cards */
.guarita-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 14px; }
.guarita-card { text-align: left; background: oklch(1 0 0 / .72); border: 1px solid var(--line); border-radius: 14px; padding: 16px; display: flex; flex-direction: column; gap: 12px; cursor: pointer; transition: transform .2s, border-color .2s, box-shadow .2s; }
.guarita-card:hover { border-color: oklch(0.82 0.005 140); box-shadow: 0 16px 32px -22px oklch(0.40 0.02 140 / .25); }
.guarita-card__head { display: flex; align-items: center; justify-content: space-between; }
.guarita-card__body { display: flex; align-items: center; gap: 10px; }
.guarita-card__name { font: 600 14px/1.2 'Manrope', sans-serif; color: var(--ink-1); }
.guarita-card__sub { font: 500 11px/1 'JetBrains Mono', monospace; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-3); margin-top: 3px; }
.guarita-card__times { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; padding-top: 10px; border-top: 1px dashed var(--line-strong); }
.guarita-card__times > div { display: flex; flex-direction: column; gap: 2px; }
.guarita-card__times span { font: 500 9.5px/1 'JetBrains Mono', monospace; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-3); }
.guarita-card__times strong { font: 600 12px/1.2 'Manrope', sans-serif; color: var(--ink-1); }
.guarita-card__obs { font: 500 13px/1.4 'Manrope', sans-serif; color: var(--ink-2); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

/* ── PRISON detail ─────────────────────────────────────── */
.prison-detail { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 24px; }
.prison-detail > div:nth-child(1), .prison-detail > div:nth-child(3), .prison-detail > div:nth-child(7) { grid-column: 1 / -1; }
.prison-detail dt { font: 500 10px/1 'JetBrains Mono', monospace; letter-spacing: 0.24em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 4px; }
.prison-detail dd { margin: 0; font: 600 14px/1.3 'Manrope', sans-serif; color: var(--ink-1); }
.prison-detail__relato { margin-top: 16px; padding: 14px; background: oklch(0.97 0.005 140); border-radius: 10px; border-left: 3px solid var(--accent); }
.prison-detail__relato p { margin: 6px 0 0; font: 500 14px/1.5 'Manrope', sans-serif; color: var(--ink-2); }

/* ── ENLISTMENT (Dossier) ──────────────────────────────── */
.enlist-layout { display: grid; grid-template-columns: 340px 1fr; gap: 18px; align-items: flex-start; }
@media (max-width: 980px) { .enlist-layout { grid-template-columns: 1fr; } }

.enlist-list__head { padding-bottom: 12px; border-bottom: 1px dashed var(--line-strong); margin-bottom: 8px; }
.enlist-list__ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 6px; max-height: 64vh; overflow: auto; }
.enlist-list__item {
  width: 100%; text-align: left;
  display: flex; align-items: center; gap: 10px;
  background: var(--surface); border: 1px solid var(--line);
  border-radius: 12px; padding: 9px 11px; cursor: pointer;
  transition: border-color .15s, transform .15s, background .15s;
}
.enlist-list__item:hover { border-color: oklch(0.82 0.005 140); }
.enlist-list__item.is-active { border-color: var(--ink-1); background: oklch(0.98 0.005 140); }
.enlist-list__name { font: 600 13px/1.2 'Manrope', sans-serif; color: var(--ink-1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.enlist-list__meta { font: 500 10px/1 'JetBrains Mono', monospace; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-3); margin-top: 3px; display: flex; gap: 6px; }

.enlist-ficha {
  position: relative;
  background: linear-gradient(180deg, oklch(0.18 0.01 250), oklch(0.13 0.01 250));
  color: oklch(0.92 0.005 140);
  border-radius: 18px;
  padding: 30px;
  overflow: hidden;
  min-height: 520px;
  border: 1px solid oklch(0.26 0.01 250);
  box-shadow: 0 30px 60px -36px oklch(0.10 0.01 250 / .75);
}
.enlist-ficha--empty { display: flex; align-items: center; justify-content: center; background: oklch(0.96 0.005 140); color: var(--ink-2); border: 1px dashed var(--line-strong); }
.enlist-ficha--empty .ui-empty { padding: 60px; }

/* Corner ticks */
.enlist-ficha__corner { position: absolute; width: 18px; height: 18px; border-color: oklch(0.70 0.04 145); border-style: solid; border-width: 0; }
.enlist-ficha__corner--tl { top: 12px; left: 12px; border-top-width: 2px; border-left-width: 2px; }
.enlist-ficha__corner--tr { top: 12px; right: 12px; border-top-width: 2px; border-right-width: 2px; }
.enlist-ficha__corner--bl { bottom: 12px; left: 12px; border-bottom-width: 2px; border-left-width: 2px; }
.enlist-ficha__corner--br { bottom: 12px; right: 12px; border-bottom-width: 2px; border-right-width: 2px; }

.enlist-ficha__head { display: flex; align-items: flex-start; justify-content: space-between; padding-bottom: 18px; border-bottom: 1px dashed oklch(0.30 0.01 250); }
.enlist-ficha__body { display: grid; grid-template-columns: 200px 1fr; gap: 28px; padding: 22px 0; }
@media (max-width: 740px) { .enlist-ficha__body { grid-template-columns: 1fr; } }
.enlist-ficha__photo { position: relative; aspect-ratio: 3 / 4; border-radius: 12px; overflow: hidden; background: oklch(0.20 0.01 250); border: 1px solid oklch(0.30 0.01 250); }
.enlist-ficha__photo img { width: 100%; height: 100%; object-fit: cover; }
.enlist-ficha__photo-empty { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; }
.enlist-ficha__photo-grid { position: absolute; inset: 0; background-image: linear-gradient(to right, oklch(0.50 0.04 145 / .1) 1px, transparent 1px), linear-gradient(to bottom, oklch(0.50 0.04 145 / .1) 1px, transparent 1px); background-size: 24px 24px; pointer-events: none; }
.enlist-ficha__photo-tag { position: absolute; left: 8px; right: 8px; bottom: 8px; display: flex; align-items: center; justify-content: space-between; background: oklch(0.14 0.01 250 / .85); border: 1px solid oklch(0.30 0.01 250); border-radius: 6px; padding: 5px 8px; }
.enlist-ficha__name { font: 700 26px/1.1 'Manrope', sans-serif; color: oklch(0.96 0.005 140); letter-spacing: -0.01em; }
.enlist-ficha__sub { font: 500 11px/1 'JetBrains Mono', monospace; letter-spacing: 0.22em; text-transform: uppercase; color: oklch(0.60 0.01 250); margin-top: 6px; }
.enlist-ficha__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 24px; margin-top: 22px; }
.enlist-ficha__grid .span-2 { grid-column: 1 / -1; }
.enlist-ficha__grid dt { font: 500 10px/1 'JetBrains Mono', monospace; letter-spacing: 0.24em; text-transform: uppercase; color: oklch(0.58 0.01 250); margin-bottom: 4px; }
.enlist-ficha__grid dd { margin: 0; font: 600 14px/1.3 'Manrope', sans-serif; color: oklch(0.94 0.005 140); }
.enlist-ficha__actions { display: flex; gap: 8px; margin-top: 22px; padding-top: 16px; border-top: 1px dashed oklch(0.30 0.01 250); }
.enlist-btn { background: transparent; border: 1px solid oklch(0.30 0.01 250); color: oklch(0.80 0.005 140); padding: 8px 12px; border-radius: 8px; font: 600 11px/1 'JetBrains Mono', monospace; letter-spacing: 0.2em; text-transform: uppercase; cursor: pointer; transition: all .15s; }
.enlist-btn:hover { border-color: #7cf0a8; color: #7cf0a8; }
.enlist-btn--danger { color: oklch(0.78 0.12 30); }
.enlist-btn--danger:hover { color: oklch(0.85 0.16 30); border-color: oklch(0.55 0.16 30); }
.enlist-ficha__foot { display: flex; align-items: center; justify-content: space-between; padding-top: 16px; border-top: 1px dashed oklch(0.30 0.01 250); }

/* Photo upload */
.enlist-photo { display: flex; flex-direction: column; align-items: center; gap: 10px; }
.enlist-photo > img,
.enlist-photo__placeholder {
  width: 140px; aspect-ratio: 3/4; object-fit: cover;
  border-radius: 10px; background: oklch(0.94 0.005 140);
  border: 1px dashed var(--line-strong);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px;
  color: var(--ink-3); font: 500 10px/1 'JetBrains Mono', monospace; letter-spacing: 0.22em; text-transform: uppercase;
}
.enlist-photo__btn { background: var(--surface); border: 1px solid var(--line-strong); padding: 7px 10px; border-radius: 8px; font: 600 10px/1 'JetBrains Mono', monospace; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-2); cursor: pointer; }
.enlist-photo__btn:hover { color: var(--ink-1); border-color: var(--ink-3); }

/* ── PERMS layout ──────────────────────────────────────── */
.perms-layout { display: grid; grid-template-columns: 2fr 1fr; gap: 14px; align-items: flex-start; }
@media (max-width: 980px) { .perms-layout { grid-template-columns: 1fr; } }
.perms-layout .span-2 { grid-column: 1 / -1; }

.rank-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.rank-item { display: grid; grid-template-columns: 50px 1fr auto; gap: 10px; align-items: center; padding: 9px 12px; border: 1px solid var(--line); border-radius: 10px; background: var(--surface); }
.rank-item__nivel { font: 600 11px/1 'JetBrains Mono', monospace; letter-spacing: 0.18em; color: var(--accent); }
.rank-item__nome { font: 600 13px/1 'Manrope', sans-serif; color: var(--ink-1); }
.rank-item__count { font: 500 11px/1 'JetBrains Mono', monospace; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-2); }

.perm-matrix { display: flex; flex-direction: column; gap: 4px; font: 500 11px/1 'JetBrains Mono', monospace; }
.perm-matrix__head, .perm-matrix__row { display: grid; grid-template-columns: minmax(180px, 1.6fr) repeat(10, minmax(36px, 1fr)); align-items: center; }
.perm-matrix__head span { font-size: 9.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-3); padding: 8px 4px; text-align: center; }
.perm-matrix__head span:first-child { text-align: left; padding-left: 10px; }
.perm-matrix__label { font: 500 12px/1.2 'Manrope', sans-serif; color: var(--ink-2); padding: 8px 10px; }
.perm-cell { text-align: center; padding: 8px 4px; color: oklch(0.82 0.005 140); }
.perm-cell.is-on { color: var(--accent); font-weight: 700; }
.perm-matrix__row:nth-child(odd) { background: oklch(0.98 0.005 140); border-radius: 6px; }

/* Misc */
.dot-sep { opacity: .55; }
.ml-auto { margin-left: auto; }
.flex { display: flex; }
.items-center { align-items: center; }
.gap-1\.5 { gap: 6px; }
.gap-2 { gap: 8px; }
.flex-wrap { flex-wrap: wrap; }
.justify-end { justify-content: flex-end; }
.justify-center { justify-content: center; }
.pb-2 { padding-bottom: 8px; }
.mt-3 { margin-top: 12px; }
.mt-4 { margin-top: 16px; }
.mt-6 { margin-top: 24px; }
.mb-1 { margin-bottom: 4px; }
.tabular-nums { font-variant-numeric: tabular-nums; }
