/* ===========================================================
   AMS — Asset Management Solution
   Shell theme: sidebar, topbar, dropdowns, content, login.
   Ported from Docs/template/styles.css and adapted for the
   Blazor app (loads after Radzen material.css to override it).
   Theme via the CSS variables in :root below.
   =========================================================== */

:root{
  --a1:#6c5ce7;            /* primary accent (dark) */
  --a2:#9b7bff;            /* primary accent (light) */
  --r:20px;               /* card corner radius */
  --sidebar-w:268px;
  --ink:#1f2433;
  --muted:#8a90a6;
}

/* Base page — override Radzen material.css body defaults */
html,body{margin:0;padding:0;}
body{
  font-family:'Plus Jakarta Sans',sans-serif !important;
  -webkit-font-smoothing:antialiased;
  color:var(--ink);
  background:
    radial-gradient(1100px 560px at 100% -8%, rgba(91,157,255,.12), transparent 60%),
    radial-gradient(900px 520px at -8% 112%, rgba(255,95,143,.12), transparent 60%),
    radial-gradient(800px 600px at 50% 50%, rgba(24,200,169,.05), transparent 70%),
    #edf0f8 !important;
}
.ams-app a{text-decoration:none;color:inherit;}
.ams-app button{font-family:inherit;}
::-webkit-scrollbar{width:9px;height:9px;}
::-webkit-scrollbar-thumb{background:rgba(31,41,80,.18);border-radius:10px;}
::-webkit-scrollbar-track{background:transparent;}

.ams-app{display:flex;min-height:100vh;}
/* border-box for the custom shell so widths match the template (kept off .content to
   avoid disturbing Radzen components' own box model). */
.ams-app .sidebar,.ams-app .sidebar *,.ams-app .sidebar *::before,.ams-app .sidebar *::after,
.ams-app .topbar,.ams-app .topbar *,.ams-app .topbar *::before,.ams-app .topbar *::after{box-sizing:border-box;}

/* ---------- Sidebar ---------- */
.ams-app .sidebar{
  width:var(--sidebar-w);flex:none;
  transition:width .32s cubic-bezier(.4,0,.2,1);
  position:sticky;top:0;align-self:flex-start;height:100vh;
  padding:20px 14px;display:flex;flex-direction:column;gap:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.92) 0%, rgba(255,255,255,.74) 100%);
  backdrop-filter:blur(22px);
  border-right:1px solid rgba(255,255,255,.7);
  box-shadow:14px 0 50px -34px rgba(31,41,80,.5);
  z-index:30;
}
.ams-app .brand{display:flex;align-items:center;gap:12px;padding:6px 8px 4px;}
.ams-app .brand .logo{
  width:42px;height:42px;flex:none;border-radius:14px;
  background:linear-gradient(135deg,var(--a2),var(--a1));
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;
  box-shadow:0 10px 22px -8px color-mix(in srgb, var(--a1) 60%, transparent);
}
.ams-app .brand .name{font-weight:800;font-size:19px;letter-spacing:-.5px;}
.ams-app .brand .tag{font-size:11px;color:#9aa0b4;font-weight:600;letter-spacing:.4px;}

.ams-app .nav{display:flex;flex-direction:column;gap:4px;overflow-y:auto;overflow-x:hidden;flex:1;margin:0 -4px;padding:0 4px;}
.ams-app .nav-title{font-size:11px;font-weight:700;letter-spacing:1px;color:#a9aec0;padding:8px 12px 4px;}
.ams-app .nav-title.mt{padding-top:16px;}
.ams-app .nav-item{
  display:flex;align-items:center;gap:14px;width:100%;
  padding:12px 14px;border-radius:15px;
  font-size:14.5px;font-weight:600;color:#5a6178;
  background:transparent;transition:.2s;cursor:pointer;
}
.ams-app .nav-item i{width:22px;text-align:center;font-size:16px;}
.ams-app .nav-item:hover{background:color-mix(in srgb, var(--a1) 9%, transparent);color:var(--a1);transform:translateX(3px);}
.ams-app .nav-item.active{
  color:#fff;font-weight:700;
  background:linear-gradient(135deg,var(--a2),var(--a1));
  box-shadow:0 12px 26px -10px color-mix(in srgb, var(--a1) 60%, transparent);
}
.ams-app .nav-item.active:hover{transform:none;}

/* collapsible groups + sub-items */
.ams-app .nav-group{display:flex;flex-direction:column;}
.ams-app .nav-group > .nav-item{cursor:pointer;user-select:none;}
.ams-app .nav-chevron{width:auto;margin-left:auto;font-size:12px;color:#b3b8c9;transition:transform .25s;}
.ams-app .nav-group.open > .nav-item .nav-chevron{transform:rotate(180deg);}
.ams-app .nav-sub{
  display:flex;flex-direction:column;gap:2px;overflow:hidden;
  max-height:0;transition:max-height .35s ease;
  margin:2px 0 2px 23px;padding-left:9px;border-left:2px solid rgba(31,41,80,.07);
}
.ams-app .nav-group.open > .nav-sub{max-height:1600px;}
.ams-app .nav-subitem{
  display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:11px;
  font-size:13px;font-weight:500;color:#737a90;transition:.15s;
}
.ams-app .nav-subitem i{width:18px;text-align:center;font-size:13.5px;}
.ams-app .nav-subitem:hover{background:color-mix(in srgb, var(--a1) 8%, transparent);color:var(--a1);transform:translateX(2px);}
.ams-app .nav-subitem.active{color:var(--a1);font-weight:700;background:color-mix(in srgb, var(--a1) 12%, transparent);}

/* ---------- Main / Topbar ---------- */
.ams-app .main{flex:1;min-width:0;display:flex;flex-direction:column;}
.ams-app .topbar{
  position:sticky;top:0;z-index:25;display:flex;align-items:center;gap:18px;
  padding:16px 30px;background:rgba(237,240,248,.72);backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(31,41,80,.06);
}
.ams-app .icon-btn{
  width:42px;height:42px;flex:none;border:1px solid rgba(31,41,80,.07);border-radius:13px;
  background:#fff;color:#4a5168;cursor:pointer;font-size:16px;transition:.2s;
  box-shadow:0 6px 16px -10px rgba(31,41,80,.4);
}
.ams-app .icon-btn:hover{color:var(--a1);transform:translateY(-1px);}
.ams-app .page-head{flex:0 0 auto;min-width:0;overflow:hidden;}
.ams-app .crumb{display:flex;align-items:center;gap:8px;font-size:12px;color:#a0a5b8;font-weight:600;margin-bottom:2px;white-space:nowrap;}
.ams-app .crumb .here{color:var(--a1);}
.ams-app .page-title{font-size:21px;font-weight:800;letter-spacing:-.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ams-app .spacer{flex:1 1 0;min-width:12px;}

.ams-app .tb-action{position:relative;flex:none;}
.ams-app .bell{
  position:relative;width:44px;height:44px;border:1px solid rgba(31,41,80,.07);border-radius:14px;
  background:#fff;color:#4a5168;cursor:pointer;font-size:16px;transition:.2s;
  box-shadow:0 6px 16px -12px rgba(31,41,80,.4);
  display:flex;align-items:center;justify-content:center;
}
.ams-app .bell:hover{color:var(--a1);transform:translateY(-1px);}
.ams-app .badge{
  position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 4px;border-radius:9px;
  background:linear-gradient(135deg,#ff8e6e,#ff5f8f);color:#fff;font-size:10px;font-weight:700;
  display:flex;align-items:center;justify-content:center;border:2px solid #edf0f8;
}
.ams-app .profile{
  display:flex;align-items:center;gap:10px;padding:6px 12px 6px 6px;
  border:1px solid rgba(31,41,80,.07);border-radius:14px;background:#fff;cursor:pointer;transition:.2s;
  box-shadow:0 6px 16px -12px rgba(31,41,80,.4);
}
.ams-app .profile:hover{transform:translateY(-1px);}
.ams-app .avatar{width:34px;height:34px;border-radius:11px;background:linear-gradient(135deg,var(--a2),var(--a1));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;}
.ams-app .profile .who{line-height:1.1;text-align:left;}
.ams-app .profile .who b{font-weight:700;font-size:13px;display:block;}
.ams-app .profile .who small{font-size:11px;color:#9aa0b4;}
.ams-app .profile .chev{font-size:11px;color:#b3b8c9;}

/* dropdown */
.ams-app .menu{
  position:absolute;right:0;top:54px;width:230px;background:#fff;border-radius:16px;
  box-shadow:0 30px 60px -24px rgba(31,41,80,.5);border:1px solid rgba(31,41,80,.06);
  overflow:hidden;padding:8px;z-index:40;display:none;animation:dropIn .18s ease;
}
.ams-app .menu.open{display:block;}
.ams-app .menu a{display:flex;align-items:center;gap:11px;width:100%;padding:11px 12px;border-radius:11px;font-size:13.5px;font-weight:600;color:#4a5168;transition:.15s;}
.ams-app .menu a i{width:18px;}
.ams-app .menu a:hover{background:color-mix(in srgb, var(--a1) 8%, transparent);color:var(--a1);}
.ams-app .menu a.danger{color:#e0476b;}
.ams-app .menu a.danger:hover{background:rgba(255,95,143,.1);}
.ams-app .menu .divider{height:1px;background:rgba(31,41,80,.07);margin:6px 4px;}
@keyframes dropIn{from{opacity:0;transform:translateY(-8px) scale(.98);}to{opacity:1;transform:none;}}

/* notifications dropdown */
.ams-app .menu.notif{width:340px;padding:0;}
.ams-app .notif-head{padding:16px 18px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(31,41,80,.06);}
.ams-app .notif-head b{font-size:15px;font-weight:800;}
.ams-app .notif-head span{font-size:12px;color:var(--a1);font-weight:700;cursor:pointer;}
.ams-app .notif-list{max-height:330px;overflow-y:auto;}
.ams-app .notif-item{display:flex;gap:13px;padding:14px 18px;cursor:pointer;transition:.15s;}
.ams-app .notif-item:hover{background:color-mix(in srgb, var(--a1) 5%, transparent);}
.ams-app .notif-ic{width:40px;height:40px;flex:none;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:15px;}
.ams-app .notif-tx{flex:1;min-width:0;}
.ams-app .notif-tx b{font-weight:700;font-size:13.5px;display:block;}
.ams-app .notif-tx small{font-size:12.5px;color:#8a90a6;}
.ams-app .notif-time{font-size:11.5px;color:#b3b8c9;flex:none;}
.ams-app .notif-foot{padding:13px;text-align:center;font-size:13px;font-weight:700;color:var(--a1);cursor:pointer;border-top:1px solid rgba(31,41,80,.06);}

/* ---------- Content ---------- */
.ams-app .content{flex:1;padding:26px 30px 42px;min-width:0;}
.ams-app .placeholder{
  min-height:60vh;border:2px dashed #d3d8e6;border-radius:var(--r);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  color:#aab0c2;background:rgba(255,255,255,.4);
}
.ams-app .placeholder .ph-icon{
  width:54px;height:54px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:22px;
  background:color-mix(in srgb, var(--a1) 12%, transparent);color:var(--a1);
}
.ams-app .placeholder .ph-label{font-family:ui-monospace,'SF Mono',Menlo,Consolas,monospace;font-size:13px;letter-spacing:.3px;}

/* collapsed state */
.ams-app.collapsed .sidebar{width:80px;}
.ams-app.collapsed .brand .name,
.ams-app.collapsed .brand .tag,
.ams-app.collapsed .nav-item span,
.ams-app.collapsed .nav-title,
.ams-app.collapsed .nav-chevron,
.ams-app.collapsed .nav-sub{display:none;}
/* Center every icon in the rail so plain items and group headers align identically. */
.ams-app.collapsed .brand{justify-content:center;}
.ams-app.collapsed .nav-item{justify-content:center;gap:0;padding-left:0;padding-right:0;}
.ams-app.collapsed .nav-item:hover{transform:none;}

/* ===========================================================
   Login screen
   =========================================================== */
.login-wrap,.login-wrap *,.login-wrap *::before,.login-wrap *::after{box-sizing:border-box;}
.login-wrap a{text-decoration:none;color:inherit;}
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;
  font-family:'Plus Jakarta Sans',sans-serif;color:var(--ink);}
.login-card{display:flex;width:min(1040px,100%);min-height:620px;background:#fff;border-radius:30px;overflow:hidden;box-shadow:0 40px 90px -40px rgba(31,41,80,.5);}
.login-brand{
  flex:1;position:relative;padding:54px 48px;color:#fff;overflow:hidden;
  display:flex;flex-direction:column;justify-content:space-between;
  background:linear-gradient(150deg,var(--a1) 0%,#5b9dff 55%,#37cdff 100%);
}
.login-brand .lg-blob{position:absolute;border-radius:50%;background:rgba(255,255,255,.12);}
.login-brand .lg-logo{position:relative;display:flex;align-items:center;gap:12px;}
.login-brand .lg-logo .ic{width:46px;height:46px;border-radius:14px;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:20px;backdrop-filter:blur(6px);}
.login-brand .lg-logo b{font-weight:800;font-size:22px;letter-spacing:-.5px;}
.login-brand h1{position:relative;font-size:34px;font-weight:800;line-height:1.15;letter-spacing:-1px;margin:0 0 16px;color:#fff;}
.login-brand p{position:relative;font-size:15px;opacity:.92;line-height:1.6;max-width:330px;margin:0;color:#fff;}
.lg-features{display:flex;flex-direction:column;gap:14px;margin-top:30px;}
.lg-feature{display:flex;align-items:center;gap:12px;font-size:14px;}
.lg-copy{position:relative;font-size:13px;opacity:.8;}
.login-form{flex:1;padding:56px 52px;display:flex;flex-direction:column;justify-content:center;}
.login-form h2{font-size:26px;font-weight:800;letter-spacing:-.5px;margin:0 0 6px;color:var(--ink);}
.login-form .sub{color:var(--muted);font-size:14px;margin-bottom:30px;}
.lg-label{font-size:13px;font-weight:600;color:#4a5168;margin-bottom:8px;display:block;}
.field{position:relative;margin-bottom:18px;}
.field > i{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:#b3b8c9;}
.field input{width:100%;padding:14px 16px 14px 44px;border:1.5px solid #e6e8f0;border-radius:14px;font-family:inherit;font-size:14px;color:var(--ink);outline:none;transition:.2s;}
.field input:focus{border-color:var(--a1);box-shadow:0 0 0 4px color-mix(in srgb, var(--a1) 12%, transparent);}
.lg-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:26px;font-size:13px;}
.lg-row label{display:flex;align-items:center;gap:8px;color:#4a5168;cursor:pointer;}
.lg-row input{width:16px;height:16px;accent-color:var(--a1);}
.lg-row .link{color:var(--a1);font-weight:600;cursor:pointer;}
.btn-primary{
  display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:15px;
  border:none;border-radius:14px;color:#fff;font-family:inherit;font-size:15px;font-weight:700;cursor:pointer;transition:.25s;
  background:linear-gradient(135deg,var(--a2),var(--a1));
  box-shadow:0 14px 30px -10px color-mix(in srgb, var(--a1) 65%, transparent);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 20px 38px -10px color-mix(in srgb, var(--a1) 70%, transparent);}

/* login alerts */
.lg-alert{padding:.7rem .85rem;border-radius:12px;margin-bottom:18px;font-size:13.5px;font-weight:600;}
.lg-alert.err{color:#b3261e;background:#fdecea;border:1px solid #f6cfca;}
.lg-alert.ok{color:#1b5e20;background:#e9f5ea;border:1px solid #c5e3c7;}

/* responsive: stack login + collapse sidebar */
@media (max-width:860px){
  .login-card{flex-direction:column;}
  .login-brand{display:none;}
}

/* ===========================================================
   Content pages: data tables, toolbars, action buttons, forms,
   stat chips, filter popup, toggle switch, hierarchy card.
   Ported from Docs/template/styles.css, scoped under .ams-app.
   =========================================================== */
/* border-box for the custom content components (off Radzen content). */
.ams-app .card,.ams-app .card *,
.ams-app .stat-row,.ams-app .stat-chip,.ams-app .stat-chip *,
.ams-app .list-toolbar,.ams-app .list-toolbar *,
.ams-app .pop,.ams-app .pop *,
.ams-app .form-layout,.ams-app .form-layout *{box-sizing:border-box;}

.ams-app .card{background:#fff;border:1px solid rgba(31,41,80,.05);border-radius:var(--r);box-shadow:0 20px 44px -28px rgba(31,41,80,.4);overflow:hidden;}
.ams-app .card-pad{padding:24px 26px;}
.ams-app .card-title{font-size:17px;font-weight:800;letter-spacing:-.3px;}
.ams-app .card-sub{font-size:12.5px;color:var(--muted);margin-top:2px;}
.ams-app .search-box{position:relative;flex:0 1 260px;min-width:160px;}
.ams-app .search-box i{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#b3b8c9;font-size:13px;}
.ams-app .search-box input{width:100%;padding:11px 14px 11px 38px;border:1px solid rgba(31,41,80,.1);border-radius:12px;background:#fff;font-family:inherit;font-size:13.5px;color:var(--ink);outline:none;transition:.2s;}
.ams-app .search-box input:focus{border-color:var(--a1);box-shadow:0 0 0 4px color-mix(in srgb,var(--a1) 12%,transparent);}
.ams-app .btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;border:none;border-radius:12px;font-family:inherit;font-size:13px;font-weight:700;cursor:pointer;transition:.2s;white-space:nowrap;text-decoration:none;}
.ams-app .btn.primary{background:linear-gradient(135deg,var(--a2),var(--a1));color:#fff;box-shadow:0 12px 24px -10px color-mix(in srgb,var(--a1) 55%,transparent);}
.ams-app .btn.primary:hover{transform:translateY(-2px);}
.ams-app .btn.light{background:#fff;border:1.5px solid #e6e8f0;color:#5a6178;}
.ams-app .btn.light:hover{border-color:#c9cdd9;}
.ams-app .btn:disabled{opacity:.55;cursor:not-allowed;transform:none;}
.ams-app .btn-icon{width:34px;height:34px;border:none;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:12.5px;transition:.15s;text-decoration:none;}
.ams-app .btn-icon.edit{background:color-mix(in srgb,var(--a1) 12%,transparent);color:var(--a1);}
.ams-app .btn-icon.edit:hover{background:color-mix(in srgb,var(--a1) 22%,transparent);}
.ams-app .btn-icon.del{background:rgba(239,68,68,.1);color:#e0476b;}
.ams-app .btn-icon.del:hover{background:rgba(239,68,68,.18);}
.ams-app .data-table{width:100%;border-collapse:collapse;}
.ams-app .data-table thead th{text-align:left;font-size:11.5px;font-weight:700;letter-spacing:.5px;color:#9aa0b4;padding:13px 18px;background:#f7f8fc;border-top:1px solid rgba(31,41,80,.05);border-bottom:1px solid rgba(31,41,80,.05);}
.ams-app .data-table tbody td{padding:14px 18px;font-size:13.5px;color:#3a4055;border-bottom:1px solid rgba(31,41,80,.045);vertical-align:middle;}
.ams-app .data-table tbody tr{transition:.15s;}
.ams-app .data-table tbody tr:hover{background:color-mix(in srgb,var(--a1) 4%,transparent);}
.ams-app .data-table .code{font-family:ui-monospace,Menlo,Consolas,monospace;font-weight:700;color:var(--ink);font-size:12.5px;}
.ams-app .data-table .empty-row td{text-align:center;color:var(--muted);padding:42px 18px;}
.ams-app .badge-status{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:8px;font-size:11.5px;font-weight:700;}
.ams-app .badge-status::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;}
.ams-app .badge-status.active{color:#15a34a;background:rgba(34,197,94,.12);}
.ams-app .badge-status.inactive{color:#5b6472;background:rgba(107,114,128,.13);}
.ams-app .cell-actions{display:flex;gap:8px;}
.ams-app .table-foot{display:flex;align-items:center;justify-content:space-between;padding:15px 20px;font-size:13px;color:var(--muted);border-top:1px solid rgba(31,41,80,.045);}
.ams-app .pager{display:flex;gap:6px;}
.ams-app .pager button{width:34px;height:34px;border:1px solid rgba(31,41,80,.08);border-radius:9px;background:#fff;color:#5a6178;font-family:inherit;font-weight:700;font-size:13px;cursor:pointer;transition:.15s;}
.ams-app .pager button:hover:not(:disabled){border-color:var(--a1);color:var(--a1);}
.ams-app .pager button.active{background:linear-gradient(135deg,var(--a2),var(--a1));color:#fff;border:none;}
.ams-app .pager button:disabled{opacity:.4;cursor:not-allowed;}
.ams-app .form-head{margin-bottom:22px;}
.ams-app .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.ams-app .form-field{display:flex;flex-direction:column;gap:8px;}
.ams-app .form-field.full{grid-column:1 / -1;}
.ams-app .form-field label{font-size:13px;font-weight:700;color:#4a5168;}
.ams-app .form-field input,.ams-app .form-field textarea,.ams-app .form-field select{width:100%;padding:12px 14px;border:1.5px solid #e6e8f0;border-radius:12px;font-family:inherit;font-size:14px;color:var(--ink);outline:none;transition:.2s;background:#fff;}
.ams-app .form-field input:focus,.ams-app .form-field textarea:focus,.ams-app .form-field select:focus{border-color:var(--a1);box-shadow:0 0 0 4px color-mix(in srgb,var(--a1) 12%,transparent);}
.ams-app .form-field textarea{resize:vertical;min-height:74px;}
.ams-app .field-hint{font-size:12px;color:var(--muted);}
.ams-app .form-actions{display:flex;gap:10px;margin-top:24px;padding-top:20px;border-top:1px solid rgba(31,41,80,.06);}

.ams-app .stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px;}
.ams-app .stat-chip{background:#fff;border:1px solid rgba(31,41,80,.05);border-radius:16px;padding:15px 18px;box-shadow:0 14px 30px -24px rgba(31,41,80,.4);display:flex;align-items:center;gap:14px;transition:.25s;}
.ams-app .stat-chip:hover{transform:translateY(-3px);}
.ams-app .stat-chip .ic{width:44px;height:44px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:18px;flex:none;}
.ams-app .stat-chip .v{font-size:22px;font-weight:800;letter-spacing:-.5px;line-height:1;}
.ams-app .stat-chip .l{font-size:12.5px;color:var(--muted);margin-top:3px;}
.ams-app .tool-btn{width:40px;height:40px;border:1px solid rgba(31,41,80,.1);border-radius:11px;background:#fff;color:#5a6178;cursor:pointer;font-size:14px;transition:.2s;display:inline-flex;align-items:center;justify-content:center;flex:none;}
.ams-app .tool-btn:hover{border-color:var(--a1);color:var(--a1);}
.ams-app .pop{position:absolute;right:0;top:50px;width:300px;background:#fff;border-radius:16px;box-shadow:0 30px 60px -24px rgba(31,41,80,.5);border:1px solid rgba(31,41,80,.06);padding:16px;z-index:45;display:none;animation:dropIn .18s ease;text-align:left;}
.ams-app .pop.open{display:block;}
/* Blazor-managed popups use .pop-shown (not .open) so the global document-click handler in
   ams-layout.js — which closes .pop.open / .menu.open — never strips them. Closing is handled
   in Blazor via the .pop-backdrop. */
.ams-app .pop.pop-shown{display:block;animation:dropIn .18s ease;}
.ams-app .pop h5{margin:0 0 14px;font-size:14px;font-weight:800;}
.ams-app .pop-field{margin-bottom:12px;}
.ams-app .pop-field label{display:block;font-size:12px;font-weight:700;color:#4a5168;margin-bottom:6px;}
.ams-app .pop-field select,.ams-app .pop-field input{width:100%;padding:9px 11px;border:1.5px solid #e6e8f0;border-radius:10px;font-family:inherit;font-size:13px;color:var(--ink);outline:none;background:#fff;}
.ams-app .pop-row{display:flex;gap:10px;}
.ams-app .pop-actions{display:flex;gap:8px;margin-top:6px;}
.ams-app .pop-backdrop{position:fixed;inset:0;z-index:44;background:transparent;}
.ams-app .rownum{color:#b3b8c9;font-weight:700;font-size:12.5px;}
.ams-app th.sortable{cursor:pointer;}
.ams-app th .th-in{display:inline-flex;align-items:center;gap:6px;}
.ams-app th .th-in i{font-size:9px;opacity:.45;}
.ams-app th.sortable:hover .th-in i{opacity:.9;color:var(--a1);}
.ams-app th.sortable.sorted .th-in i{opacity:.9;color:var(--a1);}
@keyframes spin{to{transform:rotate(360deg);}}
.ams-app .tool-btn .spin{animation:spin .6s linear infinite;}
.ams-app .form-ic{width:46px;height:46px;border-radius:13px;background:color-mix(in srgb,var(--a1) 12%,transparent);color:var(--a1);display:flex;align-items:center;justify-content:center;font-size:19px;flex:none;}
.ams-app .toggle-field{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 16px;border:1.5px solid #eef0f6;border-radius:12px;background:#fafbfe;}
.ams-app .switch{position:relative;width:46px;height:26px;border-radius:14px;background:#e2e5ef;cursor:pointer;transition:.2s;flex:none;}
.ams-app .switch.on{background:linear-gradient(135deg,var(--a2),var(--a1));}
.ams-app .switch .dot{position:absolute;width:20px;height:20px;border-radius:50%;background:#fff;top:3px;left:3px;transition:.2s;box-shadow:0 2px 5px rgba(0,0,0,.15);}
.ams-app .switch.on .dot{left:23px;}
.ams-app .hier-item{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid rgba(31,41,80,.05);}
.ams-app .hier-item:last-child{border-bottom:none;}
.ams-app .hier-rank{width:30px;height:30px;border-radius:9px;background:color-mix(in srgb,var(--a1) 12%,transparent);color:var(--a1);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;flex:none;}
.ams-app .list-toolbar{display:flex;align-items:center;gap:14px;margin-bottom:16px;flex-wrap:wrap;}
.ams-app .form-layout{display:grid;grid-template-columns:1.6fr 1fr;gap:20px;align-items:start;max-width:1000px;}
.ams-app .info-box{margin-top:16px;padding:13px 14px;border-radius:12px;background:color-mix(in srgb,var(--a1) 7%,transparent);font-size:12.5px;color:#5a6178;line-height:1.5;}
.ams-app .info-box i{color:var(--a1);margin-right:6px;}

/* Locations (tree list) + multi-section forms */
.ams-app .btn-icon.add{background:rgba(58,160,255,.12);color:#3aa0ff;}
.ams-app .btn-icon.add:hover{background:rgba(58,160,255,.2);}
.ams-app .tree-name{display:flex;align-items:center;gap:8px;}
.ams-app .tree-child{color:#c2c7d6;font-weight:700;}
.ams-app .type-pill{display:inline-block;padding:3px 10px;border-radius:7px;background:#f1f3fa;color:#5a6178;font-size:12px;font-weight:600;}
.ams-app .form-section-title{grid-column:1 / -1;font-size:12px;font-weight:800;letter-spacing:.6px;color:#9aa0b4;text-transform:uppercase;margin-top:6px;padding-top:14px;border-top:1px solid rgba(31,41,80,.06);}
.ams-app .form-section-title:first-child{border-top:none;padding-top:0;margin-top:0;}

/* ===========================================================
   Transaction documents: status badges, colored action buttons,
   document header, line-item editor, numeric cells.
   Shared by all Transaction module pages.
   =========================================================== */
/* document-status badges (reuse the dot + pill base of .badge-status) */
.ams-app .badge-status.draft{color:#7a8194;background:rgba(107,114,128,.13);}
.ams-app .badge-status.submitted{color:#2563eb;background:rgba(37,99,235,.12);}
.ams-app .badge-status.posted{color:#15a34a;background:rgba(34,197,94,.12);}
.ams-app .badge-status.cancelled{color:#dc2626;background:rgba(239,68,68,.12);}
.ams-app .badge-status.completed{color:#15a34a;background:rgba(34,197,94,.12);}
.ams-app .badge-status.inprogress{color:#c97a06;background:rgba(245,158,11,.15);}
.ams-app .badge-status.planned{color:#2563eb;background:rgba(37,99,235,.12);}
.ams-app .badge-status.reconciled{color:#6c5ce7;background:rgba(108,92,231,.14);}

/* colored filled action buttons (same shape/hover as .btn.primary) */
.ams-app .btn.info{background:linear-gradient(135deg,#5b9dff,#2f7bf0);color:#fff;box-shadow:0 12px 24px -12px rgba(47,123,240,.6);}
.ams-app .btn.success{background:linear-gradient(135deg,#34d27f,#15a34a);color:#fff;box-shadow:0 12px 24px -12px rgba(21,163,74,.55);}
.ams-app .btn.warn{background:linear-gradient(135deg,#f7b955,#ef9a1e);color:#fff;box-shadow:0 12px 24px -12px rgba(239,154,30,.55);}
.ams-app .btn.danger{background:linear-gradient(135deg,#ff7a90,#e0476b);color:#fff;box-shadow:0 12px 24px -12px rgba(224,71,107,.55);}
.ams-app .btn.info:hover,.ams-app .btn.success:hover,.ams-app .btn.warn:hover,.ams-app .btn.danger:hover{transform:translateY(-2px);}
.ams-app .btn.sm{padding:8px 13px;font-size:12.5px;border-radius:10px;}

/* document header (title + status + meta) */
.ams-app .doc-head{display:flex;align-items:center;gap:14px;margin-bottom:18px;flex-wrap:wrap;}
.ams-app .doc-head .doc-title{font-size:19px;font-weight:800;letter-spacing:-.4px;}
.ams-app .doc-head .doc-sub{font-size:12.5px;color:var(--muted);margin-top:2px;}

/* wider form grids for transaction documents */
.ams-app .form-grid.cols-3{grid-template-columns:repeat(3,1fr);}
.ams-app .form-grid.cols-4{grid-template-columns:repeat(4,1fr);}

/* inset panel used for the inline line-item editor */
.ams-app .sub-panel{border:1.5px solid #eef0f6;border-radius:14px;background:#fafbfe;padding:18px;margin-top:4px;}
.ams-app .sub-panel-title{font-size:13px;font-weight:800;color:#4a5168;margin-bottom:14px;}

/* numeric table cells + emphasised totals */
.ams-app .data-table td.num,.ams-app .data-table th.num{text-align:right;}
.ams-app .data-table tbody tr.selected-row{background:color-mix(in srgb,var(--a1) 9%,transparent);}

/* grouped key/value settings rows */
.ams-app .set-row{display:grid;grid-template-columns:1.3fr 1fr auto;gap:18px;align-items:center;padding:14px 0;border-bottom:1px solid rgba(31,41,80,.05);}
.ams-app .set-row:last-child{border-bottom:none;}
.ams-app .set-row .set-key{font-size:13.5px;font-weight:700;color:var(--ink);}
.ams-app .set-row .set-desc{font-size:12px;color:var(--muted);margin-top:2px;}
.ams-app .set-row input[type=text],.ams-app .set-row input[type=password]{width:100%;padding:10px 12px;border:1.5px solid #e6e8f0;border-radius:10px;font-family:inherit;font-size:13.5px;color:var(--ink);outline:none;background:#fff;}
.ams-app .set-row input:focus{border-color:var(--a1);box-shadow:0 0 0 4px color-mix(in srgb,var(--a1) 12%,transparent);}
.ams-app .set-row input:disabled{background:#f5f6fa;color:#9aa0b4;}
@media (max-width:880px){ .ams-app .set-row{grid-template-columns:1fr;gap:8px;} }

/* tab bar (asset edit detail panels) */
.ams-app .tabs{display:flex;gap:2px;border-bottom:1px solid rgba(31,41,80,.08);margin-bottom:20px;flex-wrap:wrap;}
.ams-app .tab{padding:11px 17px;border:none;background:none;font-family:inherit;font-size:13.5px;font-weight:700;color:#8a90a6;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:.15s;display:inline-flex;align-items:center;gap:8px;}
.ams-app .tab:hover{color:var(--a1);}
.ams-app .tab.active{color:var(--a1);border-bottom-color:var(--a1);}
.ams-app .tab .cnt{font-size:11px;font-weight:800;background:#eef0f6;color:#7a8194;border-radius:20px;padding:1px 7px;}
.ams-app .tab.active .cnt{background:color-mix(in srgb,var(--a1) 15%,transparent);color:var(--a1);}

/* selectable chips — multi-select for roles / permissions */
.ams-app .chip-wrap{display:flex;flex-wrap:wrap;gap:9px;}
.ams-app .chip{display:inline-flex;align-items:center;gap:8px;padding:8px 13px;border:1.5px solid #e6e8f0;border-radius:10px;background:#fff;font-size:13px;font-weight:600;color:#5a6178;cursor:pointer;transition:.15s;user-select:none;}
.ams-app .chip:hover{border-color:#c9cdd9;}
.ams-app .chip.on{border-color:var(--a1);background:color-mix(in srgb,var(--a1) 8%,transparent);color:var(--a1);}
.ams-app .chip .ck{width:15px;height:15px;border-radius:5px;border:1.5px solid #cdd2e0;display:inline-flex;align-items:center;justify-content:center;font-size:8px;color:transparent;flex:none;transition:.15s;}
.ams-app .chip.on .ck{background:var(--a1);border-color:var(--a1);color:#fff;}
.ams-app .perm-group{border:1px solid rgba(31,41,80,.08);border-radius:14px;padding:16px 18px;margin-bottom:12px;}
.ams-app .perm-group-head{display:flex;align-items:center;gap:12px;margin-bottom:12px;}
.ams-app .perm-group-head .nm{font-size:14px;font-weight:800;}

/* CSV upload drop-zone (Data Import/Export) */
.ams-app .upload-zone{display:flex;align-items:center;gap:14px;padding:20px 22px;border:2px dashed #d4d8e6;border-radius:14px;background:#fafbfe;transition:.2s;}
.ams-app .upload-zone:hover{border-color:var(--a1);background:color-mix(in srgb,var(--a1) 4%,transparent);}
.ams-app .upload-zone > i{font-size:24px;color:var(--a1);}
.ams-app .upload-zone input[type=file]{font-family:inherit;font-size:13.5px;color:#5a6178;}
.ams-app .data-table .money{font-variant-numeric:tabular-nums;font-weight:600;color:var(--ink);}
.ams-app .doc-total{font-size:13px;color:var(--muted);}
.ams-app .doc-total strong{font-size:16px;color:var(--ink);font-weight:800;margin-left:6px;font-variant-numeric:tabular-nums;}

/* section header row inside a form card (e.g. "Lines" + total + add button) */
.ams-app .sub-head{display:flex;align-items:center;gap:14px;margin:22px 0 12px;}
.ams-app .sub-head .t{font-size:15px;font-weight:800;letter-spacing:-.2px;}
@media (max-width:880px){
  .ams-app .form-grid.cols-3,.ams-app .form-grid.cols-4{grid-template-columns:1fr;}
}

@media (max-width:880px){
  .ams-app .stat-row{grid-template-columns:1fr;}
  .ams-app .form-layout{grid-template-columns:1fr;}
  .ams-app .form-grid{grid-template-columns:1fr;}
}

/* ===========================================================
   Configurable dashboard (GridStack widgets + Chart.js + modal)
   Ported from Docs/template/styles.css, scoped under .ams-app.
   =========================================================== */
.ams-app .greeting{margin-bottom:18px;}
.ams-app .greeting h2{margin:0;font-size:20px;font-weight:800;letter-spacing:-.4px;}
.ams-app .greeting p{margin:3px 0 0;font-size:13.5px;color:var(--muted);}

.ams-app .grid-stack{margin:0 -4px;}
.ams-app .grid-stack-item-content{inset:0;overflow:visible;}
.ams-app .widget{position:relative;height:100%;display:flex;flex-direction:column;border-radius:var(--r);overflow:hidden;box-sizing:border-box;}
.ams-app .widget.card-w{background:#fff;border:1px solid rgba(31,41,80,.05);box-shadow:0 18px 40px -28px rgba(31,41,80,.4);}
.ams-app .w-head{display:flex;align-items:flex-start;gap:8px;padding:13px 14px 6px;}
.ams-app .w-title{font-weight:800;font-size:14.5px;letter-spacing:-.2px;}
.ams-app .w-sub{font-size:11.5px;color:var(--muted);margin-top:1px;}
.ams-app .w-drag{cursor:move;}
.ams-app .w-tools{display:flex;align-items:center;gap:2px;margin-left:auto;}
.ams-app .w-tool{width:26px;height:26px;border:none;border-radius:8px;background:transparent;color:#b3b8c9;cursor:pointer;font-size:11px;display:flex;align-items:center;justify-content:center;transition:.15s;}
.ams-app .w-tool:hover{background:color-mix(in srgb,var(--a1) 10%,transparent);color:var(--a1);}
.ams-app .w-tool.rm:hover{background:rgba(239,68,68,.12);color:#e0476b;}
.ams-app .w-body{flex:1;min-height:0;padding:4px 14px 14px;overflow:auto;}
.ams-app .w-body.tight{padding:0;}
.ams-app .widget.kpi{color:#fff;padding:18px;box-shadow:0 18px 40px -24px rgba(31,41,80,.5);}
.ams-app .widget.kpi .b1{position:absolute;width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,.16);top:-46px;right:-30px;}
.ams-app .widget.kpi .b2{position:absolute;width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,.12);bottom:-24px;right:24px;}
.ams-app .widget.kpi .ic{position:relative;width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.22);display:flex;align-items:center;justify-content:center;font-size:17px;}
.ams-app .widget.kpi .v{position:relative;font-size:25px;font-weight:800;letter-spacing:-1px;margin-top:14px;line-height:1;}
.ams-app .widget.kpi .l{position:relative;font-size:12.5px;font-weight:600;opacity:.95;margin-top:6px;}
.ams-app .widget.kpi .w-tools{position:absolute;top:12px;right:12px;z-index:2;}
.ams-app .widget.kpi .w-tool{color:rgba(255,255,255,.85);}
.ams-app .widget.kpi .w-tool:hover{background:rgba(255,255,255,.22);color:#fff;}

.ams-app .chart-wrap{position:relative;height:100%;min-height:0;}
.ams-app .donut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none;}
.ams-app .donut-center .v{font-size:24px;font-weight:800;letter-spacing:-1px;}
.ams-app .donut-center .l{font-size:11.5px;color:#9aa0b4;font-weight:600;}
.ams-app .legend-list{display:flex;flex-direction:column;gap:10px;margin-top:6px;}
.ams-app .legend-list .row{display:flex;align-items:center;gap:10px;font-size:13px;}
.ams-app .legend-list .dot{width:10px;height:10px;border-radius:50%;flex:none;}
.ams-app .legend-list .nm{flex:1;color:#5a6178;font-weight:600;}
.ams-app .legend-list .vl{font-weight:800;}
.ams-app .day-badge{display:inline-block;padding:4px 10px;border-radius:7px;font-size:12px;font-weight:700;}
.ams-app .day-badge.warn{color:#c97a06;background:rgba(245,158,11,.15);}
.ams-app .day-badge.crit{color:#dc2626;background:rgba(239,68,68,.12);}

.ams-app .modal-overlay{position:fixed;inset:0;background:rgba(20,24,40,.45);backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center;z-index:60;padding:24px;}
.ams-app .modal-overlay.open{display:flex;}
.ams-app .modal{background:#fff;border-radius:22px;width:min(820px,100%);max-height:86vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 40px 90px -40px rgba(31,41,80,.6);}
.ams-app .modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid rgba(31,41,80,.06);}
.ams-app .modal-title{font-size:18px;font-weight:800;letter-spacing:-.3px;}
.ams-app .modal-body{padding:18px 24px 24px;overflow:auto;}
.ams-app .cat-group-title{font-size:12px;font-weight:800;letter-spacing:.6px;color:#9aa0b4;text-transform:uppercase;margin:16px 0 10px;}
.ams-app .cat-group-title:first-child{margin-top:0;}
.ams-app .cat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;}
.ams-app .cat-tile{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1.5px solid #eef0f6;border-radius:14px;cursor:pointer;transition:.15s;background:#fff;text-align:left;width:100%;}
.ams-app .cat-tile:hover:not(:disabled){border-color:var(--a1);background:color-mix(in srgb,var(--a1) 4%,transparent);transform:translateY(-2px);}
.ams-app .cat-tile:disabled{opacity:.5;cursor:not-allowed;}
.ams-app .cat-ic{width:40px;height:40px;border-radius:11px;background:color-mix(in srgb,var(--a1) 12%,transparent);color:var(--a1);display:flex;align-items:center;justify-content:center;font-size:15px;flex:none;}
.ams-app .cat-tx{flex:1;min-width:0;}
.ams-app .cat-tx b{font-size:13.5px;font-weight:700;display:block;}
.ams-app .cat-tx small{font-size:11.5px;color:var(--muted);}
.ams-app .cat-add{color:var(--a1);font-weight:800;}
.ams-app .dash-empty{border:2px dashed #d3d8e6;border-radius:var(--r);background:rgba(255,255,255,.4);padding:42px;text-align:center;color:#8a90a6;}
.ams-app .grid-stack-item > .ui-resizable-handle{background-image:none !important;box-shadow:none !important;}
.ams-app .grid-stack-item > .ui-resizable-handle::before,
.ams-app .grid-stack-item > .ui-resizable-handle::after{display:none !important;}
