:root{
  /* Temă caldă, stil Claude/Anthropic: paper crem + accent clay/terracotta */
  --ink:#2c2b27; --muted:#76746c; --line:#e8e4d8; --bg:#f0ede4; --card:#fbfaf6;
  --head:#2f2e2a; --accent:#c2613c; --accent2:#a8512f; --danger:#be3b34;
  --shadow:0 1px 2px rgba(50,42,30,.05),0 4px 14px rgba(50,42,30,.05);
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--bg);font-size:15.5px;line-height:1.55}
h1,h2,h3{margin:0 0 .4em}
h1{font-size:19px}h2{font-size:17px}h3{font-size:15px}

/* Accesibilitate: focus vizibil clar pentru navigarea cu tastatura */
:focus-visible{outline:3px solid #1769aa;outline-offset:2px;border-radius:4px}
button:focus-visible,.link:focus-visible,a:focus-visible{outline:3px solid #1769aa;outline-offset:2px}
/* Respecta preferinta de miscare redusa */
@media(prefers-reduced-motion:reduce){*{transition:none !important;animation:none !important;scroll-behavior:auto !important}
  .qa:hover{transform:none}}
.muted{color:var(--muted);font-size:13px}
a{color:var(--accent);text-decoration:none}
.link{color:var(--accent);cursor:pointer;text-decoration:underline}

.topbar{position:sticky;top:0;z-index:20;background:var(--head);color:#fff;
  padding:10px 18px;display:flex;align-items:center;gap:22px;flex-wrap:wrap;box-shadow:var(--shadow)}
.brand{display:flex;align-items:center;gap:10px}
.brand h1{color:#fff;margin:0}
.brand small{color:#aeb8d8}
.logo{font-size:22px;background:rgba(255,255,255,.12);width:38px;height:38px;border-radius:9px;
  display:grid;place-items:center}
.login-overlay{position:fixed;inset:0;background:linear-gradient(135deg,#2b3a67,#0b6e4f);display:grid;place-items:center;z-index:100}
.login-box{background:#fff;border-radius:16px;padding:28px;width:340px;max-width:92%;box-shadow:0 10px 40px rgba(0,0,0,.3)}
.login-logo{font-size:24px;font-weight:800;color:var(--head)}
.login-box label{display:block;margin-top:10px}
.login-box .btn{margin-top:14px}
.userbadge{color:#c7cfe6;font-size:13px;font-weight:600;margin-right:4px;white-space:nowrap}
.firma-select{width:auto;min-width:170px;max-width:240px;background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.25);padding:6px 10px;border-radius:8px;font-weight:600}
.firma-select option{color:var(--ink)}
.curgroup{display:inline-flex;align-items:center;gap:4px}
.curperiod{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.12);color:#fff;
  border:1px solid rgba(255,255,255,.25);padding:6px 12px;border-radius:8px;font-weight:700;font-size:13px;white-space:nowrap;cursor:pointer}
.curperiod:hover{background:rgba(255,255,255,.22)}
.curperiod::before{content:"📅"}
.curnav{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.25);
  border-radius:8px;padding:6px 9px;cursor:pointer;font-size:12px;font-weight:700;line-height:1;min-height:auto}
.curnav:hover{background:rgba(255,255,255,.25)}

/* Vizualizator PDF/document in aplicatie */
.pdf-modal{position:fixed;inset:0;background:rgba(20,30,60,.65);z-index:90;display:flex;
  align-items:center;justify-content:center;padding:22px}
.pdf-box{background:#fff;border-radius:14px;width:min(1000px,96vw);height:92vh;display:flex;
  flex-direction:column;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.45)}
.pdf-head{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--line);background:#f7f9fc}
.pdf-title{font-weight:700;color:var(--head);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:45%}
.pdf-frame{flex:1;width:100%;border:0;background:#525659}
.viewer-html{flex:1;overflow:auto;padding:24px;background:#eef1f7}
.efact-doc{background:#fff;max-width:780px;margin:0 auto;padding:28px 32px;border-radius:10px;box-shadow:var(--shadow)}
.efact-doc h3{color:var(--head);margin:0 0 2px}
.efact-parties{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:16px 0}
.efact-parties .lbl{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:700}
.efact-tot{margin-top:14px;margin-left:auto;width:280px}
.efact-tot td{padding:4px 8px}
.efact-tot tr.grand td{font-weight:800;font-size:15px;border-top:2px solid var(--head);color:var(--head)}
.txtview{margin:0;padding:18px 22px;background:#fff;font-family:ui-monospace,Menlo,Consolas,"Courier New",monospace;
  font-size:13px;line-height:1.5;white-space:pre;color:#1a1f36;min-height:100%}
/* Balanță — antet grupat: Sold inițial (reportat) / Rulaj / Sume / Sold final */
.bal-grp{text-align:center;font-size:11px;text-transform:uppercase;letter-spacing:.02em;border-left:2px solid #d3dcec}
.bal-grp.si{background:#eaf0fa;color:#1769aa}
.bal-grp.ru{background:#fff6e9;color:#8a6d00}
.bal-grp.su{background:#f2f5fb;color:#42506f}
.bal-grp.sf{background:#eaf4ef;color:var(--accent)}
td.grpsep,th.grpsep{border-left:2px solid #d3dcec}
/* antet pe 2 randuri: randul de grup sus, sub-anteturile Debit/Credit dedesubt (fara suprapunere la scroll) */
#balantaView thead tr:first-child th{height:26px;top:0}
#balantaView thead tr:nth-child(2) th{top:26px}
.tabs{display:flex;gap:4px;flex-wrap:wrap;align-items:center}
.tabs button{background:transparent;border:0;color:#c7cfe6;padding:10px 14px;border-radius:8px;
  cursor:pointer;font-size:13px;font-weight:600}
.tabs button:hover{background:rgba(255,255,255,.08);color:#fff}
.tabs button.active{background:#fff;color:var(--head)}
.navgroup{position:relative}
.navgroup>.navlabel.active{background:rgba(255,255,255,.20);color:#fff}
.navmenu{display:none;position:absolute;top:calc(100% + 4px);left:0;background:var(--head);
  border:1px solid rgba(255,255,255,.18);border-radius:10px;padding:6px;min-width:190px;
  flex-direction:column;gap:2px;z-index:40;box-shadow:0 10px 28px rgba(0,0,0,.35)}
.navgroup:hover .navmenu,.navgroup:focus-within .navmenu,.navgroup.open .navmenu{display:flex}
.navmenu button{text-align:left;white-space:nowrap;width:100%;color:#dbe2f4}
.navmenu button.active{background:#fff;color:var(--head)}
.navhint{font-size:10.5px;text-transform:uppercase;letter-spacing:.04em;color:#8d97bf;padding:4px 8px 2px;font-weight:700}

main{max-width:1180px;margin:22px auto;padding:0 18px}
.tab{display:none}.tab.active{display:block}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:860px){.grid2{grid-template-columns:1fr}}

.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px;
  margin-bottom:18px;box-shadow:var(--shadow)}
.card-head{display:flex;align-items:center;justify-content:space-between}

.drop{border:2px dashed var(--line);border-radius:12px;padding:26px;text-align:center;
  background:#fafbff;cursor:pointer;transition:.15s}
.drop.drag{border-color:var(--accent);background:#f0fbf6}
.drop input{display:none}
.drop p{margin:0;color:var(--muted)}

label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin:8px 0 2px}
input,select{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:9px;
  font-size:15.5px;background:#fff;color:var(--ink)}
input:focus,select:focus{outline:2px solid #cfe3da;border-color:var(--accent)}
.dyn{display:grid;grid-template-columns:1fr 1fr;gap:6px 14px}
.dyn .full{grid-column:1/-1}
.dyn .check{grid-column:1/-1;display:flex;flex-direction:row;align-items:center;gap:8px;font-size:13px}
.dyn .check input{width:auto;margin:0}

.btn{display:inline-block;background:#eef1f7;color:var(--ink);border:1px solid var(--line);
  padding:11px 16px;border-radius:9px;cursor:pointer;font-weight:600;font-size:14.5px;min-height:42px}
.btn:hover{background:#e6eaf3}
.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn.primary:hover{background:var(--accent2)}
.btn.ghost{background:transparent}
.btn.small{padding:6px 10px;font-size:12px;margin-top:8px}
.row{display:flex;gap:10px;margin-top:14px}

.preview{background:#f7f9fc;border:1px solid var(--line);border-radius:10px;padding:10px 12px;
  margin:12px 0;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12.5px;white-space:pre-wrap}
.preview .pd{color:var(--accent);font-weight:700}
.preview .pc{color:#7a3eb1;font-weight:700}

.tablewrap{overflow:auto}
table{border-collapse:collapse;width:100%;font-size:13px}
th,td{padding:7px 9px;border-bottom:1px solid var(--line);text-align:left;white-space:nowrap}
th{background:#f2f5fb;position:sticky;top:0;font-size:12px;color:#42506f}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
tr.total td{font-weight:700;background:#f3f6fc}
tr.sys td{color:#8a6d00}
/* Polish tabele: zebra discret + evidentiere rand la hover + antet mai clar la derulare */
tbody tr:nth-child(2n):not(.total):not(.sys) td{background:#f9fafd}
tbody tr:not(.total):hover td{background:#eef4fc}
thead th{box-shadow:inset 0 -1px 0 var(--line)}
.tablewrap>p.muted{text-align:center;padding:22px 12px}
/* Bara de incarcare globala (sus) */
#loadbar{position:fixed;top:0;left:0;height:3px;width:100%;z-index:200;pointer-events:none;opacity:0;transition:opacity .2s}
#loadbar.on{opacity:1}
#loadbar::after{content:"";position:absolute;top:0;height:100%;width:32%;border-radius:0 3px 3px 0;
  background:linear-gradient(90deg,transparent,var(--accent2),var(--accent));animation:loadslide 1.1s ease-in-out infinite}
@keyframes loadslide{0%{left:-32%}50%{left:50%}100%{left:100%}}
@media(prefers-reduced-motion:reduce){#loadbar::after{animation:none;left:0;width:100%;opacity:.6}}
/* Tranzitie fina la schimbarea tab-ului */
.tab.active{animation:tabfade .18s ease}
@keyframes tabfade{from{opacity:.4;transform:translateY(3px)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.tab.active{animation:none}}

/* ───── Mod COMPACT (densitate mare): mai multe randuri pe ecran ───── */
body.compact{font-size:14px;line-height:1.4}
body.compact main{margin:14px auto}
body.compact h1{font-size:17px}body.compact h2{font-size:15px}body.compact h3{font-size:13.5px}
body.compact .card{padding:11px 13px;margin-bottom:11px;border-radius:11px}
body.compact .grid2{gap:12px}
body.compact th,body.compact td{padding:3px 7px}
body.compact table{font-size:12.5px}
body.compact input,body.compact select{padding:6px 8px;font-size:13.5px}
body.compact .btn{padding:6px 11px;font-size:13px;min-height:0}
body.compact .btn.small{padding:4px 9px}
body.compact label{margin:5px 0 1px}
body.compact .toolbar{margin-bottom:8px}
body.compact .kpis{gap:10px;margin-bottom:12px}
body.compact .kpi{padding:11px}
body.compact .kpi .val{font-size:20px;margin-top:2px}
body.compact .explain{padding:9px 12px;margin-bottom:10px}
body.compact .cyclemap{margin-bottom:8px}
body.compact .docband{padding:7px 12px;margin:12px 0 8px}
body.compact .preview{padding:8px 10px;margin:8px 0}
body.compact #balantaView thead tr:first-child th{height:22px}
body.compact #balantaView thead tr:nth-child(2) th{top:22px}
.acc{font-family:ui-monospace,Menlo,Consolas,monospace;font-weight:600}

.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.toolbar .spacer{flex:1}
.period{width:auto;min-width:140px}

.status{font-size:13px;margin-top:8px;min-height:18px}
.status.err{color:var(--danger)}
.status.ok{color:var(--accent)}
.badge{background:#eef1f7;border:1px solid var(--line);border-radius:20px;padding:2px 10px;font-size:12px;color:var(--muted)}
.hidden{display:none}
.ledger-acc{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 14px;margin-bottom:12px;box-shadow:var(--shadow)}
.ledger-acc h4{margin:0 0 6px;color:var(--head)}
.pill{display:inline-block;background:#eef6f2;color:var(--accent);border-radius:6px;padding:1px 7px;font-size:11px;font-weight:700;margin-left:6px}
.pill.warn{background:#fdeaea;color:var(--danger)}

.del{color:var(--danger);cursor:pointer;font-weight:700;border:0;background:none;font-size:14px}
.linkbtn{background:none;border:0;color:var(--accent);cursor:pointer;text-decoration:underline;font-size:12px}

.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-bottom:18px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px;box-shadow:var(--shadow)}
.kpi .lbl{color:var(--muted);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}
.kpi .val{font-size:24px;font-weight:800;margin-top:6px;font-variant-numeric:tabular-nums}
.kpi .sub{color:var(--muted);font-size:12px;margin-top:2px}
.kpi.green .val{color:var(--accent)}.kpi.red .val{color:var(--danger)}.kpi.blue .val{color:var(--head)}

.items-editor{border:1px solid var(--line);border-radius:9px;padding:8px;background:#fafbff}
.item-row{display:grid;grid-template-columns:2fr .8fr .7fr 1fr .7fr auto;gap:6px;margin-bottom:5px}
.item-row input{padding:6px 8px;font-size:13px}
.item-row .delitem{padding:4px 9px}
.stoc-editor{border:1px solid var(--line);border-radius:9px;padding:8px;background:#fafbff}
.stoc-row{display:grid;grid-template-columns:2fr 1.4fr .8fr auto;gap:6px;margin-bottom:5px}
.stoc-row select,.stoc-row input{padding:6px 8px;font-size:13px}
.stoc-row .delstoc{padding:4px 9px}
body.dark .stoc-editor{background:#121a2b}

.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(40px);
  background:var(--ink);color:#fff;padding:11px 18px;border-radius:10px;opacity:0;transition:.25s;
  box-shadow:var(--shadow);z-index:50;max-width:90%}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.err{background:var(--danger)}

/* Benzi de sectiune in tab-ul Documente: intrare vs iesire */
.docband{display:flex;align-items:baseline;gap:12px;margin:20px 0 10px;padding:9px 14px;border-radius:10px;font-weight:700}
.docband:first-child{margin-top:0}
.docband b{font-size:15px}
.docband small{font-weight:500;opacity:.9}
.docband.intrare{background:#eaf4ef;color:#0b6e4f;border-left:5px solid #0b6e4f}
.docband.iesire{background:#fdeef0;color:#b00020;border-left:5px solid #b00020}
.emitgrid{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.emitgrid .emit{font-weight:800}
.linklist a{display:block;padding:7px 0;border-bottom:1px solid var(--line);color:var(--ink);text-decoration:none;font-weight:700}
.linklist a:hover{color:var(--accent)}
.linklist a:last-child{border-bottom:0}

/* Ghid de folosire pas-cu-pas */
.howto h3{margin:18px 0 6px;color:var(--head);font-size:15px}
.howto h3:first-child{margin-top:4px}
.howto ol,.howto ul{margin:4px 0 8px;padding-left:22px}
.howto li{margin:4px 0}
.howto .lead{background:#f0fbf6;border-left:4px solid var(--accent);padding:10px 14px;border-radius:8px;margin-bottom:12px}
.howto .tag{display:inline-block;font-size:11px;font-weight:800;padding:1px 8px;border-radius:6px;margin-right:6px;vertical-align:middle}
.howto .tag.in{background:#eaf4ef;color:#0b6e4f}
.howto .tag.out{background:#fdeef0;color:#b00020}
.howto kbd{background:#eef1f7;border:1px solid var(--line);border-radius:5px;padding:1px 6px;font-size:12px;font-weight:700}

/* Acțiuni rapide pe Dashboard (scurtături pentru începători) */
.quickacts{display:grid;grid-template-columns:repeat(auto-fit,minmax(185px,1fr));gap:12px}
.qa{display:flex;flex-direction:column;align-items:flex-start;gap:3px;padding:15px;border:1px solid var(--line);
  border-radius:12px;background:#fff;cursor:pointer;text-align:left;box-shadow:var(--shadow);transition:.12s}
.qa:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 6px 20px rgba(20,30,60,.12)}
.qa .ic{font-size:25px;line-height:1}
.qa .t{font-weight:800;font-size:14px;color:var(--ink)}
.qa .d{font-size:12px;color:var(--muted)}
.qa.in{border-left:5px solid var(--accent)}
.qa.out{border-left:5px solid var(--danger)}

/* Modal de bun-venit (prima logare) */
.welcome-box{background:#fff;border-radius:18px;padding:30px 32px;width:480px;max-width:94%;
  box-shadow:0 14px 50px rgba(0,0,0,.35);text-align:center}
.welcome-emoji{font-size:40px;line-height:1}
.welcome-box h2{margin:8px 0 6px;color:var(--head);font-size:20px}
.welcome-steps{display:flex;flex-direction:column;gap:12px;text-align:left;margin:16px 0}
.welcome-steps>div{display:flex;gap:12px;align-items:flex-start}
.ws-ic{font-size:24px;width:40px;height:40px;flex:0 0 40px;display:grid;place-items:center;
  background:#eef1f7;border-radius:10px}
.ws-ic.in{background:#eaf4ef}.ws-ic.out{background:#fdeef0}

/* Harta ciclului contabil (unde te afli) + explicatii simple */
.cyclemap{display:flex;flex-wrap:wrap;align-items:center;gap:5px;margin-bottom:12px}
.cyclestep{display:inline-flex;align-items:center;gap:6px;padding:8px 13px;border-radius:22px;
  border:1px solid var(--line);background:#fff;color:var(--muted);cursor:pointer;font-weight:700;font-size:13px;min-height:auto}
.cyclestep .ci{font-size:15px}
.cyclestep:hover{border-color:var(--accent);color:var(--ink)}
.cyclestep.active{background:var(--head);color:#fff;border-color:var(--head)}
.cyclearrow{color:#b9c1d6;font-weight:800}
.explain{display:flex;gap:12px;background:#eef5ff;border:1px solid #d6e4f7;border-left:5px solid #1769aa;
  border-radius:10px;padding:13px 15px;margin-bottom:16px}
.explain .ei{font-size:23px;line-height:1.2}
.explain b{color:var(--head)}
.explain p{margin:0}

/* ───────────────── Mod ÎNTUNECAT (dark) ───────────────── */
.c-si{color:#1769aa}.c-ru{color:#8a6d00}.c-sf{color:var(--accent)}
body.dark{
  --ink:#e7eaf3; --muted:#9aa6c0; --line:#2a3344; --bg:#0e1320; --card:#161d2c;
  --head:#172240; --accent:#33b07d; --accent2:#3cbd86; --danger:#ff6b81;
  --shadow:0 1px 3px rgba(0,0,0,.45),0 6px 20px rgba(0,0,0,.4);
}
body.dark input,body.dark select,body.dark textarea{background:#0f1626;color:var(--ink);border-color:var(--line)}
body.dark option,body.dark optgroup{background:#161d2c;color:var(--ink)}
body.dark .firma-select option{background:#172240;color:#fff}
/* orice textarea/input rămas, în dark, să aibă text deschis pe fond închis */
body.dark textarea,body.dark .txtview,body.dark pre{color:var(--ink)}
body.dark input:focus,body.dark select:focus{outline-color:#1f5b46}
body.dark .btn{background:#222b40;color:var(--ink);border-color:var(--line)}
body.dark .btn:hover{background:#2a3450}
body.dark .btn.ghost{background:transparent}
body.dark .btn.primary{background:var(--accent);color:#08110c;border-color:var(--accent)}
body.dark th{background:#1a2236;color:#aeb8d6}
body.dark tr.total td{background:#1d2740}
body.dark tbody tr:nth-child(2n):not(.total):not(.sys) td{background:#131a29}
body.dark tbody tr:not(.total):hover td{background:#202a44}
body.dark tr.sys td{color:#d9b65a}
body.dark .badge{background:#222b40;color:var(--muted);border-color:var(--line)}
body.dark .preview{background:#0f1626}
body.dark .drop{background:#121a2b}
body.dark .drop.drag{background:#12251d}
body.dark .qa,body.dark .cyclestep{background:#1b2235}
body.dark .pill{background:#14271f;color:#4fc596}
body.dark .pill.warn{background:#2a1620;color:#ff8a9c}
body.dark .explain{background:#15233a;border-color:#26405f}
body.dark .explain b{color:#cfe0ff}
body.dark .docband.intrare{background:#13241c;color:#5cc492}
body.dark .docband.iesire{background:#2a1620;color:#ff8a9c}
body.dark .bal-grp.si{background:#16233a;color:#7fb3e6}
body.dark .bal-grp.ru{background:#2a2410;color:#d9b65a}
body.dark .bal-grp.su{background:#1b2236;color:#aeb8d6}
body.dark .bal-grp.sf{background:#14271f;color:#4fc596}
body.dark .toast{background:#222b40;color:var(--ink)}
body.dark .login-box,body.dark .welcome-box,body.dark .pdf-box,body.dark .efact-doc,body.dark .txtview,body.dark .ledger-acc{background:#161d2c;color:var(--ink)}
body.dark .pdf-head{background:#0f1626}
body.dark .viewer-html{background:#0e1320}
body.dark .ws-ic{background:#222b40}
body.dark .ws-ic.in{background:#13241c}body.dark .ws-ic.out{background:#2a1620}
body.dark .items-editor{background:#121a2b}
body.dark .c-si{color:#7fb3e6}body.dark .c-ru{color:#d9b65a}body.dark .c-sf{color:#4fc596}
/* titluri/valori care foloseau navy (--head) ca text -> deschise pe fundal întunecat */
body.dark .howto h3,body.dark .ledger-acc h4,body.dark .welcome-box h2,body.dark .login-logo,
body.dark .pdf-title,body.dark .efact-doc h3,body.dark .efact-tot tr.grand td,body.dark .kpi.blue .val{color:#8aa0d8}

/* ───── Dashboard: KPI-uri cu iconita + tendinta + dunga de accent ───── */
.kpi{position:relative;overflow:hidden}
.kpi-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.kpi-ic{font-size:22px;line-height:1}
.kpi .trend{font-size:12px;font-weight:800;padding:2px 9px;border-radius:20px;white-space:nowrap}
.kpi .trend.good{background:#eaf4ef;color:var(--accent)}
.kpi .trend.bad{background:#fdeef0;color:var(--danger)}
.kpi.green{border-left:4px solid var(--accent)}
.kpi.red{border-left:4px solid var(--danger)}
.kpi.blue{border-left:4px solid #4a72c4}
body.dark .kpi .trend.good{background:#14271f;color:#4fc596}
body.dark .kpi .trend.bad{background:#2a1620;color:#ff8a9c}
/* grafice care urmeaza tema (clar/intunecat) */
.cgrid{stroke:var(--line)}
.caxis{stroke:var(--line)}
.ctxt{fill:var(--muted)}

/* ───────────────── MOBIL: bară de jos + panou „Mai mult" + tabele ───────────────── */
.bottomnav{display:none}
.more-sheet{display:none}
@media(max-width:0px){ /* DEZACTIVAT — aplicatie doar desktop (fara versiune mobil) */
  #tabs{display:none}                 /* meniul desktop ascuns pe mobil (inlocuit de bara de jos) */
  .topbar{gap:10px;padding:8px 12px}
  main{margin:14px auto;padding:0 12px;padding-bottom:70px}  /* loc pentru bara de jos */
  .card{padding:13px}
  h1{font-size:17px}
  .kpis{grid-template-columns:1fr 1fr;gap:10px}
  .toolbar{flex-wrap:wrap}
  .period{min-width:120px}
  /* tabele: derulare orizontala fluida + mai compacte pe mobil */
  .tablewrap{-webkit-overflow-scrolling:touch}
  table{font-size:12.5px}
  th,td{padding:6px 8px}

  .bottomnav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:60;
    background:var(--card);border-top:1px solid var(--line);box-shadow:0 -2px 14px rgba(0,0,0,.12);
    padding-bottom:env(safe-area-inset-bottom,0)}
  .bottomnav button{flex:1;background:none;border:0;color:var(--muted);font-size:20px;
    padding:8px 2px 6px;display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;min-height:0}
  .bottomnav button span{font-size:10px;font-weight:700;letter-spacing:.01em}
  .bottomnav button.active{color:var(--accent)}

  .more-sheet{display:block;position:fixed;inset:0;background:rgba(10,15,25,.55);z-index:80}
  .more-sheet.hidden{display:none}
  .more-box{position:absolute;left:0;right:0;bottom:0;background:var(--card);
    border-radius:16px 16px 0 0;padding:14px 16px calc(16px + env(safe-area-inset-bottom,0));max-height:80vh;overflow:auto}
  .more-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
  .more-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .more-grid button{text-align:left;background:var(--bg);border:1px solid var(--line);border-radius:10px;
    padding:12px 10px;font-size:13.5px;font-weight:600;color:var(--ink);cursor:pointer}
  .more-grid button:hover{border-color:var(--accent)}
}

/* Vizualizator XML ANAF — colorare usoara (tag/atribut/valoare) */
.xmlview .xtag{color:#1769aa;font-weight:600}
.xmlview .xattr{color:#8a6d00}
.xmlview .xval{color:#0b6e4f}
body.dark .xmlview .xtag{color:#7fb3e6}
body.dark .xmlview .xattr{color:#d9b65a}
body.dark .xmlview .xval{color:#5cc492}

/* Arhivă documente — spațiere linkuri */
.arh-link{margin:4px 7px 0 0}
#arhivaView .card h3{display:flex;align-items:center;gap:6px}

/* Casetă de avertizare conformitate (declarații ANAF) */
.warnbox{display:flex;gap:10px;background:#fff8ec;border:1px solid #f0d9a8;border-left:4px solid #c79100;
  border-radius:10px;padding:11px 14px;margin-bottom:14px;font-size:13.5px}
.warnbox .wi{font-size:20px;line-height:1.2}
.warnbox b{color:#8a6d00}
body.dark .warnbox{background:#2a2410;border-color:#5a4a18;color:#e7d9a8}
body.dark .warnbox b{color:#d9b65a}
/* Checklist de conformitate */
.checklist{list-style:none;padding:0;margin:6px 0}
.checklist li{padding:7px 0 7px 30px;position:relative;border-bottom:1px solid var(--line)}
.checklist li:last-child{border-bottom:0}
.checklist li::before{content:"☑";position:absolute;left:4px;top:6px;color:var(--accent);font-weight:800}

/* Checklist „de făcut" (documente lipsă) — casetă neutră */
.checklist.todo li::before{content:"☐";color:#c79100}
body.dark .checklist.todo li::before{color:#d9b65a}

/* Comutator șabloane email */
.emltpl.active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ───────── Stil Claude/Anthropic: titluri serif + topbar cald + tușe clay ───────── */
h1,h2,h3,.brand h1,.login-logo{font-family:Georgia,"Iowan Old Style","Palatino Linotype",Palatino,serif;
  letter-spacing:-.01em;font-weight:600}
.efact-doc h3{font-family:Georgia,serif}
/* topbar cald (charcoal) cu text crem */
.tabs button{color:#cdc8bd}
.tabs button:hover{background:rgba(255,255,255,.07);color:#fff}
.tabs button.active{background:#fbfaf6;color:var(--head)}
.brand small{color:#bdb8ac}
.userbadge{color:#cdc8bd}
.navmenu button{color:#e2ddd2}
.navhint{color:#aaa496}
.navmenu{background:var(--head)}
/* carduri & butoane mai „soft" */
.card{border-radius:16px}
.btn{border-radius:10px}
.btn.primary{box-shadow:0 1px 2px rgba(160,80,40,.25)}
/* fundaluri de accent calde (intrare = verde măsliniu cald rămâne; ajustăm doar cele reci) */
.drop.drag{background:#fbf2ec;border-color:var(--accent)}
.login-overlay{background:linear-gradient(135deg,#2f2e2a,#c2613c)}
.kpi-ic,.qa .ic,.ws-ic{filter:saturate(.95)}

/* Suprafețe neutre recalibrate la cald (coerent cu tema Claude) — doar tema luminoasă */
body:not(.dark) .btn{background:#efebe1}
body:not(.dark) .btn:hover{background:#e7e1d4}
body:not(.dark) .drop{background:#f6f3ea}
body:not(.dark) .preview{background:#f6f3ea}
body:not(.dark) th{background:#f1eee4;color:#6f6c62}
body:not(.dark) tr.total td{background:#f0ece1}
body:not(.dark) tbody tr:nth-child(2n):not(.total):not(.sys) td{background:#faf8f1}
body:not(.dark) tbody tr:not(.total):hover td{background:#f4ebe2}
body:not(.dark) .badge{background:#efebe1}
body:not(.dark) input:focus,body:not(.dark) select:focus{outline:2px solid #e8cdbd}
body:not(.dark) .explain{background:#f6f1e8;border-color:#e6dcc9;border-left-color:var(--accent)}
body:not(.dark) .explain b{color:#8a4a2c}
body:not(.dark) .pdf-head{background:#f6f3ea}
body:not(.dark) .viewer-html{background:#efece3}
body:not(.dark) .txtview{background:#fbfaf6;color:var(--ink)}
.pdf-modal{background:rgba(50,42,30,.5)}
body:not(.dark) .bal-grp,body:not(.dark) td.grpsep,body:not(.dark) th.grpsep{border-left-color:#e3dccc}
body:not(.dark) .kpi.blue{border-left-color:#9c7a55}

/* ============ LAYOUT SIDEBAR (stil Claude) — mereu activ (doar desktop) ============ */
@media(min-width:1px){
  .shell{display:flex;align-items:flex-start;min-height:100vh}
  /* bara devine sidebar vertical pe stânga (păstrează fundalul închis = text alb funcționează) */
  .topbar{flex-direction:column;flex-wrap:nowrap;align-items:stretch;width:250px;flex:0 0 250px;height:100vh;
    position:sticky;top:0;overflow:hidden;gap:7px;padding:14px 12px;border-bottom:0;
    border-right:1px solid rgba(255,255,255,.08);box-shadow:none}
  .topbar .spacer{display:none}
  .topbar .brand{order:1;padding:2px 6px 11px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:2px}
  .topbar .firma-select{order:2;max-width:100%;width:100%}
  .topbar .curgroup{order:3;justify-content:center}
  .topbar #tabs{order:4;flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden;flex-direction:column;flex-wrap:nowrap;align-items:stretch;gap:2px;margin:4px 0}
  .topbar #themeBtn{order:5}
  .topbar #densityBtn{order:6}
  .topbar #userBadge{order:7;text-align:center;margin:4px 0 0}
  .topbar #logoutBtn{order:8;width:100%}
  .shell>main{flex:1 1 auto;min-width:0;margin:0;max-width:none;padding:24px 28px}
  .shell>main>.tab{max-width:1120px;margin:0 auto}
  /* navigație verticală: grupuri mereu deschise (secțiuni) */
  #tabs>button[data-tab]{text-align:left;width:100%;padding:9px 12px;border-radius:9px;font-size:14px}
  #tabs button[data-tab]{display:block !important}
  #tabs button[data-tab].active{background:rgba(255,255,255,.16);color:#fff}
  #tabs .navgroup{display:block !important;position:static !important;width:100%}
  #tabs .navlabel{display:block;text-align:left;width:100%;font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;
    color:#f0c14b;padding:13px 12px 3px;background:none;cursor:default;font-weight:800}
  #tabs .navlabel:hover,#tabs .navlabel.active{background:none;color:#f0c14b}
  #tabs .navmenu{display:block !important;position:static !important;top:auto !important;left:auto !important;
    background:none;border:0;box-shadow:none;padding:0;min-width:0}
  #tabs .navmenu button{display:block !important;width:100%;color:#d9d4c9;padding:8px 12px 8px 16px;border-radius:9px;font-weight:500;font-size:13px;white-space:normal;line-height:1.3}
  #tabs .navmenu button:hover{background:rgba(255,255,255,.08);color:#fff}
  #tabs .navmenu button.active{background:rgba(255,255,255,.16);color:#fff}
  #tabs .navhint{color:#8f897e;padding:5px 12px 2px}
}

/* Ghid (.howto) — fundaluri deschise adaptate la dark (text lizibil) */
body.dark .howto .lead{background:#15233a;border-left-color:var(--accent);color:var(--ink)}
body.dark .howto kbd{background:#222b40;color:var(--ink);border-color:var(--line)}
body.dark .howto .tag.in{background:#13241c;color:#5cc492}
body.dark .howto .tag.out{background:#2a1620;color:#ff8a9c}

/* Modal scanare cu camera */
.scan-box{background:var(--card);border-radius:14px;width:min(720px,96vw);max-height:92vh;display:flex;
  flex-direction:column;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.45)}
.scan-stage{flex:1;background:#1b1b1b;display:flex;align-items:center;justify-content:center;min-height:300px}
.scan-stage video{width:100%;max-height:62vh;object-fit:contain;background:#000}
.scan-actions{display:flex;gap:10px;align-items:center;padding:12px 14px;border-top:1px solid var(--line)}
.scan-actions .period{margin:0}

/* Panou „documente lipsă" — text normal lizibil (nu galben), dungă de status */
.missingbox{display:flex;gap:10px;align-items:flex-start;background:var(--card);border:1px solid var(--line);
  border-left:4px solid var(--accent);border-radius:10px;padding:11px 14px;margin-bottom:14px;font-size:13.5px;color:var(--ink)}
.missingbox.ok{border-left-color:#2a8a5a}
.missingbox .wi{font-size:20px;line-height:1.2}
.missingbox b{color:var(--ink)}
/* explicațiile „Ce vezi aici" — bold închis, nu chihlimbar */
body:not(.dark) .explain b{color:var(--head)}
