:root{
  --bg:#f7f4f6;
  --panel:#ffffffde;
  --panel-solid:#fff;
  --line:#ead7df;
  --line-strong:#d6b5c1;
  --text:#311f2a;
  --muted:#7f6b76;
  --primary:#8c1d40;
  --primary-soft:#f9edf1;
  --success:#12824f;
  --success-soft:#e8f7ef;
  --danger:#c0392b;
  --danger-soft:#fdeceb;
  --warning:#a56b00;
  --warning-soft:#fff4dc;
  --shadow:0 14px 30px rgba(94,39,61,.08);
  --radius:20px;
  --radius-sm:14px;
  --appbar-h:72px;
  --sidebar-w:330px;
  --sidebar-w-collapsed:82px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:Inter,system-ui,sans-serif;
  color:var(--text);
  background:radial-gradient(circle at top right, rgba(160,40,88,.08), transparent 25%), linear-gradient(180deg,#fcf8fa 0,#f7f4f6 100%);
}
button,input,select,textarea{font:inherit}
.material-symbols-rounded{font-variation-settings:'FILL' 1,'wght' 500,'GRAD' 0,'opsz' 24}

.appbar{
  position:sticky;top:0;z-index:40;
  height:var(--appbar-h);display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:12px 18px;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(140,29,64,.08);
}
.appbar-left,.appbar-right{display:flex;align-items:center;gap:14px;min-width:0}
.appbar-brand{display:flex;align-items:center;gap:12px;min-width:0}
.appbar-brand strong{display:block;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.appbar-brand span{display:block;color:var(--muted);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.brand-chip,.sidebar-icon{
  width:40px;height:40px;border-radius:14px;display:grid;place-items:center;
  background:linear-gradient(135deg,#f4dce6,#fff);color:var(--primary);border:1px solid var(--line);
}
.icon-btn{
  width:42px;height:42px;border:none;border-radius:14px;background:#fff;display:grid;place-items:center;cursor:pointer;
  box-shadow:var(--shadow);color:var(--primary)
}
.top-kpis{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.top-kpi{
  min-width:118px;padding:10px 12px;border-radius:16px;background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow)
}
.top-kpi strong{display:block;font-size:11px;color:var(--muted);font-weight:600}
.top-kpi span{display:block;margin-top:4px;font-size:24px;font-weight:800;letter-spacing:-.03em}
.top-kpi.success{background:var(--success-soft);border-color:#b9e3ca}
.top-kpi.success span{color:var(--success)}

.layout{
  display:grid;grid-template-columns:var(--sidebar-w) minmax(0,1fr);min-height:calc(100vh - var(--appbar-h));
}
body.sidebar-collapsed .layout{grid-template-columns:var(--sidebar-w-collapsed) minmax(0,1fr)}
.sidebar{
  position:sticky;top:var(--appbar-h);height:calc(100vh - var(--appbar-h));overflow:auto;padding:18px 14px;background:#f4eff2;
  border-right:1px solid rgba(130,92,109,.14);transition:width .25s ease,padding .25s ease;
}
.sidebar-title-wrap{display:flex;gap:12px;align-items:flex-start;margin-bottom:14px}
.sidebar h1{margin:0;font-size:18px;line-height:1.2}
.sidebar p{margin:6px 0 0;color:var(--muted);line-height:1.45}
body.sidebar-collapsed .sidebar .sidebar-text,
body.sidebar-collapsed .sidebar .summary-text,
body.sidebar-collapsed .sidebar .expander-body{display:none}
body.sidebar-collapsed .sidebar{padding-inline:10px}
body.sidebar-collapsed .sidebar-title-wrap{justify-content:center}
body.sidebar-collapsed .sidebar .expander > summary{justify-content:center;padding:14px}
body.sidebar-collapsed .sidebar .expander > summary .material-symbols-rounded{margin:0}

.main{padding:22px 22px 34px;min-width:0}
.panel{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)
}
.hero{padding:20px 22px;margin-bottom:16px}
.eyebrow{display:inline-flex;align-items:center;gap:6px;background:var(--primary-soft);color:var(--primary);padding:6px 10px;border-radius:999px;font-size:12px;font-weight:700;margin-bottom:10px}
.hero h2{margin:0;font-size:28px;line-height:1.1;letter-spacing:-.03em}
.hero p{margin:10px 0 0;color:var(--muted);max-width:920px;line-height:1.55}

.expander{overflow:hidden}
.expander>summary{
  list-style:none;cursor:pointer;padding:14px 16px;display:flex;align-items:center;gap:10px;font-weight:800;border-bottom:1px solid rgba(140,29,64,.08)
}
.expander>summary::-webkit-details-marker{display:none}
.expander-body{padding:16px}
.tabs{display:flex;gap:8px;flex-wrap:wrap;border-bottom:1px solid rgba(140,29,64,.12);margin:0 0 16px}
.tab{
  border:none;background:transparent;padding:10px 2px 12px;margin-right:16px;cursor:pointer;color:#614b58;font-weight:700;border-bottom:2px solid transparent
}
.tab.active{color:#ff4b4b;border-color:#ff4b4b}
.tab-panel{display:none}
.tab-panel.active{display:block}
.subtabs{margin-top:6px}

.callout{
  background:var(--primary-soft);border:1px solid #efcad6;color:#5a3342;padding:14px 16px;border-radius:18px;margin-bottom:14px
}
.callout.subtle{background:#edf5ff;border-color:#d7e6ff;color:#30527b}
.callout.compact{padding:12px 14px}
.muted{color:var(--muted)}
.small-copy p{margin:.35rem 0}

.field{display:flex;flex-direction:column;gap:8px}
.field label{font-size:13px;font-weight:700;color:#5a4450}
.field input,.field select{
  height:44px;border:1px solid var(--line);background:#fff;border-radius:14px;padding:0 14px;color:var(--text)
}
.field select[multiple]{height:126px;padding:10px 12px}
.filters-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.field-wide{grid-column:span 2}
.toolbar-row,.filter-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;flex-wrap:wrap}

.upload-box{
  border:1.5px dashed var(--line-strong);border-radius:18px;background:#fff;padding:14px;cursor:pointer;display:block
}
.upload-main{display:flex;gap:12px;align-items:flex-start}
.upload-main .material-symbols-rounded{font-size:28px;color:var(--primary)}
.upload-main strong{display:block}
.upload-main p{margin:4px 0 0;color:var(--muted)}
.chip-list,.list-stack{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.chip-list.empty,.list-stack.empty{display:block;color:var(--muted)}
.file-chip,.sidebar-file{
  display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 12px;font-size:12px;font-weight:700
}
.sidebar-file{display:flex;justify-content:space-between;width:100%;border-radius:14px}
.mode-row{display:flex;gap:12px;align-items:flex-start;margin:14px 0}
.switch{position:relative;display:inline-block;width:48px;height:28px;flex:0 0 auto}
.switch input{display:none}
.switch-ui{position:absolute;inset:0;background:#dbd0d5;border-radius:999px;transition:.2s}
.switch-ui::after{content:'';position:absolute;left:3px;top:3px;width:22px;height:22px;border-radius:50%;background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.18);transition:.2s}
.switch input:checked + .switch-ui{background:#ff4b4b}
.switch input:checked + .switch-ui::after{transform:translateX(20px)}

.progress-wrap{margin-top:14px}
.progress-wrap.hidden{display:none}
.progress-head{display:flex;justify-content:space-between;gap:12px;font-size:13px;margin-bottom:8px}
.progress-track{height:10px;background:#ebdee4;border-radius:999px;overflow:hidden}
.progress-bar{height:100%;width:0;background:linear-gradient(90deg,#ff4b4b,#8c1d40);border-radius:999px;transition:width .2s ease}

.btn{
  border:none;border-radius:14px;height:44px;padding:0 16px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;font-weight:700
}
.btn-primary{background:#ff4b4b;color:#fff;box-shadow:0 12px 22px rgba(255,75,75,.18)}
.btn-secondary{background:#fff;color:#573b49;border:1px solid var(--line)}
.btn-ghost{background:#fff;color:#573b49;border:1px solid var(--line)}
.btn-full{width:100%}
.btn-status{min-width:148px}

.cards-compact-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.card{
  min-height:118px;border-radius:18px;border:1px solid var(--line);background:#fff;padding:14px 14px 12px;display:flex;flex-direction:column;gap:10px;
  box-shadow:0 10px 18px rgba(99,58,77,.06)
}
.card.compact{min-height:108px}
.card .card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.card .title{font-size:12px;font-weight:700;color:#735866;display:flex;align-items:center;gap:6px;line-height:1.3}
.card .value{font-size:16px;font-weight:800;color:#2e1f29;letter-spacing:-.02em;line-height:1.2;word-break:break-word}
.card .value.big{font-size:18px}
.card .sub{font-size:12px;color:var(--muted);line-height:1.35}
.card.success{border-color:#bfe3cb;background:linear-gradient(180deg,#fff,#f7fffa)}
.card.success .value{color:var(--success)}
.card.danger{border-color:#f2c3c3;background:linear-gradient(180deg,#fff,#fff8f8)}
.card.danger .value{color:var(--danger)}
.card.warning{border-color:#f2ddae;background:linear-gradient(180deg,#fff,#fffaf1)}
.card.warning .value{color:var(--warning)}
.badges{display:flex;gap:6px;flex-wrap:wrap}
.badge{
  display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;font-size:11px;font-weight:700;border:1px solid var(--line);background:#faf5f7;color:#6f5160
}
.badge.success{background:var(--success-soft);border-color:#c8ead6;color:var(--success)}
.badge.danger{background:var(--danger-soft);border-color:#f4c7c2;color:var(--danger)}
.badge.warning{background:var(--warning-soft);border-color:#f0ddb0;color:var(--warning)}
.badge.primary{background:var(--primary-soft);border-color:#efcad6;color:var(--primary)}
.info-badge{
  display:inline-grid;place-items:center;width:18px;height:18px;border-radius:50%;background:#fff0f4;border:1px solid #efcad6;color:var(--primary);font-size:11px
}

.table-card{margin-top:12px;background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden}
.table-wrap{overflow:auto}
.table{
  width:100%;border-collapse:separate;border-spacing:0;min-width:880px
}
.table thead th{
  position:sticky;top:0;background:#fbf3f6;color:#7d213e;font-size:13px;text-align:left;padding:12px 14px;border-bottom:1px solid var(--line);white-space:nowrap
}
.table tbody td{padding:12px 14px;border-bottom:1px solid #f1e5ea;font-size:14px;vertical-align:middle}
.table tbody tr:nth-child(even){background:#fffcfd}
.table tbody tr:hover{background:#fff6f9}
.table .status-cell{white-space:nowrap}
.table .money-positive{color:var(--success);font-weight:700}
.table .money-negative{color:var(--danger);font-weight:700}
.table .sticky-action{display:flex;justify-content:flex-end}
.table-note{padding:12px 14px;color:var(--muted);font-size:13px;border-top:1px solid #f1e5ea;background:#fff}
.empty-state{padding:18px;color:var(--muted)}

.toast-container{position:fixed;right:18px;top:88px;z-index:50;display:flex;flex-direction:column;gap:10px}
.toast{min-width:280px;max-width:420px;padding:12px 14px;border-radius:16px;color:#fff;box-shadow:var(--shadow);transition:.22s}
.toast.success{background:#11824f}.toast.error{background:#d13d3d}.toast.info{background:#30527b}

@media (max-width:1200px){
  .cards-compact-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media (max-width:960px){
  .layout{grid-template-columns:1fr}
  .sidebar{position:fixed;left:0;top:var(--appbar-h);width:min(88vw,360px);z-index:39;transform:translateX(0);transition:.25s ease}
  body.sidebar-collapsed .sidebar{transform:translateX(-102%);padding:18px 14px}
  body.sidebar-collapsed .sidebar .sidebar-text,body.sidebar-collapsed .sidebar .summary-text,body.sidebar-collapsed .sidebar .expander-body{display:block}
  .main{padding:16px}
  .cards-compact-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .filters-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .field-wide{grid-column:span 2}
  .top-kpis{display:none}
}
@media (max-width:640px){
  .cards-compact-grid,.filters-grid{grid-template-columns:1fr}
  .field-wide{grid-column:span 1}
  .hero h2{font-size:24px}
  .appbar{padding-inline:12px}
  .appbar-brand span{display:none}
}


.cards-uniform{
  grid-template-columns:repeat(5,minmax(0,1fr));
  align-items:stretch;
}
.cards-uniform .card{
  min-height:96px;
  padding:12px 12px 11px;
  gap:8px;
  border-radius:16px;
}
.cards-uniform .card .title{font-size:11px}
.cards-uniform .card .value{font-size:15px}
.cards-uniform .card .value.big{font-size:16px}
.cards-uniform .card .sub{font-size:11px}
.cards-uniform .badge{padding:5px 8px;font-size:10px}
.cards-uniform .info-badge{width:16px;height:16px;font-size:10px}

@media (max-width:1400px){
  .cards-uniform{grid-template-columns:repeat(4,minmax(0,1fr));}
}
@media (max-width:1200px){
  .cards-uniform{grid-template-columns:repeat(3,minmax(0,1fr));}
}
@media (max-width:960px){
  .cards-uniform{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width:640px){
  .cards-uniform{grid-template-columns:1fr;}
}
