:root {
  --bg: #08111f;
  --bg-soft: #0d1729;
  --surface: #111c31;
  --surface-2: #16233c;
  --surface-3: #1b2b47;
  --surface-4: #213454;
  --border: rgba(148, 163, 184, 0.16);
  --border-strong: rgba(148, 163, 184, 0.28);
  --text: #edf2fb;
  --muted: #9db0c7;
  --primary: #4f8cff;
  --primary-strong: #2f6eea;
  --primary-soft: rgba(79, 140, 255, 0.14);
  --success: #2bd576;
  --success-soft: rgba(43, 213, 118, 0.14);
  --warning: #ffb347;
  --warning-soft: rgba(255, 179, 71, 0.16);
  --danger: #ff6b7d;
  --danger-soft: rgba(255, 107, 125, 0.16);
  --info: #5dc5ff;
  --info-soft: rgba(93, 197, 255, 0.16);
  --shadow-sm: 0 14px 40px rgba(0,0,0,.22);
  --shadow-md: 0 24px 60px rgba(0,0,0,.3);
  --radius-xl: 26px;
  --radius-lg: 20px;
  --radius-md: 16px;
  --radius-sm: 12px;
  --font: Inter, "Segoe UI", Arial, sans-serif;
}

* { box-sizing: border-box; }
html, body { min-height: 100%; }
body {
  margin: 0;
  color: var(--text);
  font-family: var(--font);
  background:
    radial-gradient(circle at top left, rgba(79, 140, 255, .16), transparent 24rem),
    radial-gradient(circle at bottom right, rgba(43, 213, 118, .08), transparent 28rem),
    linear-gradient(180deg, #07111e 0%, #0a1424 45%, #0d1729 100%);
}
a { color: inherit; text-decoration: none; }
h1,h2,h3,h4,p { margin: 0; }
button,input,select,textarea { font: inherit; }

.app-shell { display: grid; grid-template-columns: 300px 1fr; min-height: 100vh; }
.sidebar {
  position: sticky; top: 0; min-height: 100vh; padding: 24px 18px;
  display: flex; flex-direction: column; gap: 18px;
  background: linear-gradient(180deg, rgba(7,17,30,.96), rgba(10,20,36,.98));
  border-right: 1px solid var(--border);
  box-shadow: inset -1px 0 0 rgba(255,255,255,.02);
}
.sidebar-brand {
  display: flex; align-items: center; gap: 14px; padding: 8px 10px 18px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.sidebar-logo {
  width: 50px; height: 50px; border-radius: 18px; display: grid; place-items: center;
  font-size: 1.4rem; font-weight: 900; color: #fff;
  background: linear-gradient(135deg, #2bd576, #4f8cff 65%, #7c5cff);
  box-shadow: 0 20px 35px rgba(79, 140, 255, .24);
}
.sidebar-title { font-size: 1.08rem; font-weight: 800; letter-spacing: -.03em; }
.sidebar-subtitle { color: var(--muted); font-size: .9rem; margin-top: 4px; }
.sidebar-nav { display: flex; flex-direction: column; gap: 6px; flex: 1; overflow: auto; padding-right: 4px; min-height: 0; }
.nav-group-title {
  font-size: .76rem; font-weight: 800; text-transform: uppercase; letter-spacing: .14em;
  color: #6f86a5; padding: 16px 12px 6px;
}
.nav-link {
  display: flex; align-items: center; gap: 12px; padding: 12px 14px; border-radius: 16px;
  color: #d6e0ef; transition: .18s ease; border: 1px solid transparent;
}
.nav-link:hover {
  background: rgba(255,255,255,.04); border-color: rgba(255,255,255,.05);
  transform: translateX(2px);
}
.nav-link.active {
  color: #fff;
  background: linear-gradient(90deg, rgba(79,140,255,.18), rgba(79,140,255,.08));
  border-color: rgba(79,140,255,.28);
  box-shadow: inset 3px 0 0 #4f8cff;
}
.nav-icon { width: 22px; text-align: center; font-size: 1rem; }
.nav-badge, .button-badge {
  margin-left: auto; min-width: 22px; height: 22px; padding: 0 6px;
  border-radius: 999px; display: inline-grid; place-items: center; font-size: .74rem; font-weight: 800;
  background: #ffb347; color: #2a1900;
}
.sidebar-footer { display: grid; gap: 12px; margin-top: auto; }
.cash-chip, .user-card {
  border-radius: 18px; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.06);
}
.cash-chip span { display:block; color:#91a4be; font-size:.78rem; text-transform:uppercase; letter-spacing:.08em; }
.status-box__metrics strong, .cash-chip strong { display:block; margin-top:4px; color:#fff; font-size:.98rem; }
.cash-chip { padding: 14px; }
.user-card { display:flex; gap:12px; align-items:flex-start; padding:14px; }
.user-avatar {
  width:44px; height:44px; border-radius:14px; display:grid; place-items:center;
  font-weight:800; background: rgba(79,140,255,.18); color:#fff;
}
.user-name { font-weight: 700; }
.user-mail { color: var(--muted); font-size: .84rem; margin-top: 3px; word-break: break-word; }
.user-role { margin-top: 10px; }

.main { padding: 24px; display: flex; flex-direction: column; gap: 20px; }
.topbar, .page-panel, .card, .login-brand, .login-form-card, .demo-box {
  background: linear-gradient(180deg, rgba(17,28,49,.96), rgba(13,23,41,.98));
  border: 1px solid var(--border); box-shadow: var(--shadow-sm);
}
.topbar {
  display:flex; justify-content:space-between; gap:18px; align-items:flex-start;
  padding:24px 26px; border-radius: var(--radius-xl);
}
.eyebrow, .panel-kicker {
  display:inline-flex; align-items:center; gap:6px; padding:8px 12px; border-radius:999px;
  background: var(--primary-soft); color: #a9c6ff; font-size:.76rem; font-weight:800;
  text-transform:uppercase; letter-spacing:.1em;
}
.topbar h1, .page-panel h2 { font-size: 2rem; letter-spacing: -.04em; margin-top: 12px; }
.topbar-text, .section-caption, .cell-meta, .page-panel p { color: var(--muted); line-height: 1.6; }
.topbar-actions, .page-panel__actions, .hero-banner__actions, .toolbar-form, .form-actions, .inline-form {
  display:flex; align-items:center; gap:12px; flex-wrap:wrap;
}
.topbar-pill {
  min-width: 130px; padding: 12px 16px; border-radius: 18px; border:1px solid var(--border);
  background: rgba(255,255,255,.03); display:flex; flex-direction:column; gap:4px;
}
.topbar-pill span { font-size:.72rem; text-transform:uppercase; color:#7f95b5; letter-spacing:.08em; }
.topbar-pill strong { font-size:1.05rem; }
.flash-stack { display:grid; gap:10px; }
.alert {
  padding:14px 16px; border-radius:16px; border:1px solid transparent; font-weight:600;
}
.alert-success { background: var(--success-soft); color:#b7ffd0; border-color: rgba(43,213,118,.28); }
.alert-danger { background: var(--danger-soft); color:#ffd0d6; border-color: rgba(255,107,125,.28); }
.alert-warning { background: var(--warning-soft); color:#ffe4b5; border-color: rgba(255,179,71,.28); }
.alert-info { background: var(--info-soft); color:#d1f0ff; border-color: rgba(93,197,255,.28); }

.grid { display:grid; gap:20px; }
.two-columns { grid-template-columns: minmax(0,1.2fr) minmax(340px,.95fr); }
.workspace-grid { display:grid; gap:20px; grid-template-columns: minmax(0,1.5fr) minmax(300px,.9fr); }
.grid-2 { display:grid; gap:20px; grid-template-columns: repeat(2, minmax(0, 1fr)); }
.card {
  border-radius: var(--radius-xl); overflow:hidden;
}
.card-dark { background: linear-gradient(180deg, rgba(13,23,41,.98), rgba(11,19,35,.98)); }
.card-header {
  display:flex; justify-content:space-between; gap:16px; align-items:flex-start;
  padding:20px 22px; border-bottom:1px solid var(--border);
}
.card-header h2 { font-size: 1.25rem; letter-spacing: -.03em; }
.card-body { padding: 22px; }
.stats-grid { display:grid; gap:16px; grid-template-columns: repeat(4, minmax(0,1fr)); }
.stats-grid--compact { grid-template-columns: repeat(3, minmax(0,1fr)); }
.stats-grid--premium { grid-template-columns: repeat(5, minmax(0,1fr)); }
.stat-card {
  padding:20px; border-radius:22px; background: linear-gradient(180deg, rgba(17,28,49,.98), rgba(21,35,60,.98));
  border:1px solid var(--border); box-shadow: var(--shadow-sm);
}
.stat-card--accent { box-shadow: inset 0 1px 0 rgba(79,140,255,.18); }
.stat-card--success { box-shadow: inset 0 1px 0 rgba(43,213,118,.18); }
.stat-card--warning { box-shadow: inset 0 1px 0 rgba(255,179,71,.18); }
.stat-card--danger { box-shadow: inset 0 1px 0 rgba(255,107,125,.18); }
.stat-card--info-outline { box-shadow: inset 0 1px 0 rgba(93,197,255,.18); }
.stat-label { display:block; color:#9fb4cf; font-size:.88rem; }
.stat-value { display:block; margin-top:12px; font-size:1.95rem; letter-spacing:-.04em; }
.stat-note { display:block; margin-top:8px; color: var(--muted); font-size: .92rem; }
.mini-grid { display:grid; gap:14px; grid-template-columns: repeat(2, minmax(0,1fr)); padding:22px; }
.mini-stat {
  padding:16px; border-radius:18px; background: rgba(255,255,255,.03); border:1px solid var(--border);
}
.mini-stat--danger { background: var(--danger-soft); }
.mini-stat--warning { background: var(--warning-soft); }
.mini-stat--info { background: var(--info-soft); }
.mini-stat span { color:#9fb4cf; font-size:.84rem; }
.mini-stat strong { display:block; margin-top:8px; font-size:1.14rem; }

.hero-banner {
  display:grid; grid-template-columns: minmax(0,1.35fr) minmax(300px,.75fr); gap:18px;
  padding:24px 26px; border-radius:28px; border:1px solid var(--border);
  background:
    radial-gradient(circle at top right, rgba(79,140,255,.16), transparent 18rem),
    linear-gradient(180deg, rgba(17,28,49,.98), rgba(11,19,35,.98));
  box-shadow: var(--shadow-md);
}
.hero-banner h2 { margin-top: 12px; font-size: 2rem; letter-spacing: -.04em; }
.hero-banner p { margin-top: 10px; color: var(--muted); line-height: 1.6; max-width: 56rem; }
.hero-banner__metrics { display:grid; gap:14px; }
.hero-metric {
  padding:18px; border-radius:20px; border:1px solid var(--border); background: rgba(255,255,255,.04);
}
.hero-metric span { display:block; color:#91a4be; font-size:.82rem; text-transform:uppercase; letter-spacing:.08em; }
.hero-metric strong { display:block; margin-top:10px; font-size:1.85rem; }
.hero-metric small { display:block; margin-top:6px; color:var(--muted); }
.dashboard-grid-top { grid-template-columns: minmax(0, .95fr) minmax(0, 1.2fr); }

.form-grid { display:grid; gap:18px; grid-template-columns: repeat(2, minmax(0,1fr)); }
.form-group { display:flex; flex-direction:column; gap:8px; }
.form-group.full { grid-column: 1 / -1; }
.form-group label, .line-item.header { font-size:.92rem; font-weight:700; color:#c8d5e7; }
.checkbox-row { display:inline-flex; align-items:center; gap:10px; }
input, select, textarea {
  width:100%; padding:14px 16px; border-radius:16px; border:1px solid var(--border-strong);
  background: rgba(255,255,255,.04); color: var(--text); outline:none;
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}

select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  color-scheme: dark;
  background-image:
    linear-gradient(45deg, transparent 50%, #9db0c7 50%),
    linear-gradient(135deg, #9db0c7 50%, transparent 50%);
  background-position:
    calc(100% - 22px) calc(50% - 3px),
    calc(100% - 16px) calc(50% - 3px);
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
  padding-right: 42px;
}

select option,
select optgroup {
  background: #0d1729;
  color: #edf2fb;
}

select option[value=""],
select option[disabled] {
  color: #9db0c7;
}

select option:checked,
select option:hover,
select option:focus {
  background: #213454;
  color: #ffffff;
  box-shadow: 0 0 0 9999px #213454 inset;
}

select[multiple] {
  min-height: 180px;
  padding-right: 16px;
  background-image: none;
}

input[type="file"] {
  padding: 10px 12px;
  background: rgba(255,255,255,.03);
  color: var(--text);
}

input[type="file"]::file-selector-button {
  margin-right: 12px;
  border: 1px solid rgba(79,140,255,.25);
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(79,140,255,.18), rgba(47,110,234,.16));
  color: #ffffff;
  padding: 10px 14px;
  font-weight: 700;
  cursor: pointer;
}

input::placeholder, textarea::placeholder { color:#6f84a3; }
input:focus, select:focus, textarea:focus {
  border-color: rgba(79,140,255,.62); box-shadow: 0 0 0 4px rgba(79,140,255,.12); background: rgba(255,255,255,.06);
}

input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
textarea:-webkit-autofill,
select:-webkit-autofill {
  -webkit-text-fill-color: #edf2fb;
  -webkit-box-shadow: 0 0 0 1000px rgba(17,28,49,.98) inset;
  transition: background-color 9999s ease-in-out 0s;
}

textarea { resize: vertical; min-height: 120px; }
.button {
  display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:13px 18px;
  border-radius:16px; border:1px solid transparent; background: linear-gradient(180deg, #4f8cff, #2f6eea);
  color:#fff; font-weight:800; letter-spacing:-.01em; cursor:pointer;
  box-shadow: 0 14px 28px rgba(47,110,234,.24); transition: transform .15s ease, box-shadow .15s ease, opacity .15s ease;
}
.button:hover { transform: translateY(-1px); box-shadow: 0 18px 30px rgba(47,110,234,.28); }
.button-secondary {
  background: rgba(255,255,255,.04); color: var(--text); border-color: var(--border); box-shadow:none;
}
.button-secondary:hover, .button-ghost:hover { background: rgba(255,255,255,.08); box-shadow:none; }
.button-ghost { background: transparent; color: var(--muted); border-color: var(--border); box-shadow:none; }
.button-danger { background: linear-gradient(180deg, #ff6b7d, #e54963); }
.button-sm { padding:10px 14px; border-radius:14px; font-size:.92rem; }
.button-block { width:100%; }
.button-group, .button-stack { display:flex; gap:10px; flex-wrap:wrap; }
.badge {
  display:inline-flex; align-items:center; justify-content:center; gap:6px; min-height:30px;
  padding:6px 12px; border-radius:999px; font-size:.78rem; font-weight:800; white-space:nowrap;
}
.badge-success { color:#b7ffd0; background: var(--success-soft); border:1px solid rgba(43,213,118,.18); }
.badge-warning { color:#ffe0ae; background: var(--warning-soft); border:1px solid rgba(255,179,71,.18); }
.badge-danger { color:#ffd0d6; background: var(--danger-soft); border:1px solid rgba(255,107,125,.18); }
.badge-info { color:#d1f0ff; background: var(--info-soft); border:1px solid rgba(93,197,255,.18); }
.table-wrap { overflow-x:auto; }
table { width:100%; border-collapse: collapse; }
thead th {
  padding: 15px 18px; text-align:left; font-size:.78rem; color:#88a0bf; text-transform:uppercase;
  letter-spacing:.08em; background: rgba(255,255,255,.03); border-bottom:1px solid var(--border);
}
tbody td {
  padding: 15px 18px; border-bottom:1px solid rgba(255,255,255,.05); vertical-align:top;
}
tbody tr:last-child td { border-bottom:none; }
tbody tr:hover { background: rgba(255,255,255,.025); }
.table-actions { width:1%; white-space:nowrap; }
.empty-cell, .empty-state { color: var(--muted); text-align:center; padding:22px !important; }
.detail-chip {
  display:inline-flex; align-items:center; gap:8px; margin:0 8px 8px 0; padding:8px 12px;
  border-radius:999px; background: var(--primary-soft); color: #b9d0ff; font-size:.84rem;
}
.detail-panel { display:grid; gap:18px; align-content:start; }
.detail-panel__block, .list-compact__item {
  padding:18px; border-radius:20px; background: rgba(255,255,255,.03); border:1px solid var(--border);
}
.detail-panel__eyebrow { display:inline-block; color:#b9d0ff; font-size:.78rem; text-transform:uppercase; letter-spacing:.08em; font-weight:800; }
.detail-panel__block h3 { margin-top:10px; font-size:1.1rem; letter-spacing:-.02em; }
.detail-panel__header, .list-compact__item { display:flex; justify-content:space-between; gap:14px; align-items:center; }
.detail-list { display:grid; gap:12px; margin-top:16px; }
.detail-list div { display:flex; justify-content:space-between; gap:14px; padding:12px 0; border-bottom:1px solid var(--border); }
.detail-list div:last-child { border-bottom:none; }
.detail-list span { color: var(--muted); }
.list-compact, .audit-list, .clean-list { display:grid; gap:12px; }
.audit-list { padding: 22px; }
.audit-item { display:grid; grid-template-columns:14px 1fr; gap:12px; }
.audit-item__dot {
  width:12px; height:12px; border-radius:999px; background: var(--primary); margin-top:6px;
  box-shadow: 0 0 0 5px rgba(79,140,255,.12);
}
.line-items { display:grid; gap:12px; margin-top:22px; }
.line-item { display:grid; grid-template-columns:minmax(0,2fr) 1fr 1fr 1fr 1fr auto; gap:10px; align-items:center; }
.line-item.header { color:#7f95b5; font-size:.82rem; text-transform:uppercase; letter-spacing:.08em; }
.line-items[data-lines="sale"] .line-item { grid-template-columns:minmax(0,2.5fr) 1fr 1fr auto; }
.catalog-tabs { display:flex; gap:12px; flex-wrap:wrap; padding:16px 18px; }
.catalog-tab { padding:12px 16px; border-radius:16px; background: rgba(255,255,255,.03); border:1px solid var(--border); font-weight:700; color: var(--muted); }
.catalog-tab.active { background: var(--primary-soft); color:#bdd2ff; border-color: rgba(79,140,255,.28); }

.login-body {
  min-height:100vh; display:grid; place-items:center; padding:30px;
  background:
    radial-gradient(circle at top left, rgba(79,140,255,.20), transparent 24rem),
    radial-gradient(circle at bottom right, rgba(43,213,118,.12), transparent 24rem),
    linear-gradient(180deg, #07111e 0%, #0a1424 55%, #0d1729 100%);
}
.login-shell {
  width:min(1240px,100%); min-height: calc(100vh - 60px); display:grid;
  grid-template-columns: 1.1fr minmax(380px,.8fr); gap:28px; align-items:stretch;
}
.login-hero, .login-panel { min-height: 100%; }
.login-hero {
  padding: 38px; border-radius: 32px; border:1px solid var(--border);
  background:
    radial-gradient(circle at top right, rgba(79,140,255,.16), transparent 18rem),
    linear-gradient(180deg, rgba(17,28,49,.96), rgba(11,19,35,.98));
  box-shadow: var(--shadow-md); display:flex; flex-direction:column; justify-content:center;
}
.login-hero h1 { margin-top:18px; font-size: clamp(2.1rem, 3vw, 3.5rem); line-height:1.04; letter-spacing:-.05em; }
.login-hero p { margin-top:18px; color:#b3c2d8; font-size:1.05rem; max-width:42rem; }
.login-feature-list { display:grid; gap:16px; margin-top:30px; grid-template-columns:repeat(3,minmax(0,1fr)); }
.login-feature {
  padding:18px; border-radius:20px; background: rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.06);
}
.login-feature strong { display:block; font-size:1rem; }
.login-feature span { display:block; margin-top:8px; color:#aabbd3; line-height:1.55; font-size:.92rem; }
.login-panel { display:grid; place-items:center; }
.login-card { width:min(100%, 460px); display:grid; gap:16px; }
.login-brand { display:flex; align-items:center; gap:14px; padding:20px 22px; border-radius: 24px; }
.login-brand h1 { font-size:1.5rem; letter-spacing:-.04em; }
.login-brand p { color:var(--muted); margin-top:4px; }
.login-form-card { border-radius: 24px; }
.login-demo { display:grid; gap:12px; grid-template-columns: repeat(2, minmax(0,1fr)); }
.demo-box { padding:16px; border-radius:18px; display:grid; gap:6px; }
.demo-box span, .muted, .login-note { color:var(--muted); font-size:.9rem; }
.login-note { margin-bottom: 6px; }

.print-body {
  background: linear-gradient(180deg, #0b1424 0%, #0f1930 100%);
  margin: 0;
  padding: 28px;
  color: #0f172a;
}
.print-sheet {
  width: min(100%, 980px);
  margin: 0 auto;
  background: #ffffff;
  border-radius: 24px;
  padding: 0;
  overflow: hidden;
  box-shadow: 0 28px 60px rgba(3, 10, 24, .28);
}
.print-shell {
  padding: 30px 34px 34px;
}
.print-cover {
  background:
    radial-gradient(circle at top right, rgba(93, 197, 255, .35), transparent 22rem),
    linear-gradient(135deg, #0b1730 0%, #102549 60%, #163566 100%);
  color: #f8fbff;
  padding: 28px 34px;
}
.print-cover__top {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  align-items: flex-start;
}
.print-brand h1 {
  font-size: 2rem;
  margin: 0;
  letter-spacing: -.04em;
  color: #ffffff;
}
.print-brand p,
.print-brand small,
.print-doc-chip span,
.print-note,
.print-notes,
.print-muted,
.print-panel p,
.print-meta-line,
.print-footer,
.label-card__meta,
.label-card__footer,
.report-meta__item span,
.report-kpi span,
.report-note {
  color: #64748b;
}
.print-cover .print-brand p,
.print-cover .print-brand small,
.print-cover .print-doc-chip span,
.print-cover .print-note,
.print-cover .print-meta-line {
  color: rgba(238, 245, 255, .82);
}
.print-brand p { margin-top: 8px; line-height: 1.6; }
.print-brand small { display: block; margin-top: 6px; }
.print-doc-chip {
  min-width: 240px;
  display: grid;
  gap: 8px;
  padding: 18px 20px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.08);
  backdrop-filter: blur(4px);
}
.print-doc-chip strong {
  font-size: 1.1rem;
  color: #fff;
}
.print-doc-chip .print-doc-ref {
  font-size: 1.35rem;
  font-weight: 800;
  color: #fff;
}
.print-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 18px;
  margin-top: 22px;
}
.print-panel {
  border: 1px solid #d8e3f0;
  border-radius: 18px;
  padding: 18px 18px 16px;
  background: linear-gradient(180deg, #ffffff, #f8fbff);
}
.print-panel h3 {
  margin-bottom: 10px;
  font-size: .95rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: #27426a;
}
.print-panel p {
  margin: 4px 0;
  line-height: 1.55;
}
.print-table-wrap {
  margin-top: 22px;
  border: 1px solid #d8e3f0;
  border-radius: 18px;
  overflow: hidden;
}
.print-table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
  color: #0f172a;
}
.print-table thead th {
  background: linear-gradient(180deg, #eef5ff, #e8f0fb);
  color: #28466f;
  text-align: left;
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  padding: 12px 14px;
}
.print-table tbody td {
  padding: 13px 14px;
  border-top: 1px solid #e6edf7;
  vertical-align: top;
  word-wrap: break-word;
  overflow-wrap: anywhere;
}
.print-table tbody tr:nth-child(even) td {
  background: #fbfdff;
}
.print-table td strong { display: block; color: #0f172a; }
.print-table td .cell-meta { color: #6b7d94; margin-top: 4px; }
.print-summary {
  display: grid;
  grid-template-columns: repeat(5, minmax(0,1fr));
  gap: 12px;
  margin-top: 22px;
}
.print-summary__item,
.report-kpi {
  border: 1px solid #d8e3f0;
  border-radius: 18px;
  padding: 14px 16px;
  background: linear-gradient(180deg, #ffffff, #f7fbff);
}
.print-summary__item span,
.report-kpi span {
  display: block;
  font-size: .74rem;
  text-transform: uppercase;
  letter-spacing: .1em;
}
.print-summary__item strong,
.report-kpi strong {
  display: block;
  margin-top: 8px;
  font-size: 1rem;
  color: #0f172a;
}
.print-total {
  margin-top: 22px;
  text-align: right;
  font-size: 1.45rem;
  font-weight: 800;
  color: #0f172a;
}
.print-note,
.print-notes,
.report-note {
  margin-top: 18px;
  line-height: 1.65;
}
.print-footer {
  margin-top: 24px;
  padding-top: 16px;
  border-top: 1px solid #d8e3f0;
  display: flex;
  justify-content: space-between;
  gap: 18px;
  font-size: .88rem;
}
.label-sheet {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 18px;
}
.label-card {
  border: 1px solid #d8e3f0;
  border-radius: 18px;
  overflow: hidden;
  background: #ffffff;
}
.label-card__head {
  padding: 14px 16px;
  background: linear-gradient(135deg, #0e1d39 0%, #163461 100%);
  color: #ffffff;
}
.label-card__head h3 {
  margin: 0;
  font-size: 1.15rem;
  letter-spacing: -.03em;
}
.label-card__head span {
  display: block;
  margin-top: 4px;
  color: rgba(239, 246, 255, .8);
}
.label-card__body {
  padding: 16px;
  display: grid;
  gap: 8px;
}
.label-card__meta strong {
  color: #0f172a;
}
.label-card__price {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 8px;
  padding-top: 10px;
  border-top: 1px dashed #d8e3f0;
}
.label-card__price strong {
  font-size: 1.1rem;
  color: #0f172a;
}
.label-card__footer {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  font-size: .82rem;
}
.report-sheet {
  width: min(100%, 1120px);
}
.report-toolbar {
  width: min(100%, 1120px);
  margin: 0 auto 16px;
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: center;
  color: #d8e5f8;
}
.report-toolbar__actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.print-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 18px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.08);
  color: #fff;
  font-weight: 700;
}
.print-action--primary {
  background: linear-gradient(135deg, #2f6eea, #4f8cff);
  border-color: rgba(79,140,255,.35);
}
.report-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 14px;
  margin-top: 22px;
}
.report-meta__item {
  border: 1px solid #d8e3f0;
  border-radius: 18px;
  padding: 14px 16px;
  background: linear-gradient(180deg, #ffffff, #f7fbff);
}
.report-meta__item span {
  display: block;
  font-size: .74rem;
  text-transform: uppercase;
  letter-spacing: .1em;
}
.report-meta__item strong {
  display: block;
  margin-top: 8px;
  color: #0f172a;
}
.report-kpis {
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 12px;
  margin-top: 20px;
}
.report-section {
  margin-top: 22px;
}
.report-section h3 {
  margin-bottom: 12px;
  color: #18365c;
  font-size: 1rem;
}
.report-section--grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 20px;
}
.report-table--compact thead th,
.report-table--compact tbody td {
  padding-top: 10px;
  padding-bottom: 10px;
  font-size: .92rem;
}
.report-table--tight thead th,
.report-table--tight tbody td {
  font-size: .83rem;
  padding-left: 10px;
  padding-right: 10px;
}
.report-empty {
  padding: 18px;
  border: 1px dashed #d8e3f0;
  border-radius: 18px;
  color: #6b7d94;
  background: #fbfdff;
}

@media print {
  @page {
    size: A4;
    margin: 12mm;
  }
  .print-body {
    background: #ffffff;
    padding: 0;
  }
  .print-sheet,
  .report-sheet {
    width: 100%;
    max-width: none;
    box-shadow: none;
    border-radius: 0;
  }
  .report-toolbar {
    display: none;
  }
  .print-cover {
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
}

@media (max-width: 1260px) {
  .stats-grid, .stats-grid--compact, .dashboard-grid-top { grid-template-columns:1fr 1fr; }
  .login-shell { grid-template-columns:1fr; min-height:auto; }
  .login-feature-list { grid-template-columns:1fr; }
}
@media (max-width: 960px) {
  .app-shell { grid-template-columns:1fr; }
  .sidebar { position:relative; min-height:auto; }
  .main { padding:18px; }
  .topbar, .page-panel, .card-header, .hero-banner, .detail-panel__header, .list-compact__item, .print-header { flex-direction:column; }
  .hero-banner, .two-columns, .workspace-grid, .stats-grid, .stats-grid--compact, .grid-2, .mini-grid, .form-grid, .dashboard-grid-top, .login-demo, .print-grid {
    grid-template-columns:1fr;
  }
  .line-item, .line-items[data-lines="sale"] .line-item { grid-template-columns:1fr 1fr; }
  .line-item.header { display:none; }
}
@media (max-width: 640px) {
  .login-body { padding:16px; }
  .login-hero, .topbar, .hero-banner, .card-header, .card-body { padding-left:18px; padding-right:18px; }
  .toolbar-form, .form-actions, .topbar-actions, .hero-banner__actions, .button-group, .button-stack, .inline-form { flex-direction:column; align-items:stretch; }
  .button, .button-secondary, .button-ghost { width:100%; }
}


.stats-grid--alerts { margin-bottom: 0; }
.card-header--stacked { align-items: stretch; flex-direction: column; }
.alert-center-card .card-body { padding-top: 0; }
.alert-filters {
  display:flex; flex-wrap:wrap; gap:10px;
}
.filter-chip {
  display:inline-flex; align-items:center; gap:10px; padding:10px 14px; border-radius:999px;
  background: rgba(255,255,255,.04); border:1px solid var(--border); color:#c9d6e6; font-weight:700;
}
.filter-chip span {
  min-width: 24px; height:24px; padding:0 8px; border-radius:999px; display:inline-grid; place-items:center;
  background: rgba(255,255,255,.08); color:#fff; font-size:.76rem;
}
.filter-chip.is-active {
  background: linear-gradient(180deg, rgba(79,140,255,.18), rgba(79,140,255,.08)); border-color: rgba(79,140,255,.34); color:#fff;
}
.alert-center-list { display:grid; gap:16px; }
.alert-item {
  padding:18px; border-radius:24px; border:1px solid var(--border); background: rgba(255,255,255,.03);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
}
.alert-item--danger { border-color: rgba(255,107,125,.24); background: linear-gradient(180deg, rgba(255,107,125,.08), rgba(255,255,255,.02)); }
.alert-item--warning { border-color: rgba(255,179,71,.20); background: linear-gradient(180deg, rgba(255,179,71,.07), rgba(255,255,255,.02)); }
.alert-item--resolved { opacity: .9; }
.alert-item__head { display:flex; justify-content:space-between; gap:18px; align-items:flex-start; }
.alert-item__badges { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:12px; }
.alert-item h3 { font-size:1.2rem; letter-spacing:-.03em; }
.alert-item__subtitle, .alert-item__footnote { color: var(--muted); margin-top:6px; }
.alert-item__message { margin-top:14px; color:#dbe5f2; line-height:1.6; }
.alert-item__meta { display:flex; gap:10px; flex-wrap:wrap; justify-content:flex-end; }
.alert-item__meta-chip {
  padding:10px 12px; min-width: 145px; border-radius:16px; background: rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.06);
  color:#a9bdd7; font-size:.84rem;
}
.alert-item__meta-chip strong { display:block; margin-top:4px; color:#fff; font-size:.98rem; }
.alert-item__actions { display:flex; gap:10px; flex-wrap:wrap; margin-top:16px; }
.alert-action-form { display:inline-flex; }
.page-panel--alerts { margin-bottom: 0; }
.list-compact--alerts { padding:0 22px 22px; display:grid; gap:12px; }
.list-compact { display:grid; }
.list-compact__item { display:flex; align-items:center; justify-content:space-between; gap:16px; }
.mini-grid--alerts { border-top:1px solid var(--border); }
@media (max-width: 980px) {
  .alert-item__head { flex-direction:column; }
  .alert-item__meta { justify-content:flex-start; }
}

.split-highlight {
  display: grid;
  gap: 18px;
  align-items: center;
  grid-template-columns: minmax(0, 1fr) minmax(300px, .9fr);
}
.split-highlight--stack { grid-template-columns: 1fr; }
.mini-card-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.mini-card-grid--four { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.mini-card {
  padding: 18px;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.03);
}
.mini-card span { display:block; color:#8fa5c1; font-size:.82rem; text-transform:uppercase; letter-spacing:.08em; }
.mini-card strong { display:block; margin-top:10px; font-size:1.2rem; }
.mini-card small { display:block; margin-top:6px; color:var(--muted); }
.import-row--premium {
  padding: 18px;
  border-radius: 18px;
  border: 1px dashed var(--border-strong);
  background: rgba(255,255,255,.03);
}
.stacked-badges { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:8px; }
.print-center-grid {
  display:grid;
  gap:14px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.print-center-card {
  display:grid;
  gap:8px;
  padding:18px;
  border-radius:20px;
  border:1px solid var(--border);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  transition: transform .15s ease, border-color .15s ease, background .15s ease;
}
.print-center-card:hover {
  transform: translateY(-2px);
  border-color: rgba(79,140,255,.28);
  background: linear-gradient(180deg, rgba(79,140,255,.12), rgba(255,255,255,.03));
}
.print-center-card strong { font-size: 1rem; }
.print-center-card span { color: var(--muted); line-height: 1.5; }
.ops-note {
  padding: 18px;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.03);
  display:grid;
  gap:12px;
}
.toolbar-form--wide input[type="date"] { width: auto; min-width: 180px; }

@media (max-width: 1200px) {
  .mini-card-grid--four,
  .print-center-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 900px) {
  .split-highlight,
  .mini-card-grid,
  .mini-card-grid--four,
  .print-center-grid { grid-template-columns: 1fr; }
}


.branch-scope-form{display:flex;flex-direction:column;gap:6px;min-width:220px}.branch-scope-form label{font-size:11px;color:var(--text-muted,#9fb0c8)}.branch-scope-form select{background:#0f1c32;border:1px solid #25385a;color:#fff;border-radius:12px;padding:10px 12px}.checkbox-inline{display:flex;align-items:center;gap:10px;font-weight:600}.topbar .branch-scope-form{margin-right:6px}.table-branch-chip{font-size:11px;padding:4px 8px;border-radius:999px;background:#10233f;color:#dce8ff;display:inline-block}

/* ===== Multi-sucursal premium polish ===== */
.branch-scope-form {
  min-width: 250px;
  padding: 12px 14px;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}
.branch-scope-form label {
  display:block;
  margin-bottom: 8px;
  color:#b8c8dd;
  font-size:.78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .12em;
}
.branch-scope-form select {
  min-width: 220px;
  background: rgba(9,16,29,.92);
}
.scope-chip {
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-top: 12px;
  padding: 10px 14px;
  border-radius: 999px;
  border:1px solid rgba(79,140,255,.24);
  background: rgba(79,140,255,.12);
  color:#dce9ff;
  font-size:.86rem;
  font-weight:700;
}
.scope-chip__dot {
  width:10px; height:10px; border-radius:50%;
  background: linear-gradient(135deg, #2bd576, #4f8cff);
  box-shadow: 0 0 0 4px rgba(79,140,255,.14);
}
.branch-overview-grid,
.transfer-overview-grid {
  display:grid;
  gap:16px;
  grid-template-columns: repeat(3, minmax(0,1fr));
}
.branch-overview-card,
.transfer-panel,
.branch-summary-card {
  padding: 18px;
  border-radius: 22px;
  border: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  box-shadow: var(--shadow-sm);
}
.branch-overview-card span,
.transfer-panel span,
.branch-summary-card span {
  display:block;
  color:#96aac5;
  font-size:.78rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.12em;
}
.branch-overview-card strong,
.transfer-panel strong,
.branch-summary-card strong {
  display:block;
  margin-top:10px;
  font-size:1.5rem;
  letter-spacing:-.04em;
}
.branch-overview-card small,
.transfer-panel small,
.branch-summary-card small {
  display:block;
  margin-top:8px;
  color:var(--muted);
  line-height:1.5;
}
.branch-code {
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border-radius:999px;
  background: rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.06);
  font-size:.77rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.branch-row {
  display:grid;
  gap:12px;
}
.branch-row__meta {
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:8px;
}
.table-highlight {
  background: linear-gradient(180deg, rgba(79,140,255,.10), rgba(79,140,255,.04));
}
.transfer-layout {
  display:grid;
  gap:20px;
  grid-template-columns: minmax(0,1.2fr) minmax(300px,.8fr);
}
.transfer-panel ul {
  margin: 12px 0 0;
  padding-left: 18px;
  color: var(--muted);
}
.transfer-panel li { margin-bottom: 8px; }
.stat-card__inline {
  display:flex;
  justify-content:space-between;
  gap:10px;
  align-items:flex-start;
}
.stat-card__inline .badge { margin-left: auto; }
.metric-pill-row {
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top: 12px;
}
.metric-pill {
  padding: 10px 12px;
  border-radius: 16px;
  background: rgba(255,255,255,.04);
  border:1px solid var(--border);
  min-width: 132px;
}
.metric-pill span {
  display:block;
  font-size:.72rem;
  text-transform:uppercase;
  color:#89a0bf;
  letter-spacing:.09em;
}
.metric-pill strong {
  display:block;
  margin-top:6px;
  font-size:1rem;
}
.branch-performance-grid {
  display:grid;
  gap:16px;
  grid-template-columns: repeat(3, minmax(0,1fr));
  margin-bottom: 18px;
}
.branch-performance-card {
  padding:18px;
  border-radius:22px;
  border:1px solid var(--border);
  background: linear-gradient(180deg, rgba(79,140,255,.08), rgba(255,255,255,.02));
}
.branch-performance-card h3 {
  font-size:1.06rem;
  margin-bottom:10px;
  letter-spacing:-.02em;
}
.branch-performance-card__stats {
  display:grid;
  gap:10px;
  grid-template-columns: repeat(2, minmax(0,1fr));
}
.branch-performance-card__stats div {
  padding: 12px;
  border-radius: 16px;
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.05);
}
.branch-performance-card__stats span {
  display:block;
  font-size:.72rem;
  text-transform:uppercase;
  color:#8da2c1;
  letter-spacing:.08em;
}
.branch-performance-card__stats strong {
  display:block;
  margin-top:6px;
  font-size:1rem;
}
@media (max-width: 1180px) {
  .transfer-layout,
  .branch-performance-grid,
  .branch-overview-grid,
  .transfer-overview-grid { grid-template-columns: 1fr; }
}


.permissions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-top:4px}
.permission-item{display:flex;align-items:flex-start;gap:10px;padding:14px;border:1px solid rgba(255,255,255,.08);border-radius:16px;background:rgba(8,20,43,.68);cursor:pointer}
.permission-item input{margin-top:4px;accent-color:#4f7cff}
.permission-item strong{display:block;color:#f8fbff;font-size:.95rem}
.permission-item small{display:block;color:#97a8c6;margin-top:4px}

.permissions-grid--actions{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.permission-item--detail{min-height:88px}
.permission-item--detail small{line-height:1.45}
.sync-chip-row{display:flex;gap:12px;flex-wrap:wrap}
.sync-note-card{padding:18px;border-radius:18px;border:1px solid rgba(255,255,255,.08);background:rgba(8,20,43,.68)}

@media (max-width: 1500px) { .stats-grid--premium { grid-template-columns: repeat(3, minmax(0,1fr)); } }
@media (max-width: 1100px) { .stats-grid--premium { grid-template-columns: repeat(2, minmax(0,1fr)); } }


.form-group select,
.toolbar-form select,
.inline-form select {
  min-height: 52px;
}

@supports selector(::-webkit-scrollbar) {
  .table-wrap::-webkit-scrollbar,
  .sidebar-nav::-webkit-scrollbar,
  .card-body::-webkit-scrollbar {
    width: 10px;
    height: 10px;
  }

  .table-wrap::-webkit-scrollbar-thumb,
  .sidebar-nav::-webkit-scrollbar-thumb,
  .card-body::-webkit-scrollbar-thumb {
    background: rgba(157, 176, 199, .24);
    border-radius: 999px;
    border: 2px solid transparent;
    background-clip: padding-box;
  }
}
