:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#0f172a;background-color:#f5f7fb;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:#f5f7fb}a{color:inherit;text-decoration:none}#root{min-height:100vh}.layout{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{background:#0f172a;color:#e2e8f0;padding:24px;display:flex;flex-direction:column;gap:16px;position:sticky;top:0;min-height:100vh;width:260px}.brand{font-size:18px;font-weight:700}.nav-link{display:block;padding:10px 12px;border-radius:10px;color:#cbd5e1;margin-bottom:6px;transition:background .2s,color .2s}.nav-link:hover,.nav-link.active{background:#1e293b;color:#fff}.sidebar-footer{margin-top:auto;display:flex;flex-direction:column;gap:10px}.user-name{font-weight:600}.user-role{font-size:13px;color:#94a3b8}.main{background:#f5f7fb;min-height:100vh}.topbar{padding:20px 24px 0}.page-title{font-size:22px;font-weight:700}.content{padding:12px 24px 32px}.topbar-actions{margin-left:auto}.mobile-logout{display:none;padding:8px 12px}.card{background:#fff;border-radius:16px;padding:20px;box-shadow:0 10px 30px -18px #0f172a33}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.metric .label{color:#64748b;font-size:13px}.metric .value{font-size:28px;font-weight:700}.filter-bar{background:#fff;border-radius:16px;padding:16px;box-shadow:0 10px 30px -18px #0f172a33;display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.filters{display:flex;gap:12px;flex-wrap:wrap}.filter{display:flex;flex-direction:column;gap:6px;min-width:160px}.filter select{padding:10px 12px;border-radius:12px;border:1px solid #d8e0f0;background:#f7f9fd;font-size:14px;color:#0f172a}.form textarea{min-height:80px;padding:10px 12px;border-radius:10px;border:1px solid #cbd5e1;font-size:14px;resize:vertical}.form select{padding:10px 12px;border-radius:10px;border:1px solid #cbd5e1;font-size:14px;background:#fff}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-bottom:16px}.kpi-card{border-radius:16px;padding:16px 18px;background:#f8fafc;border:1px solid #e2e8f0;box-shadow:0 10px 30px -22px #0f172a4d}.kpi-label{color:#64748b;font-size:13px;margin-bottom:4px}.kpi-value{font-size:28px;font-weight:800;color:#0f172a}.kpi-sub{color:#22c55e;font-size:12px;margin-top:4px}.accent-blue{background:linear-gradient(135deg,#eef2ff,#e0e7ff)}.accent-purple{background:linear-gradient(135deg,#f5f3ff,#ede9fe)}.accent-green{background:linear-gradient(135deg,#ecfdf3,#e7f7ec)}.accent-orange{background:linear-gradient(135deg,#fff7ed,#fffbeb)}.table{width:100%;border-collapse:collapse;font-size:14px}.table th,.table td{text-align:left;padding:12px 10px;border-bottom:1px solid #e2e8f0;vertical-align:middle}.table th{color:#64748b;font-weight:600}.grid-2{display:grid;grid-template-columns:2fr 1fr;gap:16px}.gap{gap:16px}.chart-card{min-height:360px}.segmented{display:inline-flex;background:#eef2ff;border-radius:12px;padding:4px;gap:6px}.seg{border:none;background:transparent;padding:8px 12px;border-radius:10px;font-weight:600;color:#4f46e5;cursor:pointer}.seg.active{background:#4f46e5;color:#fff;box-shadow:0 10px 25px -18px #4f46e599}.form{display:flex;flex-direction:column;gap:12px}label{display:flex;flex-direction:column;gap:6px;font-size:14px;color:#0f172a}input{padding:10px 12px;border-radius:10px;border:1px solid #cbd5e1;font-size:14px;outline:none;transition:border .2s,box-shadow .2s}input:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e526}.btn{border:none;border-radius:10px;padding:10px 14px;font-weight:600;cursor:pointer;font-size:14px}.btn.primary{background:linear-gradient(135deg,#4f46e5,#6366f1);color:#fff}.btn.secondary{background:#1e293b;color:#e2e8f0}.error{background:#fef2f2;border:1px solid #fecdd3;color:#b91c1c;padding:10px 12px;border-radius:10px;margin:8px 0}.success{background:#f0fdf4;border:1px solid #bbf7d0;color:#15803d;padding:10px 12px;border-radius:10px;margin:8px 0}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0f172a}.between{display:flex;align-items:center;justify-content:space-between}.auth-card{background:#fff;padding:32px;border-radius:18px;width:360px;box-shadow:0 20px 60px -28px #00000059}.auth-card h1{margin:0 0 6px}.auth-card p{margin:0 0 18px;color:#475569}.auth-form{display:flex;flex-direction:column;gap:12px}.page{padding:40px;text-align:center}@media(max-width:960px){.layout{grid-template-columns:1fr}.sidebar{position:fixed;top:0;left:-260px;bottom:0;width:240px;flex-direction:column;align-items:flex-start;gap:12px;padding:16px;overflow-y:auto;z-index:1000;transition:left .25s ease}.sidebar.open{left:0}.main{padding-left:0;padding-top:56px}.sidebar nav{display:flex;gap:8px;flex:1;flex-direction:column;width:100%}.nav-link{padding:10px 12px;margin-bottom:4px;white-space:normal}.sidebar-footer{margin-top:auto;flex-direction:column;gap:8px}.grid-2{grid-template-columns:1fr}.filter-bar{flex-direction:column;align-items:flex-start}.chart-legend{grid-template-columns:1fr}.topbar{position:fixed;top:0;left:0;right:0;z-index:1100;background:#0f172a;color:#fff;padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:12px;justify-content:space-between}.page-title{color:#fff}.mobile-nav-toggle,.mobile-logout{display:inline-flex}.topbar-actions{margin-left:auto}}.main{background:linear-gradient(135deg,#f4f6ff,#f9fbff 40%,#f7fbff)}.card{background:linear-gradient(145deg,#fff,#f7f9ff);box-shadow:0 15px 40px -18px #0f172a38;border:1px solid #e6e9f5}.filter-bar{background:linear-gradient(145deg,#fff,#f3f6ff);box-shadow:0 12px 32px -18px #0f172a40;border:1px solid #e6e9f5}.kpi-card{background:linear-gradient(145deg,#f7f9ff,#eef2ff);border:1px solid #e0e7ff;box-shadow:0 15px 40px -22px #4f46e559}.accent-blue{background:linear-gradient(135deg,#eef2ff,#dfe6ff)}.btn{transition:transform .1s ease,box-shadow .2s ease}.btn.primary{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;box-shadow:0 10px 25px -18px #22c55e99}.btn.secondary{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;margin-left:8px;box-shadow:0 10px 25px -18px #dc262699}.btn:hover{transform:translateY(-1px);box-shadow:0 12px 28px -18px #0f172a4d}.table th,.table td{vertical-align:middle}.chart-card{background:linear-gradient(145deg,#fff,#f5f7ff)}.chart-legend{display:grid;grid-template-columns:1.2fr .8fr;gap:12px;align-items:center}.legend-list{display:flex;flex-direction:column;gap:8px}.legend-item{display:flex;align-items:center;gap:10px;font-size:14px;color:#0f172a;justify-content:space-between}.legend-label{flex:1;margin-left:6px}.legend-dot{width:12px;height:12px;border-radius:50%;display:inline-block}.mobile-overlay{display:none}@media(max-width:960px){.mobile-overlay{display:block;position:fixed;inset:0;background:#0f172a73;opacity:0;pointer-events:none;transition:opacity .25s ease;z-index:900}.mobile-overlay.show{opacity:1;pointer-events:auto}}.mobile-nav-toggle{display:inline-flex;align-items:center;justify-content:center;border:1px solid #e2e8f0;background:#fff;color:#0f172a;padding:10px 12px;border-radius:10px;font-size:18px;cursor:pointer;box-shadow:0 8px 18px -14px #0f172a59}.print-page{min-height:100vh;background:#f5f7fb;display:flex;align-items:center;justify-content:center;padding:24px}.print-card{width:100%;max-width:800px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 18px 36px -24px #0f172a47;padding:24px;color:#0f172a}.print-header{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #e2e8f0;padding-bottom:12px;margin-bottom:16px}.print-title{font-size:22px;font-weight:800}.print-sub{color:#64748b;font-size:13px}.print-meta{font-weight:700;color:#4f46e5}.print-section{margin-bottom:14px}.print-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-bottom:10px}.print-label{font-size:12px;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em}.print-value{font-size:15px;font-weight:600;color:#0f172a}.print-notes{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:12px;white-space:pre-wrap;min-height:60px}.sig-canvas{border:1px solid #e2e8f0;border-radius:8px;background:#fff;width:100%;touch-action:none}.sig-preview img{max-width:280px;max-height:160px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;display:block;margin-bottom:8px}.modal-backdrop{position:fixed;inset:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;z-index:5000}.modal{background:#fff;padding:16px;border-radius:12px;width:min(640px,95vw);max-height:90vh;overflow:auto;box-shadow:0 20px 60px -30px #0006;display:flex;flex-direction:column;gap:12px}.contract-block{line-height:1.5}.contract-title{text-align:center;font-size:22px;font-weight:800;margin-bottom:4px}.contract-subtitle{text-align:center;color:#475569;font-weight:600;margin-bottom:12px}.contract-sep{border:none;border-bottom:1px solid #e2e8f0;margin:12px 0}.underline{border-bottom:1px dotted #94a3b8;display:inline-block;min-width:140px;padding-bottom:2px}.sign-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin:14px 0}.sign-block{padding:10px 0}.contract-meta p{margin:0}.contract-notes,.mt-12{margin-top:12px}@media print{.sidebar,.topbar,.mobile-overlay,.nav-link,.btn,.actions-cell{display:none!important}.print-page{background:#fff;padding:0}.print-card{box-shadow:none;border:none;padding:0}}
