:root {
    --bg-a: #f5f2e8;
    --bg-b: #e8f1ef;
    --paper: #fffef9;
    --ink: #152338;
    --muted: #536476;
    --line: rgba(21, 35, 56, 0.12);
    --brand: #0f766e;
    --brand-alt: #0b4f8a;
    --accent: #c2410c;
    --danger: #b91c1c;
    --shadow-lg: 0 24px 68px rgba(20, 32, 50, 0.16);
    --shadow-md: 0 14px 34px rgba(20, 32, 50, 0.1);
    --radius-xl: 28px;
    --radius-lg: 20px;
    --radius-md: 14px;
    --radius-sm: 10px;
    --shell-max: 1640px;
    --shell-gutter: clamp(10px, 2.2vw, 30px);
}

* {
    box-sizing: border-box;
}

body {
    margin: 0;
    min-height: 100vh;
    color: var(--ink);
    font-family: "Outfit", sans-serif;
    background:
        radial-gradient(circle at 12% 14%, rgba(194, 65, 12, 0.2), transparent 36%),
        radial-gradient(circle at 88% 12%, rgba(11, 79, 138, 0.18), transparent 31%),
        radial-gradient(circle at 78% 84%, rgba(15, 118, 110, 0.18), transparent 32%),
        linear-gradient(142deg, var(--bg-a), var(--bg-b));
    overflow-x: hidden;
}

html[data-auth-state="token"] .login-shell {
    display: none;
}

html[data-auth-state="token"] .app-shell {
    display: block;
}

.ambient {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    background-image:
        linear-gradient(rgba(21, 35, 56, 0.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(21, 35, 56, 0.04) 1px, transparent 1px);
    background-size: 38px 38px;
    -webkit-mask-image: radial-gradient(circle at center, black 44%, transparent 82%);
    mask-image: radial-gradient(circle at center, black 44%, transparent 82%);
}

.noise {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    opacity: 0.08;
    background-image: radial-gradient(circle at 1px 1px, #000 1px, transparent 0);
    background-size: 9px 9px;
}

.login-shell,
.app-shell {
    position: relative;
    z-index: 1;
    width: min(var(--shell-max), calc(100vw - (var(--shell-gutter) * 2)));
    margin: clamp(10px, 1.8vw, 20px) auto;
    border-radius: var(--radius-xl);
    border: 1px solid rgba(255, 255, 255, 0.75);
    background: rgba(255, 255, 255, 0.74);
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    box-shadow: var(--shadow-lg);
    overflow: hidden;
}

.login-shell {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    min-height: calc(100vh - 40px);
}

.login-left,
.login-right {
    padding: clamp(20px, 3.5vw, 44px);
    position: relative;
}

.login-left {
    border-right: 1px solid var(--line);
}

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

.brand {
    display: flex;
    align-items: center;
    gap: 12px;
}

.brand-icon {
    width: 40px;
    height: 40px;
    border-radius: 12px;
    background: linear-gradient(140deg, var(--accent), #ea580c);
    box-shadow: 0 10px 24px rgba(194, 65, 12, 0.35);
    position: relative;
    flex: 0 0 auto;
}

.brand-icon::before,
.brand-icon::after {
    content: "";
    position: absolute;
    left: 8px;
    height: 3px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.8);
}

.brand-icon::before {
    width: 20px;
    top: 10px;
}

.brand-icon::after {
    width: 14px;
    top: 18px;
}

.brand h1,
.sidebar-brand-text strong {
    margin: 0;
    font-family: "Sora", sans-serif;
    font-size: 1.02rem;
    letter-spacing: 0.01em;
}

.brand p,
.sidebar-brand-text span {
    margin: 0;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--muted);
}

.chip {
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-weight: 700;
    color: #115e59;
    border: 1px solid rgba(15, 118, 110, 0.32);
    border-radius: 999px;
    padding: 6px 10px;
    background: rgba(255, 255, 255, 0.9);
}

.hero-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 7px 12px;
    border-radius: 999px;
    background: rgba(11, 79, 138, 0.12);
    color: #0b4f8a;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-weight: 700;
}

.hero-eyebrow::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: var(--brand-alt);
}

.hero-title {
    margin: 18px 0 12px;
    font-family: "Sora", sans-serif;
    font-size: clamp(2rem, 4.6vw, 3.8rem);
    line-height: 0.95;
    max-width: 14ch;
    letter-spacing: -0.02em;
}

.hero-title span {
    color: var(--brand-alt);
    position: relative;
}

.hero-title span::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0.08em;
    height: 0.18em;
    border-radius: 4px;
    background: rgba(15, 118, 110, 0.25);
    z-index: -1;
}

.hero-sub {
    margin: 0;
    max-width: 58ch;
    color: var(--muted);
    line-height: 1.75;
}

.metric-grid {
    margin-top: 24px;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.metric,
.card,
.sidebar-stat,
.app-card {
    border-radius: var(--radius-md);
    border: 1px solid var(--line);
    background: linear-gradient(130deg, rgba(255, 255, 255, 0.95), rgba(245, 249, 250, 0.7));
    box-shadow: var(--shadow-md);
}

.metric {
    padding: 12px;
}

.metric small,
.card-title,
.sidebar-stat small {
    display: block;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.65rem;
    margin-bottom: 8px;
    font-weight: 700;
}

.metric strong,
.card-value,
.sidebar-stat strong {
    font-family: "Sora", sans-serif;
    font-size: 1.18rem;
    margin: 0;
}

.signal-board {
    margin-top: 16px;
    display: grid;
    gap: 8px;
}

.signal-item {
    border-radius: var(--radius-sm);
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.8);
    padding: 9px 11px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.83rem;
}

.signal-state,
.pill {
    font-size: 0.66rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.09em;
    border-radius: 999px;
    padding: 4px 8px;
    display: inline-block;
}

.signal-state,
.pill.ok {
    color: #115e59;
    background: rgba(15, 118, 110, 0.15);
    border: 1px solid rgba(15, 118, 110, 0.28);
}

.pill.warn {
    color: #9a3412;
    background: rgba(194, 65, 12, 0.14);
    border: 1px solid rgba(194, 65, 12, 0.28);
}

.login-card {
    border-radius: var(--radius-lg);
    border: 1px solid var(--line);
    background: var(--paper);
    box-shadow: var(--shadow-md);
    padding: 22px;
    position: sticky;
    top: 24px;
}

.login-card h2 {
    margin: 0 0 8px;
    font-family: "Sora", sans-serif;
    font-size: 1.5rem;
}

.login-card p,
.hint,
#headerSubtitle,
.subtext,
.empty,
.app-meta {
    color: var(--muted);
    line-height: 1.6;
}

.login-card p {
    margin: 0 0 18px;
    font-size: 0.92rem;
}

.hint-box {
    margin-top: 14px;
    border-radius: 12px;
    border: 1px solid rgba(11, 79, 138, 0.2);
    background: linear-gradient(145deg, rgba(11, 79, 138, 0.08), rgba(15, 118, 110, 0.07));
    padding: 11px 12px;
}

.hint-box strong {
    display: block;
    margin-bottom: 6px;
    font-size: 0.73rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #0b4f8a;
}

.hint-box p {
    margin: 0;
    font-size: 0.83rem;
    line-height: 1.6;
    color: var(--muted);
}

.field {
    margin-bottom: 12px;
}

.crud-form {
    display: grid;
    gap: 8px;
}

.form-grid {
    display: grid;
    gap: 8px;
}

.form-grid.two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.toggle-field {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 0.82rem;
    color: var(--muted);
    margin: 2px 0 6px;
}

.field label {
    display: block;
    font-size: 0.74rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-weight: 700;
    color: #334155;
    margin-bottom: 7px;
}

.field input,
.field select,
.search {
    width: 100%;
    border: 1px solid rgba(21, 35, 56, 0.2);
    border-radius: 11px;
    background: #fff;
    padding: 11px 12px;
    font-size: 0.93rem;
    font-family: inherit;
    transition: box-shadow 160ms ease, border-color 160ms ease;
}

.field input:focus,
.field select:focus,
.search:focus {
    outline: none;
    border-color: rgba(11, 79, 138, 0.55);
    box-shadow: 0 0 0 3px rgba(11, 79, 138, 0.16);
}

.btn-primary,
.btn-ghost,
.btn-danger,
.icon-btn {
    border: 0;
    border-radius: 11px;
    padding: 10px 12px;
    font-size: 0.84rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    cursor: pointer;
    transition: transform 130ms ease, box-shadow 130ms ease;
    font-family: "Outfit", sans-serif;
}

.btn-primary.compact {
    width: auto;
    padding: 8px 12px;
    font-size: 0.76rem;
}

.icon-btn {
    border: 1px solid rgba(21, 35, 56, 0.2);
    background: rgba(255, 255, 255, 0.85);
    min-width: 38px;
    height: 38px;
    padding: 0 10px;
}

.btn-primary {
    width: 100%;
    color: #fff;
    background: linear-gradient(125deg, var(--brand-alt), var(--brand), var(--accent));
    background-size: 180% 180%;
    box-shadow: 0 10px 22px rgba(11, 79, 138, 0.3);
    animation: pulseBg 6s ease-in-out infinite;
}

.btn-ghost {
    color: var(--ink);
    border: 1px solid rgba(21, 35, 56, 0.24);
    background: rgba(255, 255, 255, 0.85);
}

.btn-danger {
    color: #fff;
    background: linear-gradient(120deg, #dc2626, #b91c1c);
    box-shadow: 0 10px 20px rgba(185, 28, 28, 0.2);
}

.btn-primary:hover,
.btn-ghost:hover,
.btn-danger:hover,
.icon-btn:hover {
    transform: translateY(-1px);
}

.message {
    margin-top: 12px;
    border-radius: 10px;
    border: 1px solid transparent;
    padding: 9px 11px;
    font-size: 0.84rem;
    display: none;
}

.message.ok {
    color: #065f46;
    background: rgba(15, 118, 110, 0.11);
    border-color: rgba(15, 118, 110, 0.24);
}

.message.err {
    color: #991b1b;
    background: rgba(220, 38, 38, 0.1);
    border-color: rgba(185, 28, 28, 0.24);
}

.app-shell {
    display: none;
    min-height: calc(100vh - 40px);
}

.app-layout {
    display: grid;
    grid-template-columns: clamp(264px, 18vw, 320px) 1fr;
    min-height: calc(100vh - 40px);
    position: relative;
}

.sidebar {
    border-right: 1px solid var(--line);
    padding: 18px 16px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.78), rgba(255, 255, 255, 0.5));
    transition: width 220ms ease, transform 220ms ease;
    width: clamp(264px, 18vw, 320px);
}

.sidebar.collapsed {
    width: 88px;
}

.sidebar.collapsed .sidebar-brand-text,
.sidebar.collapsed .menu-btn span,
.sidebar.collapsed .menu-btn strong,
.sidebar.collapsed .sidebar-foot {
    display: none;
}

.sidebar.collapsed .menu-btn {
    min-height: 44px;
}

.sidebar-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    margin-bottom: 18px;
}

.menu-list {
    display: grid;
    gap: 7px;
}

.menu-btn {
    width: 100%;
    border: 1px solid transparent;
    background: transparent;
    border-radius: 12px;
    padding: 10px 12px;
    text-align: left;
    display: grid;
    gap: 3px;
    cursor: pointer;
    transition: all 150ms ease;
}

/* Default aman: sebelum data role siap, tampilkan dashboard saja. */
.menu-list .menu-btn {
    display: none;
}

.menu-list .menu-btn[data-section="dashboardSection"] {
    display: grid;
}

body.rbac-ready .menu-list .menu-btn {
    display: grid;
}

body.rbac-ready .menu-list .menu-btn.is-hidden-by-role {
    display: none;
}

.menu-btn strong {
    font-size: 0.88rem;
    color: var(--ink);
    font-weight: 700;
}

.menu-btn span {
    font-size: 0.76rem;
    color: var(--muted);
}

.menu-btn:hover {
    border-color: rgba(21, 35, 56, 0.18);
    background: rgba(255, 255, 255, 0.8);
}

.menu-btn.active {
    border-color: rgba(11, 79, 138, 0.36);
    background: linear-gradient(135deg, rgba(11, 79, 138, 0.14), rgba(15, 118, 110, 0.13));
}

.sidebar-foot {
    margin-top: 16px;
    border-top: 1px dashed rgba(21, 35, 56, 0.2);
    padding-top: 12px;
    display: grid;
    gap: 8px;
}

.sidebar-stats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}

.sidebar-stat {
    padding: 8px;
}

.main {
    display: grid;
    grid-template-rows: auto 1fr;
    min-width: 0;
}

.topbar {
    border-bottom: 1px solid var(--line);
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
    padding: clamp(12px, 1.6vw, 18px) clamp(14px, 2vw, 24px);
    background: rgba(255, 255, 255, 0.62);
}

.top-left {
    display: flex;
    align-items: center;
    gap: 10px;
}

.topbar h2 {
    margin: 0;
    font-family: "Sora", sans-serif;
    font-size: 1.05rem;
}

#headerSubtitle {
    margin: 2px 0 0;
    font-size: 0.82rem;
}

.top-actions {
    display: flex;
    gap: 8px;
    align-items: center;
}

.search {
    min-width: 230px;
}

.content {
    padding: clamp(14px, 1.8vw, 24px);
    min-width: 0;
    overflow: auto;
}

.section {
    display: none;
    animation: fadeIn 260ms ease;
}

.section.active {
    display: block;
}

.grid-4,
.grid-3,
.grid-2,
.apps-grid {
    display: grid;
    gap: 10px;
    margin-bottom: 10px;
}

.grid-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

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

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

.apps-grid {
    grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
    gap: 9px;
}

.card {
    padding: 14px;
    min-width: 0;
}

.table-wrap {
    overflow: auto;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.8);
}

table {
    width: 100%;
    border-collapse: collapse;
    min-width: 700px;
}

th,
td {
    padding: 11px 10px;
    border-bottom: 1px solid rgba(21, 35, 56, 0.08);
    text-align: left;
    font-size: 0.82rem;
    vertical-align: top;
}

th {
    font-size: 0.7rem;
    letter-spacing: 0.09em;
    text-transform: uppercase;
    color: var(--muted);
}

.action-link {
    border: 1px solid rgba(11, 79, 138, 0.26);
    color: #0b4f8a;
    background: linear-gradient(120deg, rgba(11, 79, 138, 0.14), rgba(15, 118, 110, 0.12));
    border-radius: 8px;
    padding: 5px 8px;
    font-size: 0.72rem;
    font-weight: 700;
    cursor: pointer;
    margin-right: 4px;
    margin-bottom: 4px;
    transition: transform 120ms ease, box-shadow 120ms ease;
}

.action-link:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 12px rgba(11, 79, 138, 0.14);
}

.action-link:disabled {
    opacity: 0.45;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

.action-link.warn {
    color: #9a3412;
    border-color: rgba(194, 65, 12, 0.28);
    background: linear-gradient(120deg, rgba(194, 65, 12, 0.16), rgba(234, 88, 12, 0.1));
}

.section-header-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    margin-bottom: 8px;
}

.section-inline-actions {
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
    margin-bottom: 12px;
}

.section-inline-actions .btn-primary {
    width: auto;
}

.pagination-bar {
    margin-top: 10px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.pagination-meta {
    font-size: 0.78rem;
    color: var(--muted);
}

.pagination-actions {
    display: flex;
    gap: 6px;
    align-items: center;
}

.pagination-actions button {
    border: 1px solid rgba(21, 35, 56, 0.2);
    background: rgba(255, 255, 255, 0.84);
    border-radius: 8px;
    padding: 6px 9px;
    font-size: 0.75rem;
    font-weight: 700;
    cursor: pointer;
}

.pagination-actions select {
    border: 1px solid rgba(21, 35, 56, 0.2);
    background: rgba(255, 255, 255, 0.92);
    border-radius: 8px;
    padding: 6px 8px;
    font-size: 0.74rem;
    font-weight: 700;
    color: #1b2430;
}

.pagination-actions button:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}

.modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.45);
    opacity: 0;
    pointer-events: none;
    transition: opacity 180ms ease;
    z-index: 20;
}

.modal-overlay.show {
    opacity: 1;
    pointer-events: auto;
}

.crud-modal,
.confirm-modal {
    position: fixed;
    border-radius: 14px;
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.98);
    box-shadow: 0 26px 58px rgba(15, 23, 42, 0.22);
    opacity: 0;
    pointer-events: none;
    transition: opacity 220ms ease, transform 300ms cubic-bezier(0.2, 0.9, 0.2, 1);
    z-index: 21;
}

.crud-modal {
    position: absolute;
    top: 0;
    right: 0;
    width: min(480px, 96vw);
    height: 100%;
    border-left: 1px solid var(--line);
    border-radius: 0;
    background: rgba(255, 255, 255, 0.95);
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
    box-shadow: -20px 0 42px rgba(15, 23, 42, 0.12);
    transform: translateX(100%);
    transition: transform 230ms ease;
    display: flex;
    flex-direction: column;
    z-index: 22;
}

.confirm-modal {
    top: 50%;
    left: 50%;
    width: min(620px, 94vw);
    transform: translate(-50%, -48%) scale(0.98);
}

.crud-modal.open,
.confirm-modal.open {
    opacity: 1;
    pointer-events: auto;
}

.crud-modal.open {
    transform: translateX(0);
}

.confirm-modal.open {
    transform: translate(-50%, -50%) scale(1);
}

.crud-modal-head {
    padding: 12px 14px;
    border-bottom: 1px solid var(--line);
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 10px;
}

.crud-modal-body {
    padding: 14px;
    display: grid;
    gap: 10px;
    max-height: 100%;
    overflow: auto;
}

.crud-modal-body.is-submitting {
    pointer-events: none;
    opacity: 0.7;
}

.btn-primary.is-loading {
    position: relative;
    padding-right: 34px;
}

.btn-primary.is-loading::after {
    content: "";
    position: absolute;
    right: 10px;
    top: 50%;
    width: 12px;
    height: 12px;
    margin-top: -6px;
    border: 2px solid rgba(255, 255, 255, 0.95);
    border-right-color: transparent;
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

.inline-error {
    margin-top: 5px;
    font-size: 0.72rem;
    color: #991b1b;
    min-height: 1em;
}

.confirm-body {
    padding: 14px;
}

.confirm-actions {
    margin-top: 12px;
    display: flex;
    justify-content: flex-end;
    gap: 8px;
}

.toast-stack {
    position: fixed;
    right: 18px;
    top: 18px;
    z-index: 40;
    display: grid;
    gap: 8px;
    width: min(360px, calc(100vw - 24px));
    pointer-events: none;
}

.toast-item {
    border-radius: 12px;
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 12px 24px rgba(15, 23, 42, 0.18);
    padding: 10px 12px;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 8px;
    align-items: start;
    pointer-events: auto;
    animation: toastIn 260ms ease;
}

.toast-item.ok {
    border-left: 4px solid #0f766e;
}

.toast-item.err {
    border-left: 4px solid #b91c1c;
}

.toast-item p {
    margin: 0;
    font-size: 0.82rem;
    color: #1f2937;
    line-height: 1.5;
}

.toast-close {
    border: 0;
    border-radius: 8px;
    padding: 3px 7px;
    font-size: 0.76rem;
    background: rgba(21, 35, 56, 0.08);
    color: #334155;
    cursor: pointer;
}

.toast-item.leaving {
    animation: toastOut 220ms ease forwards;
}

.app-card {
    --card-accent: #0b4f8a;
    --card-ink: #0b3c66;
    --card-soft: rgba(11, 79, 138, 0.14);
    --card-soft-border: rgba(11, 79, 138, 0.32);
    --card-soft-strong: rgba(11, 79, 138, 0.24);
    padding: 10px;
    display: grid;
    gap: 8px;
    border-radius: 16px;
    border: 1px solid rgba(255, 255, 255, 0.74);
    background:
        radial-gradient(circle at 104% -8%, rgba(11, 79, 138, 0.34), transparent 42%),
        radial-gradient(circle at 2% 104%, rgba(15, 118, 110, 0.3), transparent 46%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(230, 242, 248, 0.92));
    box-shadow:
        0 14px 28px rgba(15, 23, 42, 0.14),
        inset 0 1px 0 rgba(255, 255, 255, 0.9);
    position: relative;
    overflow: hidden;
    isolation: isolate;
    transition: transform 170ms ease, box-shadow 170ms ease, border-color 170ms ease;
}

.app-card-enter {
    opacity: 0;
    transform: translateY(10px) scale(0.985);
    animation: launcherCardIn 520ms cubic-bezier(0.2, 0.75, 0.2, 1) forwards;
    animation-delay: var(--launcher-enter-delay, 0ms);
}

.app-card:hover {
    transform: translateY(-3px);
    border-color: rgba(11, 79, 138, 0.44);
    box-shadow:
        0 18px 34px rgba(11, 79, 138, 0.22),
        inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.app-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(130deg, rgba(255, 255, 255, 0.35), transparent 52%);
    pointer-events: none;
    z-index: -1;
}

.app-card::after {
    content: "";
    position: absolute;
    inset: auto -20px -24px auto;
    width: 92px;
    height: 92px;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(11, 79, 138, 0.24), transparent 70%);
    pointer-events: none;
}

.app-card-asset {
    --card-accent: #0b4f8a;
    --card-ink: #0b3c66;
    --card-soft: rgba(11, 79, 138, 0.14);
    --card-soft-border: rgba(11, 79, 138, 0.32);
    --card-soft-strong: rgba(11, 79, 138, 0.24);
}

.app-card-sustain {
    --card-accent: #0f766e;
    --card-ink: #0d5b56;
    --card-soft: rgba(15, 118, 110, 0.14);
    --card-soft-border: rgba(15, 118, 110, 0.32);
    --card-soft-strong: rgba(15, 118, 110, 0.24);
    --card-glow-a: rgba(15, 118, 110, 0.42);
    --card-glow-b: rgba(22, 101, 52, 0.28);
    --card-bg-b: rgba(227, 245, 238, 0.94);
}

.app-card-finance {
    --card-accent: #1d4ed8;
    --card-ink: #163fba;
    --card-soft: rgba(29, 78, 216, 0.14);
    --card-soft-border: rgba(29, 78, 216, 0.32);
    --card-soft-strong: rgba(29, 78, 216, 0.24);
    --card-glow-a: rgba(29, 78, 216, 0.42);
    --card-glow-b: rgba(14, 116, 144, 0.26);
    --card-bg-b: rgba(227, 240, 255, 0.94);
}

.app-card-people {
    --card-accent: #b45309;
    --card-ink: #8c3f07;
    --card-soft: rgba(180, 83, 9, 0.16);
    --card-soft-border: rgba(180, 83, 9, 0.34);
    --card-soft-strong: rgba(180, 83, 9, 0.24);
    --card-glow-a: rgba(194, 65, 12, 0.42);
    --card-glow-b: rgba(161, 98, 7, 0.28);
    --card-bg-b: rgba(255, 240, 223, 0.95);
}

.app-card-ops {
    --card-accent: #1f2937;
    --card-ink: #1f2937;
    --card-soft: rgba(31, 41, 55, 0.15);
    --card-soft-border: rgba(31, 41, 55, 0.3);
    --card-soft-strong: rgba(31, 41, 55, 0.22);
    --card-glow-a: rgba(31, 41, 55, 0.38);
    --card-glow-b: rgba(30, 64, 175, 0.22);
    --card-bg-b: rgba(229, 235, 242, 0.95);
}

.app-card-custom {
    border-color: rgba(194, 65, 12, 0.34);
    --card-accent: #c2410c;
    --card-ink: #9a3412;
    --card-soft: rgba(194, 65, 12, 0.15);
    --card-soft-border: rgba(194, 65, 12, 0.36);
    --card-soft-strong: rgba(194, 65, 12, 0.26);
    --card-glow-a: rgba(194, 65, 12, 0.4);
    --card-glow-b: rgba(234, 88, 12, 0.28);
    --card-bg-b: rgba(255, 241, 230, 0.94);
}

.app-head {
    display: flex;
    align-items: flex-start;
    gap: 8px;
}

.app-title-block {
    display: grid;
    gap: 6px;
    min-width: 0;
    flex: 1 1 auto;
}

.app-icon {
    width: 34px;
    height: 34px;
    border-radius: 9px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.58rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    color: #fff;
    box-shadow: 0 6px 12px rgba(15, 23, 42, 0.16);
    flex: 0 0 auto;
    overflow: hidden;
    position: relative;
}

.app-icon-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.app-monogram {
    width: 100%;
    height: 100%;
    display: grid;
    place-items: center;
    position: relative;
    padding-top: 1px;
}

.app-monogram-main {
    font-size: 0.58rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    line-height: 1;
}

.app-monogram-sub {
    position: absolute;
    right: 3px;
    bottom: 2px;
    font-size: 0.4rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    line-height: 1;
    color: rgba(255, 255, 255, 0.88);
    background: rgba(15, 23, 42, 0.28);
    border: 1px solid rgba(255, 255, 255, 0.24);
    border-radius: 5px;
    padding: 1px 2px;
}

.app-icon.asset {
    background: linear-gradient(130deg, #0f766e, #0b4f8a);
}

.app-icon.sustain {
    background: linear-gradient(130deg, #166534, #0f766e);
}

.app-icon.finance {
    background: linear-gradient(130deg, #1d4ed8, #0b4f8a);
}

.app-icon.people {
    background: linear-gradient(130deg, #a16207, #c2410c);
}

.app-icon.ops {
    background: linear-gradient(130deg, #1f2937, #0f172a);
}

.app-icon.security {
    background: linear-gradient(130deg, #7f1d1d, #991b1b);
}

.app-icon.data {
    background: linear-gradient(130deg, #0f766e, #0891b2);
}

.app-icon.academic {
    background: linear-gradient(130deg, #6d28d9, #4f46e5);
}

.app-icon.default {
    background: linear-gradient(130deg, #475569, #0b4f8a);
}

.app-name {
    margin: 0;
    font-weight: 800;
    font-size: 0.83rem;
    line-height: 1.3;
    max-width: none;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
}

.app-chip-row {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}

.app-role-badge {
    font-size: 0.54rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--card-accent);
    border: 1px solid var(--card-soft-border);
    border-radius: 999px;
    background: var(--card-soft);
    padding: 3px 6px;
    white-space: nowrap;
    display: inline-flex;
    align-items: center;
    line-height: 1;
    flex: 0 0 auto;
}

.app-code-badge {
    font-size: 0.53rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    color: #334155;
    border: 1px solid rgba(71, 85, 105, 0.28);
    border-radius: 999px;
    background: rgba(248, 250, 252, 0.82);
    padding: 3px 6px;
    line-height: 1;
    white-space: nowrap;
}

.app-meta,
.subtext,
.empty {
    margin: 0;
    font-size: 0.72rem;
}

.launch-app-btn {
    width: 100%;
    border: 1px solid var(--card-soft-border);
    border-radius: 11px;
    background: linear-gradient(128deg, rgba(255, 255, 255, 0.82), var(--card-soft));
    color: var(--card-ink);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 7px 10px;
    font-size: 0.72rem;
    font-weight: 700;
    cursor: pointer;
    transition: transform 140ms ease, box-shadow 140ms ease, border-color 140ms ease;
}

.launch-app-btn:hover {
    transform: translateY(-1px);
    border-color: var(--card-accent);
    box-shadow: 0 10px 18px var(--card-soft-strong);
}

.launch-app-label {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.launch-app-arrow {
    width: 18px;
    height: 18px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--card-soft-strong);
    color: var(--card-ink);
    flex: 0 0 auto;
}

.empty {
    border: 1px dashed rgba(21, 35, 56, 0.2);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.6);
    padding: 14px;
    text-align: center;
}

.detail-drawer {
    position: absolute;
    top: 0;
    right: 0;
    width: min(480px, 96vw);
    height: 100%;
    border-left: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.95);
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
    box-shadow: -20px 0 42px rgba(15, 23, 42, 0.12);
    transform: translateX(100%);
    transition: transform 230ms ease;
    z-index: 8;
    display: flex;
    flex-direction: column;
}

.detail-drawer.open {
    transform: translateX(0);
}

.detail-head {
    padding: 14px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    border-bottom: 1px solid var(--line);
}

.detail-kicker {
    margin: 0;
    font-size: 0.67rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--muted);
    font-weight: 700;
}

.detail-title {
    margin: 6px 0 0;
    font-family: "Sora", sans-serif;
    font-size: 1.08rem;
}

.detail-content {
    padding: 14px;
    overflow: auto;
    display: grid;
    gap: 10px;
}

.detail-item {
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 10px;
    background: rgba(255, 255, 255, 0.82);
}

.detail-item small {
    display: block;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.66rem;
    margin-bottom: 6px;
}

.detail-item strong {
    font-size: 0.92rem;
}

.mobile-overlay {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.42);
    opacity: 0;
    pointer-events: none;
    transition: opacity 220ms ease;
    z-index: 6;
}

.mobile-overlay.show {
    opacity: 1;
    pointer-events: auto;
}

.mobile-only {
    display: none;
}

.desktop-only {
    display: inline-flex;
}

@keyframes pulseBg {
    0%,
    100% {
        background-position: 0% 50%;
    }

    50% {
        background-position: 100% 50%;
    }
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(6px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes launcherCardIn {
    from {
        opacity: 0;
        transform: translateY(10px) scale(0.985);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

@keyframes toastIn {
    from {
        opacity: 0;
        transform: translateY(14px) scale(0.94);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

@keyframes toastOut {
    from {
        opacity: 1;
        transform: translateY(0) scale(1);
    }

    to {
        opacity: 0;
        transform: translateY(8px) scale(0.96);
    }
}

@keyframes spin {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(360deg);
    }
}

@media (max-width: 1120px) {
    .login-shell {
        grid-template-columns: 1fr;
    }

    .login-card {
        position: static;
    }

    .login-left {
        border-right: 0;
        border-bottom: 1px solid var(--line);
    }

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

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

@media (max-width: 900px) {
    .app-layout {
        grid-template-columns: 1fr;
    }

    .sidebar {
        position: fixed;
        top: 0;
        left: 0;
        height: 100vh;
        width: min(88vw, 360px);
        transform: translateX(-100%);
        z-index: 7;
        border-right: 1px solid var(--line);
    }

    .sidebar.open {
        transform: translateX(0);
    }

    .mobile-only {
        display: inline-flex;
    }

    .desktop-only {
        display: none;
    }

    .topbar {
        position: sticky;
        top: 0;
        z-index: 5;
    }

    .content {
        padding: 12px;
    }

    .crud-modal {
        width: min(100%, 540px);
    }

    .toast-stack {
        right: 8px;
        top: 8px;
        width: min(100vw - 16px, 360px);
    }
}

@media (max-width: 760px) {
    .login-shell,
    .app-shell {
        width: min(var(--shell-max), calc(100vw - 12px));
        margin: 10px auto;
        border-radius: 18px;
    }

    .login-left,
    .login-right {
        padding: 16px;
    }

    .hero-title {
        font-size: clamp(1.75rem, 8vw, 2.5rem);
        line-height: 1;
    }

    .topbar {
        gap: 10px;
    }

    .top-actions .btn-ghost,
    .top-actions .btn-primary,
    .top-actions .btn-danger {
        min-height: 42px;
    }

    .metric-grid,
    .grid-4,
    .grid-3,
    .grid-2,
    .apps-grid,
    .form-grid.two {
        grid-template-columns: 1fr;
    }

    .section-header-row {
        flex-direction: column;
        align-items: flex-start;
    }

    .pagination-actions {
        width: 100%;
        justify-content: flex-start;
        flex-wrap: wrap;
    }

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

    .top-left {
        align-items: flex-start;
    }

    .top-actions {
        width: 100%;
        flex-wrap: wrap;
    }

    .search {
        width: 100%;
        min-width: 0;
    }

    .sidebar-stats {
        grid-template-columns: 1fr;
    }

    .card {
        padding: 12px;
    }

    th,
    td {
        padding: 10px 8px;
    }
}

@media (max-width: 560px) {
    .brand-row {
        flex-direction: column;
        align-items: flex-start;
        margin-bottom: 18px;
    }

    .chip {
        align-self: flex-start;
    }

    .section-header-row {
        gap: 8px;
    }

    .btn-primary.compact,
    .section-inline-actions .btn-primary {
        width: 100%;
    }

    .top-actions {
        display: grid;
        grid-template-columns: 1fr;
    }

    .pagination-bar {
        align-items: flex-start;
    }

    .pagination-actions button,
    .pagination-actions select {
        min-height: 38px;
    }

    .crud-modal,
    .detail-drawer {
        width: 100%;
    }
}

@media (min-width: 1500px) {
    .grid-4 {
        grid-template-columns: repeat(4, minmax(220px, 1fr));
    }

    .apps-grid {
        grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
    }

    .topbar h2 {
        font-size: 1.14rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    .app-card-enter {
        opacity: 1;
        transform: none;
        animation: none;
    }
}
