:root{
  --bg:#f4f6f9; --card:#fff; --ink:#1c2733; --muted:#7a8794; --line:#e2e8f0;
  --brand:#1f4e78; --brand2:#2e7d32; --danger:#c0392b; --accent:#eaf1f8;
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--ink);font-size:14px}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
.muted{color:var(--muted)}
.center{text-align:center}
.r{text-align:right}
.dim{color:var(--muted)}

.topbar{display:flex;align-items:center;gap:18px;background:var(--brand);color:#fff;
  padding:10px 20px}
.topbar .brand{color:#fff;font-weight:700;font-size:18px}
.topbar .brand span{font-weight:300}
.topbar nav{flex:1}
.topbar .muted{color:#cfe0f0}
.rolbox{display:flex;align-items:center;gap:14px}
.rolbox select{padding:5px 8px;border-radius:6px;border:none}
.rolbox label{color:#cfe0f0}
.logout{color:#fff;border:1px solid #ffffff55;padding:5px 10px;border-radius:6px}

.container{max-width:1280px;margin:0 auto;padding:22px 20px 60px}
h1{font-size:24px;margin:.2em 0}
h2{font-size:18px;margin-top:1.4em}
h3{font-size:15px}
.crumbs{color:var(--muted);margin:0 0 6px}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;margin:16px 0}
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:18px;
  box-shadow:0 1px 2px #0000000a}
.corp-card{display:block;text-align:center}
.corp-card:hover{border-color:var(--brand);text-decoration:none}
.corp-name{font-size:28px;font-weight:700;color:var(--brand)}

.tbl{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);
  border-radius:10px;overflow:hidden}
.tbl th,.tbl td{padding:8px 10px;border-bottom:1px solid var(--line);text-align:left}
.tbl th{background:var(--accent);font-size:12px;text-transform:uppercase;letter-spacing:.02em;color:#445}
.tbl tbody tr:hover{background:#fafcff}
.tbl .chap td{background:#eef2f7;font-weight:600}
.tbl tfoot .tot td{background:#dCe6f1;font-weight:700}

.panel{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px 18px;margin:18px 0}
.inline-form{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:12px}
input,select,button{font-size:14px}
input[type=text],input[type=number],input[type=date],input[type=password]{
  padding:8px 10px;border:1px solid var(--line);border-radius:8px}
button,.btn{background:var(--brand);color:#fff;border:none;padding:8px 14px;border-radius:8px;cursor:pointer}
button:hover,.btn:hover{filter:brightness(1.08);text-decoration:none}
.btn.primary{background:var(--brand2);font-size:15px;padding:10px 20px}
.link-danger{background:none;color:var(--danger);padding:0}

.badge{padding:2px 9px;border-radius:20px;font-size:12px;font-weight:600}
.b-draft{background:#eee;color:#666}
.b-solicitat{background:#fff3cd;color:#856404}
.b-aprobat{background:#d4edda;color:#155724}

.st-neinceput{background:#eef0f2;color:#667}
.st-in_curs{background:#fff3cd;color:#8a6d00}
.st-finalizat{background:#d4edda;color:#155724}
.progbar{width:120px;height:8px;background:#eef0f2;border-radius:6px;overflow:hidden;display:inline-block;vertical-align:middle;margin-right:6px}
.progfill{height:100%;border-radius:6px}
.progfill.st-in_curs{background:#e0a800}
.progfill.st-finalizat{background:#2e7d32}
.progfill.st-neinceput{background:#ccc}

.sl-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.sl-actions{display:flex;gap:10px;align-items:center}
.tbl-scroll{overflow-x:auto;margin-top:10px}
.sl-tbl{font-size:12.5px;min-width:1100px}
.sl-tbl td,.sl-tbl th{padding:5px 7px}
.sl-tbl .art{max-width:340px;white-space:normal}
.qin{width:84px;text-align:right;padding:5px 6px;border:1px solid #b9c6d6;border-radius:6px}
.save-bar{position:sticky;bottom:0;background:#fffffff2;padding:12px 0;border-top:1px solid var(--line);margin-top:8px}

.tabbar{display:flex;gap:6px;margin:14px 0 18px;border-bottom:2px solid var(--line)}
.tab{padding:8px 16px;border-radius:8px 8px 0 0;color:var(--muted);font-weight:600}
.tab:hover{background:#eef2f7;text-decoration:none}
.tab.active{background:var(--brand);color:#fff}

.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin:16px 0}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:18px}
.kpi.sm{padding:14px}
.kpi-val{font-size:24px;font-weight:700;color:var(--brand)}
.kpi.sm .kpi-val{font-size:19px}
.kpi-lbl{color:var(--muted);font-size:12.5px;margin-top:4px}
.bigbar{height:26px;background:#eef0f2;border-radius:14px;overflow:hidden;margin:6px 0 10px}
.bigfill{height:100%;background:linear-gradient(90deg,#2e7d32,#43a047);color:#fff;font-size:13px;
  font-weight:700;display:flex;align-items:center;justify-content:flex-end;padding-right:12px;min-width:42px}
.btn.sm{padding:5px 10px;font-size:12.5px}
.nowrap{white-space:nowrap}

/* gantt */
.gantt{border:1px solid var(--line);border-radius:10px;overflow-x:auto;background:var(--card);margin:14px 0}
.gantt-row{display:flex;border-bottom:1px solid #eef0f2;min-width:760px}
.gantt-head{position:sticky;top:0;background:var(--accent);font-weight:600;font-size:12px}
.gantt-name{width:240px;min-width:240px;padding:7px 10px;border-right:1px solid var(--line);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gantt-name.summary{font-weight:700;background:#eef2f7}
.gantt-track{position:relative;flex:1;display:flex}
.gantt-month{flex:1;text-align:center;padding:7px 2px;border-right:1px solid #eef0f2;font-size:11px;min-width:46px}
.gantt-cell{flex:1;border-right:1px solid #f3f5f8;min-width:46px}
.gantt-bar{position:absolute;top:5px;height:18px;background:#9db8d6;border-radius:5px;overflow:hidden;
  min-width:4px;box-shadow:0 1px 2px #0002}
.gantt-bar.is-summary{background:#5a6b7d;height:12px;top:8px;border-radius:3px}
.gantt-progress{height:100%;background:#1f4e78;border-radius:5px}
.gantt-label{position:absolute;right:4px;top:0;font-size:10px;color:#16324f;line-height:18px}

.login-wrap{display:flex;justify-content:center;align-items:center;min-height:90vh}
.login-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:34px;width:340px;
  box-shadow:0 10px 30px #0000001a}
.login-logo{font-size:30px;font-weight:700;color:var(--brand);text-align:center}
.login-logo span{font-weight:300}
.login-card label{display:block;margin:14px 0 4px;font-size:13px;color:#445}
.login-card input{width:100%}
.login-card button{width:100%;margin-top:20px;padding:11px}
.alert{background:#f8d7da;color:#721c24;padding:9px 12px;border-radius:8px;margin-top:12px;font-size:13px}
