@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700;800&family=DM+Serif+Display&display=swap');

:root {
  --navy:#0B1F3A; --navy2:#142847; --navy3:#1E3A5F;
  --blue:#2563EB; --blue2:#3B82F6; --teal:#0EA5E9;
  --gold:#F59E0B; --green:#10B981; --red:#EF4444; --purple:#7C3AED;
  --surf:#F0F4F8; --surf2:#E2EAF2; --white:#fff;
  --txt:#0B1F3A; --txt2:#4A6080; --txt3:#8BA0B8;
  --bdr:#D1DCEA; --sw:210px;
}

html, body { margin:0 !important; padding:0 !important; overflow:hidden; width:100%; height:100%; }
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; font-family:'DM Sans',sans-serif !important; }
body { font-family:'DM Sans',sans-serif !important; background:var(--surf); color:var(--txt); font-size:14px; -webkit-font-smoothing:antialiased; }
#root { margin:0 !important; padding:0 !important; width:100vw; height:100vh; overflow:hidden; }

/* BUTTONS */
.btn { display:inline-flex; align-items:center; gap:6px; padding:6px 13px; border-radius:7px; font-size:12.5px; font-weight:600; cursor:pointer; border:none; transition:all .15s; white-space:nowrap; }
.bp { background:var(--blue); color:#fff; box-shadow:0 2px 8px rgba(37,99,235,0.25); }
.bp:hover { background:#1D4ED8; }
.bg { background:transparent; border:1px solid var(--bdr); color:var(--txt2); }
.bg:hover { background:var(--surf); }
.bsm { padding:5px 10px; font-size:12px; }
.brd { background:rgba(239,68,68,0.1); color:var(--red); border:1px solid rgba(239,68,68,0.2); }
.brd:hover { background:rgba(239,68,68,0.15); }
.bgn { background:rgba(16,185,129,0.1); color:var(--green); border:1px solid rgba(16,185,129,0.2); }

/* BADGES */
.bdg { display:inline-flex; align-items:center; padding:2px 8px; border-radius:12px; font-size:11px; font-weight:600; }
.bg2 { background:rgba(16,185,129,0.12); color:#059669; }
.bb2 { background:rgba(37,99,235,0.12); color:var(--blue); }
.bo2 { background:rgba(245,158,11,0.12); color:#D97706; }
.br2 { background:rgba(239,68,68,0.12); color:#DC2626; }
.bgr2 { background:rgba(100,116,139,0.12); color:#475569; }
.bt2 { background:rgba(14,165,233,0.12); color:#0284C7; }
.bpu2 { background:rgba(124,58,237,0.12); color:#6D28D9; }

/* TABS */
.tabs { display:flex; gap:3px; padding:3px; background:var(--surf2); border-radius:7px; margin-bottom:18px; width:fit-content; }
.tab { padding:6px 14px; border-radius:5px; font-size:12.5px; font-weight:500; cursor:pointer; color:var(--txt2); transition:all .15s; background:none; border:none; }
.tab:hover { color:var(--navy); }
.tab.active { background:#fff; color:var(--navy); font-weight:700; box-shadow:0 1px 4px rgba(0,0,0,0.08); }

/* CARD */
.card { background:#fff; border-radius:11px; border:1px solid var(--bdr); overflow:hidden; margin-bottom:14px; }
.card:last-child { margin-bottom:0; }
.ch { padding:14px 18px; border-bottom:1px solid var(--bdr); display:flex; align-items:center; justify-content:space-between; }
.ct { font-size:13.5px; font-weight:700; color:var(--navy); }
.cs { font-size:11.5px; color:var(--txt3); margin-top:1px; }
.cb { padding:14px 18px; }
.cl { font-size:12px; color:var(--blue); font-weight:600; cursor:pointer; background:none; border:none; }
.cl:hover { text-decoration:underline; }

/* TABLE */
.tbl { width:100%; border-collapse:collapse; }
.tbl th { text-align:left; font-size:10.5px; font-weight:700; color:var(--txt3); text-transform:uppercase; letter-spacing:.5px; padding:9px 14px; background:var(--surf); border-bottom:1px solid var(--bdr); }
.tbl td { padding:11px 14px; border-bottom:1px solid var(--bdr); font-size:12.5px; color:var(--txt); vertical-align:middle; }
.tbl tr:last-child td { border-bottom:none; }
.tbl tbody tr { cursor:pointer; transition:background .1s; }
.tbl tbody tr:hover td { background:var(--surf); }

/* LAYOUT GRIDS */
.g2 { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:14px; }
.g31 { display:grid; grid-template-columns:2fr 1fr; gap:14px; margin-bottom:14px; }
.g13 { display:grid; grid-template-columns:1fr 2fr; gap:14px; margin-bottom:14px; }
.g3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:14px; margin-bottom:14px; }
.g4 { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:14px; }
.stk { display:flex; flex-direction:column; gap:14px; }

/* STAT CARDS */
.srow { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:20px; }
.sc { background:#fff; border-radius:11px; padding:18px; border:1px solid var(--bdr); position:relative; overflow:hidden; transition:box-shadow .2s; cursor:pointer; }
.sc:hover { box-shadow:0 4px 20px rgba(0,0,0,0.07); }
.sc::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; }
.sc.sbl::before { background:linear-gradient(90deg,var(--blue),var(--teal)); }
.sc.sgn::before { background:linear-gradient(90deg,var(--green),#34D399); }
.sc.sgo::before { background:linear-gradient(90deg,var(--gold),#FCD34D); }
.sc.srd::before { background:linear-gradient(90deg,var(--red),#FB923C); }
.sc.spu::before { background:linear-gradient(90deg,var(--purple),#A78BFA); }
.sic { position:absolute; top:14px; right:14px; width:38px; height:38px; border-radius:9px; display:flex; align-items:center; justify-content:center; font-size:18px; }
.ic-bl { background:rgba(37,99,235,0.1); } .ic-gn { background:rgba(16,185,129,0.1); }
.ic-go { background:rgba(245,158,11,0.1); } .ic-rd { background:rgba(239,68,68,0.1); }
.ic-pu { background:rgba(124,58,237,0.1); }
.slb { font-size:11px; font-weight:600; color:var(--txt3); text-transform:uppercase; letter-spacing:.5px; margin-bottom:7px; }
.sv { font-family:'DM Serif Display',serif !important; font-size:30px; font-weight:700; color:var(--navy); line-height:1; margin-bottom:5px; }
.ss { font-size:11.5px; color:var(--txt2); }
.gu { color:var(--green); font-weight:600; } .gd { color:var(--red); font-weight:600; }

/* ACTIVITY */
.ai { display:flex; gap:9px; padding:9px 0; border-bottom:1px solid var(--bdr); }
.ai:last-child { border-bottom:none; }
.aic { width:30px; height:30px; border-radius:7px; display:flex; align-items:center; justify-content:center; font-size:13px; flex-shrink:0; }
.ait { flex:1; font-size:12px; color:var(--txt); line-height:1.5; }
.alk { color:var(--blue); cursor:pointer; font-weight:600; }
.atm { font-size:10.5px; color:var(--txt3); white-space:nowrap; }

/* TIMELINE */
.tli { display:flex; gap:10px; padding:10px 0; position:relative; }
.tli::before { content:''; position:absolute; left:13px; top:38px; bottom:-10px; width:1px; background:var(--bdr); }
.tli:last-child::before { display:none; }
.tld { width:28px; height:28px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:13px; flex-shrink:0; z-index:1; }
.tlt { font-size:12.5px; font-weight:600; color:var(--navy); }
.tls { font-size:11.5px; color:var(--txt2); margin-top:2px; }
.tlm { font-size:10.5px; color:var(--txt3); margin-top:2px; }

/* TASKS */
.tski { display:flex; align-items:flex-start; gap:9px; padding:10px 0; border-bottom:1px solid var(--bdr); }
.tski:last-child { border-bottom:none; }
.tskc { width:17px; height:17px; border:2px solid var(--bdr); border-radius:4px; flex-shrink:0; margin-top:1px; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all .15s; }
.tskc:hover { border-color:var(--blue); }
.tskc.done { background:var(--green); border-color:var(--green); color:#fff; font-size:10px; }
.tskt { font-size:12.5px; color:var(--txt); }
.tskt.done { text-decoration:line-through; color:var(--txt3); }
.tskm { font-size:11px; color:var(--txt3); margin-top:1px; }

/* PIPELINE */
.pipe { display:grid; grid-template-columns:repeat(5,1fr); gap:10px; overflow-x:auto; }
.pcol { min-width:165px; }
.phd { padding:9px 11px; border-radius:7px; margin-bottom:8px; display:flex; justify-content:space-between; align-items:center; }
.plb { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.5px; }
.dc { background:#fff; border:1px solid var(--bdr); border-radius:7px; padding:10px; margin-bottom:7px; cursor:pointer; transition:all .15s; }
.dc:hover { box-shadow:0 4px 12px rgba(0,0,0,0.09); transform:translateY(-1px); }
.da { font-size:11.5px; font-weight:700; color:var(--navy); margin-bottom:3px; }
.dp { font-size:13px; font-weight:700; color:var(--blue); margin-bottom:5px; }
.dn { font-size:10.5px; color:var(--txt3); }

/* PERFORMANCE */
.pfrow { margin-bottom:12px; }
.pft2 { display:flex; justify-content:space-between; margin-bottom:4px; font-size:12px; }
.pfn { font-weight:600; color:var(--navy); }
.pfv { font-weight:700; color:var(--blue); }
.pfbg { height:5px; background:var(--surf2); border-radius:3px; overflow:hidden; }
.pfb { height:100%; border-radius:3px; }

/* PROPERTY CARDS */
.pgrid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.pc { background:#fff; border-radius:11px; border:1px solid var(--bdr); overflow:hidden; cursor:pointer; transition:all .2s; }
.pc:hover { box-shadow:0 8px 28px rgba(0,0,0,0.09); transform:translateY(-2px); }
.pimg { height:150px; display:flex; align-items:flex-end; padding:10px; position:relative; overflow:hidden; }
.pi1 { background:linear-gradient(135deg,#0B1F3A,#1E3A5F); }
.pi2 { background:linear-gradient(135deg,#1A3A2A,#166534); }
.pi3 { background:linear-gradient(135deg,#3A1A0B,#7C2D12); }
.pi4 { background:linear-gradient(135deg,#2A0B3A,#6B21A8); }
.pi5 { background:linear-gradient(135deg,#0B2A3A,#0E4F6A); }
.pi6 { background:linear-gradient(135deg,#1A2A0B,#365314); }
.psb { position:absolute; top:10px; left:10px; }
.pmk { position:absolute; top:10px; right:10px; background:rgba(0,0,0,0.5); color:#fff; font-size:9px; font-weight:700; padding:2px 7px; border-radius:3px; text-transform:uppercase; letter-spacing:.5px; }
.ppr { position:absolute; bottom:10px; left:10px; background:rgba(0,0,0,0.6); color:#fff; font-size:15px; font-weight:700; padding:3px 9px; border-radius:5px; }
.pinf { padding:12px 14px; }
.pad { font-size:13px; font-weight:700; color:var(--navy); margin-bottom:3px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.psub { font-size:11.5px; color:var(--txt3); margin-bottom:8px; }
.psts { display:flex; gap:10px; font-size:11.5px; color:var(--txt2); }
.pft { padding:9px 14px; border-top:1px solid var(--bdr); display:flex; align-items:center; justify-content:space-between; font-size:11.5px; color:var(--txt3); background:var(--surf); }

/* DETAIL HERO */
.dh { background:#fff; border-radius:11px; border:1px solid var(--bdr); padding:20px; margin-bottom:14px; display:flex; gap:18px; align-items:flex-start; }
.dimg { border-radius:9px; display:flex; align-items:center; justify-content:center; font-size:36px; flex-shrink:0; }
.dtitle { font-size:20px; font-weight:700; color:var(--navy); margin-bottom:3px; }
.dsub { font-size:13px; color:var(--txt2); margin-bottom:10px; }
.pills { display:flex; gap:7px; flex-wrap:wrap; }
.pill { padding:4px 10px; border-radius:5px; font-size:11.5px; font-weight:600; background:var(--surf); border:1px solid var(--bdr); color:var(--txt2); }
.pill-bl { background:rgba(37,99,235,0.08); border-color:rgba(37,99,235,0.2); color:var(--blue); }

/* BREADCRUMB */
.bc { display:flex; align-items:center; gap:7px; margin-bottom:14px; font-size:12.5px; }
.bc a { color:var(--blue); cursor:pointer; font-weight:600; background:none; border:none; font-size:12.5px; }
.bc a:hover { text-decoration:underline; }
.bc span { color:var(--txt3); }

/* AVATAR */
.av { width:36px; height:36px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:700; color:#fff; flex-shrink:0; }

/* FORMS */
.frow { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:14px; }
.fg { display:flex; flex-direction:column; gap:5px; }
.fg label { font-size:11px; font-weight:600; color:var(--txt2); text-transform:uppercase; letter-spacing:.5px; }
.fi { padding:8px 11px; border:1px solid var(--bdr); border-radius:7px; font-size:13px; color:var(--txt); outline:none; transition:border-color .15s; width:100%; }
.fi:focus { border-color:var(--blue); }

/* MODAL */
.mo { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.5); z-index:200; align-items:center; justify-content:center; }
.mo.open { display:flex; }
.mb { background:#fff; border-radius:14px; width:660px; max-height:85vh; overflow-y:auto; box-shadow:0 20px 60px rgba(0,0,0,0.25); }
.mb.sm { width:460px; }
.mb.lg { width:860px; }
.mh { padding:20px 22px 0; display:flex; align-items:flex-start; justify-content:space-between; }
.mt { font-size:19px; font-weight:700; color:var(--navy); }
.ms { font-size:12.5px; color:var(--txt3); margin-top:3px; }
.mc { padding:18px 22px 22px; }
.mcl { background:none; border:none; font-size:22px; cursor:pointer; color:var(--txt3); line-height:1; padding:0; }
.mac { display:flex; gap:9px; justify-content:flex-end; margin-top:18px; padding-top:14px; border-top:1px solid var(--bdr); }

/* TOGGLE */
.toggle { width:40px; height:22px; background:var(--surf2); border-radius:11px; position:relative; cursor:pointer; transition:background .2s; border:none; flex-shrink:0; }
.toggle.on { background:var(--green); }
.toggle::after { content:''; position:absolute; left:3px; top:3px; width:16px; height:16px; background:#fff; border-radius:50%; transition:left .2s; box-shadow:0 1px 3px rgba(0,0,0,0.2); }
.toggle.on::after { left:21px; }

/* WORKFLOW BUILDER */
.wb-canvas { background:#fff; border:1px solid var(--bdr); border-radius:11px; padding:30px; min-height:400px; position:relative; }
.wb-node { background:#fff; border:2px solid var(--bdr); border-radius:10px; padding:16px 20px; width:280px; position:relative; cursor:pointer; transition:all .15s; }
.wb-node:hover { border-color:var(--blue); box-shadow:0 4px 16px rgba(37,99,235,0.12); }
.wb-node.wn-when { border-color:var(--blue); background:rgba(37,99,235,0.03); }
.wb-node.wn-cond { border-color:var(--gold); background:rgba(245,158,11,0.03); }
.wb-node.wn-act { border-color:var(--green); background:rgba(16,185,129,0.03); }
.wb-nl { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.8px; margin-bottom:5px; }
.wb-nl.bl { color:var(--blue); } .wb-nl.go { color:var(--gold); } .wb-nl.gn { color:var(--green); } .wb-nl.pu { color:var(--purple); }
.wb-nt { font-size:13px; font-weight:600; color:var(--navy); margin-bottom:3px; }
.wb-ns { font-size:12px; color:var(--txt2); }

/* COMPLIANCE */
.comp-bar { height:8px; background:var(--surf2); border-radius:4px; overflow:hidden; margin:6px 0; }
.comp-fill { height:100%; border-radius:4px; }

/* CALENDAR */
.cg { display:grid; grid-template-columns:repeat(7,1fr); gap:3px; }
.cd { aspect-ratio:1; display:flex; flex-direction:column; align-items:center; justify-content:center; border-radius:6px; cursor:pointer; font-size:12.5px; transition:background .1s; position:relative; }
.cd:hover { background:var(--surf); }
.cd.today { background:var(--blue); color:#fff; font-weight:700; }
.cd.has-ev::after { content:''; position:absolute; bottom:4px; width:4px; height:4px; background:var(--gold); border-radius:50%; }

/* FILTER BAR */
.fbar { display:flex; gap:9px; margin-bottom:18px; align-items:center; flex-wrap:wrap; }
.fsel { padding:6px 11px; border-radius:6px; border:1px solid var(--bdr); background:#fff; font-size:12.5px; color:var(--txt2); cursor:pointer; }

/* TOAST */
.toast { position:fixed; bottom:22px; right:22px; background:var(--navy); color:#fff; padding:11px 18px; border-radius:9px; font-size:13px; font-weight:500; z-index:300; box-shadow:0 8px 24px rgba(0,0,0,0.25); max-width:340px; }

/* SCROLLBAR */
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-thumb { background:var(--bdr); border-radius:3px; }

/* ANIMATION */
@keyframes fadeIn { from { opacity:0; transform:translateY(5px); } to { opacity:1; transform:translateY(0); } }
.fade-in { animation:fadeIn .2s ease; }

/* FILTER BAR SEARCH INPUT */
input[type="text"], input[type="search"], input[type="email"],
input[type="date"], input[type="time"], input[type="number"],
select, textarea {
  font-family:'DM Sans',sans-serif !important;
  font-size:13px;
  color:var(--txt);
  border:1px solid var(--bdr);
  border-radius:7px;
  padding:8px 11px;
  outline:none;
  transition:border-color .15s;
}
input:focus, select:focus, textarea:focus { border-color:var(--blue); }