:root{
  --primary:#2563eb;--navy:#0f172a;--soft-blue:#dbeafe;--bg:#f8fafc;--card:#fff;--border:#e2e8f0;--text:#1e293b;--muted:#64748b;--green:#22c55e;--orange:#f59e0b;--red:#ef4444;--cyan:#06b6d4;--purple:#8b5cf6;--gray:#94a3b8;--radius:16px;--shadow:0 8px 24px rgba(15,23,42,.06)
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,sans-serif;font-size:14px}a{text-decoration:none}h1,h2,h3,h4,h5{font-family:Poppins,Inter,sans-serif;color:var(--navy)}
.app-shell{display:flex;min-height:100vh}.sidebar{position:fixed;inset:0 auto 0 0;width:280px;background:linear-gradient(180deg,#0f172a,#111827 62%,#1e3a8a);color:#fff;padding:24px;flex-direction:column;z-index:20;max-height:100vh;overflow:hidden}.brand-lockup{display:flex;align-items:center;gap:12px;flex-shrink:0}.brand-mark{display:grid;place-items:center;width:44px;height:44px;border-radius:14px;background:linear-gradient(135deg,var(--primary),var(--cyan));box-shadow:0 12px 30px rgba(37,99,235,.35);color:#fff}.brand-lockup strong{display:block;font-family:Poppins;font-size:18px}.brand-lockup small{display:block;color:#93c5fd}.sidebar-nav{display:flex;flex:1 1 auto;flex-direction:column;gap:6px;margin-top:30px;min-height:0;overflow-y:auto;overflow-x:hidden;padding-right:6px;scrollbar-width:thin;scrollbar-color:rgba(191,219,254,.35) transparent}.sidebar-nav::-webkit-scrollbar{width:8px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:rgba(191,219,254,.28);border-radius:999px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:rgba(191,219,254,.42)}.sidebar-nav a{display:flex;align-items:center;gap:12px;border-radius:14px;padding:12px 14px;color:#cbd5e1;font-weight:600;flex-shrink:0}.sidebar-nav a:hover,.sidebar-nav a.active{background:rgba(255,255,255,.12);color:#fff}.sidebar-nav i{font-size:18px}.sidebar-user{margin-top:18px;display:flex;align-items:center;gap:12px;padding:14px;border:1px solid rgba(255,255,255,.12);border-radius:18px;background:rgba(255,255,255,.08);flex-shrink:0}.sidebar-user img{width:42px;height:42px;border-radius:50%;object-fit:cover}.sidebar-user small{display:block;color:#bfdbfe}.main-wrap{width:100%;padding-left:280px}.topbar{position:sticky;top:0;z-index:15;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px 28px;background:rgba(248,250,252,.86);backdrop-filter:blur(18px);border-bottom:1px solid rgba(226,232,240,.8)}.topbar h1{margin:0;font-size:24px}.eyebrow{color:var(--muted);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.topbar-actions{display:flex;align-items:center;gap:12px}.icon-btn{border:1px solid var(--border);background:#fff;color:var(--text);border-radius:14px;width:44px;height:44px;display:grid;place-items:center}.notify-dot{position:absolute;top:-6px;right:-6px;background:var(--red);color:#fff;border-radius:999px;font-size:11px;font-weight:800;padding:2px 6px}.search-box{align-items:center;gap:10px;background:#fff;border:1px solid var(--border);border-radius:999px;padding:0 14px;height:44px;min-width:300px}.search-box input{border:0;outline:0;width:100%;background:transparent}.btn-primary-soft{background:var(--primary);border:0;color:#fff;border-radius:12px;font-weight:700}.content-area{padding:28px;display:flex;flex-direction:column;gap:22px;padding-bottom:96px}.hero-panel{display:flex;justify-content:space-between;gap:24px;align-items:flex-end;padding:28px;border-radius:24px;background:radial-gradient(circle at top right,rgba(37,99,235,.18),transparent 30%),linear-gradient(135deg,#fff,#eff6ff);border:1px solid #dbeafe;box-shadow:var(--shadow);overflow:hidden}.hero-panel h2{font-size:32px;line-height:1.18;max-width:760px;margin:14px 0 10px}.hero-panel p{max-width:720px;color:var(--muted);font-size:15px;margin:0}.pill{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:#fff;color:var(--primary);font-weight:800;border:1px solid #bfdbfe}.hero-actions{display:flex;gap:10px;flex-shrink:0}.date-range{width:210px;border-radius:12px;border-color:var(--border)}.stat-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:16px}.stat-card{position:relative;overflow:hidden;display:flex;flex-direction:column;gap:5px;padding:18px;border-radius:var(--radius);background:#fff;border:1px solid var(--border);box-shadow:var(--shadow);min-height:164px}.stat-card:before{content:"";position:absolute;inset:auto -24px -42px auto;width:110px;height:110px;border-radius:50%;opacity:.12;background:currentColor}.stat-icon{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;margin-bottom:8px;font-size:20px;background:color-mix(in srgb,currentColor 12%,white)}.stat-card small,.stat-card span{color:var(--muted)}.stat-card strong{font-size:30px;font-family:Poppins;color:var(--navy)}.stat-card a{margin-top:auto;font-weight:800;color:currentColor}.blue{color:var(--primary)}.green{color:var(--green)}.red{color:var(--red)}.orange{color:var(--orange)}.purple{color:var(--purple)}.cyan{color:var(--cyan)}.panel{background:#fff;border:1px solid var(--border);border-radius:22px;padding:22px;box-shadow:var(--shadow)}.dashboard-grid{display:grid;grid-template-columns:1.4fr .9fr;gap:22px}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:22px}.section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.section-head h3{font-size:18px;margin:0}.section-head p{margin:4px 0 0;color:var(--muted)}.filter-actions{display:flex;gap:8px;flex-wrap:wrap}.division-list{display:flex;flex-direction:column;gap:14px}.division-list>div{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}.division-list span{font-weight:800}.division-list small{display:block;color:var(--muted);font-weight:500}.division-list>div>div{grid-column:1/-1;height:9px;background:#eef2f7;border-radius:999px;overflow:hidden}.division-list b{display:block;height:100%;border-radius:999px;background:var(--primary)}.division-list [data-color=green] b{background:var(--green)}.division-list [data-color=indigo] b{background:#6366f1}.division-list [data-color=cyan] b{background:var(--cyan)}.division-list [data-color=orange] b{background:var(--orange)}.kanban-board{display:flex;gap:16px;overflow-x:auto;padding-bottom:10px;scrollbar-color:#cbd5e1 transparent}.kanban-column{min-width:282px;background:#f8fafc;border:1px solid var(--border);border-radius:18px;padding:14px}.kanban-column.muted{background:#fbfdff}.kanban-column h4{font-size:14px;display:flex;justify-content:space-between;margin-bottom:12px}.kanban-column h4 span{background:#e2e8f0;border-radius:999px;padding:2px 8px}.project-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:14px;margin-bottom:12px;box-shadow:0 6px 16px rgba(15,23,42,.05)}.project-card.danger{border-color:#fecaca;background:#fff7f7}.project-card>div:first-child,.project-card footer{display:flex;align-items:center;justify-content:space-between;gap:10px}.project-card h5{font-size:14px;margin:12px 0 4px}.project-card p,.project-card footer{color:var(--muted);margin:0}.mini-progress{height:7px;background:#e2e8f0;border-radius:999px;margin:12px 0}.mini-progress b{display:block;height:100%;background:linear-gradient(90deg,var(--primary),var(--cyan));border-radius:999px}.badge{border-radius:999px;font-weight:800;padding:.45em .7em}.badge-blue{background:#dbeafe;color:#1d4ed8}.badge-green{background:#dcfce7;color:#15803d}.badge-red{background:#fee2e2;color:#b91c1c}.badge-orange{background:#ffedd5;color:#c2410c}.badge-purple{background:#ede9fe;color:#6d28d9}.badge-gray{background:#f1f5f9;color:#475569}.badge-yellow{background:#fef3c7;color:#a16207}.badge-cyan{background:#cffafe;color:#0e7490}.table{--bs-table-bg:transparent}.table th{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em}.mobile-card-list{display:none}.closing-matrix,.payment-list,.task-list{display:grid;gap:12px}.closing-matrix{grid-template-columns:repeat(3,1fr)}.closing-matrix div,.payment-card,.task-row,.report-grid div{border:1px solid var(--border);border-radius:16px;background:#fbfdff;padding:14px}.closing-matrix strong,.closing-matrix span{display:block}.closing-matrix span{color:var(--muted);margin-top:6px}.task-row{display:flex;align-items:center;gap:14px}.task-row i,.report-grid i{width:42px;height:42px;display:grid;place-items:center;border-radius:14px;background:var(--soft-blue);color:var(--primary);font-size:20px;flex:0 0 auto}.task-row div{flex:1}.task-row small,.payment-card small,.report-grid small{display:block;color:var(--muted)}.payment-list{grid-template-columns:1fr 1fr}.payment-card{display:grid;gap:6px}.payment-card span{font-size:18px;font-weight:800;color:var(--navy)}.payment-card.h-1{border-color:#fed7aa;background:#fff7ed}.payment-card.overdue{border-color:#fecaca;background:#fff7f7}.content-matrix{display:grid;grid-template-columns:1.2fr repeat(3,1fr);gap:10px;align-items:center}.content-matrix>*{padding:10px;border-radius:12px;background:#f8fafc}.matrix-head{font-weight:800;color:var(--muted);text-transform:uppercase;font-size:11px}.report-grid,.state-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.report-grid strong{display:block;margin:10px 0 3px}.empty-state{text-align:center;border:1px dashed #cbd5e1;border-radius:18px;padding:20px;background:#fbfdff}.empty-state i{font-size:34px;color:var(--primary)}.empty-state strong,.empty-state small{display:block}.empty-state small{color:var(--muted);margin:6px 0 14px}.loading-state{display:grid;gap:12px;border:1px solid var(--border);border-radius:18px;padding:18px}.loading-state span{height:18px;border-radius:999px;background:linear-gradient(90deg,#e2e8f0,#f8fafc,#e2e8f0);background-size:200% 100%;animation:skeleton 1.2s infinite}.loading-state span:nth-child(2){width:80%}.loading-state span:nth-child(3){width:55%}@keyframes skeleton{to{background-position:-200% 0}}.bottom-nav{position:fixed;left:12px;right:12px;bottom:12px;z-index:30;display:grid;grid-template-columns:repeat(5,1fr);background:#fff;border:1px solid var(--border);box-shadow:0 14px 40px rgba(15,23,42,.18);border-radius:22px;padding:8px}.bottom-nav a{display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--muted);font-size:11px;font-weight:800;padding:7px 4px;border-radius:16px}.bottom-nav a.active{background:var(--soft-blue);color:var(--primary)}.offcanvas{border:0}.sidebar-nav.mobile{margin-top:0}.sidebar-nav.mobile a{color:var(--text);background:#f8fafc}.notification-list{display:grid;gap:12px}.notif{display:flex;gap:12px;padding:14px;border:1px solid var(--border);border-radius:16px}.notif i{font-size:20px}.notif small{display:block;color:var(--muted)}.notif.info i{color:var(--primary)}.notif.warning i{color:var(--orange)}.notif.danger i{color:var(--red)}.notif.success i{color:var(--green)}
@media (max-width:1399px){.stat-grid{grid-template-columns:repeat(3,1fr)}.report-grid,.state-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:1199px){.main-wrap{padding-left:0}.topbar{padding:14px 18px}.content-area{padding:18px}.hero-panel{flex-direction:column;align-items:stretch}.dashboard-grid,.two-col{grid-template-columns:1fr}.stat-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:767px){body{font-size:13px}.topbar h1{font-size:18px}.topbar .eyebrow{display:none}.content-area{padding:14px 12px 92px}.hero-panel{padding:20px;border-radius:20px}.hero-panel h2{font-size:24px}.hero-actions{flex-direction:column}.date-range{width:100%}.stat-grid{gap:10px}.stat-card{padding:14px;min-height:142px}.stat-card strong{font-size:24px}.stat-icon{width:36px;height:36px}.section-head{flex-direction:column}.panel{padding:16px;border-radius:18px}.desktop-table{display:none}.mobile-card-list{display:grid;gap:10px}.mobile-card{border:1px solid var(--border);border-radius:14px;padding:12px;background:#fbfdff}.mobile-card small{display:block;color:var(--muted);margin-top:5px}.closing-matrix,.payment-list,.report-grid,.state-grid{grid-template-columns:1fr}.content-matrix{grid-template-columns:1fr 1fr}.matrix-head:nth-child(3),.matrix-head:nth-child(4){display:none}.search-box{display:none}.topbar-actions .btn{display:none}.kanban-column{min-width:260px}}

.login-page{background:#eff6ff}.login-shell{min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr}.login-visual{position:relative;display:flex;flex-direction:column;justify-content:space-between;padding:44px;background:radial-gradient(circle at 80% 12%,rgba(6,182,212,.22),transparent 32%),linear-gradient(135deg,#0f172a,#1e3a8a);color:#fff;overflow:hidden}.login-visual:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.08) 1px,transparent 1px);background-size:44px 44px;mask-image:linear-gradient(180deg,#000,transparent)}.login-visual>*{position:relative}.login-visual h1{color:#fff;font-size:42px;line-height:1.12;margin:18px 0 12px}.login-visual p{color:#bfdbfe;font-size:16px;max-width:680px}.blueprint-card{max-width:760px}.login-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:28px}.login-stats div{padding:18px;border:1px solid rgba(255,255,255,.18);border-radius:18px;background:rgba(255,255,255,.1);backdrop-filter:blur(8px)}.login-stats strong{display:block;font-family:Poppins;font-size:30px}.login-stats span{color:#bfdbfe}.login-form-wrap{display:grid;place-items:center;padding:34px}.login-card{width:min(100%,460px);background:#fff;border:1px solid var(--border);border-radius:26px;box-shadow:0 24px 70px rgba(15,23,42,.16);padding:30px}.login-card h2{margin:18px 0 6px}.login-card p{color:var(--muted)}.back-link{display:inline-flex;align-items:center;gap:6px;color:var(--primary);font-weight:800}.input-icon{position:relative}.input-icon i{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--muted)}.input-icon .form-control{height:48px;border-radius:14px;padding-left:42px}.login-options{display:flex;justify-content:space-between;align-items:center;margin:16px 0 20px;color:var(--muted)}.login-options a{font-weight:800;color:var(--primary)}.demo-accounts{margin-top:18px;padding:14px;border-radius:16px;background:#f8fafc;border:1px solid var(--border)}.demo-accounts span,.demo-accounts small{display:block;color:var(--muted);margin-top:4px}.detail-page{max-width:1320px;margin:0 auto;padding:28px;display:flex;flex-direction:column;gap:22px}.detail-title-row{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-top:16px}.detail-title-row h1{font-size:34px;margin:8px 0 4px}.detail-title-row p{color:var(--muted);margin:0}.detail-meta-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:22px}.detail-meta-grid>div,.info-card{padding:16px;border:1px solid var(--border);border-radius:18px;background:#fbfdff}.detail-meta-grid small{display:block;color:var(--muted)}.detail-meta-grid strong{display:block;font-family:Poppins;font-size:18px;margin:4px 0}.workflow-timeline{display:flex;overflow-x:auto;gap:10px;padding-bottom:4px}.workflow-timeline div{position:relative;display:flex;align-items:center;gap:8px;min-width:max-content;padding:10px 14px;border-radius:999px;background:#f1f5f9;color:var(--muted);font-weight:800}.workflow-timeline .done{background:#dcfce7;color:#15803d}.workflow-timeline .active{background:#dbeafe;color:#1d4ed8}.detail-tabs{gap:8px}.detail-tabs .nav-link{border-radius:999px;font-weight:800;color:var(--muted)}.detail-tabs .nav-link.active{background:var(--primary)}.info-card h3{font-size:16px}.activity-timeline{display:grid;gap:12px}.activity-timeline div{display:flex;gap:14px;border-left:3px solid var(--soft-blue);padding-left:14px}.activity-timeline time{font-weight:800;color:var(--primary);min-width:50px}
@media (max-width:991px){.login-shell{grid-template-columns:1fr}.login-visual{min-height:46vh}.login-visual h1{font-size:30px}.detail-meta-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:767px){.login-visual{padding:24px}.login-form-wrap{padding:16px}.login-card{padding:22px;border-radius:22px}.login-stats{grid-template-columns:1fr}.detail-page{padding:12px}.detail-title-row{flex-direction:column}.detail-title-row h1{font-size:26px}.detail-meta-grid{grid-template-columns:1fr}}

.chart-box{position:relative;width:100%;overflow:hidden}.chart-box canvas{display:block;width:100%!important;height:100%!important}.chart-box-line{height:320px}.chart-box-donut{height:270px}@media (max-width:767px){.chart-box-line{height:260px}.chart-box-donut{height:240px}}

/* Dashboard UI refresh */
:root{
  --primary-strong:#1d4ed8;
  --ink:#0b1220;
  --surface:#ffffff;
  --surface-soft:#f8fbff;
  --surface-muted:#f1f5f9;
  --border-strong:#d7e1ee;
  --shadow-soft:0 14px 40px rgba(15,23,42,.08);
  --shadow-card:0 20px 44px rgba(15,23,42,.06);
  --radius-lg:24px;
  --radius-md:18px;
}
body{
  background:
    radial-gradient(circle at top right, rgba(37,99,235,.08), transparent 28%),
    linear-gradient(180deg, #f5f9ff 0%, #f8fafc 28%, #f8fafc 100%);
  color:var(--text);
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(rgba(255,255,255,.5), rgba(255,255,255,0)),
    radial-gradient(circle at 20% 0, rgba(6,182,212,.08), transparent 22%);
  z-index:-1;
}
a{color:inherit}
.main-wrap{min-width:0}
.content-area{
  gap:24px;
  max-width:100%;
}
.content-area > section,
.content-area > .panel{
  position:relative;
}
.topbar{
  background:rgba(248,250,252,.92);
  box-shadow:0 12px 32px rgba(148,163,184,.10);
}
.topbar h1{
  font-size:24px;
  letter-spacing:-.03em;
}
.topbar > div:first-of-type{
  flex:0 0 auto;
  min-width:260px;
  max-width:420px;
}
.topbar-actions{
  margin-left:auto;
  flex:1 1 auto;
  flex-wrap:wrap;
  justify-content:flex-end;
  align-items:center;
}
.search-box{
  position:relative;
  display:flex;
  align-items:center;
  min-width:min(28vw, 400px);
  min-height:46px;
  padding:0 8px 0 12px;
  border-color:#d7e3f1;
  border-width:1px;
  border-style:solid;
  background:linear-gradient(180deg,#ffffff,#fbfdff);
  box-shadow:0 16px 34px rgba(148,163,184,.12), inset 0 1px 0 rgba(255,255,255,.72);
}
.search-box i{
  flex:0 0 auto;
  color:#0f172a;
  font-size:18px;
  line-height:1;
  opacity:.9;
}
.search-box:focus-within{
  border-color:#9bbcf5;
  box-shadow:0 20px 40px rgba(37,99,235,.14), 0 0 0 .22rem rgba(37,99,235,.10);
  transform:translateY(-1px);
  transition:box-shadow .18s ease, border-color .18s ease, transform .18s ease;
}
.search-box input{
  height:100%;
  padding:0 8px;
  color:var(--ink);
  font-size:14px;
  font-weight:500;
  line-height:1.4;
}
.search-box input::-webkit-search-cancel-button{
  appearance:none;
}
.search-box input::placeholder{
  color:#94a3b8;
}
.search-submit{
  flex:0 0 auto;
  width:32px;
  height:32px;
  display:grid;
  place-items:center;
  border:0;
  border-radius:10px;
  background:linear-gradient(135deg,#eff6ff,#dbeafe);
  color:#2563eb;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.82);
}
.search-submit i{
  color:inherit;
  font-size:18px;
}
.search-submit:hover,
.search-submit:focus-visible{
  background:linear-gradient(135deg,#2563eb,#1d4ed8);
  color:#fff;
  outline:0;
}
.topbar-action-btn{
  min-height:42px;
  padding:7px 12px;
  align-items:center;
  gap:7px;
  border-radius:14px;
  font-size:13px;
  font-weight:800;
  letter-spacing:-.01em;
}
.topbar-action-btn-primary{
  padding-right:14px;
  padding-left:10px;
}
.topbar-action-btn-danger{
  background:linear-gradient(180deg,#ffffff,#fffafb);
  border-color:#fca5a5;
  color:#dc2626;
}
.topbar-action-btn-danger:hover,
.topbar-action-btn-danger:focus-visible{
  border-color:#ef4444;
  background:linear-gradient(180deg,#fff5f5,#ffe9e9);
  color:#b91c1c;
}
.topbar-action-icon{
  width:24px;
  height:24px;
  display:grid;
  place-items:center;
  border-radius:8px;
  background:rgba(255,255,255,.18);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.28);
  font-size:12px;
}
.topbar-action-btn-primary .topbar-action-icon{
  background:rgba(255,255,255,.16);
}
.topbar-action-btn-danger .topbar-action-icon{
  background:#fff1f2;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.92);
}
@media (min-width:1200px){
  .topbar{
    gap:12px;
    padding:14px 22px;
  }
  .topbar h1{
    font-size:20px;
  }
  .topbar-actions{
    flex-wrap:nowrap;
    gap:8px;
  }
  .search-box{
    flex:0 1 400px;
    min-width:320px;
    margin-right:10px;
  }
  .topbar-action-btn{
    white-space:nowrap;
    min-height:40px;
    padding:6px 11px;
  }
  .topbar-action-btn-primary{
    padding-left:9px;
    padding-right:13px;
  }
  .topbar-action-btn-danger{
    padding-left:9px;
    padding-right:11px;
  }
}
@media (min-width:1400px){
  .topbar{
    gap:14px;
    padding:14px 22px;
  }
  .topbar h1{
    font-size:22px;
  }
  .eyebrow{
    font-size:11px;
    letter-spacing:.09em;
  }
  .topbar-actions{
    gap:8px;
  }
  .search-box{
    flex:0 1 360px;
    min-width:min(24vw, 360px);
    min-height:42px;
    padding:0 7px 0 10px;
    margin-right:8px;
  }
  .search-box i{
    font-size:16px;
  }
  .search-box input{
    font-size:13px;
    padding:0 7px;
  }
  .search-submit{
    width:30px;
    height:30px;
    border-radius:9px;
  }
  .search-submit i{
    font-size:16px;
  }
  .icon-btn{
    width:38px;
    height:38px;
    border-radius:12px;
  }
  .icon-btn i{
    font-size:16px;
  }
  .notify-dot{
    top:-5px;
    right:-5px;
    min-width:18px;
    padding:1px 5px;
    font-size:10px;
  }
  .topbar-action-btn{
    min-height:38px;
    padding:6px 10px;
    gap:6px;
    border-radius:13px;
    font-size:12px;
  }
  .topbar-action-btn-primary{
    padding-left:9px;
    padding-right:12px;
  }
  .topbar-action-icon{
    width:22px;
    height:22px;
    border-radius:7px;
    font-size:11px;
  }
}
.icon-btn{
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease, background-color .2s ease;
  box-shadow:0 10px 24px rgba(15,23,42,.05);
}
.icon-btn:hover,
.icon-btn:focus-visible{
  transform:translateY(-1px);
  border-color:#bfd2eb;
  box-shadow:0 14px 28px rgba(15,23,42,.08);
}
.notify-dot{
  min-width:22px;
  text-align:center;
  box-shadow:0 10px 20px rgba(239,68,68,.28);
}
.btn,
.form-control,
.form-select,
.nav-link,
.page-link{
  transition:all .18s ease;
}
.btn{
  border-radius:14px;
  font-weight:700;
  letter-spacing:.01em;
  box-shadow:none;
}
.btn-primary,
.btn-primary-soft{
  background:linear-gradient(135deg, var(--primary), var(--primary-strong));
  border-color:transparent;
  box-shadow:0 14px 26px rgba(37,99,235,.22);
}
.btn-primary:hover,
.btn-primary:focus-visible,
.btn-primary-soft:hover,
.btn-primary-soft:focus-visible{
  transform:translateY(-1px);
  box-shadow:0 18px 30px rgba(37,99,235,.26);
}
.btn-outline-primary,
.btn-outline-secondary,
.btn-outline-success,
.btn-outline-warning,
.btn-outline-danger,
.btn-outline-info,
.btn-light{
  border-width:1px;
  background:#fff;
}
.btn-sm{
  border-radius:12px;
}
.form-control,
.form-select{
  min-height:46px;
  border-radius:14px;
  border-color:#d9e2ee;
  background:#fff;
  box-shadow:0 1px 2px rgba(15,23,42,.02);
}
textarea.form-control{
  min-height:auto;
}
.form-control:focus,
.form-select:focus{
  border-color:#8fb7ff;
  box-shadow:0 0 0 .24rem rgba(37,99,235,.14);
}
.form-label{
  margin-bottom:8px;
  font-size:13px;
  font-weight:700;
  color:#334155;
}
.panel,
.hero-panel,
.stat-card,
.kanban-column,
.project-card,
.detail-meta-grid > div,
.info-card,
.payment-card,
.task-row,
.closing-matrix div,
.report-grid div,
.notif{
  box-shadow:var(--shadow-card);
}
.panel{
  padding:24px;
  border-radius:var(--radius-lg);
  border:1px solid #e4ebf3;
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.98));
}
.hero-panel{
  min-height:220px;
  align-items:center;
  border-radius:30px;
  border-color:#dce8fb;
  box-shadow:0 26px 54px rgba(37,99,235,.10);
}
.hero-panel::after{
  content:"";
  position:absolute;
  right:-34px;
  bottom:-34px;
  width:180px;
  height:180px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(6,182,212,.16), transparent 68%);
}
.hero-panel > *{
  position:relative;
  z-index:1;
}
.hero-panel h2{
  letter-spacing:-.04em;
}
.hero-actions{
  align-items:center;
}
.stat-grid,
.metric-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
}
.stat-card{
  min-height:182px;
  padding:20px;
  border-radius:22px;
  border:1px solid #e4ebf3;
  background:linear-gradient(180deg, #ffffff, #f8fbff);
}
.stat-card strong{
  letter-spacing:-.04em;
}
.stat-card small{
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.stat-card span{
  line-height:1.45;
}
.stat-card a{
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.stat-card a::after{
  content:"\F138";
  font-family:bootstrap-icons;
  font-size:12px;
}
.stat-icon{
  box-shadow:inset 0 1px 0 rgba(255,255,255,.6);
}
.section-head{
  margin-bottom:20px;
}
.section-head h3{
  font-size:19px;
  letter-spacing:-.02em;
}
.section-head p{
  line-height:1.55;
  max-width:72ch;
}
.filter-bar,
form.row.g-2.mb-3,
form.row.g-2,
form.row.g-3,
form.row.g-2.mb-3,
form.row.g-3.mb-3{
  align-items:end;
}
.filter-bar{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
  padding:16px;
  margin-bottom:18px;
  border:1px solid #e4ebf3;
  border-radius:20px;
  background:linear-gradient(180deg, #fbfdff, #f8fafc);
}
.filter-bar .btn{
  min-height:46px;
}
.table-responsive{
  border:1px solid #e6edf5;
  border-radius:20px;
  background:#fff;
  overflow:auto;
}
.table{
  margin-bottom:0;
}
.table thead th{
  padding:16px 18px;
  background:#f8fbff;
  border-bottom-color:#e5edf6;
  white-space:nowrap;
}
.table tbody td{
  padding:16px 18px;
  border-color:#edf2f7;
  vertical-align:middle;
}
.table tbody tr{
  background:#fff;
}
.table tbody tr:hover{
  background:#fafcff;
}
.table tbody tr.table-danger,
.table tbody tr.table-danger:hover{
  background:#fff8f8;
}
.mini-progress{
  height:8px;
  margin:10px 0 8px;
  background:#e8eef6;
}
.mini-progress b{
  box-shadow:0 8px 18px rgba(37,99,235,.18);
}
.task-row{
  padding:16px 18px;
  border-radius:18px;
  border-color:#e5edf6;
  background:linear-gradient(180deg, #ffffff, #fbfdff);
}
.task-row + .task-row{
  margin-top:12px;
}
.task-row strong{
  display:block;
  margin-bottom:4px;
}
.kanban-board{
  gap:18px;
  padding-bottom:8px;
}
.kanban-column{
  min-width:320px;
  background:linear-gradient(180deg, #f8fbff, #f8fafc);
  border-color:#dde7f3;
}
.kanban-column h4{
  position:sticky;
  top:0;
  z-index:1;
  padding-bottom:10px;
  background:linear-gradient(180deg, #f8fbff 70%, rgba(248,251,255,0));
}
.project-card{
  padding:16px;
  border-radius:18px;
  background:linear-gradient(180deg, #ffffff, #fbfdff);
}
.project-card h5{
  font-size:15px;
}
.project-card footer a{
  font-weight:700;
  color:var(--primary);
}
.detail-header{
  overflow:hidden;
}
.detail-header::after{
  content:"";
  position:absolute;
  inset:auto -10% -55% auto;
  width:280px;
  height:280px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(37,99,235,.10), transparent 70%);
}
.detail-title-row,
.detail-meta-grid{
  position:relative;
  z-index:1;
}
.detail-title-row .btn{
  flex-shrink:0;
}
.detail-meta-grid{
  gap:16px;
}
.detail-meta-grid > div,
.info-card{
  background:linear-gradient(180deg, #ffffff, #fbfdff);
  border-color:#e4ebf3;
}
.detail-tabs{
  flex-wrap:wrap;
}
.detail-tabs .nav-link{
  border:1px solid #dce6f2;
  background:#fff;
  padding:10px 16px;
}
.detail-tabs .nav-link.active{
  border-color:transparent;
  box-shadow:0 12px 26px rgba(37,99,235,.18);
}
.workflow-timeline div{
  border:1px solid transparent;
}
.workflow-timeline .done,
.workflow-timeline .active{
  box-shadow:inset 0 1px 0 rgba(255,255,255,.5);
}
.empty-state{
  padding:28px 20px;
  border-radius:20px;
  border-style:solid;
  background:linear-gradient(180deg, #fbfdff, #f8fafc);
}
.alert{
  border:1px solid transparent;
  border-radius:18px;
  padding:14px 16px;
  box-shadow:var(--shadow-soft);
}
.alert strong{
  font-size:14px;
}
.notification-list{
  gap:14px;
}
.notif{
  align-items:flex-start;
  background:linear-gradient(180deg, #ffffff, #fbfdff);
}
.notif.unread{
  border-color:#bfd5ff;
  background:linear-gradient(180deg, #f8fbff, #f3f8ff);
}
.notif.unread::before{
  content:"";
  width:10px;
  height:10px;
  margin-top:6px;
  border-radius:999px;
  background:var(--primary);
  box-shadow:0 0 0 4px rgba(37,99,235,.10);
  flex:0 0 auto;
}
.notif.unread i{
  display:none;
}
.notif div{
  min-width:0;
}
.notif strong{
  display:block;
  margin-bottom:4px;
}
.notif small + small{
  margin-top:6px;
  font-size:12px;
}
.sidebar{
  border-right:1px solid rgba(255,255,255,.08);
  box-shadow:24px 0 60px rgba(15,23,42,.16);
}
.sidebar-nav{
  gap:8px;
}
.sidebar-nav a{
  position:relative;
  padding:13px 14px;
  border:1px solid transparent;
}
.sidebar-nav a.active{
  border-color:rgba(191,219,254,.24);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.sidebar-nav.mobile a{
  border:1px solid #e3ebf4;
  background:#fff;
}
.sidebar-nav.mobile a.active{
  background:#eff6ff;
  color:var(--primary);
  border-color:#bfdbfe;
}
.sidebar-group{
  display:grid;
  gap:8px;
  margin-top:4px;
}
.sidebar-group summary{
  list-style:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:13px 14px;
  border-radius:14px;
  border:1px solid transparent;
  color:#cbd5e1;
  font-weight:600;
  cursor:pointer;
}
.sidebar-group summary::-webkit-details-marker{
  display:none;
}
.sidebar-group summary span{
  display:flex;
  align-items:center;
  gap:12px;
}
.sidebar-group summary:hover,
.sidebar-group summary.active{
  background:rgba(255,255,255,.12);
  color:#fff;
  border-color:rgba(191,219,254,.24);
}
.sidebar-group[open] .sidebar-group-arrow{
  transform:rotate(180deg);
}
.sidebar-group-arrow{
  font-size:14px;
  transition:transform .2s ease;
}
.sidebar-subnav{
  display:grid;
  gap:6px;
  margin-left:14px;
  padding-left:16px;
  border-left:1px solid rgba(191,219,254,.18);
}
.sidebar-subnav a{
  display:flex;
  align-items:center;
  min-height:42px;
  padding:10px 14px;
  border-radius:12px;
  color:#bfdbfe;
  font-size:13px;
  font-weight:600;
}
.sidebar-subnav a:hover,
.sidebar-subnav a.active{
  background:rgba(255,255,255,.10);
  color:#fff;
}
.sidebar-group.mobile summary{
  color:var(--text);
  background:#fff;
  border-color:#e3ebf4;
}
.sidebar-group.mobile summary:hover,
.sidebar-group.mobile summary.active{
  background:#eff6ff;
  color:var(--primary);
  border-color:#bfdbfe;
}
.sidebar-subnav.mobile{
  margin-left:10px;
  padding-left:14px;
  border-left:1px solid #dbe7f5;
}
.sidebar-subnav.mobile a{
  background:#fff;
  border:1px solid #e3ebf4;
  color:#475569;
}
.sidebar-subnav.mobile a:hover,
.sidebar-subnav.mobile a.active{
  background:#eff6ff;
  color:var(--primary);
  border-color:#bfdbfe;
}
.sidebar-user{
  background:rgba(255,255,255,.10);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
@media (min-width:1200px){
  .sidebar{
    width:232px;
    padding:18px;
  }
  .main-wrap{
    padding-left:232px;
  }
  .sidebar .brand-lockup{
    gap:10px;
  }
  .sidebar .brand-mark{
    width:40px;
    height:40px;
    border-radius:13px;
  }
  .sidebar .brand-lockup strong{
    font-size:16px;
  }
  .sidebar .brand-lockup small{
    font-size:12px;
  }
  .sidebar-nav{
    gap:5px;
    margin-top:22px;
    padding-right:4px;
  }
  .sidebar-nav a,
  .sidebar-group summary{
    gap:10px;
    padding:10px 11px;
    border-radius:12px;
    font-size:14px;
  }
  .sidebar-nav i,
  .sidebar-group summary i:first-child{
    font-size:16px;
  }
  .sidebar-group summary span{
    gap:10px;
  }
  .sidebar-subnav{
    margin-left:10px;
    padding-left:12px;
  }
  .sidebar-subnav a{
    min-height:36px;
    padding:8px 10px;
    font-size:12px;
  }
  .sidebar-user{
    gap:10px;
    padding:10px;
    border-radius:15px;
  }
  .sidebar-user img{
    width:34px;
    height:34px;
  }
  .sidebar-user strong{
    font-size:13px;
    line-height:1.2;
  }
  .sidebar-user small{
    font-size:11px;
    line-height:1.25;
    word-break:break-word;
  }
}
.offcanvas{
  background:rgba(248,250,252,.98);
  backdrop-filter:blur(18px);
}
.offcanvas-header{
  padding:20px 20px 10px;
}
.offcanvas-body{
  padding:14px 20px 24px;
}
.bottom-nav{
  backdrop-filter:blur(18px);
  background:rgba(255,255,255,.95);
}
.bottom-nav a.active{
  box-shadow:0 8px 18px rgba(37,99,235,.14);
}
.pagination{
  gap:6px;
  margin-top:18px;
}
.page-item .page-link{
  border-radius:12px;
  border-color:#dbe5f1;
  color:#334155;
  min-width:40px;
  text-align:center;
  box-shadow:none;
}
.page-item.active .page-link{
  background:linear-gradient(135deg, var(--primary), var(--primary-strong));
  border-color:transparent;
}
.page-item.disabled .page-link{
  background:#f8fafc;
}
.mobile-card{
  border-radius:18px;
  background:linear-gradient(180deg, #ffffff, #fbfdff);
  box-shadow:var(--shadow-card);
}
.content-matrix > *,
.closing-matrix div,
.payment-card,
.report-grid div{
  border-color:#e5edf6;
  background:linear-gradient(180deg, #ffffff, #fbfdff);
}
@media (max-width:1399px){
  .stat-grid,
  .metric-grid{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
}
@media (max-width:1199px){
  .topbar{
    padding:14px 16px;
  }
  .filter-bar{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media (max-width:767px){
  .topbar{
    gap:12px;
  }
  .topbar h1{
    font-size:20px;
  }
  .panel{
    padding:18px;
    border-radius:20px;
  }
  .hero-panel{
    min-height:auto;
    border-radius:24px;
  }
  .stat-grid,
  .metric-grid{
    grid-template-columns:1fr 1fr;
    gap:12px;
  }
  .stat-card{
    min-height:156px;
    padding:16px;
  }
  .filter-bar{
    grid-template-columns:1fr;
    padding:14px;
  }
  .table-responsive{
    border:0;
    background:transparent;
  }
  .task-row{
    padding:14px;
  }
  .content-matrix{
    grid-template-columns:1fr;
  }
}

.finance-tabs{display:flex;gap:8px;overflow-x:auto;padding:7px;border:1px solid #dfe8f3;border-radius:20px;background:rgba(255,255,255,.9);box-shadow:0 14px 34px rgba(15,23,42,.06);scrollbar-width:none}
.finance-tabs::-webkit-scrollbar{display:none}
.finance-tabs a{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:10px 15px;border-radius:14px;color:#64748b;font-weight:800;white-space:nowrap;transition:background-color .16s ease,color .16s ease,box-shadow .16s ease}
.finance-tabs a:hover{background:#f1f5f9;color:#1e40af}
.finance-tabs a.active{background:linear-gradient(135deg,#2563eb,#0891b2);color:#fff;box-shadow:0 10px 24px rgba(37,99,235,.22)}
.finance-tabs a b{display:grid;place-items:center;min-width:22px;height:22px;padding:0 6px;border-radius:999px;background:#ef4444;color:#fff;font-size:11px}
@media (max-width:767px){
  .finance-tabs{margin:0 -2px;border-radius:17px}
  .finance-tabs a{min-height:40px;padding:9px 12px}
}

.customer-combobox{position:relative}
.customer-combobox-control{position:relative;display:flex;align-items:center}
.customer-combobox-control>i{position:absolute;left:15px;z-index:2;color:#64748b;font-size:16px;pointer-events:none}
.customer-combobox-control .form-control{padding-left:42px;padding-right:46px}
.customer-combobox.has-selection .form-control{font-weight:700;color:#0f172a;background:#f8fbff}
.customer-combobox-clear{position:absolute;right:9px;width:32px;height:32px;display:grid;place-items:center;border:0;border-radius:10px;background:#eef2f7;color:#64748b}
.customer-combobox-clear:hover{background:#fee2e2;color:#dc2626}
.customer-combobox.is-invalid .form-control{border-color:#dc3545}
.customer-combobox-results{position:absolute;z-index:40;top:calc(100% + 7px);left:0;right:0;max-height:310px;overflow-y:auto;padding:7px;border:1px solid #dbe5f1;border-radius:16px;background:#fff;box-shadow:0 22px 55px rgba(15,23,42,.16)}
.customer-combobox-option{width:100%;display:flex;align-items:center;gap:11px;padding:10px 11px;border:0;border-radius:11px;background:transparent;color:#0f172a;text-align:left}
.customer-combobox-option:hover,.customer-combobox-option.is-active{background:#eff6ff;color:#1d4ed8}
.customer-combobox-option>span:last-child{min-width:0}
.customer-combobox-option strong,.customer-combobox-option small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.customer-combobox-option small{margin-top:2px;color:#64748b}
.customer-option-icon{width:34px;height:34px;display:grid;place-items:center;flex:0 0 auto;border-radius:11px;background:#dbeafe;color:#2563eb}
.customer-combobox-loading,.customer-combobox-empty{display:flex;align-items:center;justify-content:center;gap:9px;min-height:70px;padding:14px;color:#64748b;text-align:center}
.customer-combobox-loading .btn-loading-spinner{color:#2563eb}
@media (max-width:767px){
  .customer-combobox-results{position:fixed;z-index:1060;top:auto;left:12px;right:12px;bottom:82px;max-height:min(52vh,380px);border-radius:20px;box-shadow:0 24px 70px rgba(15,23,42,.24)}
}

.region-loading{position:relative;overflow:hidden;min-height:180px}
.region-loading > *{opacity:0!important;pointer-events:none}
.region-loading::before{content:"";position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(248,250,252,.98))}
.region-loading::after{content:"";position:absolute;inset:18px;z-index:3;border-radius:20px;background:
linear-gradient(90deg,#e2e8f0,#f8fafc,#e2e8f0) 0 0/42% 16px no-repeat,
linear-gradient(90deg,#e2e8f0,#f8fafc,#e2e8f0) 0 38px/100% 52px no-repeat,
linear-gradient(90deg,#e2e8f0,#f8fafc,#e2e8f0) 0 108px/100% 52px no-repeat,
linear-gradient(90deg,#e2e8f0,#f8fafc,#e2e8f0) 0 178px/100% 52px no-repeat;
background-size:200% 100%,100% 52px,100% 52px,100% 52px;
animation:skeleton 1.2s infinite}
.table-responsive.region-loading{min-height:260px}
.kanban-board.region-loading{min-height:320px}
.mobile-card-list.region-loading{min-height:220px}
.detail-header.region-loading{min-height:240px}

.app-loader{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:24px;background:rgba(248,250,252,.76);backdrop-filter:blur(8px);opacity:0;pointer-events:none;transition:opacity .18s ease;z-index:1055}
.app-loader.is-visible{opacity:1;pointer-events:auto}
.app-loader-card{width:min(100%,860px);display:grid;gap:18px;padding:24px;border:1px solid #dfe8f3;border-radius:28px;background:rgba(255,255,255,.96);box-shadow:0 24px 60px rgba(15,23,42,.12)}
.app-loader-card.guest{width:min(100%,420px)}
.app-loader-head{display:flex;gap:12px;align-items:center}
.app-loader-pill{display:block;width:180px;height:18px;border-radius:999px;background:linear-gradient(90deg,#e2e8f0,#f8fafc,#e2e8f0);background-size:200% 100%;animation:skeleton 1.2s infinite}
.app-loader-pill.short{width:92px}
.app-loader-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.app-loading{cursor:progress}
.app-loading .app-shell,.app-loading .login-shell,.app-loading main{pointer-events:none}
.btn.is-loading{display:inline-flex;align-items:center;justify-content:center;gap:8px;pointer-events:none}
.btn-loading-spinner{width:16px;height:16px;border:2px solid currentColor;border-right-color:transparent;border-radius:999px;animation:btnSpin .75s linear infinite}
@keyframes btnSpin{to{transform:rotate(360deg)}}
@media (max-width:767px){
  .topbar-actions{
    gap:10px;
  }
  .app-loader-card{padding:18px;border-radius:22px}
  .app-loader-grid{grid-template-columns:1fr}
  .region-loading::after{inset:14px;background:
  linear-gradient(90deg,#e2e8f0,#f8fafc,#e2e8f0) 0 0/56% 14px no-repeat,
  linear-gradient(90deg,#e2e8f0,#f8fafc,#e2e8f0) 0 32px/100% 44px no-repeat,
  linear-gradient(90deg,#e2e8f0,#f8fafc,#e2e8f0) 0 92px/100% 44px no-repeat,
  linear-gradient(90deg,#e2e8f0,#f8fafc,#e2e8f0) 0 152px/100% 44px no-repeat;
  background-size:200% 100%,100% 44px,100% 44px,100% 44px}
}

.topbar .search-box{
  border-radius:18px;
}
.topbar .topbar-action-btn{
  display:inline-flex;
  justify-content:center;
  min-height:40px;
  max-height:44px;
  padding:7px 13px;
  line-height:1.15;
  box-shadow:0 12px 24px rgba(15,23,42,.08);
}
.topbar .topbar-action-btn-primary{
  color:#fff;
  background:linear-gradient(135deg,#2563eb,#1d4ed8);
  box-shadow:0 14px 28px rgba(37,99,235,.24);
}
.topbar .topbar-action-btn-danger{
  color:#dc2626;
  background:linear-gradient(180deg,#fff,#fff7f7);
  border-color:#fecaca;
  box-shadow:0 10px 22px rgba(239,68,68,.10);
}
.topbar .topbar-action-icon{
  width:24px;
  height:24px;
  border-radius:9px;
  font-size:13px;
}
.topbar .topbar-action-btn span:last-child{
  white-space:nowrap;
}
@media (min-width:1200px) and (max-width:1399px){
  .topbar .topbar-action-btn{
    padding:7px 10px;
    font-size:12px;
  }
  .topbar .topbar-action-icon{
    width:22px;
    height:22px;
    font-size:12px;
  }
}

/* Lightweight workflow loading motion */
.app-loader{
  background:
    radial-gradient(circle at 20% 18%, rgba(37,99,235,.16), transparent 28%),
    radial-gradient(circle at 82% 80%, rgba(6,182,212,.14), transparent 26%),
    rgba(241,245,249,.78);
  backdrop-filter:blur(12px);
}
.app-loader-card{
  position:relative;
  overflow:hidden;
  width:min(100%,360px);
  place-items:center;
  gap:14px;
  padding:30px;
  border:1px solid rgba(219,234,254,.95);
  border-radius:30px;
  background:linear-gradient(145deg,rgba(255,255,255,.98),rgba(248,251,255,.96));
  box-shadow:0 30px 80px rgba(15,23,42,.16),inset 0 1px 0 rgba(255,255,255,.9);
  animation:workflowCardEnter .28s ease-out both;
}
.app-loader-card::before{
  content:"";
  position:absolute;
  inset:-90px auto auto -70px;
  width:210px;
  height:210px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(37,99,235,.16),transparent 68%);
  animation:workflowGlow 2.4s ease-in-out infinite;
}
.app-loader-card::after{
  content:"";
  position:absolute;
  inset:auto -55px -90px auto;
  width:190px;
  height:190px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(6,182,212,.13),transparent 68%);
  animation:workflowGlow 2.4s ease-in-out .5s infinite;
  pointer-events:none;
}
.workflow-loader{
  position:relative;
  z-index:1;
  width:112px;
  height:112px;
  display:grid;
  place-items:center;
}
.workflow-loader-orbit{
  position:absolute;
  inset:5px;
  border:1px solid rgba(37,99,235,.24);
  border-radius:50%;
  animation:workflowOrbit 2.1s linear infinite;
}
.workflow-loader-orbit::before{
  content:"";
  position:absolute;
  inset:13px;
  border:1px dashed rgba(6,182,212,.28);
  border-radius:50%;
}
.workflow-loader-dot{
  position:absolute;
  width:11px;
  height:11px;
  border-radius:50%;
  box-shadow:0 4px 12px currentColor;
}
.workflow-loader-dot.dot-one{top:-5px;left:44px;background:#2563eb;color:rgba(37,99,235,.35)}
.workflow-loader-dot.dot-two{right:3px;bottom:17px;background:#06b6d4;color:rgba(6,182,212,.35)}
.workflow-loader-dot.dot-three{left:4px;bottom:17px;background:#22c55e;color:rgba(34,197,94,.3)}
.workflow-loader-core{
  position:relative;
  z-index:2;
  width:58px;
  height:58px;
  display:grid;
  place-items:center;
  border-radius:20px;
  color:#fff;
  font-size:26px;
  background:linear-gradient(135deg,#2563eb,#0891b2);
  box-shadow:0 16px 30px rgba(37,99,235,.28),inset 0 1px 0 rgba(255,255,255,.35);
  animation:workflowCore 1.8s ease-in-out infinite;
}
.workflow-loader-pulse{
  position:absolute;
  inset:27px;
  border:2px solid rgba(37,99,235,.24);
  border-radius:22px;
  animation:workflowPulse 1.8s ease-out infinite;
}
.workflow-loader-copy{
  position:relative;
  z-index:1;
  display:grid;
  gap:4px;
  text-align:center;
}
.workflow-loader-copy strong{
  font-family:Poppins,Inter,sans-serif;
  font-size:20px;
  color:#0f172a;
  letter-spacing:-.02em;
}
.workflow-loader-copy span{
  color:#64748b;
  font-size:13px;
}
.workflow-loader-progress{
  position:relative;
  z-index:1;
  width:100%;
  height:7px;
  overflow:hidden;
  border-radius:999px;
  background:#e8eef6;
}
.workflow-loader-progress span{
  display:block;
  width:44%;
  height:100%;
  border-radius:inherit;
  background:linear-gradient(90deg,#2563eb,#06b6d4,#22c55e);
  box-shadow:0 0 14px rgba(37,99,235,.35);
  animation:workflowProgress 1.35s ease-in-out infinite;
}
.workflow-loader-steps{
  position:relative;
  z-index:1;
  display:flex;
  gap:7px;
}
.workflow-loader-steps i{
  width:6px;
  height:6px;
  border-radius:50%;
  background:#cbd5e1;
  animation:workflowStep 1.2s ease-in-out infinite;
}
.workflow-loader-steps i:nth-child(2){animation-delay:.16s}
.workflow-loader-steps i:nth-child(3){animation-delay:.32s}
.app-loader-card.guest{
  width:min(100%,340px);
}
.region-loading::before{
  background:
    radial-gradient(circle at 15% 18%, rgba(37,99,235,.08), transparent 22%),
    linear-gradient(180deg,rgba(255,255,255,.97),rgba(248,250,252,.99));
}
.region-loading::after{
  animation:skeleton 1.2s infinite, regionPulse 1.9s ease-in-out infinite;
}
.btn.is-loading{
  box-shadow:0 10px 24px rgba(37,99,235,.16);
}
.btn-loading-spinner{
  border-width:2px;
  animation:btnSpin .75s linear infinite, loaderPulse 1.6s ease-in-out infinite;
}
@keyframes workflowCardEnter{
  from{opacity:0;transform:translateY(8px) scale(.98)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
@keyframes workflowOrbit{
  to{transform:rotate(360deg)}
}
@keyframes workflowCore{
  0%,100%{transform:scale(1) rotate(0)}
  50%{transform:scale(1.06) rotate(-3deg)}
}
@keyframes workflowPulse{
  0%{opacity:.75;transform:scale(.8)}
  75%,100%{opacity:0;transform:scale(1.75)}
}
@keyframes workflowProgress{
  0%{transform:translateX(-115%)}
  55%{transform:translateX(75%)}
  100%{transform:translateX(230%)}
}
@keyframes workflowStep{
  0%,100%{background:#cbd5e1;transform:scale(.8)}
  50%{background:#2563eb;transform:scale(1.25)}
}
@keyframes workflowGlow{
  0%,100%{opacity:.65;transform:scale(1)}
  50%{opacity:1;transform:scale(1.08)}
}
@keyframes loaderPulse{
  0%,100%{opacity:1}
  50%{opacity:.78}
}
@keyframes regionPulse{
  0%,100%{opacity:1}
  50%{opacity:.9}
}
@media (prefers-reduced-motion:reduce){
  .app-loader-card,
  .app-loader-card::before,
  .app-loader-card::after,
  .workflow-loader-orbit,
  .workflow-loader-core,
  .workflow-loader-pulse,
  .workflow-loader-progress span,
  .workflow-loader-steps i{
    animation-duration:3s;
    animation-timing-function:linear;
  }
  .workflow-loader-core{animation:none}
  .workflow-loader-pulse{display:none}
}

.confirm-modal .modal-dialog{max-width:520px}
.confirm-modal .modal-content{position:relative;overflow:hidden;border:1px solid #dce6f4;border-radius:28px;background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,250,252,.98));box-shadow:0 30px 70px rgba(15,23,42,.18)}
.confirm-modal-glow{position:absolute;inset:-40% auto auto -10%;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(37,99,235,.16),transparent 70%);pointer-events:none}
.confirm-modal .modal-body{position:relative;display:grid;gap:20px;padding:28px}
.confirm-modal-icon{width:64px;height:64px;display:grid;place-items:center;border-radius:22px;background:linear-gradient(135deg,#eff6ff,#dbeafe);color:var(--primary);font-size:30px;box-shadow:inset 0 1px 0 rgba(255,255,255,.8),0 14px 28px rgba(37,99,235,.14)}
.confirm-modal-copy{display:grid;gap:8px}
.confirm-modal-eyebrow{font-size:12px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#64748b}
.confirm-modal-copy h3{margin:0;font-size:28px;letter-spacing:-.04em;color:#0f172a}
.confirm-modal-copy p{margin:0;color:#475569;line-height:1.65;font-size:15px}
.confirm-modal-actions{display:flex;justify-content:flex-end;gap:10px;padding-top:4px}
.confirm-modal .btn{min-width:128px}
.modal-backdrop.show{opacity:.55;backdrop-filter:blur(3px)}
@media (max-width:767px){
  .confirm-modal .modal-dialog{max-width:calc(100% - 24px);margin:12px auto}
  .confirm-modal .modal-body{padding:22px}
  .confirm-modal-copy h3{font-size:24px}
  .confirm-modal-actions{flex-direction:column-reverse}
  .confirm-modal .btn{width:100%}
}

/* Staff task kanban polish */
.task-kanban-board{
  align-items:flex-start;
  padding-top:4px;
}
.task-board-metrics{
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
}
.task-board-metrics .stat-card{
  min-height:132px;
  padding:14px 16px;
  border-radius:20px;
  box-shadow:0 14px 30px rgba(15,23,42,.06);
}
.task-board-metrics .stat-card:before{
  width:84px;
  height:84px;
  inset:auto -18px -30px auto;
}
.task-board-metrics .stat-icon{
  width:34px;
  height:34px;
  margin-bottom:6px;
  border-radius:12px;
  font-size:17px;
}
.task-board-metrics .stat-card small{
  font-size:11px;
  letter-spacing:.05em;
}
.task-board-metrics .stat-card strong{
  font-size:24px;
}
.task-board-metrics .stat-card a{
  font-size:12px;
  margin-top:6px;
}
.board-density-note{
  display:flex;
  align-items:flex-start;
  gap:10px;
  margin-bottom:14px;
  padding:11px 14px;
  border:1px solid #dbe7f5;
  border-radius:16px;
  background:linear-gradient(180deg,#fbfdff,#f8fafc);
  color:#64748b;
  font-size:12px;
  line-height:1.55;
}
.board-density-note i{
  color:#2563eb;
  font-size:15px;
  margin-top:1px;
}
.board-limit-form{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 8px 6px 10px;
  border:1px solid #dbe7f5;
  border-radius:14px;
  background:linear-gradient(180deg,#ffffff,#f8fafc);
}
.board-limit-label{
  margin:0;
  font-size:12px;
  font-weight:700;
  color:#64748b;
  white-space:nowrap;
}
.board-limit-select{
  min-width:128px;
  min-height:36px;
  padding-top:5px;
  padding-bottom:5px;
  border-radius:10px;
  font-size:12px;
}
.task-head-summary-strip{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
.task-head-summary-card{
  position:relative;
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:14px 16px;
  border-radius:18px;
  border:1px solid #e4ebf3;
  background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,250,252,.98));
  box-shadow:0 14px 30px rgba(15,23,42,.07);
  overflow:hidden;
}
.task-head-summary-card::before{
  content:"";
  position:absolute;
  inset:0 auto 0 0;
  width:4px;
  background:linear-gradient(180deg,#94a3b8,#64748b);
}
.task-head-summary-card.review::before{
  background:linear-gradient(180deg,#f59e0b,#facc15);
}
.task-head-summary-card.overdue::before{
  background:linear-gradient(180deg,#ef4444,#f97316);
}
.task-head-summary-icon{
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border-radius:14px;
  background:linear-gradient(135deg,#f8fafc,#eef2f7);
  color:#475569;
  font-size:18px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.85);
  flex:0 0 auto;
}
.task-head-summary-card.review .task-head-summary-icon{
  background:linear-gradient(135deg,#fff7cc,#fef3c7);
  color:#a16207;
}
.task-head-summary-card.overdue .task-head-summary-icon{
  background:linear-gradient(135deg,#fff1f2,#ffe4e6);
  color:#be123c;
}
.task-head-summary-card small{
  display:block;
  margin-bottom:2px;
  font-size:10px;
  font-weight:800;
  letter-spacing:.07em;
  text-transform:uppercase;
  color:#64748b;
}
.task-head-summary-card strong{
  display:block;
  margin-bottom:2px;
  font-family:Poppins,Inter,sans-serif;
  font-size:24px;
  line-height:1;
  letter-spacing:-.04em;
  color:#0f172a;
}
.task-head-summary-card p{
  margin:0;
  color:#64748b;
  line-height:1.45;
  font-size:12px;
}
.task-kanban-column{
  position:relative;
  overflow:hidden;
  min-width:332px;
  padding:16px;
  border-width:1px;
  box-shadow:0 18px 42px rgba(15,23,42,.08);
}
.task-kanban-column::before{
  content:"";
  position:absolute;
  inset:0 0 auto;
  height:4px;
  background:linear-gradient(90deg,#cbd5e1,#94a3b8);
}
.task-kanban-column.queue{
  background:linear-gradient(180deg,#fbfdff,#f8fafc);
}
.task-kanban-column.queue::before{
  background:linear-gradient(90deg,#94a3b8,#64748b);
}
.task-kanban-column.active{
  background:linear-gradient(180deg,#f8fbff,#eff6ff);
}
.task-kanban-column.active::before{
  background:linear-gradient(90deg,#2563eb,#06b6d4);
}
.task-kanban-column.review{
  background:linear-gradient(180deg,#fffdf5,#fffbeb);
}
.task-kanban-column.review::before{
  background:linear-gradient(90deg,#f59e0b,#facc15);
}
.task-kanban-column.revision{
  background:linear-gradient(180deg,#fff9f4,#fff7ed);
}
.task-kanban-column.revision::before{
  background:linear-gradient(90deg,#f97316,#fb923c);
}
.task-kanban-column.done{
  background:linear-gradient(180deg,#f5fff8,#ecfdf5);
}
.task-kanban-column.done::before{
  background:linear-gradient(90deg,#16a34a,#22c55e);
}
.task-kanban-header{
  position:sticky;
  top:0;
  z-index:4;
  margin:-16px -16px 14px;
  padding:16px 16px 14px;
  background:linear-gradient(180deg,rgba(255,255,255,.94),rgba(255,255,255,.88));
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(226,232,240,.82);
  box-shadow:0 14px 22px rgba(148,163,184,.08);
}
.task-kanban-column.queue .task-kanban-header{
  background:linear-gradient(180deg,rgba(248,250,252,.96),rgba(248,250,252,.88));
}
.task-kanban-column.active .task-kanban-header{
  background:linear-gradient(180deg,rgba(239,246,255,.96),rgba(239,246,255,.88));
}
.task-kanban-column.review .task-kanban-header{
  background:linear-gradient(180deg,rgba(255,251,235,.97),rgba(255,251,235,.89));
}
.task-kanban-column.revision .task-kanban-header{
  background:linear-gradient(180deg,rgba(255,247,237,.97),rgba(255,247,237,.89));
}
.task-kanban-column.done .task-kanban-header{
  background:linear-gradient(180deg,rgba(236,253,245,.97),rgba(236,253,245,.89));
}
.task-kanban-header h4{
  margin-bottom:10px;
}
.task-kanban-column-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.task-kanban-monitoring{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  margin-top:12px;
}
.task-kanban-monitor-chip{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:7px 10px;
  border-radius:999px;
  font-size:11px;
  font-weight:800;
  letter-spacing:.02em;
  background:rgba(255,255,255,.82);
  color:#334155;
  border:1px solid rgba(226,232,240,.9);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
}
.task-kanban-monitor-chip i{
  font-size:12px;
}
.task-kanban-monitor-chip.review{
  background:linear-gradient(135deg,#fff8db,#fef3c7);
  color:#a16207;
  border-color:#fde68a;
}
.task-kanban-monitor-chip.followup{
  background:linear-gradient(135deg,#fff1f2,#ffe4e6);
  color:#be123c;
  border-color:#fecdd3;
}
.task-kanban-monitor-chip.neutral{
  background:linear-gradient(135deg,#f8fafc,#eef2f7);
  color:#475569;
  border-color:#dbe3ed;
}
.task-kanban-column-indicator{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.82);
  color:#334155;
  font-size:12px;
  font-weight:800;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.75);
}
.task-kanban-column-indicator::before{
  content:"";
  width:8px;
  height:8px;
  border-radius:999px;
  background:#94a3b8;
  box-shadow:0 0 0 4px rgba(148,163,184,.12);
}
.task-kanban-column.active .task-kanban-column-indicator::before{
  background:#2563eb;
  box-shadow:0 0 0 4px rgba(37,99,235,.14);
}
.task-kanban-column.review .task-kanban-column-indicator::before{
  background:#f59e0b;
  box-shadow:0 0 0 4px rgba(245,158,11,.14);
}
.task-kanban-column.revision .task-kanban-column-indicator::before{
  background:#f97316;
  box-shadow:0 0 0 4px rgba(249,115,22,.14);
}
.task-kanban-column.done .task-kanban-column-indicator::before{
  background:#16a34a;
  box-shadow:0 0 0 4px rgba(34,197,94,.14);
}
.task-kanban-column-subtitle{
  font-size:11px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#64748b;
}
.task-kanban-heading{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#0f172a;
}
.task-kanban-heading i{
  width:28px;
  height:28px;
  display:grid;
  place-items:center;
  border-radius:10px;
  background:rgba(255,255,255,.78);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
}
.task-kanban-card{
  position:relative;
  isolation:isolate;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background-color .18s ease;
  cursor:grab;
}
.task-kanban-card::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  border:1px dashed transparent;
  transition:border-color .18s ease, opacity .18s ease;
  opacity:0;
  pointer-events:none;
}
.task-kanban-card:hover,
.task-kanban-card:focus-within{
  transform:translateY(-4px) rotate(-.35deg);
  box-shadow:0 22px 38px rgba(15,23,42,.12);
  border-color:#cfe0f6;
}
.task-kanban-card:hover::after,
.task-kanban-card:focus-within::after{
  opacity:1;
  border-color:rgba(37,99,235,.18);
}
.task-kanban-card:active{
  cursor:grabbing;
  transform:translateY(-1px) scale(.995);
}
.task-kanban-card > div:first-child{
  align-items:flex-start;
}
.task-kanban-meta{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  margin-top:12px;
}
.task-kanban-late-badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:7px 10px;
  border-radius:999px;
  background:linear-gradient(135deg,#fee2e2,#fecaca);
  color:#b91c1c;
  font-size:11px;
  font-weight:800;
  letter-spacing:.03em;
  text-transform:uppercase;
  box-shadow:0 10px 24px rgba(239,68,68,.16);
}
.task-kanban-card.is-late{
  border-color:#fca5a5;
  background:linear-gradient(180deg,#ffffff,#fff7f7);
}
.task-kanban-card.is-late::before{
  content:"";
  position:absolute;
  inset:12px auto 12px 0;
  width:4px;
  border-radius:999px;
  background:linear-gradient(180deg,#ef4444,#f97316);
}
.task-kanban-footer{
  margin-top:2px;
}
.task-kanban-deadline{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:7px 10px;
  border-radius:999px;
  background:#f8fafc;
  color:#64748b;
  font-size:12px;
  font-weight:700;
}
.task-kanban-deadline.late{
  background:linear-gradient(135deg,#fff1f2,#ffe4e6);
  color:#be123c;
}
.task-kanban-card small{
  display:block;
  margin-top:2px;
  color:#64748b;
}
.task-kanban-empty{
  display:grid;
  place-items:center;
  gap:10px;
  min-height:212px;
  padding:18px;
  border:1px dashed #d7e3f1;
  border-radius:20px;
  background:linear-gradient(180deg,rgba(255,255,255,.84),rgba(248,250,252,.92));
  text-align:center;
}
.task-kanban-empty-icon{
  width:62px;
  height:62px;
  display:grid;
  place-items:center;
  border-radius:22px;
  background:rgba(255,255,255,.88);
  color:#475569;
  font-size:28px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9),0 12px 24px rgba(15,23,42,.05);
}
.task-kanban-empty strong{
  font-size:15px;
  color:#0f172a;
}
.task-kanban-empty small{
  max-width:24ch;
  margin:0;
  line-height:1.55;
  color:#64748b;
}
.task-kanban-empty.active .task-kanban-empty-icon{
  color:#2563eb;
  background:linear-gradient(135deg,#eff6ff,#dbeafe);
}
.task-kanban-empty.review .task-kanban-empty-icon{
  color:#b45309;
  background:linear-gradient(135deg,#fff7cc,#fef3c7);
}
.task-kanban-empty.revision .task-kanban-empty-icon{
  color:#c2410c;
  background:linear-gradient(135deg,#ffedd5,#fed7aa);
}
.task-kanban-empty.done .task-kanban-empty-icon{
  color:#15803d;
  background:linear-gradient(135deg,#dcfce7,#bbf7d0);
}
.board-overflow-card{
  display:grid;
  gap:8px;
  padding:14px;
  border-style:dashed;
  border-color:#cddbea;
  background:linear-gradient(180deg,#ffffff,#f8fbff);
}
.board-overflow-card strong{
  font-size:14px;
  color:#0f172a;
}
.board-overflow-card p{
  margin:0;
  color:#64748b;
  line-height:1.5;
}
.board-overflow-card .btn{
  justify-self:start;
}
@media (max-width:767px){
  .task-board-metrics{
    grid-template-columns:1fr 1fr;
    gap:10px;
  }
  .task-board-metrics .stat-card{
    min-height:118px;
    padding:12px 13px;
    border-radius:18px;
  }
  .task-board-metrics .stat-card strong{
    font-size:21px;
  }
  .task-head-summary-strip{
    grid-template-columns:1fr;
  }
  .task-head-summary-card{
    padding:13px 14px;
    border-radius:18px;
  }
  .board-density-note{
    padding:10px 12px;
    border-radius:14px;
  }
  .board-limit-form{
    width:100%;
    justify-content:space-between;
  }
  .board-limit-select{
    min-width:112px;
  }
  .task-kanban-column{
    min-width:286px;
    padding:14px;
  }
  .task-kanban-header{
    top:0;
    margin:-14px -14px 12px;
    padding:14px 14px 12px;
  }
  .task-kanban-column-meta{
    flex-direction:column;
    align-items:flex-start;
  }
  .task-kanban-monitoring{
    gap:6px;
  }
  .task-kanban-card:hover,
  .task-kanban-card:focus-within{
    transform:translateY(-2px);
  }
  .task-kanban-meta{
    gap:6px;
  }
}
