:root {
    --primary: #0F2D52;
    --primary-2: #1F4E79;
    --accent: #D9A404;
    --accent-soft: #F2C94C;
    --bg: #F5F7FB;
    --card: #FFFFFF;
    --text: #1E293B;
    --muted: #64748B;
    --border: #E2E8F0;
    --danger: #B42318;
    --success: #027A48;
    --warning: #B54708;
    --shadow: 0 16px 32px rgba(15, 45, 82, 0.08);
    --radius: 18px;
}
* { box-sizing: border-box; }
body {
    margin: 0;
    font-family: Arial, Helvetica, sans-serif;
    background: var(--bg);
    color: var(--text);
}
a { color: inherit; text-decoration: none; }
.login-body {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #0f2d52 0%, #173e6d 40%, #f5f7fb 40%, #f5f7fb 100%);
    padding: 24px;
}
.login-wrapper {
    width: min(1100px, 100%);
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 24px;
}
.login-card {
    background: var(--card);
    border-radius: 24px;
    box-shadow: var(--shadow);
    padding: 36px;
}
.brand-panel {
    background: linear-gradient(180deg, #0f2d52 0%, #173e6d 100%);
    color: #fff;
}
.login-logo { width: 110px; margin-bottom: 20px; }
.brand-list { margin: 24px 0 0; padding-left: 18px; line-height: 1.8; }
.form-panel-header h2 { margin: 0 0 8px; }
.login-form { display: grid; gap: 14px; }
.login-form label { font-weight: 700; color: var(--primary); }
.login-form input {
    height: 50px; border: 1px solid var(--border); border-radius: 14px; padding: 0 14px; font-size: 15px;
}
.btn-primary, .quick-btn {
    background: var(--primary);
    color: #fff;
    border: none;
    border-radius: 14px;
    padding: 13px 18px;
    font-weight: 700;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.quick-btn.secondary { background: var(--accent); color: #1a1a1a; }
.alert {
    border-radius: 14px; padding: 14px 16px; margin-bottom: 18px; font-weight: 700;
}
.alert-success { background: #ecfdf3; color: var(--success); }
.alert-error { background: #fef3f2; color: var(--danger); }
.app-shell { display: grid; grid-template-columns: 280px 1fr; min-height: 100vh; }
.sidebar {
    background: linear-gradient(180deg, #0f2d52 0%, #163960 100%);
    color: #fff;
    padding: 24px 18px;
    display: flex;
    flex-direction: column;
}
.brand-box {
    display: flex; gap: 12px; align-items: center; padding: 8px 10px 24px; border-bottom: 1px solid rgba(255,255,255,.12);
}
.brand-logo { width: 52px; height: 52px; object-fit: contain; }
.brand-box h1 { font-size: 18px; margin: 0; }
.brand-box span { font-size: 12px; opacity: 0.8; }
.sidebar-nav { padding-top: 20px; }
.nav-group {
    margin: 18px 10px 8px; text-transform: uppercase; font-size: 11px; letter-spacing: 0.08em; color: rgba(255,255,255,.65);
}
.nav-link {
    display: block; padding: 13px 14px; border-radius: 14px; margin: 4px 0; color: rgba(255,255,255,.92); font-weight: 700;
}
.nav-link:hover, .nav-link.active { background: rgba(255,255,255,.12); }
.app-content { display: flex; flex-direction: column; }
.topbar {
    background: #fff;
    border-bottom: 1px solid var(--border);
    padding: 18px 28px;
    display: flex;
    justify-content: space-between;
    gap: 18px;
    align-items: center;
}
.page-title { margin: 0; font-size: 24px; color: var(--primary); }
.page-subtitle { margin: 6px 0 0; color: var(--muted); }
.topbar-right { display: flex; align-items: center; gap: 18px; }
.quick-links { display: flex; gap: 10px; }
.user-box {
    display: flex; align-items: center; gap: 12px; padding: 8px 12px; border: 1px solid var(--border); border-radius: 18px; background: #fff;
}
.user-avatar {
    width: 42px; height: 42px; border-radius: 50%; background: var(--primary); color: #fff; display: grid; place-items: center; font-weight: 700;
}
.user-meta { display: flex; flex-direction: column; gap: 3px; }
.user-meta span { color: var(--muted); font-size: 13px; }
.logout-link { color: var(--danger); font-weight: 700; }
.page-wrapper { padding: 26px; display: grid; gap: 24px; }
.stats-grid {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 18px;
}
.stat-card {
    background: var(--card); border-radius: var(--radius); padding: 20px; box-shadow: var(--shadow); border-left: 5px solid var(--primary);
}
.stat-card.warning { border-left-color: var(--warning); }
.stat-card.success { border-left-color: var(--success); }
.stat-card.danger { border-left-color: var(--danger); }
.stat-card span { display: block; color: var(--muted); margin-bottom: 10px; font-size: 14px; }
.stat-card strong { font-size: 28px; color: var(--primary); }
.charts-grid {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 18px;
}
.chart-card.wide-full { grid-column: 1 / -1; }
.panel-card {
    background: var(--card); border-radius: var(--radius); padding: 22px; box-shadow: var(--shadow);
}
.panel-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }
.panel-header.between h3, .panel-header h3 { margin: 0; color: var(--primary); }
.dashboard-lower-grid {
    display: grid; grid-template-columns: 2fr 1fr; gap: 18px;
}
.table-responsive { overflow-x: auto; }
.data-table { width: 100%; border-collapse: collapse; }
.data-table th, .data-table td { padding: 13px 12px; border-bottom: 1px solid var(--border); text-align: left; }
.data-table th { color: var(--muted); font-size: 13px; text-transform: uppercase; }
.quick-actions-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
}
.action-tile {
    display: flex; align-items: center; justify-content: center; min-height: 92px; border-radius: 16px; background: #f8fafc; border: 1px solid var(--border); font-weight: 700; color: var(--primary);
}
.action-tile:hover { background: #eef4fb; }
@media (max-width: 1100px) {
    .charts-grid, .dashboard-lower-grid, .login-wrapper, .app-shell { grid-template-columns: 1fr; }
    .sidebar { min-height: auto; }
}
@media (max-width: 700px) {
    .topbar, .topbar-right, .quick-links, .user-box { flex-direction: column; align-items: stretch; }
    .page-wrapper { padding: 18px; }
    .login-card { padding: 24px; }
}


.filter-bar, .form-grid, .info-grid { display:grid; gap:14px; }
.filter-bar { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); align-items:end; }
.form-grid { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.form-grid .full, .info-grid .full { grid-column: 1 / -1; }
.form-field { display:grid; gap:8px; }
.form-field label { font-weight:700; color: var(--primary); }
.form-field input, .form-field select, .form-field textarea {
    width:100%; min-height:48px; border:1px solid var(--border); border-radius:14px; padding:12px 14px; font-size:14px; background:#fff;
}
.form-field textarea { min-height:110px; resize:vertical; }
.form-actions { display:flex; gap:12px; flex-wrap:wrap; margin-top:8px; }
.btn-outline { background:#fff; color:var(--primary); border:1px solid var(--primary); border-radius:14px; padding:13px 18px; font-weight:700; }
.btn-danger { background:var(--danger); color:#fff; border:none; border-radius:14px; padding:13px 18px; font-weight:700; }
.inline-form { display:inline-block; }
.tag { display:inline-flex; align-items:center; padding:6px 10px; border-radius:999px; font-size:12px; font-weight:700; background:#edf2f7; color:var(--primary); }
.muted { color:var(--muted); }
.card-grid-2 { display:grid; grid-template-columns: 2fr 1fr; gap:18px; }
.code-box { background:#0f172a; color:#fff; padding:14px; border-radius:14px; overflow:auto; font-size:13px; }
.kpi-box { background:#f8fafc; border:1px solid var(--border); border-radius:16px; padding:16px; }
.kpi-box strong { font-size:22px; color:var(--primary); }
.empty-state { padding:18px; text-align:center; color:var(--muted); background:#f8fafc; border:1px dashed var(--border); border-radius:16px; }
.autocomplete-list { position:relative; }
.autocomplete-menu { position:absolute; top:100%; left:0; right:0; background:#fff; border:1px solid var(--border); border-radius:14px; box-shadow: var(--shadow); z-index:20; max-height:220px; overflow:auto; }
.autocomplete-option { padding:12px 14px; cursor:pointer; }
.autocomplete-option:hover { background:#f8fafc; }
.status-dot { width:10px; height:10px; border-radius:50%; display:inline-block; margin-right:8px; }
.gallery-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap:14px; }
.gallery-item { border:1px solid var(--border); border-radius:16px; padding:10px; background:#fff; }
.gallery-item img { width:100%; height:140px; object-fit:cover; border-radius:12px; background:#f1f5f9; }
.topbar-stats { display:flex; gap:12px; flex-wrap:wrap; }
.topbar-chip { background:#f8fafc; border:1px solid var(--border); border-radius:999px; padding:8px 12px; font-size:12px; font-weight:700; color:var(--primary); }
@media (max-width: 1100px) { .card-grid-2 { grid-template-columns:1fr; } }

.mini-list { display:grid; gap:10px; }
.mini-list-item { display:flex; justify-content:space-between; align-items:center; padding:12px 14px; border:1px solid var(--border); border-radius:14px; background:#f8fafc; }
.separator { border:none; border-top:1px solid var(--border); margin:18px 0; }
.table-actions { display:flex; gap:8px; flex-wrap:wrap; }
canvas { width:100% !important; min-height:280px; }


.qr-wrap{display:grid;grid-template-columns:220px 1fr;gap:18px;align-items:center}.qr-preview{width:220px;max-width:100%;border:1px solid #d8e2ef;border-radius:16px;background:#fff;padding:12px}.timeline-list{display:grid;gap:14px}.timeline-item{display:grid;grid-template-columns:18px 1fr;gap:14px;align-items:start}.timeline-dot{width:14px;height:14px;border-radius:999px;margin-top:8px;background:#94a3b8}.timeline-content{border:1px solid #dbe5f0;border-radius:14px;padding:14px;background:#fff}.timeline-top{display:flex;justify-content:space-between;gap:12px;margin-bottom:6px}.timeline-item.success .timeline-dot{background:#16a34a}.timeline-item.warning .timeline-dot{background:#d9a404}.timeline-item.primary .timeline-dot{background:#1f4e79}.timeline-item.danger .timeline-dot{background:#dc2626}.timeline-item.neutral .timeline-dot{background:#64748b}.filter-grid-audit{grid-template-columns:repeat(5,minmax(0,1fr));align-items:end}.audit-pill{display:inline-flex;padding:6px 10px;border-radius:999px;background:#eef4fb;color:#0f2d52;font-size:12px;font-weight:600}.chart-card canvas{min-height:280px;max-height:320px}@media (max-width: 900px){.qr-wrap{grid-template-columns:1fr}.filter-grid-audit{grid-template-columns:1fr}.timeline-top{flex-direction:column}}


