:root{--bg:#0d0f14;--surface:#161820;--surface2:#1e2029;--surface3:#252836;--border:#2e3145;--border2:#3a3f58;--text:#e8eaf6;--text2:#9095b0;--text3:#5a5f7a;--accent:#6c63ff;--accent2:#8b83ff;--accent-glow:rgba(108,99,255,0.18);--green:#22c55e;--yellow:#f59e0b;--red:#ef4444;--pink:#ec4899;--cyan:#06b6d4;--orange:#f97316;--card-w:272px;--r:10px;--r2:14px;}
html.theme-light{--bg:#f0f2f8;--surface:#ffffff;--surface2:#f5f6fb;--surface3:#eaecf5;--border:#d8daea;--border2:#c4c7de;--text:#1a1d30;--text2:#5a5f7a;--text3:#9095b0;--accent:#6c63ff;--accent2:#5650d4;--accent-glow:rgba(108,99,255,0.12);--green:#16a34a;--yellow:#d97706;--red:#dc2626;--pink:#db2777;--cyan:#0891b2;--orange:#ea580c;}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);height:100vh;overflow:hidden;display:flex;flex-direction:column;transition:background .25s,color .25s;padding-left:var(--sidebar-w,248px);}
body.sidebar-collapsed{--sidebar-w:64px;}
body:not(.sidebar-collapsed){--sidebar-w:248px;}
.app-sidebar{position:fixed;inset:0 auto 0 0;width:var(--sidebar-w,248px);background:var(--surface);border-right:1px solid var(--border);z-index:180;display:flex;flex-direction:column;transition:width .18s ease,transform .18s ease;box-shadow:8px 0 30px rgba(0,0,0,.18);}
.app-sidebar-head{height:56px;display:flex;align-items:center;gap:10px;padding:0 12px;border-bottom:1px solid var(--border);position:relative;}
.app-side-toggle{width:40px;height:40px;border-radius:999px;border:1px solid var(--border2);background:transparent;color:var(--text2);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;flex-shrink:0;transition:background .15s,border-color .15s,color .15s;}
.app-side-toggle:hover{background:var(--surface2);border-color:var(--accent);color:var(--text);}
.app-side-account{min-width:0;flex:1;position:relative;}
.app-side-account-btn{width:100%;height:38px;display:flex;align-items:center;gap:8px;background:var(--surface2);border:1px solid var(--border);border-radius:999px;color:var(--text);cursor:pointer;padding:0 10px;font-family:'DM Sans',sans-serif;text-align:left;}
.app-side-account-btn:hover{border-color:var(--accent);}
.app-side-account-ico{font-size:14px;line-height:1;flex-shrink:0;}
.app-side-account-text{min-width:0;display:flex;flex-direction:column;gap:1px;flex:1;}
.app-side-account-text strong{font-size:12px;font-weight:800;line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.app-side-account-text small{font-size:9px;color:var(--text3);line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.app-side-account-caret{font-size:12px;color:var(--text3);flex-shrink:0;}
.app-side-account-dd{display:none;position:absolute;top:calc(100% + 8px);left:0;right:0;min-width:210px;background:var(--surface);border:1px solid var(--border2);border-radius:var(--r2);box-shadow:0 12px 40px rgba(0,0,0,.5);z-index:260;padding:6px 0;overflow:hidden;}
.app-side-nav{flex:1;min-height:0;overflow-y:auto;padding:8px 8px;display:flex;flex-direction:column;gap:4px;scrollbar-width:thin;scrollbar-color:var(--border) transparent;}
.app-side-nav::-webkit-scrollbar{width:4px;}.app-side-nav::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px;}
.app-side-item{width:100%;height:38px;border:none;border-radius:7px;background:transparent;color:var(--text2);display:flex;align-items:center;gap:12px;padding:0 10px;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;text-align:left;position:relative;transition:background .15s,color .15s;}
.app-side-item:hover{background:var(--surface2);color:var(--text);}
.app-side-item.active{background:rgba(6,182,212,.16);color:var(--cyan);}
.app-side-item.side-primary{background:var(--accent);color:#fff;margin-bottom:2px;}
.app-side-item.side-primary:hover{background:var(--accent2);}
.app-side-ico{width:20px;min-width:20px;display:inline-flex;align-items:center;justify-content:center;line-height:1;color:inherit;}
.app-side-ico svg{width:18px;height:18px;stroke:currentColor;stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;}
.app-side-item .app-side-ico svg{opacity:.65;transition:opacity .15s;}
.app-side-item:hover .app-side-ico svg,.app-side-item.active .app-side-ico svg{opacity:1;}
.side-primary .app-side-ico svg{opacity:.9;}
.app-side-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.app-side-badge{margin-left:auto;min-width:18px;height:18px;border-radius:999px;background:var(--yellow);color:#111;font-size:10px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;padding:0 5px;}
.app-side-sep{height:1px;background:var(--border);margin:6px 8px;}
.app-side-section{font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text3);padding:10px 14px 3px;white-space:nowrap;pointer-events:none;}
.app-side-user{height:32px;padding:3px 8px;border-top:1px solid var(--border);display:flex;align-items:center;}
.app-side-user-card{width:100%;height:26px;display:flex;align-items:center;gap:8px;padding:2px 6px;border-radius:7px;background:transparent;border:1px solid transparent;min-width:0;cursor:pointer;color:var(--text2);font-family:'DM Sans',sans-serif;text-align:left;}
.app-side-user-card:hover{background:var(--surface2);border-color:var(--border);color:var(--text);}
.app-side-user-card .avatar{width:22px;height:22px;font-size:9px;}
.app-side-user-meta{min-width:0;display:flex;flex-direction:column;gap:1px;}
.app-side-user-name{font-size:11px;font-weight:800;line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.app-side-user-company{font-size:9px;color:var(--text3);line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
body.sidebar-collapsed .app-sidebar{width:64px;}
body.sidebar-collapsed .app-sidebar-head{justify-content:center;padding:0;}
body.sidebar-collapsed .app-side-account,body.sidebar-collapsed .app-side-label,body.sidebar-collapsed .app-side-user-meta,body.sidebar-collapsed .app-side-section{display:none;}
body.sidebar-collapsed .app-side-item{justify-content:center;padding:0;}
body.sidebar-collapsed .app-side-badge{position:absolute;right:5px;top:5px;margin:0;min-width:15px;height:15px;font-size:9px;padding:0 4px;}
body.sidebar-collapsed .app-side-sep{margin-left:10px;margin-right:10px;}
body.sidebar-collapsed .app-side-user-card{justify-content:center;padding:2px;background:transparent;border-color:transparent;}
/* Tooltip harmônico: aparece à direita do ícone no modo recolhido */
body.sidebar-collapsed .app-side-nav{overflow:visible;}
body.sidebar-collapsed .app-side-item{overflow:visible;}
body.sidebar-collapsed .app-side-item::after{content:attr(title);position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%) translateX(-4px);background:var(--surface3);border:1px solid var(--border2);color:var(--text);padding:5px 11px;border-radius:var(--r);font-size:12px;font-weight:600;white-space:nowrap;pointer-events:none;z-index:400;box-shadow:0 6px 20px rgba(0,0,0,.35);opacity:0;transition:opacity .12s ease,transform .12s ease;}
body.sidebar-collapsed .app-side-item:hover::after{opacity:1;transform:translateY(-50%) translateX(0);}
body.sidebar-collapsed .app-side-item::before{content:'';position:absolute;left:calc(100% + 5px);top:50%;transform:translateY(-50%);border:5px solid transparent;border-right-color:var(--border2);pointer-events:none;z-index:401;opacity:0;transition:opacity .12s ease;}
body.sidebar-collapsed .app-side-item:hover::before{opacity:1;}
.app-sidebar-scrim{display:none;}
.topbar{display:flex;align-items:center;gap:8px;padding:0 18px;height:56px;background:var(--surface);border-bottom:1px solid var(--border);z-index:100;position:relative;}
.app-mobile-menu-btn{display:none;width:40px;height:40px;border-radius:999px;border:1px solid var(--border2);background:var(--surface2);color:var(--text2);align-items:center;justify-content:center;cursor:pointer;font-size:18px;flex-shrink:0;}
.logo{font-family:'Syne',sans-serif;font-weight:800;font-size:18px;letter-spacing:-.5px;white-space:nowrap;}.logo span{color:var(--accent2);}
.topbar-brand{display:flex;flex-direction:column;gap:1px;user-select:none;flex-shrink:0;}
.brand-client-name{font-family:'Syne',sans-serif;font-weight:800;font-size:17px;letter-spacing:-.4px;color:var(--text);line-height:1;}
.brand-client-name::after{content:'.';color:var(--accent);}
.brand-powered{font-size:9px;color:var(--text3);line-height:1;letter-spacing:.2px;}
.brand-powered span{color:var(--accent2);font-weight:600;}
.brand-powered.hidden{display:none;}
.app-footer{height:32px;background:var(--surface);border-top:1px solid var(--border);display:flex;align-items:center;padding:0 16px;gap:10px;flex-shrink:0;}
.footer-sys-name{font-size:11px;color:var(--text3);display:flex;align-items:center;gap:6px;}
.footer-sys-name strong{color:var(--text2);}
.footer-sys-name strong span{color:var(--accent);}
.footer-version{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-size:9.5px;color:var(--text3);}
.footer-links{margin-left:auto;display:flex;align-items:center;gap:10px;font-size:10.5px;color:var(--text3);}
.footer-links a{color:var(--text3);text-decoration:none;transition:color .15s;}
.footer-links a:hover{color:var(--text2);}
.footer-sep{color:var(--text3);opacity:.4;}
.topbar-filter{width:240px;max-width:28vw;background:var(--surface2);border:1px solid var(--border2);border-radius:20px;padding:6px 12px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:12px;outline:none;transition:border-color .15s,box-shadow .15s;}
.topbar-filter:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);}
.topbar-filter::placeholder{color:var(--text3);}
.fdsearch-wrap{position:relative;display:flex;align-items:center;}
.fdsearch{width:100%;background:var(--surface2);border:1px solid var(--border2);border-radius:20px;padding:6px 30px 6px 12px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;outline:none;transition:border-color .15s,box-shadow .15s;}
.fdsearch:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);}
.fdsearch::placeholder{color:var(--text3);}
.fdsearch-clear{display:none;align-items:center;justify-content:center;position:absolute;right:8px;width:18px;height:18px;border:none;border-radius:50%;background:var(--surface3);color:var(--text3);font-size:11px;cursor:pointer;line-height:1;padding:0;flex-shrink:0;}
.fdsearch-clear:hover{background:var(--border2);color:var(--text);}
.ci-cell[type="number"]{appearance:textfield;-moz-appearance:textfield;}
.ci-cell[type="number"]::-webkit-outer-spin-button,.ci-cell[type="number"]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
.fdsearch-wrap.topbar .fdsearch{font-size:12px;}
.topbar-sep{flex:1;}
.btn{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:var(--r);border:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;transition:all .15s;white-space:nowrap;}
.btn:disabled{opacity:.32;cursor:not-allowed;pointer-events:none;}
.btn-primary{background:var(--accent);color:#fff;}.btn-primary:hover{background:var(--accent2);transform:translateY(-1px);}
.btn-ghost{background:var(--surface3);color:var(--text2);border:1px solid var(--border);}.btn-ghost:hover{color:var(--text);border-color:var(--border2);}
.btn-green{background:rgba(34,197,94,.1);color:var(--green);border:1px solid rgba(34,197,94,.28);}.btn-green:hover{background:rgba(34,197,94,.2);}
.btn-cyan{background:rgba(6,182,212,.1);color:var(--cyan);border:1px solid rgba(6,182,212,.28);}.btn-cyan:hover{background:rgba(6,182,212,.2);}
.btn-orange{background:rgba(249,115,22,.12);color:var(--orange);border:1px solid rgba(249,115,22,.3);}.btn-orange:hover{background:rgba(249,115,22,.22);}
.btn-yellow{background:rgba(245,158,11,.12);color:var(--yellow);border:1px solid rgba(245,158,11,.3);}.btn-yellow:hover{background:rgba(245,158,11,.22);}
.tb-badge{border-radius:20px;padding:1px 6px;font-size:11px;font-weight:700;}
.avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--pink));display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;cursor:pointer;flex-shrink:0;}
.board-tb-bar{flex-shrink:0;padding:6px 18px;background:var(--surface);border-bottom:1px solid var(--border);}
.board-wrapper{flex:1;min-height:0;display:flex;overflow-x:auto;padding:16px 18px;gap:12px;scroll-behavior:smooth;user-select:none;}
.board-wrapper::-webkit-scrollbar{height:6px;}.board-wrapper::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px;}
.board-wrapper.is-panning{cursor:grabbing !important;scroll-behavior:auto;}
.board-wrapper.is-panning .col-insert{pointer-events:none;}
.pan-handle{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:8px;padding:8px 20px;border-radius:30px;background:var(--surface);border:1px solid var(--border2);color:var(--text2);font-size:13px;font-weight:500;cursor:grab;z-index:90;box-shadow:0 4px 20px rgba(0,0,0,.55);transition:background .15s,border-color .15s,color .15s,box-shadow .15s;user-select:none;touch-action:none;white-space:nowrap;}
.pan-handle:hover{background:var(--surface2);color:var(--text);border-color:var(--accent);box-shadow:0 4px 24px var(--accent-glow);}
.pan-handle.active{cursor:grabbing;background:var(--accent);color:#fff;border-color:var(--accent2);box-shadow:0 4px 24px var(--accent-glow);}
.pan-handle svg{flex-shrink:0;transition:transform .15s;}.pan-handle.active svg{transform:scaleX(1.2);}
.column{flex-shrink:0;width:var(--card-w);display:flex;flex-direction:column;gap:8px;max-height:100%;}
.col-header{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--surface2);border-radius:var(--r2);border:1px solid var(--border);cursor:pointer;transition:border-color .15s;user-select:none;}.col-header:hover{border-color:var(--border2);}
.col-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;}
.col-name{font-family:'Syne',sans-serif;font-size:13px;font-weight:700;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.col-count{background:var(--surface3);color:var(--text2);font-size:11px;font-weight:600;padding:2px 7px;border-radius:20px;min-width:22px;text-align:center;}
.col-header-actions{display:flex;align-items:center;gap:6px;flex-shrink:0;}
.col-manual-btn{width:24px;height:24px;border-radius:6px;border:1px solid transparent;background:none;color:var(--text3);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s;font-size:13px;}
.col-manual-btn:hover{background:var(--surface3);border-color:var(--border);color:var(--text);}
.col-manual-btn.has-content{color:var(--accent2);}
.col-manual-badge{min-width:15px;height:15px;border-radius:999px;background:var(--yellow);color:var(--bg);font-size:9px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;padding:0 4px;}
.col-edit-btn{color:var(--text3);font-size:14px;opacity:0.45;transition:all .15s;background:none;border:none;cursor:pointer;padding:2px 4px;border-radius:6px;}.col-edit-btn:hover{opacity:1;color:var(--text);background:var(--surface3);}
.col-wrap{flex-shrink:0;width:var(--card-w);display:flex;flex-direction:column;gap:8px;max-height:100%;}
.col-body{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:8px;padding:2px 2px 8px;scrollbar-width:thin;scrollbar-color:var(--border) transparent;}
.col-body::-webkit-scrollbar{width:4px;}.col-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}
.col-body.drag-active{outline:2px dashed var(--accent);outline-offset:3px;border-radius:var(--r);background:var(--accent-glow);}
.col-footer{padding:4px 2px;}
.add-card-btn{width:100%;background:none;border:1px dashed var(--border);color:var(--text3);border-radius:var(--r);padding:8px;font-size:12px;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:6px;}.add-card-btn:hover{border-color:var(--accent);color:var(--accent2);background:var(--accent-glow);}
.add-col-btn{flex-shrink:0;width:44px;height:44px;background:var(--surface2);border:1px dashed var(--border);color:var(--text3);border-radius:var(--r2);font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;align-self:flex-start;}.add-col-btn:hover{border-color:var(--accent);color:var(--accent2);background:var(--accent-glow);}
.col-empty{color:var(--text3);font-size:12px;text-align:center;padding:18px 0;}
.card{flex-shrink:0;background:var(--surface2);border:1px solid var(--border);border-radius:var(--r2);padding:12px 14px;cursor:grab;position:relative;overflow:hidden;}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--col-color,var(--accent));border-radius:var(--r2) var(--r2) 0 0;}
.card.due-ok{box-shadow:inset 4px 0 0 rgba(34,197,94,.75);}
.card.due-warn{box-shadow:inset 4px 0 0 rgba(245,158,11,.75);}
.card.due-urgent{box-shadow:inset 4px 0 0 rgba(249,115,22,.8);}
.card.due-overdue{box-shadow:inset 4px 0 0 rgba(239,68,68,.85);}
.card:hover{border-color:var(--border2);background:var(--surface3);}.card:active{cursor:grabbing;}.card.dragging{opacity:.3;}
.card-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px;}
.tag{font-size:10px;font-weight:600;padding:2px 7px;border-radius:20px;text-transform:uppercase;letter-spacing:.4px;}
.tag-tech{background:rgba(108,99,255,.2);color:var(--accent2);}.tag-build{background:rgba(245,158,11,.2);color:#fbbf24;}.tag-infra{background:rgba(34,197,94,.2);color:#4ade80;}.tag-support{background:rgba(236,72,153,.2);color:#f472b6;}.tag-custom{background:rgba(6,182,212,.2);color:#22d3ee;}
.card-title{font-family:'Syne',sans-serif;font-size:13px;font-weight:700;line-height:1.4;margin-bottom:10px;}
.card-fields{display:flex;flex-direction:column;gap:5px;margin-bottom:10px;}
.card-field{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text2);}
.card-field svg{width:12px;height:12px;flex-shrink:0;color:var(--text3);}
.card-field span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.card-footer{display:flex;align-items:center;justify-content:space-between;}
.badge-date{font-size:10px;font-weight:600;padding:3px 8px;border-radius:6px;}
.badge-overdue{background:rgba(239,68,68,.2);color:#f87171;}.badge-soon{background:rgba(245,158,11,.2);color:#fbbf24;}.badge-ok{background:rgba(34,197,94,.2);color:#4ade80;}.badge-neutral{background:var(--surface3);color:var(--text2);}
.card-priority{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.card-done{opacity:.45;filter:grayscale(.7);transition:opacity .2s;}.card-done:hover{opacity:.75;filter:grayscale(.3);}
.priority-high{background:var(--red);box-shadow:0 0 6px var(--red);}.priority-med{background:var(--yellow);}.priority-low{background:var(--green);}
.client-chip{display:inline-flex;align-items:center;gap:5px;background:var(--surface3);border:1px solid var(--border2);border-radius:20px;padding:3px 8px 3px 4px;font-size:11px;color:var(--text2);max-width:100%;overflow:hidden;}
.chip-av{width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700;flex-shrink:0;color:#fff;}
.chip-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.unit-chip{display:inline-flex;align-items:center;gap:4px;background:rgba(6,182,212,.1);border:1px solid rgba(6,182,212,.25);border-radius:20px;padding:2px 8px;font-size:10px;color:var(--cyan);max-width:100%;overflow:hidden;}
.unit-chip span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s;}.overlay.open{opacity:1;pointer-events:all;backdrop-filter:blur(5px);}
.modal{background:var(--surface);border:1px solid var(--border2);border-radius:18px;padding:26px 28px;width:520px;max-width:95vw;max-height:90vh;overflow-y:auto;box-shadow:0 24px 80px rgba(0,0,0,.6);transform:translateY(10px) scale(.97);transition:transform .2s;}.overlay.open .modal{transform:translateY(0) scale(1);}
.modal::-webkit-scrollbar{width:4px;}.modal::-webkit-scrollbar-thumb{background:var(--border);}
.modal-title{font-family:'Syne',sans-serif;font-size:18px;font-weight:800;margin-bottom:20px;}
.ms{margin-bottom:15px;}
.ml{font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px;display:flex;align-items:center;justify-content:space-between;}
.mi,.msel,.mta{width:100%;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--r);padding:9px 12px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;outline:none;transition:border-color .15s;}
.mi:focus,.msel:focus,.mta:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);}
.mta{resize:vertical;min-height:68px;}.msel option{background:var(--surface2);}
.mrow{display:flex;gap:12px;}.mrow .ms{flex:1;}
.mfooter{display:flex;gap:10px;justify-content:flex-end;margin-top:20px;border-top:1px solid var(--border);padding-top:18px;}
.color-swatches{display:flex;gap:8px;flex-wrap:wrap;}
.swatch{width:28px;height:28px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:all .15s;flex-shrink:0;}.swatch.selected,.swatch:hover{border-color:#fff;transform:scale(1.15);}
.cfl-list{display:flex;flex-direction:column;gap:7px;margin-bottom:10px;}
.cfl-item{display:flex;align-items:center;gap:8px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);padding:8px 12px;}
.cfi-label{font-size:12px;font-weight:600;flex:1;}.cfi-type{font-size:11px;color:var(--text3);background:var(--surface3);padding:2px 7px;border-radius:4px;}
.cfi-del{background:none;border:none;color:var(--text3);cursor:pointer;font-size:15px;transition:color .15s;line-height:1;}.cfi-del:hover{color:var(--red);}
.cfi-name-input{width:100%;min-width:0;background:transparent;border:1px solid transparent;border-radius:6px;padding:4px 6px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;outline:none;transition:border-color .12s,background .12s;}
.cfi-name-input:hover{background:var(--surface3);border-color:var(--border);}
.cfi-name-input:focus{background:var(--surface3);border-color:var(--accent);}
.cfi-drag{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;color:var(--text3);font-size:13px;line-height:1;cursor:grab;user-select:none;touch-action:none;}
.cfi-drag:active{cursor:grabbing;}
.cfl-item.dragging{opacity:.55;}
.cfl-item.drop-before{box-shadow:inset 0 2px 0 var(--accent);}
.cfl-item.drop-after{box-shadow:inset 0 -2px 0 var(--accent);}
.ac-wrap{position:relative;}
.ac-list{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--r);z-index:400;max-height:200px;overflow-y:auto;box-shadow:0 8px 24px rgba(0,0,0,.4);display:none;}.ac-list.open{display:block;}
.ac-item{display:flex;align-items:center;gap:10px;padding:9px 12px;cursor:pointer;transition:background .1s;}.ac-item:hover{background:var(--surface3);}
.ac-av{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0;}
.ac-name{font-size:13px;font-weight:600;}.ac-sub{font-size:11px;color:var(--text2);}
.sel-badge{display:flex;align-items:center;gap:10px;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--r);padding:9px 12px;}
.sel-av{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0;}
.sel-info{flex:1;min-width:0;}.sel-name{font-size:13px;font-weight:600;}.sel-sub{font-size:11px;color:var(--text2);}
.sel-clear{background:none;border:none;color:var(--text3);cursor:pointer;font-size:17px;line-height:1;padding:2px 4px;transition:color .15s;}.sel-clear:hover{color:var(--red);}
.unit-placeholder{font-size:12px;color:var(--text3);padding:8px 12px;background:var(--surface2);border:1px dashed var(--border);border-radius:var(--r);text-align:center;}
.modal-lg{width:min(1040px,98vw);}
#detailModal .modal{width:860px;}
.db-tabs{display:flex;gap:4px;margin-bottom:16px;background:var(--surface2);border-radius:var(--r);padding:4px;}
.db-tab{flex:1;padding:7px;border-radius:8px;border:none;background:none;color:var(--text2);font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;text-align:center;}
.db-tab.active{background:var(--surface3);color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,.3);}
.db-topbar{display:flex;align-items:center;gap:10px;margin-bottom:10px;min-width:0;}
.db-footer{display:flex;gap:10px;justify-content:space-between;align-items:center;flex-wrap:wrap;}
.db-footer-toolbar{flex:1 1 100%;min-width:0;}
.db-footer-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;}
.db-search{flex:1;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--r);padding:8px 14px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;outline:none;transition:border-color .15s;}.db-search:focus{border-color:var(--accent);}
.db-list{display:flex;flex-direction:column;gap:8px;max-height:340px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent;}
.db-list::-webkit-scrollbar{width:4px;}.db-list::-webkit-scrollbar-thumb{background:var(--border);}
.db-list[data-pager-view="grid"]{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:8px;}
.db-list[data-pager-view="grid"] .row-card{flex-direction:column;align-items:flex-start;gap:6px;}
.db-list[data-pager-view="grid"] .row-card .row-av,.db-list[data-pager-view="grid"] .row-card .row-av-sq{align-self:flex-start;}
.fdtb{display:flex;align-items:center;gap:6px;flex-wrap:wrap;overflow:visible;padding:4px 0;}
.fdtb-search-group{display:flex;align-items:center;gap:6px;flex:1 1 280px;min-width:220px;max-width:100%;}
.fdtb-search-group .fdsearch-wrap{flex:1 1 auto;min-width:140px;}
.fdtb-pg{display:flex;align-items:center;gap:3px;flex-wrap:wrap;flex-shrink:0;}
.fdtb-sort,.fdtb-ie,.fdtb-field{font-size:11px;padding:3px 6px;width:auto;flex-shrink:0;}
.fdtb-field{max-width:140px;flex:0 0 120px;}
@media(max-width:900px){
	.fdtb{gap:8px;}
	.fdtb-search-group{flex:1 1 100%;min-width:0;}
	.fdtb-pg{flex:1 1 100%;order:10;}
}
.row-card{display:flex;align-items:center;gap:12px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--r2);padding:12px 14px;transition:border-color .15s,background .15s;cursor:pointer;}.row-card:hover{border-color:var(--border2);background:var(--surface3);}.row-card.selected{border-color:var(--accent);background:rgba(108,99,255,.08);}
.row-av{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0;}
.row-av-sq{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;}
.row-info{flex:1;min-width:0;}.row-name{font-size:14px;font-weight:600;}
.row-sub{display:flex;gap:10px;margin-top:4px;flex-wrap:wrap;}.row-sub-item{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text2);}
.row-actions{display:flex;gap:6px;flex-shrink:0;}
.rbtn{background:var(--surface3);border:1px solid var(--border);color:var(--text2);border-radius:8px;padding:5px 10px;font-size:12px;cursor:pointer;transition:all .15s;}.rbtn:hover{color:var(--text);border-color:var(--border2);}
.rbtn.danger:hover{color:var(--red);border-color:var(--red);}.rbtn.accent{color:var(--accent2);border-color:rgba(108,99,255,.4);}.rbtn.accent:hover{background:var(--accent-glow);}
.db-empty{text-align:center;color:var(--text3);font-size:13px;padding:32px 0;}
/* Board list mode */
.board-wrapper.list-mode{display:block;overflow-x:hidden;overflow-y:auto;padding:0;}
.board-list-row{display:flex;align-items:center;gap:10px;padding:8px 14px;border-bottom:1px solid var(--border);border-left:3px solid var(--col-color,var(--accent));background:var(--surface2);transition:background .12s;cursor:pointer;position:relative;}
.board-list-row:hover{background:var(--surface3);}
.board-list-row.card-done{opacity:.5;}
.board-list-row.due-ok{border-left-color:var(--green);}
.board-list-row.due-warn{border-left-color:var(--orange);}
.board-list-row.due-urgent{border-left-color:#f97316;}
.board-list-row.due-overdue{border-left-color:var(--red);}
.board-list-phase{font-size:11px;font-weight:600;color:var(--text2);white-space:nowrap;min-width:120px;display:flex;align-items:center;flex-shrink:0;}
.board-list-title{flex:1;font-size:13px;font-weight:500;color:var(--text);min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.board-list-meta{min-width:120px;max-width:200px;flex-shrink:0;}
.board-list-due{min-width:100px;flex-shrink:0;}
.board-list-val{min-width:90px;font-size:11px;flex-shrink:0;}
.board-list-pri{font-size:11px;font-weight:600;min-width:38px;flex-shrink:0;}
.board-list-bulk-bar{display:flex;align-items:center;gap:10px;padding:6px 14px;background:rgba(239,68,68,.1);border-bottom:1px solid rgba(239,68,68,.2);font-size:12px;color:var(--text2);}
.form-box{background:rgba(108,99,255,.06);border:1px solid rgba(108,99,255,.25);border-radius:var(--r2);padding:18px;margin-bottom:14px;}
.form-box-title{font-family:'Syne',sans-serif;font-size:14px;font-weight:700;color:var(--accent2);margin-bottom:14px;}
.info-box{display:flex;align-items:center;gap:12px;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--r);padding:12px 14px;}
.info-av{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;color:#fff;flex-shrink:0;}
.info-av-sq{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
.info-links{display:flex;gap:14px;margin-top:5px;flex-wrap:wrap;}

/* ── BACKUP & RESTORE MODAL ── */
.br-cols{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.br-col-title{font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px;}
.br-info{font-size:12px;color:var(--text2);line-height:1.6;padding:10px 12px;background:var(--surface2);border-radius:var(--r);border-left:3px solid var(--accent);}
.br-warn{font-size:12px;color:var(--text);line-height:1.6;padding:10px 12px;background:rgba(220,60,60,.08);border-radius:var(--r);border-left:3px solid #e05555;}
.br-log{width:100%;height:200px;resize:none;font-family:monospace;font-size:11px;line-height:1.6;background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);color:var(--text2);padding:10px;margin:10px 0;}
.br-filepath{display:flex;gap:8px;align-items:center;margin-bottom:4px;}
.br-filepath input{flex:1;}
.btn-danger{background:#c0392b;color:#fff;border:none;}
.btn-danger:hover:not(:disabled){background:#a93226;}
.btn-danger:disabled{opacity:.5;cursor:not-allowed;}
@media(max-width:700px){.br-cols{grid-template-columns:1fr;}}

/* ── CONFIG DROPDOWN ── */
.cfg-wrap{position:relative;flex-shrink:0;}
.cfg-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:240px;background:var(--surface);border:1px solid var(--border2);border-radius:var(--r2);box-shadow:0 12px 40px rgba(0,0,0,.5);z-index:500;opacity:0;pointer-events:none;transform:translateY(-6px);transition:all .18s;}
.cfg-dropdown.open{opacity:1;pointer-events:all;transform:translateY(0);}
.cfg-header{padding:12px 16px 8px;font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.6px;border-bottom:1px solid var(--border);}
.cfg-item{display:flex;align-items:center;gap:10px;padding:11px 16px;cursor:pointer;transition:background .12s;font-size:13px;font-weight:500;color:var(--text2);border:none;background:none;width:100%;text-align:left;font-family:'DM Sans',sans-serif;}
.cfg-item:hover{background:var(--surface2);color:var(--text);}
.cfg-item-icon{font-size:16px;width:20px;text-align:center;flex-shrink:0;}
.cfg-item-info{flex:1;}
.cfg-item-label{font-size:13px;font-weight:500;}
.cfg-item-sub{font-size:11px;color:var(--text3);margin-top:1px;}
.cfg-sep{height:1px;background:var(--border);margin:4px 0;}


/* INLINE VIEW/EDIT PANEL */
.inline-panel{background:var(--surface2);border:1px solid var(--border2);border-radius:var(--r2);margin-top:2px;margin-bottom:8px;overflow:hidden;animation:panelIn .15s ease;}
@keyframes panelIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.inline-panel-header{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border);}
.inline-panel-av{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:800;color:#fff;flex-shrink:0;}
.inline-panel-av-sq{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;}
.inline-panel-name{font-family:'Syne',sans-serif;font-size:16px;font-weight:800;line-height:1.2;}
.inline-panel-sub{font-size:12px;color:var(--text2);margin-top:2px;}
.inline-panel-fields{padding:14px 16px;display:grid;gap:10px;}
.inline-panel-fields.cols2{grid-template-columns:1fr 1fr;}
.ipf{display:flex;flex-direction:column;gap:4px;}
.ipf label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text3);}
.ipf input,.ipf select,.ipf textarea{background:var(--surface3);border:1px solid var(--border);border-radius:var(--r);padding:8px 10px;font-size:13px;color:var(--text);font-family:'DM Sans',sans-serif;width:100%;outline:none;transition:border-color .15s;}
.ipf input:disabled,.ipf select:disabled,.ipf textarea:disabled{opacity:.85;cursor:default;background:var(--surface3);border-color:transparent;}
.ipf input:not(:disabled):focus,.ipf select:not(:disabled):focus{border-color:var(--accent);}
.ipf .ipf-val{font-size:13px;color:var(--text);display:flex;align-items:center;gap:6px;}
.inline-panel-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-top:1px solid var(--border);background:var(--surface);}
.inline-panel-stats{display:flex;gap:12px;}
.inline-panel-stat{font-size:12px;color:var(--text2);display:flex;align-items:center;gap:4px;}
.col-manual-modal-shell{width:min(1100px,98vw);}
.col-manual-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px;}
.col-manual-sub{font-size:12px;color:var(--text3);}
.col-manual-head-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end;}
.col-manual-textarea{min-height:260px;font-family:'DM Mono','Courier New',monospace;line-height:1.6;}
.col-manual-preview{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r2);padding:14px;min-height:120px;max-height:260px;overflow:auto;}
.markdown-body{font-size:13px;line-height:1.7;color:var(--text2);}
.markdown-body p{margin:0 0 10px;}
.markdown-body h1,.markdown-body h2,.markdown-body h3,.markdown-body h4{color:var(--text);line-height:1.3;}
.markdown-body h1{font-family:'Syne',sans-serif;font-size:18px;margin:0 0 12px;}
.markdown-body h2{font-size:14px;margin:18px 0 8px;padding-bottom:6px;border-bottom:1px solid var(--border);}
.markdown-body h3{font-size:13px;margin:14px 0 6px;color:var(--accent2);}
.markdown-body h4{font-size:12px;margin:12px 0 6px;color:var(--text2);}
.markdown-body ul{margin:0 0 12px 18px;padding:0;}
.markdown-body li{margin:0 0 5px;}
.markdown-body strong{color:var(--text);}
.markdown-body em{font-style:italic;}
.markdown-body code{background:var(--surface3);border:1px solid var(--border);border-radius:5px;padding:1px 5px;color:var(--cyan);font-size:12px;}
.markdown-body hr{border:none;border-top:1px solid var(--border);margin:14px 0;}
.manual-suggestion-card{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r2);padding:12px;display:flex;flex-direction:column;gap:10px;}
.manual-suggestion-card.is-pendente{border-left:3px solid var(--yellow);}
.manual-suggestion-card.is-aprovada{border-left:3px solid var(--green);}
.manual-suggestion-card.is-rejeitada{border-left:3px solid var(--red);}
.manual-suggestion-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:11px;color:var(--text3);}
.manual-suggestion-status{font-weight:700;text-transform:uppercase;letter-spacing:.3px;}
.manual-suggestion-desc{font-size:13px;color:var(--text);font-weight:600;}
.manual-suggestion-split{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.manual-suggestion-box{background:var(--surface3);border:1px solid var(--border);border-radius:var(--r);padding:10px;min-height:80px;max-height:220px;overflow:auto;}
.manual-suggestion-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;}
@media(max-width:900px){.manual-suggestion-split{grid-template-columns:1fr;}}
/* Edit button on row */
.row-edit-btn{background:var(--surface3);border:1px solid var(--border2);border-radius:8px;padding:5px 10px;font-size:11px;font-weight:600;color:var(--accent2);cursor:pointer;font-family:'DM Sans',sans-serif;white-space:nowrap;flex-shrink:0;transition:background .15s;}
.row-edit-btn:hover{background:var(--surface2);border-color:var(--accent);}
.row-del-btn{background:var(--surface3);border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:5px 10px;font-size:11px;font-weight:600;color:var(--red);cursor:pointer;font-family:'DM Sans',sans-serif;white-space:nowrap;flex-shrink:0;transition:background .15s;}
.row-del-btn:hover{background:rgba(239,68,68,.08);}
.row-card-wrap{display:flex;flex-direction:column;}


.notif{display:none;}
.notif-stack{position:fixed;top:72px;right:18px;width:min(440px,calc(100vw - 28px));display:flex;flex-direction:column;gap:10px;z-index:2147483000;pointer-events:none;}
.notif-toast{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:start;gap:10px;background:rgba(28,31,44,.98);border:1px solid var(--border2);border-left:3px solid var(--accent);border-radius:8px;padding:11px 12px;box-shadow:0 18px 50px rgba(0,0,0,.48);font-size:13px;font-weight:600;color:var(--text);line-height:1.4;opacity:0;transform:translateY(-8px) scale(.98);transition:opacity .18s,transform .18s;pointer-events:auto;}
.notif-toast.show{opacity:1;transform:translateY(0) scale(1);}
.notif-icon{line-height:1.4;flex-shrink:0;}
.notif-text{min-width:0;overflow-wrap:anywhere;word-break:normal;}
.notif-close{background:none;border:0;color:var(--text3);cursor:pointer;font-size:18px;line-height:1;padding:0 0 0 6px;}
.notif-close:hover{color:var(--text);}
/* DEV MODE */
.dev-badge{position:absolute;top:6px;right:8px;background:#1a1030;border:1px solid #7c3aed;color:#a78bfa;font-size:10px;font-family:'DM Mono','Courier New',monospace;font-weight:600;padding:2px 7px;border-radius:6px;letter-spacing:.3px;z-index:9999;pointer-events:none;white-space:nowrap;box-shadow:0 2px 8px rgba(124,58,237,.25);}
.dev-badge-board{position:fixed;top:56px;left:8px;background:#1a1030;border:1px solid #7c3aed;color:#a78bfa;font-size:10px;font-family:'DM Mono','Courier New',monospace;font-weight:600;padding:2px 7px;border-radius:6px;letter-spacing:.3px;z-index:9999;pointer-events:none;}
.overlay.dev-active{outline:2px dashed rgba(124,58,237,.4);}
body.devmode .dev-badge,.body.devmode .dev-badge-board{display:block!important;}
@media(max-width:720px){.notif-stack{top:64px;right:10px;left:10px;width:auto;}}

/* ─── KDS — Phase Display ─── */
#kdsModal { align-items: stretch; justify-content: stretch; }
#kds-container {
	width: 100%;
	height: 100%;
	background: var(--bg);
	display: flex;
	flex-direction: column;
	overflow: hidden;
}
.kds-header {
	background: var(--surface);
	border-bottom: 1px solid var(--border);
	padding: 12px 20px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	flex-shrink: 0;
}
.kds-header-left { display: flex; flex-direction: column; gap: 3px; }
.kds-header-title {
	font-size: 18px;
	font-weight: 700;
	color: var(--text);
	display: flex;
	align-items: center;
	gap: 10px;
}
.kds-header-sub { font-size: 12px; color: var(--text3); }
.kds-header-right { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
.kds-counters {
	background: var(--surface2);
	border-bottom: 1px solid var(--border);
	padding: 8px 20px;
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
	flex-shrink: 0;
}
.kds-cnt {
	font-size: 11px;
	color: var(--text3);
	background: var(--surface3);
	border: 1px solid var(--border);
	border-radius: 6px;
	padding: 3px 10px;
}
.kds-cnt b { color: var(--text); margin-right: 3px; }
.kds-cnt.danger b { color: var(--red); }
.kds-cnt.warning b { color: var(--yellow); }
.kds-cnt.success b { color: var(--green); }
.kds-last-update { font-size: 11px; color: var(--text3); margin-left: auto; }
.kds-body {
	flex: 1;
	overflow-y: auto;
	padding: 14px;
	scrollbar-width: thin;
	scrollbar-color: var(--border) transparent;
}
.kds-grid { display: grid; gap: 10px; }
.kds-card {
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: var(--r2);
	padding: 12px;
	display: flex;
	flex-direction: column;
	gap: 7px;
	cursor: pointer;
	min-height: 148px;
	transition: border-color .15s, transform .1s;
}
.kds-card:hover { transform: translateY(-1px); border-color: var(--accent); }
.kds-card.kds-overdue  { border-color: rgba(239,68,68,.5); background: rgba(239,68,68,.04); }
.kds-card.kds-today    { border-color: rgba(245,158,11,.4); background: rgba(245,158,11,.03); }
.kds-card.kds-tomorrow { border-color: rgba(245,158,11,.25); }
.kds-card-top  { display: flex; justify-content: space-between; align-items: center; }
.kds-card-id   { font-size: 10px; color: var(--text3); font-family: monospace; }
.kds-card-age  { font-size: 10px; color: var(--text3); }
.kds-card-title {
	font-size: 12px;
	font-weight: 600;
	color: var(--text);
	line-height: 1.4;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.kds-card-empresa { font-size: 11px; color: var(--text2); }
.kds-card-labels  { display: flex; gap: 4px; flex-wrap: wrap; }
.kds-card-footer  { display: flex; justify-content: space-between; align-items: center; margin-top: auto; }
.kds-due {
	font-size: 10px;
	font-weight: 600;
	padding: 2px 7px;
	border-radius: 20px;
}
.kds-due.overdue  { background: rgba(239,68,68,.15); color: var(--red); }
.kds-due.today    { background: rgba(245,158,11,.15); color: var(--yellow); }
.kds-due.tomorrow { background: rgba(245,158,11,.1);  color: var(--yellow); }
.kds-due.soon     { background: rgba(34,197,94,.12);  color: var(--green); }
.kds-due.none     { background: var(--surface3); color: var(--text3); }
.kds-resp {
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: var(--surface3);
	border: 1px solid var(--border);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 9px;
	color: var(--text2);
	font-weight: 600;
	overflow: hidden;
	flex-shrink: 0;
}
.kds-resp img { width: 100%; height: 100%; object-fit: cover; }
.kds-empty {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	height: 300px;
	color: var(--text3);
	font-size: 14px;
	gap: 10px;
}
.kds-refreshing { opacity: .65; pointer-events: none; }
@keyframes kds-pulse { 0%,100%{opacity:1} 50%{opacity:.5} }
.kds-updating { animation: kds-pulse .8s ease-in-out 2; }

/* Hint clicável no nome da fase no board */
.col-name-kds {
	cursor: pointer;
	border-bottom: 1px dashed transparent;
	transition: border-color .15s;
}
.col-name-kds:hover { border-color: var(--text3); }
/* Sortable.js styles */
.sortable-ghost {
  opacity: 0.4;
  background: var(--accent-glow);
  border: 2px dashed var(--accent);
}
.sortable-chosen {
  transform: scale(1.02);
}
.sortable-drag {
  transform: rotate(5deg);
  box-shadow: 0 8px 24px rgba(0,0,0,.6);
}


/* ══ MAPPINGS REDESIGN ══ */

.modal-xl{width:min(900px,98vw);}
#mappingsEditModal .modal-xl{width:min(1400px,98vw);}
#mappingsEditModal .modal{
	display:flex;
	flex-direction:column;
	height:min(880px,92vh);
	overflow:hidden;
}
@media (min-width:1200px){
	#mappingsEditModal .fdtb{flex-wrap:nowrap;}
	#mappingsEditModal .fdtb-search-group{flex:1 1 360px;min-width:300px;}
}
.btn-sm{padding:4px 10px;font-size:12px;}
.items-toolbar-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.toolbar-sep{width:1px;height:20px;background:var(--border);flex-shrink:0;margin:0 2px;}
.items-count{font-size:12px;color:var(--text2);}
.items-dirty{font-size:12px;color:var(--yellow);font-weight:600;}

.btn-danger-soft{color:var(--red);border-color:rgba(239,68,68,.35);}
.btn-danger-soft:hover{background:rgba(239,68,68,.1);}

/* Level 1 — unit rows */
.mg-unit-row{
    display:flex;align-items:center;gap:10px;
    padding:10px 14px;
    border:1px solid var(--border);
    border-radius:var(--r);
    background:var(--surface2);
    cursor:pointer;
    transition:background .12s;
    margin-bottom:6px;
}
.mg-unit-row:hover{background:var(--surface3);}
.mg-unit-icon{font-size:18px;flex-shrink:0;}
.mg-unit-name{flex:1;font-weight:600;font-size:14px;}
.mg-unit-count{font-size:12px;color:var(--text2);background:var(--surface3);border:1px solid var(--border);border-radius:20px;padding:2px 10px;}

/* Level 2 — sheet */
.mg-sheet-wrap{
    overflow:auto;
    flex:1 1 auto;
    min-height:0;
    border:1px solid var(--border);
    border-radius:var(--r);
}
.mg-sheet{
    width:100%;
    border-collapse:collapse;
    font-size:12px;
}
.mg-sheet thead th{
    position:sticky;top:0;z-index:2;
    background:var(--surface2);
    border-bottom:2px solid var(--border);
    padding:6px 8px;
    text-align:left;
    font-weight:600;
    color:var(--text2);
    white-space:nowrap;
}
.mg-sheet tbody td{
    border-bottom:1px solid var(--border);
    padding:2px 4px;
    vertical-align:middle;
}
.mg-sheet tbody tr:hover{background:rgba(99,102,241,.05);}
.mg-sheet tbody tr.mg-selected{background:rgba(99,102,241,.12);}
.mg-sheet tbody tr.mg-dirty{background:rgba(245,158,11,.07);}
.mg-sheet tbody tr.mg-new{background:rgba(16,185,129,.07);}

.mg-cell{
    width:100%;
    background:transparent;
    border:none;
    padding:4px 6px;
    font-size:12px;
    color:var(--text);
    outline:none;
    min-width:60px;
}
.mg-cell:focus{
    background:var(--surface);
    border:1px solid var(--accent);
    border-radius:3px;
    outline:none;
}
.mg-cell-ro{
    color:var(--text2);
    cursor:default;
    background:transparent !important;
    border:none !important;
}

/* Column widths */
.mg-col-sel{width:32px;text-align:center;}
.mg-col-codigo{width:90px;}
.mg-col-sku{width:110px;}
.mg-col-desc{min-width:160px;}
.mg-col-un{width:60px;}
.mg-col-stock-sku{width:120px;}
.mg-col-stock-desc{min-width:140px;}

/* Autocomplete dropdown */
.mg-ac-dropdown{
    position:absolute;top:100%;left:0;right:0;z-index:200;
    background:var(--surface2);
    border:1px solid var(--border);
    border-radius:var(--r);
    box-shadow:0 8px 24px rgba(0,0,0,.35);
    max-height:180px;overflow-y:auto;
    margin-top:2px;
}
.mg-ac-item{
    display:flex;align-items:baseline;gap:8px;
    padding:6px 10px;cursor:pointer;font-size:12px;
}
.mg-ac-item:hover{background:var(--surface3);}
.mg-ac-sku{font-weight:600;color:var(--accent2);flex-shrink:0;}
.mg-ac-name{color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}

@media (max-width: 820px){
  body{padding-left:0;}
  body.sidebar-collapsed{--sidebar-w:248px;}
  .app-sidebar{transform:translateX(-100%);width:248px;}
  body.sidebar-collapsed .app-sidebar{width:248px;}
  body.sidebar-mobile-open .app-sidebar{transform:translateX(0);}
  body.sidebar-mobile-open .app-sidebar-scrim{display:block;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:170;}
  body.sidebar-collapsed .app-sidebar-head{justify-content:flex-start;padding:0 12px;}
  body.sidebar-collapsed .app-side-account,body.sidebar-collapsed .app-side-label,body.sidebar-collapsed .app-side-user-meta{display:flex;}
  body.sidebar-collapsed .app-side-item{justify-content:flex-start;padding:0 10px;}
  body.sidebar-collapsed .app-side-badge{position:static;margin-left:auto;min-width:18px;height:18px;font-size:10px;}
  .topbar{padding-left:12px;}
  .app-mobile-menu-btn{display:flex;}
  .topbar-brand{max-width:42vw;}
}
