*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--bg:#f5f3ef;--c:#fff;--t:#2d2d2d;--t2:#6b6b6b;--t3:#999;--ac:#3d5a80;--ac2:#e8eef4;--ach:#2c4a6e;--bd:#e0ddd8;--ok:#4a8c6f;--wn:#c17d3b;--er:#b05050;--r:8px;--rs:5px;--sh:0 1px 3px rgba(0,0,0,.06);--sh2:0 3px 12px rgba(0,0,0,.08);--tr:.2s ease}
body{font-family:'DM Sans',-apple-system,sans-serif;background:var(--bg);color:var(--t);line-height:1.5;height:100vh;overflow:hidden}
.layout{display:flex;height:100vh}

/* Sidebar (narrow) */
.sb{width:130px;background:var(--c);border-right:1px solid var(--bd);display:flex;flex-direction:column;flex-shrink:0}
.sb-hd{display:flex;justify-content:space-between;align-items:center;padding:.4rem .5rem;border-bottom:1px solid var(--bd);background:#faf9f7;font-weight:700;font-size:.72rem}
.sb-list{flex:1;overflow-y:auto;padding:.2rem}
.sb-ft{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.35rem;border-top:1px solid var(--bd)}
.sb-ic{background:none;border:none;font-size:.85rem;cursor:pointer;color:var(--t3);transition:var(--tr);padding:.15rem}.sb-ic:hover{color:var(--ac)}
.sb-dot{background:none;border:none;cursor:pointer;padding:.15rem}
.dot{display:block;width:8px;height:8px;border-radius:50%;background:var(--t3)}.dot.on{background:var(--ok);box-shadow:0 0 5px var(--ok)}.dot.off{background:var(--er)}
.pi{display:flex;justify-content:space-between;padding:.3rem .4rem;border-radius:var(--rs);cursor:pointer;transition:var(--tr);margin-bottom:.08rem}
.pi:hover{background:#f0eeea}.pi.sel{background:var(--ac);color:#fff}.pi.sel .pi-m{color:rgba(255,255,255,.7)}
.pi-n{font-weight:600;font-size:.7rem}.pi-m{font-size:.58rem;color:var(--t3)}
.empty{text-align:center;padding:.7rem;color:var(--t3);font-size:.68rem}

/* Main */
.mn{flex:1;overflow-y:auto;padding:.8rem 1rem}

/* Dashboard rows */
.row{margin-bottom:.8rem;background:var(--c);border:1px solid #e8ecf0;border-radius:12px;padding:.6rem}.row-label{font-size:.65rem;font-weight:700;color:var(--ac);letter-spacing:.03em;margin-bottom:.35rem;padding-bottom:.2rem;border-bottom:2px solid var(--ac2)}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));max-width:660px;gap:.35rem}
.card{background:var(--c);border:1px solid #d0d5dd;border-radius:10px;padding:.55rem .5rem;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:.15rem;text-align:center;position:relative;min-height:75px;justify-content:center;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.card:hover{box-shadow:var(--sh2);border-color:var(--ac)}.card.locked{opacity:.45;cursor:default}.card.locked:hover{box-shadow:none;border-color:var(--bd)}
.card.wip{opacity:.5}
.card-ic{font-size:1.1rem}.card-lb{font-size:.6rem;font-weight:600;line-height:1.2}
.card-tag{position:absolute;top:2px;right:4px;font-size:.45rem;color:var(--t3)}
.card-tones{display:flex;gap:.15rem;margin-top:.1rem}
.tn{padding:.1rem .22rem;border:1px solid var(--bd);border-radius:3px;background:none;font-family:inherit;font-size:.55rem;cursor:pointer;transition:var(--tr)}
.tn:hover:not(.dis){border-color:var(--ac);color:var(--ac)}.tn-positiu:hover:not(.dis){color:var(--ok);border-color:var(--ok)}.tn-negatiu:hover:not(.dis){color:var(--er);border-color:var(--er)}
.tn.dis{opacity:.3;pointer-events:none}
.td{width:8px;height:8px;border-radius:50%;display:inline-block}.tn-positiu,.td.tn-positiu{background:#b6dfc8}.tn-negatiu,.td.tn-negatiu{background:#f0b6b6}

/* Workspace */
.ws-hd{display:flex;align-items:center;gap:.4rem;margin-bottom:.3rem;flex-wrap:wrap}
.ws-hd h2{font-family:'DM Serif Display',serif;font-weight:400;font-size:1rem;flex:1}
.ws-mdl{display:flex;align-items:center;gap:.2rem}.ws-mdl label{font-size:.55rem;font-weight:600;color:var(--t2)}
.ws-info{background:var(--ac2);color:var(--ac);padding:.2rem .4rem;border-radius:var(--rs);font-size:.65rem;margin-bottom:.4rem}
.ws-act{text-align:center;margin-top:.4rem}
.sb2{background:var(--c);border:1px solid var(--bd);border-radius:var(--r);padding:.4rem .55rem;margin-bottom:.25rem}
.sb2-hd{display:flex;align-items:center;gap:.2rem;margin-bottom:.15rem;flex-wrap:wrap}
.sb2-t{font-weight:600;font-size:.72rem;color:var(--ac)}
.wc{font-size:.5rem;color:var(--t3);background:#f0f0f0;padding:.02rem .15rem;border-radius:3px}
.tog{background:none;border:1px solid var(--bd);padding:.03rem .15rem;border-radius:3px;font-size:.58rem;cursor:pointer;margin-left:auto}
.sb2-ref{background:#faf9f7;padding:.2rem .35rem;border-radius:var(--rs);border-left:2px solid var(--ac2);margin:.08rem 0}
.ref-s,.ref-f p{font-size:.65rem;color:var(--t2);font-style:italic;line-height:1.35}
.sec-inp{margin-top:.15rem}

/* Common */
.inp{width:100%;padding:.28rem .38rem;border:1px solid var(--bd);border-radius:var(--rs);font-family:inherit;font-size:.7rem;resize:vertical;transition:var(--tr)}
.inp:focus{outline:none;border-color:var(--ac);box-shadow:0 0 0 2px rgba(61,90,128,.1)}
.inp.sm{padding:.15rem .25rem;font-size:.65rem}
.btn{display:inline-flex;align-items:center;gap:.2rem;padding:.3rem .6rem;border:none;border-radius:var(--rs);font-family:inherit;font-size:.68rem;font-weight:600;cursor:pointer;text-decoration:none;transition:var(--tr)}
.btn.pri{background:var(--ac);color:#fff}.btn.pri:hover{background:var(--ach)}
.btn.sec{background:var(--bg);color:var(--t);border:1px solid var(--bd)}.btn.sec:hover{border-color:var(--ac);color:var(--ac)}
.btn.out{background:transparent;color:var(--ac);border:1px solid var(--ac)}.btn.out:hover{background:var(--ac);color:#fff}
.btn.danger{color:var(--er)!important;border-color:var(--er)!important}.btn.danger:hover{background:var(--er)!important;color:#fff!important}
.btn.lg{padding:.4rem .9rem;font-size:.78rem}.btn.xs{padding:.12rem .28rem;font-size:.6rem}
.btn:disabled,.btn.dis{opacity:.4;pointer-events:none}
.btn-back{background:none;border:none;color:var(--t2);font-family:inherit;font-size:.68rem;cursor:pointer}.btn-back:hover{color:var(--ac)}
.btn-link{background:none;border:none;color:var(--ac);cursor:pointer;font-size:.6rem;font-family:inherit}.btn-link:hover{text-decoration:underline}
.btn-icon{background:none;border:none;font-size:.85rem;cursor:pointer;padding:.12rem;border-radius:var(--rs)}.btn-icon:hover{background:var(--bg)}
.badge{display:inline-block;font-size:.5rem;font-weight:600;padding:.06rem .25rem;border-radius:6px;text-transform:uppercase}
.badge-ok{background:#d4edda;color:var(--ok)}.badge-no{background:#fff3e0;color:var(--wn)}
.tone-positiu{background:#e8f5e9;color:var(--ok)}.tone-negatiu{background:#fce4ec;color:var(--er)}
.muted{color:var(--t3);font-size:.65em}

/* Progress */
.spin{display:inline-block;width:12px;height:12px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:sp .6s linear infinite}
.spin-lg{width:24px;height:24px;border:3px solid var(--bd);border-top-color:var(--ac);border-radius:50%;animation:sp .8s linear infinite;margin:0 auto .4rem}
@keyframes sp{to{transform:rotate(360deg)}}
.prog-card{background:var(--c);border:1px solid var(--bd);border-radius:var(--r);padding:1rem;text-align:center;max-width:320px;margin:.8rem auto;box-shadow:var(--sh2)}
.prog-card h3{font-size:.82rem;margin-bottom:.1rem}
.prog-bar{height:4px;background:var(--bd);border-radius:2px;margin:.35rem 0;overflow:hidden}
.prog-fill{height:100%;background:var(--ac);border-radius:2px;transition:width .5s;width:0}
.res-card{background:var(--c);border:1px solid var(--bd);border-radius:var(--r);padding:.8rem;text-align:center;box-shadow:var(--sh2);max-width:420px;margin:0 auto}
.res-ic{font-size:1.3rem}.res-card h2{font-family:'DM Serif Display',serif;font-weight:400;font-size:.88rem;margin:.1rem 0 .2rem}
.res-prv{text-align:left;margin:.3rem 0;max-height:50vh;overflow-y:auto}.rp{background:#faf9f7;padding:.3rem .4rem;border-radius:var(--rs);margin-bottom:.15rem;border-left:2px solid var(--ok)}
.rp h4{font-size:.6rem;color:var(--ac);margin-bottom:.1rem}.rp p{font-size:.6rem;color:var(--t2);line-height:1.5;white-space:pre-wrap}
.rp.rp-empty{border-left-color:var(--er);opacity:.7}.rp.rp-empty p{color:var(--er);font-style:italic}
.com-bt{display:flex;gap:.2rem;justify-content:center;margin:.2rem 0}
.res-act{display:flex;gap:.2rem;justify-content:center;margin-top:.3rem}
.res-card h3{font-size:.72rem;margin:.2rem 0 .1rem}.res-card hr{border:none;border-top:1px solid var(--bd);margin:.2rem 0}

/* Drawers (wider) */
.dw-ov{position:fixed;inset:0;background:rgba(0,0,0,.25);z-index:200}
.dw{position:fixed;top:0;right:0;bottom:0;width:370px;background:var(--c);border-left:1px solid var(--bd);z-index:201;display:flex;flex-direction:column;box-shadow:-3px 0 15px rgba(0,0,0,.08)}
.dw-hd{display:flex;justify-content:space-between;align-items:center;padding:.45rem .65rem;border-bottom:1px solid var(--bd)}.dw-hd h2{font-size:.82rem}
.dw-bd{flex:1;overflow-y:auto;padding:.5rem .65rem}
.dw-sub{font-size:.65rem;font-weight:600;color:var(--t2);margin:.4rem 0 .15rem;display:flex;align-items:center;gap:.2rem}
.dw-act{display:flex;gap:.2rem;margin-top:.5rem;flex-wrap:wrap}
.dw-sec{margin-bottom:.6rem}.dw-sec h3{font-size:.7rem;margin-bottom:.15rem;border-bottom:1px solid var(--bd);padding-bottom:.1rem}
.fg{margin-bottom:.2rem}.fg label{display:block;font-size:.55rem;font-weight:600;color:var(--t2);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.03rem}
.fg2{display:grid;grid-template-columns:1fr 1fr;gap:.2rem}
.lvls{display:flex;flex-direction:column;gap:.08rem}.lvl{display:flex;align-items:center;justify-content:space-between;font-size:.65rem}.lvl span:first-child{min-width:45px}.lvl select{width:80px}
.chips{display:flex;flex-wrap:wrap;gap:.12rem;margin:.12rem 0}
.chip{padding:.07rem .28rem;border:1px solid var(--bd);border-radius:8px;font-size:.6rem;font-family:inherit;background:none;cursor:pointer;transition:var(--tr)}.chip:hover{border-color:var(--ac)}.chip.on{background:var(--ac);color:#fff;border-color:var(--ac)}
.led{display:flex;gap:.12rem;margin:.1rem 0}.elist{display:flex;flex-direction:column;gap:.05rem}
.ei{display:flex;justify-content:space-between;align-items:center;padding:.04rem .18rem;font-size:.58rem;background:#faf9f7;border-radius:3px}.ei .btn-link{color:var(--er)}
.ex-bar{font-size:.65rem;padding:.25rem .35rem;background:var(--ac2);border-radius:var(--rs);margin-bottom:.3rem;color:var(--ac)}
.sp-bt{display:flex;gap:.12rem;flex-wrap:wrap;margin:.12rem 0}.sp.on{background:var(--ac);color:#fff;border-color:var(--ac)}
.act-text{font-size:.7rem;line-height:1.5;white-space:pre-wrap;font-family:inherit;background:#faf9f7;padding:.5rem;border-radius:var(--rs);border-left:2px solid var(--ac);margin-top:.3rem}

/* Config items */
.cfg-desc{font-size:.58rem;color:var(--t3);margin-bottom:.2rem}
.ci{padding:.2rem 0;border-bottom:1px solid #f0f0f0}.ci:last-child{border:none}
.ci-hd{display:flex;align-items:center;gap:.15rem;margin-bottom:.06rem}.ci-lb{font-size:.68rem;font-weight:500;flex:1}
.ci-f{display:flex;align-items:center;gap:.15rem;margin-bottom:.08rem;padding:.08rem .15rem;background:#faf9f7;border-radius:3px}
.ci-fn{font-size:.58rem;color:var(--t2);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ci-up{display:flex;align-items:center;gap:.15rem}.file-input{display:none}
.fl{display:inline-block;padding:.08rem .25rem;border:1px dashed var(--bd);border-radius:3px;font-size:.58rem;color:var(--t3);cursor:pointer;text-align:center}.fl:hover{border-color:var(--ac);color:var(--ac)}
.help section{margin-bottom:.5rem}.help h3{font-size:.72rem;color:var(--ac);margin-bottom:.1rem}.help p{font-size:.62rem;margin-bottom:.1rem;line-height:1.35}

/* Status popup */
.popup{position:fixed;bottom:50px;left:140px;width:280px;background:var(--c);border:1px solid var(--bd);border-radius:var(--r);box-shadow:var(--sh2);z-index:300;padding:.5rem .6rem;font-size:.68rem}
.popup-hd{display:flex;justify-content:space-between;align-items:center;margin-bottom:.3rem}
.popup p{margin-bottom:.15rem}.popup ul{list-style:none;padding-left:.3rem;font-size:.62rem;color:var(--t2)}
.popup li::before{content:"· "}

/* Modal */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:300;display:flex;align-items:center;justify-content:center}
.mod-in{background:var(--c);border-radius:var(--r);width:90%;max-width:480px;max-height:75vh;display:flex;flex-direction:column;box-shadow:var(--sh2)}
.mod-hd{display:flex;justify-content:space-between;align-items:center;padding:.35rem .55rem;border-bottom:1px solid var(--bd)}.mod-hd h2{font-size:.82rem}
.mod-bd{flex:1;overflow-y:auto;padding:.25rem .45rem}.mod-ft{padding:.3rem .55rem;border-top:1px solid var(--bd);display:flex;gap:.2rem;justify-content:flex-end}
.se-row{display:flex;align-items:flex-start;gap:.25rem;padding:.12rem .18rem;border-radius:3px;cursor:pointer;font-size:.65rem}.se-row:hover{background:#f5f3ef}
.se-row.hd{background:var(--ac2);font-weight:600}.se-row input{margin-top:.06rem}.se-row .bold{font-weight:600}

/* Situacions & Caixa */
.dw-desc{font-size:.68rem;color:var(--t2);margin-bottom:.4rem;line-height:1.4}
.folder-input{display:flex;gap:.2rem;align-items:center}
.folder-input .inp{flex:1}
.caixa-files{min-height:60px;background:#faf9f7;border-radius:var(--rs);padding:.3rem;margin:.3rem 0}
.caixa-count{font-size:.7rem;font-weight:600;color:var(--ac)}
.caixa-file-item{display:flex;justify-content:space-between;align-items:center;padding:.15rem .3rem;font-size:.62rem;border-bottom:1px solid var(--bd)}
.caixa-file-item:last-child{border:none}

.phase{margin:.3rem 0;padding:.18rem .35rem;background:#f0f4ff;border:1px solid #d0daf0;border-radius:var(--rs);font-size:.58rem;color:var(--t2);text-align:center}
.ex-dl{display:flex;gap:.3rem;margin-bottom:.3rem}
.ex-dl a{flex:1;text-align:center;font-size:.65rem;text-decoration:none}
.hi-row{display:flex;align-items:center;gap:.3rem;padding:.15rem .2rem;font-size:.6rem;border-bottom:1px solid var(--bd)}
.hi-row:last-child{border:none}
.hi-d{color:var(--t3);min-width:55px}.hi-b{font-weight:600;flex:1}.hi-q{color:var(--t2)}
.hi-sc{width:40px;border:1px solid var(--bd);border-radius:var(--rs);padding:.05rem .15rem;font-size:.58rem;text-align:center;background:var(--c)}
.hi-sc:focus{border-color:var(--ac);outline:none}
.ex-prog-card{display:flex;align-items:center;gap:.4rem;padding:.5rem;background:#f0f4ff;border:1px solid #d0daf0;border-radius:var(--r);margin:.3rem 0;font-size:.7rem;font-weight:500}
.pdf-list{margin:.2rem 0}.pdf-item{display:flex;align-items:center;gap:.3rem;padding:.15rem .2rem;font-size:.6rem;border-bottom:1px solid var(--bd)}
.pdf-idx{width:16px;height:16px;border-radius:50%;background:var(--ac);color:#fff;font-size:.5rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pdf-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.toast{position:fixed;bottom:.7rem;left:50%;transform:translateX(-50%);background:var(--t);color:#fff;padding:.25rem .55rem;border-radius:var(--r);font-size:.65rem;box-shadow:var(--sh2);z-index:400;display:flex;align-items:center;gap:.15rem}
.hidden{display:none!important}

@media(max-width:768px){.sb{width:100%;height:auto;max-height:80px;border-right:none;border-bottom:1px solid var(--bd)}
.sb-list{display:flex;overflow-x:auto;gap:.15rem}.pi{flex-shrink:0;white-space:nowrap}
.layout{flex-direction:column}.dw{width:100%}.fg2{grid-template-columns:1fr}.cards{max-width:none}}

/* Albarans */
.alb-header{margin-bottom:.4rem}
.alb-note{font-size:.6rem;padding:.2rem .35rem;margin-bottom:.2rem;border-radius:var(--rs);background:#fef9e7;border:1px solid #f0e0a0}
.alb-tbl{width:100%;border-collapse:collapse;font-size:.58rem;margin-bottom:.3rem}
.alb-tbl th{background:#f0eeea;padding:.15rem .2rem;text-align:left;font-weight:600;border-bottom:2px solid var(--bd);white-space:nowrap}
.alb-tbl td{padding:.1rem .15rem;border-bottom:1px solid var(--bd);vertical-align:middle}
.alb-tbl input.inp.xs{padding:.1rem .2rem;font-size:.55rem;border:1px solid var(--bd);border-radius:var(--rs);background:var(--c)}
.alb-tbl input.inp.xs:focus{border-color:var(--ac);outline:none}
.alb-step{font-size:.6rem;padding:.1rem 0;color:var(--t2)}
.alb-err{font-size:.6rem;padding:.1rem 0;color:var(--er);font-weight:600}
.alb-ok{font-size:.7rem;padding:.3rem;background:#e8f5e9;border:1px solid #a5d6a7;border-radius:var(--rs);text-align:center;font-weight:600;margin:.3rem 0}
.alb-sc{width:100%;max-height:300px;object-fit:contain;border:1px solid var(--bd);border-radius:var(--r);margin:.2rem 0;cursor:pointer}
.alb-prods{max-height:300px;overflow-y:auto;border:1px solid var(--bd);border-radius:var(--rs);background:var(--c)}
.alb-cmp{padding:.35rem;border-radius:var(--rs);margin:.3rem 0;font-size:.65rem}
.alb-cmp-ok{background:#e8f5e9;border:1px solid #a5d6a7}
.alb-cmp-warn{background:#fff3e0;border:1px solid #ffcc80}
.alb-cmp-row{display:flex;justify-content:space-between;padding:.1rem 0}
.alb-side{display:grid;grid-template-columns:1fr 1fr;gap:.4rem}
@media(max-width:600px){.alb-side{grid-template-columns:1fr}}
.alb-side-col{overflow-x:auto}
.tbl-grid{display:grid;grid-template-columns:1fr 1fr;gap:.3rem .5rem;margin-bottom:.5rem}
.tbl-f label{font-size:.65rem;color:var(--m);display:block;margin-bottom:.05rem}
.tbl-f .inp{font-size:.75rem;padding:.2rem .3rem}
@media(max-width:600px){.tbl-grid{grid-template-columns:1fr}}
#wsTbl h3{font-size:.85rem;margin:0 0 .3rem 0;color:var(--ac)}
#wsTbl{background:var(--c);border:1px solid var(--bd);border-radius:var(--r);padding:.5rem;margin-bottom:.4rem}
/* Usuaris */
.ua-box{background:var(--c);border:1px solid var(--bd);border-radius:var(--r);padding:.5rem;margin-bottom:.5rem}
.ua-box h3{margin:0 0 .3rem;font-size:.8rem}
.ua-list{display:flex;flex-direction:column;gap:.2rem}
.ua-item{font-size:.65rem;padding:.25rem .4rem;border-radius:var(--rs);display:flex;align-items:center;gap:.3rem}
.ua-item strong{white-space:nowrap}
.ua-urg{background:#fbfbfc;color:#5a5a63;border-left:2px solid #d89090}
.ua-warn{background:#fbfbfc;color:#5a5a63;border-left:2px solid #d6c080}
.ua-info{background:#fbfbfc;color:#5a5a63;border-left:2px solid #9db5d6}
.ua-ico{font-size:.75rem;opacity:.7}
.uc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.4rem}
.uc-card{background:var(--c);border:1px solid var(--bd);border-radius:var(--r);padding:.5rem;cursor:pointer;transition:all .15s}
.uc-card:hover{border-color:var(--ac);box-shadow:0 2px 8px rgba(0,0,0,.08)}
.uc-top{display:flex;align-items:center;gap:.3rem;margin-bottom:.2rem}
.uc-top strong{font-size:.75rem;flex:1}
.uc-flag{font-size:.9rem}
.uc-age{font-size:.6rem;color:var(--t3);background:var(--bg);padding:.1rem .3rem;border-radius:var(--rs)}
.uc-exp{font-size:.55rem;color:var(--t3);font-family:monospace;margin-bottom:.3rem}
.uc-docs{display:flex;gap:.2rem;margin-bottom:.2rem}
.uc-ip{font-size:.6rem}

.uib{font-size:.6rem;font-weight:600;padding:.1rem .3rem;border-radius:3px}
.uib-ok{background:#eef3ee;color:#4a6850}.uib-warn{background:#f5f1e6;color:#6b5f3e}.uib-urg{background:#f5ebeb;color:#6b4a4a}.uib-no{color:var(--t3);font-weight:400}
.ud-sec{margin-bottom:.4rem}
.ud-sec h4{margin:0 0 .2rem;font-size:.7rem;color:var(--ac);border-bottom:1px solid var(--bd);padding-bottom:.15rem}
.ud-row{display:flex;justify-content:space-between;align-items:center;padding:.15rem 0;font-size:.65rem;border-bottom:1px solid #f5f5f5}
.ud-l{color:var(--t3);font-weight:500}.ud-v{font-weight:400;text-align:right}

/* Dashboard header */
.dash-hd{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem;padding-bottom:.4rem;border-bottom:1px solid #e8ecf0}
.dash-hd h1{margin:0;font-size:1.1rem;font-family:'DM Serif Display',serif;color:var(--ac)}
.dash-act{display:flex;gap:.3rem;align-items:center}

.card.disabled{opacity:.4;pointer-events:none;cursor:default}
/* Expandable drawers */
.dw-expanded{max-width:min(800px,70vw)!important;width:min(800px,70vw)!important}
@media(max-width:700px){.dw-expanded{max-width:100vw!important;width:100vw!important}}
/* Calendar */
.cal-hd{font-weight:600;font-size:.8rem;text-align:center;margin-bottom:.3rem;color:var(--ac)}
.cal-grid{margin-bottom:.4rem}
.cal-head{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;font-size:.55rem;font-weight:600;color:var(--t3)}
.cal-body{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;gap:1px}
.cal-day{padding:.25rem;font-size:.6rem;cursor:pointer;border-radius:3px}
.cal-day:hover{background:var(--ac2)}
.cal-today{background:var(--ac)!important;color:#fff;font-weight:700}

.cal-empty{padding:.25rem}
.cal-upcoming{margin-top:.3rem}
.cal-ev{display:flex;align-items:center;gap:.3rem;padding:.15rem 0;border-bottom:1px solid var(--bd);font-size:.6rem}
.cal-ev-d{color:var(--ac);font-weight:600;min-width:2.5rem}
/* Usuaris alert cards */
.ua-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.3rem;margin-bottom:.5rem}
.ua-card{border-radius:var(--r);padding:.4rem;font-size:.62rem}
.ua-card-hd{display:flex;align-items:center;gap:.3rem;margin-bottom:.15rem}
.ua-card-hd strong{flex:1;font-size:.68rem}
.ua-cnt{background:rgba(0,0,0,.05);padding:.05rem .25rem;border-radius:10px;font-size:.55rem;font-weight:600;opacity:.8}
.ua-card-list{color:inherit;opacity:.75;line-height:1.4}
.ua-urg{background:#fbfbfc;color:#5a5a63;border-left:2px solid #d89090}
.ua-warn{background:#fbfbfc;color:#5a5a63;border-left:2px solid #d6c080}
.ua-info{background:#fbfbfc;color:#5a5a63;border-left:2px solid #9db5d6}
.ua-bday{background:#fbfbfc;color:#5a5a63;border-left:2px solid #9cc2a1}

/* WIP/Beta cards */
.card.wip{opacity:.35;border:1px dashed #d0d5dd;filter:grayscale(.4);min-height:55px;font-size:.8em;transform:scale(.92)}
.card.wip:hover{opacity:.6;border-style:solid;filter:grayscale(.2);transform:scale(.95)}
.card.disabled{opacity:.3;pointer-events:none;cursor:default}
/* Alert rows */
.ua-rows{display:flex;flex-direction:column;gap:.1rem}
.ua-row{font-size:.62rem;padding:.1rem .2rem;border-bottom:1px solid rgba(0,0,0,.05)}
.ua-row:last-child{border-bottom:none}
/* Workspace options in drawer */
.ws-opts{display:flex;gap:.4rem;margin-bottom:.3rem}
.ws-opts .fg{flex:1}
.ws-opts select{min-width:180px;background:var(--c);color:var(--t)}
select option{background:var(--c);color:var(--t)}
.dark select option{background:#0f1629;color:var(--t)}
/* Tasks */
.task-toggle{display:flex;gap:0;margin-bottom:.4rem;border:1px solid var(--bd);border-radius:var(--r);overflow:hidden}
.task-tab{flex:1;padding:.3rem;font-size:.68rem;font-weight:600;border:none;background:var(--bg);cursor:pointer;text-align:center}
.task-tab.on{background:var(--ac);color:#fff}
.task-panel{min-height:60px}
.task-item{display:flex;align-items:center;gap:.3rem;padding:.3rem .2rem;border-bottom:1px solid var(--bd);font-size:.68rem;cursor:pointer;transition:background .1s}
.task-item:hover{background:var(--ac2)}
.task-done{opacity:.5;text-decoration:line-through}
.task-chk{font-size:.8rem;min-width:1.2rem}
.task-add{display:flex;gap:.2rem;margin-bottom:.3rem}
.task-add .inp{flex:1;font-size:.68rem}
/* Calendar source colors */
.cal-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:.2rem;flex-shrink:0}
.cal-a{background:#4285f4}
.cal-b{background:#ea4335}
/* Task time */
.task-time{margin-left:auto;font-size:.58rem;color:var(--t3);background:var(--bg);padding:.05rem .25rem;border-radius:var(--rs);white-space:nowrap}
/* Icon badges */
.udb{display:inline-flex;align-items:center;gap:.1rem;padding:.1rem .25rem;border-radius:var(--rs);font-size:.55rem;font-weight:600}
.udb-ok{background:#d4edda;color:#155724}
.udb-no{background:#f8d7da;color:#721c24}
/* Buenos días */
.bd-sec{background:var(--c);border:1px solid var(--bd);border-radius:var(--r);padding:.5rem;margin-bottom:.4rem}
.bd-sec-t{margin:0 0 .3rem;font-size:.78rem;color:var(--ac)}
.bd-fich{display:flex;gap:.3rem}
.bd-fich-res{font-size:.62rem;padding:.3rem;border-radius:var(--rs);background:var(--bg)}
.bd-fich-ok{background:#d4edda;color:#155724}
.bd-bkmk{font-size:.55rem;background:var(--bg);padding:.3rem;border-radius:var(--rs);margin-top:.2rem}
.bd-mail{background:var(--bg);border:1px solid var(--bd);border-radius:var(--rs);padding:.35rem;margin-bottom:.2rem;font-size:.62rem}
.bd-mail-hd{display:flex;gap:.3rem;align-items:baseline;flex-wrap:wrap;margin-bottom:.15rem}
.bd-mail-body{color:var(--t3);font-size:.58rem;line-height:1.4;max-height:4rem;overflow:hidden;margin-bottom:.2rem}
.bd-mail-err{background:#f8d7da;color:#721c24;padding:.3rem;border-radius:var(--rs);font-size:.62rem}
/* Structured document forms */
.sf-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.45rem;margin-bottom:.45rem}
.sf-field{display:flex;flex-direction:column;gap:.2rem}
.sf-field-full{grid-column:1/-1}
.sf-field label{font-size:.62rem;font-weight:600;color:var(--t2)}
.sf-req{color:#dc3545;margin-left:.15rem}
.salida-pack-row{margin-top:.45rem;padding:.35rem .45rem;background:var(--bg);border:1px solid var(--bd);border-radius:var(--rs)}
.salida-pack-check{display:flex;align-items:center;gap:.45rem;font-size:.68rem;font-weight:500}
.beta-sec{opacity:.55;filter:saturate(.65)}
.dark .beta-sec{opacity:.45}
.beta-sec .bd-sec-t{color:var(--t2)}
/* Task highlight */
.task-hl{background:#fff3cd;border-left:3px solid #ffc107;font-weight:600}
.task-acts{display:flex;gap:.1rem;margin-left:auto;opacity:.3;transition:opacity .15s}
.task-item:hover .task-acts{opacity:1}
.task-txt{flex:1}
/* Editable fields in user detail */
.ud-edit{border:1px solid var(--bd);border-radius:3px;padding:.1rem .2rem;font-size:.62rem;width:55%;text-align:right;background:var(--bg)}
.ud-edit:focus{border-color:var(--ac);outline:none;background:#fff}
/* Notes */
.res-note{display:flex;justify-content:space-between;align-items:center;padding:.15rem .2rem;font-size:.62rem;border-bottom:1px solid rgba(0,0,0,.05);font-weight:500}
/* Calendar purple */
.cal-c{background:#9c27b0}
/* Birthday card highlight */
.uc-bday{border:1px solid #d8c89a;background:#fbfaf4}
.uc-bday-tag{font-size:.55rem;color:#8a6d2e;font-weight:500;margin-top:.1rem}

/* Casa */
.casa-list{display:flex;flex-direction:column;gap:.1rem}
.casa-item{display:flex;align-items:center;gap:.3rem;padding:.2rem .1rem;border-bottom:1px solid var(--bd);font-size:.62rem}
.casa-item span:first-child{font-size:.75rem;min-width:1.2rem}
.casa-item span:nth-child(2){flex:1}
.casa-next{font-size:.55rem;color:var(--ac);font-weight:500;white-space:nowrap}
.casa-pend{background:#fff5f5}.casa-done{opacity:.5;text-decoration:line-through}
/* Calendar multi-color dots under day numbers */
.cal-day{position:relative;padding:.25rem .1rem .35rem;font-size:.6rem;cursor:pointer;border-radius:3px;text-align:center}
.cal-day:hover{background:var(--ac2)}
.cal-dots{position:absolute;bottom:1px;left:50%;transform:translateX(-50%);display:flex;gap:2px}
.cal-dd{display:block;width:5px;height:5px;border-radius:50%}
.cal-dd.cal-a{background:#dc3545}
.cal-dd.cal-b{background:#fd7e14}
.cal-dd.cal-c{background:#9c27b0}
.cal-today{background:var(--ac)!important;color:#fff!important;font-weight:700}
.cal-today .cal-dd{border:1px solid #fff}
.cal-legend{font-size:.55rem;display:flex;align-items:center;gap:.4rem;margin-top:.2rem}
/* Diagnostics */
.diag-ok{font-size:.62rem;color:#155724;padding:.2rem}
.diag-item{font-size:.6rem;padding:.15rem .2rem;border-bottom:1px solid var(--bd);display:flex;align-items:center;gap:.2rem}
.diag-error{background:#f8d7da}.diag-warn{background:#fff3cd}.diag-info{background:#e8f0fe}
.diag-badge{position:absolute;top:-4px;right:-4px;background:#dc3545;color:#fff;font-size:.45rem;font-weight:700;width:14px;height:14px;border-radius:50%;display:flex;align-items:center;justify-content:center}
/* Bye bye */
.bye-check{margin:.2rem 0}
.bye-row{display:flex;justify-content:space-between;align-items:center;padding:.2rem 0;border-bottom:1px solid var(--bd);font-size:.65rem}
.bye-st{font-size:.55rem;padding:.1rem .3rem;border-radius:var(--rs);font-weight:600}
.bye-st-pend{background:#fff3cd;color:#856404}
.bye-st-ok{background:#d4edda;color:#155724}
/* Backups */
.bk-row{display:flex;gap:.4rem;align-items:center;padding:.15rem 0;border-bottom:1px solid var(--bd);font-size:.58rem}

/* Settings collapsible */
.dw-sec>h3{cursor:pointer;user-select:none}
.dw-sec>h3::before{content:'▸ ';font-size:.7em;color:var(--t3)}
.dw-sec.open>h3::before{content:'▾ '}

/* Dark mode */
.dark{--bg:#1a1a2e;--c:#16213e;--bd:#2a2d4a;--ac:#4fc3f7;--ac2:#1a3a5c;--t:#e0e0e0;--t2:#b0b0c0;--t3:#808090;--m:#909099;--sh:0 2px 8px rgba(0,0,0,.4)}
.dark body,.dark .layout-full{background:var(--bg);color:var(--t)}
.dark .card{background:var(--c);border-color:var(--bd);color:var(--t)}
.dark .card:not(.wip):not(.disabled){border-color:#3a4060;box-shadow:0 2px 6px rgba(0,0,0,.2)}
.dark .card:hover{border-color:var(--ac);box-shadow:0 4px 12px rgba(79,195,247,.15)}
.dark .row{background:var(--c);border-color:var(--bd)}
.dark .row-label{color:var(--ac);border-color:var(--ac2)}
.dark .dash-hd{border-color:var(--bd)}
.dark .dw{background:var(--c);border-color:var(--bd);color:var(--t)}
.dark .dw-hd{border-color:var(--bd)}
.dark .inp,.dark select,.dark textarea{background:#0f1629;border-color:var(--bd);color:var(--t)}
.dark .inp:focus,.dark select:focus,.dark textarea:focus{border-color:var(--ac)}
.dark .btn.pri{background:var(--ac);color:#111}
.dark .btn.sec{border-color:var(--ac);color:var(--ac)}
.dark .btn.out{border-color:var(--bd);color:var(--t2)}
.dark .bd-sec{background:#0f1629;border-color:var(--bd)}
.dark .ud-sec{background:#0f1629;border-color:var(--bd)}
.dark .ud-edit{background:#1a1a2e;border-color:var(--bd);color:var(--t)}
.dark .task-item{border-color:var(--bd)}.dark .task-item:hover{background:var(--ac2)}
.dark .task-hl{background:#3a3000;border-color:#ffc107}
.dark .task-tab{background:#0f1629;color:var(--t2)}.dark .task-tab.on{background:var(--ac);color:#111}
.dark .ua-urg{background:#1a1d26;color:#aaa8b5;border-color:#6a4848}
.dark .ua-warn{background:#1a1d26;color:#aaa8b5;border-color:#6a5c3a}
.dark .ua-info{background:#1a1d26;color:#aaa8b5;border-color:#4a5c74}
.dark .ua-bday{background:#1a1d26;color:#aaa8b5;border-color:#4a6a50}
.dark .uc-card{background:var(--c);border-color:var(--bd)}
.dark .uc-card:hover{border-color:var(--ac)}
.dark .casa-item{border-color:var(--bd)}
.dark .casa-pend{background:#2a1015}.dark .casa-done{opacity:.4}
.dark .muted{color:var(--t3)!important}
.dark .popup{background:var(--c);border-color:var(--bd);color:var(--t)}
.dark .modal{background:rgba(0,0,0,.7)}
.dark .mod-in{background:var(--c);color:var(--t)}
.dark .cal-today{background:var(--ac)!important;color:#111!important}
.dark .udb-ok{background:#1e2a22;color:#8ca893}.dark .udb-no{background:#2a1e20;color:#a88a8a}
.dark .uib-ok{background:#1e2a22;color:#8ca893}.dark .uib-warn{background:#2a2820;color:#a89b75}.dark .uib-urg{background:#2a1e20;color:#a88a8a}
.dark .uc-bday{border-color:#6a5c3a;background:#1d1f1a}
.dark hr{border-color:var(--bd)}
.dark a{color:var(--ac)}
/* Dark toggle */
.theme-toggle{cursor:pointer;font-size:1rem;background:none;border:none;padding:.2rem}

/* Dark mode fixes */
.dark .diag-warn{background:#3a3000;color:#ffd54f}
.dark .diag-error{background:#3a1015;color:#ff8a80}
.dark .diag-info{background:#0d2137;color:#90caf9}
.dark .diag-ok{color:#a5d6a7}
.dark .toast{background:#16213e;color:var(--t);border:1px solid var(--bd)}

/* Triple panel */
.triple-panel{position:fixed;top:0;left:0;right:0;bottom:0;z-index:100;display:none}
.triple-panel:not(.hidden){display:block}
.triple-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.3)}
.triple-cols{position:absolute;top:0;right:0;bottom:0;display:flex;max-width:100vw;z-index:1}
.tp-col{height:100%;border-left:1px solid var(--bd);background:var(--c);transition:width .2s ease;width:0;overflow:hidden}
.tp-col.open{width:min(33vw,380px)}
.tp-col.open.tp-wide{width:min(66vw,760px)}
.tp-hd{display:flex;align-items:center;padding:.4rem .5rem;border-bottom:1px solid var(--bd);position:sticky;top:0;background:inherit;z-index:1}
.tp-hd h3{margin:0;font-size:.72rem;flex:1}
.tp-bd{padding:.4rem}
.tp-close{position:fixed;top:.4rem;right:.4rem;background:var(--c);border:1px solid var(--bd);border-radius:50%;width:28px;height:28px;cursor:pointer;font-size:.8rem;z-index:102;display:flex;align-items:center;justify-content:center}
.dark .tp-col{background:var(--c);border-color:var(--bd)}
.dark .triple-overlay{background:rgba(0,0,0,.5)}
.dark .tp-close{background:var(--c);border-color:var(--bd);color:var(--t)}
/* Global overflow fixes */
.dw-bd,.tp-bd{overflow-x:hidden;word-break:break-word}
.task-add{flex-wrap:wrap}
.bd-sec{overflow:hidden}
.ud-row{flex-wrap:wrap}
.casa-item{flex-wrap:wrap}

/* Fix internal calendar config overflow */
.dw-sec{overflow:hidden}
.ci{overflow:hidden}

/* Expanded drawer improvements */
.dw-expanded .dw-bd{padding:.6rem 1rem}
.dw-expanded .bd-sec{padding:.6rem .8rem}
.dw-expanded .task-item{padding:.4rem .3rem;font-size:.72rem}
.dw-expanded .task-time{font-size:.65rem}
.dw-expanded .casa-item{font-size:.7rem;padding:.3rem .2rem}
.dw-expanded .ud-row{font-size:.7rem}
.dw-expanded .ud-edit{font-size:.68rem}
.dw-expanded .ud-sec h4{font-size:.82rem}
.dw-expanded .uc-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}
.dw-expanded .ua-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.3rem}
.dw-expanded .ua-card{font-size:.65rem}

/* Triple panel expanded */
.tp-col.open{min-width:0;overflow-y:auto;overflow-x:hidden}
.tp-bd{overflow-x:hidden;word-break:break-word}

/* Dark mode: fix notes/alerts visibility */
.dark .bd-sec[style*="fff3cd"]{background:#2a2400!important;border-color:#5a4800!important}
.dark .res-note{color:var(--t)}
.dark .ua-card{border:1px solid}
.dark .ua-urg{background:#1a1d26;color:#aaa8b5;border-color:#3a2a2f}
.dark .ua-warn{background:#1a1d26;color:#aaa8b5;border-color:#3a342a}
.dark .ua-info{background:#1a1d26;color:#aaa8b5;border-color:#2a3240}
.dark .ua-bday{background:#1a1d26;color:#aaa8b5;border-color:#2a3a2e}
.dark .ua-card-hd{color:inherit}
.dark .ua-row{color:inherit}
.dark .ua-cnt{color:inherit;background:rgba(255,255,255,.06)}
.dark .uc-bday{border-color:#6a5c3a;background:#1d1f1a}
.dark .uc-bday-tag{color:#b89e6e}
.dark .bye-st-pend{background:#2a2000;color:#ffd54f}
.dark .bye-st-ok{background:#0d2a0d;color:#a5d6a7}
.dark .casa-pend{background:#2a1015}
/* Notes section */
.bd-notes{background:#fff3cd;border-left:3px solid #ffc107}
.dark .bd-notes{background:#2a2000;border-color:#5a4800}
.dark .bd-notes h4{color:#ffd54f}

.dark .act-text{background:#f4f6fb;color:#1d2433;border-left-color:var(--ac)}
