
:root{
  --bg:#f4f7fb; --panel:#ffffff; --line:#dde5f0; --text:#1d2838; --muted:#6c7a8f; --accent:#2457d6;
  --accent-soft:#edf3ff; --green:#2f9e44; --red:#d9485f; --amber:#f59f00;
}
*{box-sizing:border-box}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text)}
.layout{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.sidebar{background:#111927;color:#fff;padding:24px 18px;position:sticky;top:0;height:100vh}
.brand{font-size:22px;font-weight:800;margin-bottom:22px}
.sidebar nav{display:flex;flex-direction:column;gap:8px}
.sidebar a{color:#d8e0ef;text-decoration:none;padding:10px 12px;border-radius:12px}
.sidebar a.active,.sidebar a:hover{background:#1c2940;color:#fff}
.main{padding:28px}
.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}
h1{margin:0;font-size:28px}
.subtitle{color:var(--muted);margin-top:4px}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:0 8px 24px rgba(18,32,55,.04);margin-bottom:18px}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:18px}
.card{background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid var(--line);border-radius:18px;padding:18px;text-decoration:none;color:inherit}
.kpi{font-size:30px;font-weight:800}
.quick-links,.actions,.filters,.section-header,.inline-form,.tabs{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.grid-2{display:grid;grid-template-columns:1.1fr 1fr;gap:18px}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.form-grid.compact{grid-template-columns:repeat(4,minmax(0,1fr))}
.form-grid label{display:flex;flex-direction:column;gap:6px;font-size:14px}
.form-grid .span-2{grid-column:span 2}
.checkbox{justify-content:end}
input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],select,textarea{width:100%;padding:10px 12px;border-radius:12px;border:1px solid var(--line);background:#fff}
textarea{resize:vertical;font:inherit}

input[type=checkbox]{transform:scale(1.1)}
.button{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:12px;border:1px solid var(--line);background:#fff;text-decoration:none;color:var(--text);cursor:pointer}
.button.small{padding:6px 10px;border-radius:10px;font-size:13px}
.button.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.button.danger{background:#fff0f0;color:var(--red);border-color:#f2b6c0}
table{width:100%;border-collapse:collapse}
th,td{padding:11px 10px;border-bottom:1px solid #edf2f7;vertical-align:middle;text-align:left}
thead th{font-size:13px;text-transform:uppercase;color:var(--muted);letter-spacing:.02em}
tbody tr:hover{background:#fafcff}
.badge{display:inline-block;padding:4px 10px;border-radius:999px;background:var(--accent-soft);color:var(--accent);font-size:12px;font-weight:600}
.mini-badge{display:inline-block;padding:2px 8px;border-radius:999px;background:#eef7ec;color:#2b8a3e;font-size:11px;margin-right:4px}
.muted{color:var(--muted);font-size:12px;margin-top:2px}
.flash-wrap{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.flash{padding:12px 14px;border-radius:12px;background:#ecfdf3;border:1px solid #c7f0d4;color:#217a39}
.tabs .tab{padding:9px 12px;border-radius:12px;text-decoration:none;border:1px solid var(--line);background:#fff;color:var(--text)}
.tabs .tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.tabs.compact .tab{padding:7px 10px;font-size:13px}
.due-category-filters{align-items:center;margin-top:12px;padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:#fbfdff}
.due-category-option{display:inline-flex;align-items:center;gap:7px;justify-content:flex-start;padding:6px 9px;border:1px solid #e5ecf6;border-radius:8px;background:#fff;font-size:13px}
.due-category-option input{margin:0}
.center{text-align:center}
.right{text-align:right}
.top-gap{margin-top:12px}
.totals-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.totals-grid div{padding:12px;border:1px solid var(--line);border-radius:14px;background:#fbfdff;display:flex;justify-content:space-between}
.contract-summary-section h2{font-size:20px;margin:0 0 12px}
.contract-summary-box{border-radius:8px}
.contract-summary-header{justify-content:space-between}
.contract-summary-warning{background:#fff4e6;color:#ad6800}
.contract-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-top:14px}
.contract-summary-grid div{display:flex;flex-direction:column;gap:5px;padding:12px;border:1px solid var(--line);border-radius:8px;background:#fbfdff}
.contract-summary-grid span{color:var(--muted);font-size:12px}
.contract-summary-grid strong{font-size:18px}
.contract-summary-note{margin-top:12px;padding:10px 12px;border:1px solid #f2d59a;border-radius:8px;background:#fff8e6;color:#7a5200;font-size:13px}
.contract-summary-lines td{vertical-align:top}
.contract-summary-drafts{background:#fffdf7}
.timeline{display:flex;flex-direction:column;gap:12px}
.timeline-item{display:grid;grid-template-columns:170px 1fr;gap:14px;padding:12px;border:1px solid var(--line);border-radius:14px;background:#fbfdff}
.timeline-date{color:var(--muted);font-size:12px}
.timeline-body{display:flex;flex-direction:column;gap:6px}
.metadata-list{display:flex;gap:8px;flex-wrap:wrap;color:var(--muted);font-size:12px}
.metadata-list span{padding:4px 8px;border:1px solid var(--line);border-radius:10px;background:#fff}
.table-scroll{width:100%;overflow-x:auto}
.services-header-actions,.row-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.service-filters{margin:14px 0 18px}
.service-filters input[type=text]{max-width:380px}
.service-filters select{max-width:240px}
.service-groups{display:flex;flex-direction:column;gap:16px}
.service-category-section{border:1px solid var(--line);border-radius:8px;background:#fff;overflow:hidden}
.service-category-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:13px 14px;border-bottom:1px solid var(--line);background:#fbfdff}
.service-category-header h3{margin:0;font-size:18px}
.service-category-unclassified{border-color:#f2c46d;background:#fffdf7}
.service-category-unclassified .service-category-header{background:#fff8e6;border-bottom-color:#f2d59a}
.service-warning{margin-top:5px;color:#8a5a00;font-size:12px;line-height:1.35}
.fiscal-badge{background:#eef3ff;color:#2457d6}
.inline-delete-form{display:inline}
.empty-state{padding:18px;border:1px dashed var(--line);border-radius:8px;color:var(--muted);background:#fbfdff}
.report-cards .card{border-radius:8px}
.panel h2,.panel h3{margin:0}
.client-situation-card{
  padding:24px;
  margin-bottom:24px;
  border-radius:18px;
  box-shadow:0 10px 28px rgba(18,32,55,.055);
}
.client-situation-header{
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  padding-bottom:18px;
}
.client-situation-title{
  min-width:220px;
}
.client-situation-title h3{
  font-size:22px;
  line-height:1.25;
}
.client-situation-subtitle{
  margin-top:7px;
  font-size:13px;
  line-height:1.4;
}
.client-summary-badges{
  justify-content:flex-end;
  gap:9px;
  row-gap:10px;
}
.client-summary-badges .badge{
  padding:7px 12px;
}
.client-report-section{
  margin-top:18px;
  padding:18px;
  border:1px solid var(--line);
  border-radius:14px;
  background:#fbfdff;
}
.client-report-section + .client-report-section{
  margin-top:20px;
}
.client-report-section h3{
  margin-bottom:14px;
  font-size:17px;
  line-height:1.3;
}
.client-report-table-wrap{
  border:1px solid #e8eef7;
  border-radius:12px;
  background:#fff;
}
.client-report-table{
  min-width:720px;
}
.client-report-table th,
.client-report-table td{
  padding:14px 14px;
  line-height:1.45;
}
.client-report-table thead th{
  padding-top:15px;
  padding-bottom:13px;
  background:#f6f9fd;
  color:#53637a;
  font-size:12px;
  font-weight:800;
}
.client-report-table tbody td{
  min-height:50px;
}
.client-report-table tbody tr:last-child td{
  border-bottom:0;
}
.client-report-empty{
  padding:18px 14px;
  font-size:13px;
  background:#fcfdff;
}
.diagnostic-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:14px}
.diagnostic-box{border:1px solid var(--line);border-radius:8px;background:#fbfdff;padding:14px;min-width:0}
.compact-table th,.compact-table td{padding:8px;border-bottom:1px solid #edf2f7}
.row-warning td{background:#fff8e6}
.row-danger td{background:#fff0f3}
.row-muted td{background:#f8fafc}
.competence-main-cards{display:flex;flex-direction:column;gap:16px;margin-bottom:18px}
.competence-card{background:#fff;border:1px solid var(--line);border-radius:8px;padding:22px;box-shadow:0 8px 24px rgba(18,32,55,.04)}
.competence-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:18px}
.competence-card-head h2{margin:0;font-size:22px}
.competence-card-head p{margin:6px 0 0;color:var(--muted);font-size:13px;line-height:1.4}
.competence-card-value{font-size:38px;font-weight:850;line-height:1;white-space:nowrap}
.competence-card-detail{margin-top:18px;border-top:1px solid var(--line);padding-top:14px}
.competence-card-detail>summary,.competence-section>summary,.competence-area>summary,.inline-detail>summary{cursor:pointer;font-weight:700}
.competence-section>summary{display:flex;align-items:center;justify-content:space-between;gap:14px;list-style:none}
.competence-section>summary::-webkit-details-marker{display:none}
.competence-section>summary span{font-size:19px}
.competence-section>summary strong{font-size:20px}
.competence-area-list{display:flex;flex-direction:column;gap:12px;margin-top:14px}
.competence-area{border:1px solid var(--line);border-radius:8px;background:#fbfdff;padding:12px}
.competence-area>summary{display:flex;align-items:center;justify-content:space-between;gap:12px}
.competence-area>summary strong{font-size:18px}
.competence-area .table-scroll{margin-top:12px}
.competence-table{min-width:760px;background:#fff}
.inline-detail{margin-top:8px}
.inline-detail>summary{color:var(--accent);font-size:13px}
.client-line-detail{padding:10px 0;border-top:1px solid #edf2f7}
.client-line-detail>summary{display:flex;justify-content:space-between;gap:12px;color:var(--text)}
#lines-table input[type=text]{min-width:280px}
#lines-table .economic-field{min-width:120px;padding:8px 10px}
#lines-table .small-number{min-width:90px}
#payroll-table input[type=number], #payroll-table input[type=text]{padding:8px 10px}
.toggle-pill{padding:8px 12px;border-radius:999px;border:1px solid var(--line);background:#fff;cursor:pointer}
.toggle-pill.done{background:#cefcaf;color:#216e39;border-color:#a8e58a}
.red-col{background:#fff5f5}
.disabled-cell{background:#ffe3e3}
.ready-cell{background:#fff}
.green-input{background:#cefcaf}
.row-suspended td{background:#ffd9d9 !important}
.stack-cell{display:flex;align-items:center;gap:8px}
.user-menu{display:flex;align-items:center;gap:10px;justify-content:flex-end;flex-wrap:wrap}
.current-issuer-form label{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:12px}
.current-issuer-form select{min-width:220px;padding:8px 10px;border-radius:10px}
.auth-page{min-height:100vh;display:grid;place-items:center;padding:24px}
.auth-panel{width:min(440px,100%);background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:24px;box-shadow:0 12px 32px rgba(18,32,55,.08)}
.auth-brand{margin-bottom:12px}
.auth-form{margin-top:18px}

.matrix-page-header{border-radius:16px}
.matrix-header-content{align-items:flex-start;justify-content:space-between}
.matrix-ccnl-name{font-size:16px;font-weight:700;margin:5px 0 3px}
.matrix-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.matrix-save-bar{
  position:sticky;
  top:12px;
  z-index:4;
  display:flex;
  justify-content:flex-end;
  margin:-4px 0 14px;
  padding:10px;
  border:1px solid var(--line);
  border-radius:14px;
  background:rgba(244,247,251,.92);
  backdrop-filter:blur(8px);
}
.matrix-level-card{
  border-radius:16px;
  padding:0;
  overflow:hidden;
}
.matrix-level-header{
  display:flex;
  align-items:stretch;
  justify-content:space-between;
  gap:16px;
  padding:18px;
  border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,#fbfdff,#f5f8fd);
}
.matrix-level-header h3{margin:2px 0 8px;font-size:22px}
.matrix-eyebrow{
  color:var(--muted);
  font-size:12px;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.matrix-status-active{background:#eef7ec;color:#2b8a3e}
.matrix-status-inactive{background:#fff0f0;color:var(--red)}
.matrix-total{
  min-width:240px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:5px;
  padding:14px 16px;
  border:1px solid #cbd8ee;
  border-radius:14px;
  background:#fff;
  box-shadow:0 8px 18px rgba(18,32,55,.06);
}
.matrix-total span{color:var(--muted);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.03em}
.matrix-total strong{font-size:24px;color:var(--accent)}
.matrix-section{padding:18px}
.matrix-section + .matrix-section{border-top:1px solid var(--line)}
.matrix-section-title{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:12px;
}
.matrix-section-title h4{margin:0;font-size:16px}
.matrix-level-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(170px,1fr));
  gap:13px;
}
.matrix-field{
  display:flex;
  flex-direction:column;
  gap:7px;
  min-width:0;
  color:var(--text);
  font-size:13px;
  font-weight:650;
}
.matrix-field span{color:#41506a}
.matrix-field input,
.matrix-field select{
  min-height:42px;
  border-radius:10px;
  font-size:14px;
}
.matrix-checkbox-field{
  justify-content:flex-start;
}
.matrix-checkbox-field input{
  width:auto;
  min-height:0;
  align-self:flex-start;
  margin-top:8px;
}
.matrix-voices-section{background:#fbfcfe}
.matrix-voices-scroll{
  width:100%;
  overflow-x:auto;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
}
.matrix-voices-table{
  min-width:720px;
  table-layout:fixed;
}
.matrix-voices-table th,
.matrix-voices-table td{
  vertical-align:top;
  background:#fff;
}
.matrix-voices-table th:first-child,
.matrix-voices-table td:first-child{width:34%}
.matrix-voices-table th:nth-child(2),
.matrix-voices-table td:nth-child(2){width:20%}
.matrix-voices-table th:nth-child(3),
.matrix-voices-table td:nth-child(3){width:22%}
.matrix-voices-table th:nth-child(4),
.matrix-voices-table td:nth-child(4){width:14%}
.matrix-voices-table th:nth-child(5),
.matrix-voices-table td:nth-child(5){width:10%}
.matrix-voices-table input[type=text],
.matrix-voices-table input[type=number]{
  min-width:0;
  border-radius:10px;
  padding:9px 10px;
  font-size:14px;
}
.matrix-voices-table input[type=checkbox]{min-width:0;margin-top:10px}
.matrix-voice-name-cell{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.matrix-row-hint{
  display:inline-flex;
  width:max-content;
  padding:3px 8px;
  border-radius:999px;
  background:#f1f5f9;
  color:#506077;
  font-size:11px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.03em;
}
.matrix-empty-voice td{background:#fcfdff}
@media(max-width:980px){
  .layout{grid-template-columns:1fr}
  .sidebar{height:auto;position:static}
  .grid-2,.form-grid.compact,.totals-grid{grid-template-columns:1fr}
  .timeline-item{grid-template-columns:1fr}
  .matrix-level-header{flex-direction:column}
  .matrix-total{min-width:0}
  .matrix-level-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .matrix-save-bar{top:8px}
}
@media(max-width:640px){
  .main{padding:18px}
  .competence-card{padding:18px}
  .competence-card-head{flex-direction:column}
  .competence-card-value{font-size:32px}
  .client-situation-card{padding:18px}
  .client-situation-header{gap:14px}
  .client-situation-title{min-width:0}
  .client-situation-title h3{font-size:20px}
  .client-summary-badges{justify-content:flex-start}
  .client-report-section{padding:14px}
  .client-report-table th,.client-report-table td{padding:12px}
  .matrix-level-grid{grid-template-columns:1fr}
  .matrix-level-header,.matrix-section{padding:14px}
  .matrix-actions{width:100%}
  .matrix-actions .button{flex:1 1 180px}
  .matrix-save-bar{justify-content:stretch}
  .matrix-save-bar .button{width:100%}
}
