:root{color:#172033;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#eef3f8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:radial-gradient(80% 50% at 50% -10%,#1663f30f,#0000),linear-gradient(#ffffffd1,#fff0),#eef3f8;min-width:320px;min-height:100vh;margin:0}button,input,select,textarea{font:inherit}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,a:focus-visible{outline-offset:2px;outline:2px solid #1663f3}::selection{background:#cfe0ff}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#c5cdd9;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#a0aabb}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.app-shell{flex-direction:column;max-width:1600px;min-height:100vh;margin:0 auto;padding:28px 36px 24px;display:flex}.topbar{border-bottom:1px solid #0000000a;justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:20px;padding-bottom:20px;display:flex}.topbar h1{color:#0f172a;letter-spacing:-.01em;margin:4px 0 0;font-size:28px;font-weight:750;line-height:1.15}.topbar-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.file-input{display:none}.eyebrow{color:#6366f1;letter-spacing:.1em;text-transform:uppercase;margin:0;font-size:11px;font-weight:750;line-height:1.4}.primary-action,.secondary-action,.ghost-action,.danger-action,.mini-action,.icon-button{font:inherit;cursor:pointer;border:0;transition:background .18s,border-color .18s,color .18s,transform .18s,box-shadow .18s,opacity .18s}.primary-action,.secondary-action,.ghost-action,.danger-action{white-space:nowrap;border-radius:8px;justify-content:center;align-items:center;gap:7px;min-height:38px;padding:0 16px;font-size:14px;font-weight:550;display:inline-flex}.primary-action{color:#fff;background:#1663f3;box-shadow:0 1px 2px #1663f333,0 4px 14px #1663f326}.primary-action:hover{background:#0e55d7;transform:translateY(-1px);box-shadow:0 2px 4px #1663f338,0 8px 20px #1663f333}.primary-action:active{transform:translateY(0);box-shadow:0 1px 3px #1663f32e}.secondary-action{color:#3730a3;background:#eef2ff;border:1px solid #e0e7ff}.secondary-action span{color:#4338ca;background:#fff;border-radius:999px;justify-content:center;align-items:center;min-width:20px;height:20px;font-size:11px;font-weight:750;display:inline-flex;box-shadow:0 0 0 1px #6366f11a}.secondary-action:hover{background:#e0e7ff;border-color:#c7d2fe}.ghost-action{color:#475569;background:#fff;border:1px solid #e2e8f0}.ghost-action:hover{color:#1e293b;background:#f8fafc;border-color:#cbd5e1}.danger-action{color:#dc2626;background:#fef2f2;border:1px solid #fecaca}.danger-action:hover{background:#fee2e2;border-color:#fca5a5}.icon-button,.mini-action{color:#64748b;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;display:inline-flex}.mini-action{flex:none;width:40px;height:40px}.icon-button:hover,.mini-action:hover{color:#1e293b;background:#f1f5f9;border-color:#cbd5e1}.icon-button.danger:hover{color:#dc2626;background:#fef2f2;border-color:#fecaca}.overview-grid{grid-template-columns:repeat(5,minmax(120px,1fr));gap:12px;margin-bottom:16px;display:grid}.metric-tile{cursor:default;background:#fff;border:1px solid #0000000a;border-radius:12px;flex-direction:column;justify-content:center;gap:6px;min-height:78px;padding:14px 16px;transition:transform .22s,box-shadow .22s;display:flex;position:relative;overflow:hidden;box-shadow:0 1px 3px #00000005,0 4px 16px #00000008}.metric-tile:hover{transform:translateY(-2px);box-shadow:0 2px 6px #00000008,0 12px 28px #0000000f}.metric-tile:before{content:"";background:var(--tile-accent,#1663f3);border-radius:0 2px 2px 0;width:3px;position:absolute;inset:0 auto 0 0}.metric-tile:after{content:"";background:linear-gradient(135deg, var(--tile-accent,#1663f3) 0%, transparent 60%);opacity:.025;pointer-events:none;border-radius:12px;position:absolute;inset:0}.metric-tile span{color:#64748b;letter-spacing:.01em;align-items:center;gap:6px;font-size:12px;font-weight:550;display:inline-flex}.metric-tile span svg{color:var(--tile-accent,#1663f3);opacity:.85}.metric-tile strong{color:#0f172a;letter-spacing:-.02em;font-size:26px;font-weight:750;line-height:1}.accent-blue{--tile-accent:#3b82f6}.accent-green{--tile-accent:#10b981}.accent-purple{--tile-accent:#8b5cf6}.accent-orange{--tile-accent:#f59e0b}.accent-cyan{--tile-accent:#06b6d4}.toolbar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff2;border:1px solid #e2e8f0;border-radius:12px 12px 0 0;align-items:center;gap:10px;padding:10px;transition:border-color .2s;display:flex}.toolbar:focus-within{border-color:#93c5fd}.search-box,.filter-control,.date-cell{color:#94a3b8;background:#fff;border:1px solid #e2e8f0;align-items:center;gap:8px;transition:border-color .18s,box-shadow .18s;display:inline-flex}.search-box:focus-within,.filter-control:focus-within{border-color:#93c5fd;box-shadow:0 0 0 3px #3b82f614}.search-box{border-radius:8px;flex:360px;min-width:240px;height:40px;padding:0 12px}.search-box input,.filter-control select,.date-cell input,.field input,.field select,.field textarea{color:#0f172a;width:100%;font:inherit;background:0 0;border:0;outline:0}.search-box input::placeholder,.field input::placeholder,.field textarea::placeholder{color:#94a3b8}.filter-control{border-radius:8px;flex:none;min-width:140px;height:40px;padding:0 10px}.filter-control select{cursor:pointer;color:#475569;font-weight:500}.table-panel{background:#fff;border:1px solid #e2e8f0;border-top:0;border-radius:0 0 12px 12px;flex:1;min-height:0;overflow:auto;box-shadow:0 1px 3px #00000005,0 8px 30px #0000000a}.task-table{min-width:1100px;min-height:100%}.table-row{border-bottom:1px solid #f1f5f9;grid-template-columns:1.25fr 116px 116px 1.35fr 172px 150px 150px 138px;align-items:stretch;min-height:60px;display:grid}.task-row{background:#fff;transition:background .15s;position:relative}.task-row:hover{background:#fafbff}.task-row.is-dragging{opacity:.4;background:#f8fafc}.task-row.is-drag-over{background:#eff6ff}.task-row.is-drag-over:before{content:"";z-index:3;background:#3b82f6;border-radius:0 0 2px 2px;height:2px;position:absolute;top:-1px;left:0;right:0;box-shadow:0 1px 4px #3b82f64d}.table-row>*{border-right:1px solid #f1f5f9;min-width:0}.table-row>:last-child{border-right:0}.table-head{z-index:2;color:#64748b;letter-spacing:.03em;text-transform:uppercase;background:#f8fafc;border-bottom:1px solid #e2e8f0;min-height:42px;font-size:11.5px;font-weight:700;position:sticky;top:0}.table-head span{align-items:center;gap:6px;padding:0 12px;display:flex}.table-head svg{color:#94a3b8;flex:none}.name-cell,.tag-cell{width:100%;font:inherit;text-align:left;cursor:pointer;background:0 0;border:0;transition:background .15s}.name-cell{color:#0f172a;align-items:center;gap:8px;padding:10px 12px 10px 8px;font-size:14px;font-weight:650;display:flex}.name-cell:hover,.tag-cell:hover{background:#f1f5f9}.drag-handle{color:#cbd5e1;cursor:grab;border-radius:6px;flex:none;justify-content:center;align-items:center;width:24px;height:28px;transition:color .15s,background .15s;display:inline-flex}.drag-handle:hover{color:#3b82f6;background:#e0e7ff}.drag-handle:active{cursor:grabbing}.tag-cell{color:#475569;align-items:center;padding:0 10px;font-size:13px;font-weight:500;display:flex}.tag-cell:before{content:"";opacity:.65;background:currentColor;border-radius:999px;flex:none;width:7px;height:7px;margin-right:8px}.status-tag{color:#059669;font-weight:600}.category-tag{color:#7c3aed}.detail-cell{color:#64748b;-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:60px;margin:0;padding:10px 12px;font-size:13px;line-height:1.55;display:-webkit-box;overflow:hidden}.progress-cell{flex-direction:column;justify-content:center;gap:8px;padding:0 12px;display:flex}.progress-line{justify-content:space-between;align-items:center;gap:8px;display:flex}.progress-line strong{color:#0f172a;font-size:14px;font-weight:700}.progress-line em{color:#94a3b8;background:#f1f5f9;border-radius:4px;padding:1px 6px;font-size:11px;font-style:normal;font-weight:500}input[type=range]{appearance:none;cursor:pointer;background:#e2e8f0;border-radius:3px;outline:none;width:100%;height:6px;margin:0}input[type=range]::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#3b82f6;border:2px solid #fff;border-radius:50%;width:16px;height:16px;transition:transform .15s,box-shadow .15s;box-shadow:0 1px 3px #00000026}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 2px 6px #3b82f64d}input[type=range]::-moz-range-thumb{cursor:pointer;background:#3b82f6;border:2px solid #fff;border-radius:50%;width:16px;height:16px;transition:transform .15s,box-shadow .15s;box-shadow:0 1px 3px #00000026}.progress-bar{background:#e2e8f0;border-radius:3px;height:6px;position:relative;overflow:visible}.progress-bar:before{content:"";height:100%;width:var(--progress,0%);pointer-events:none;background:linear-gradient(90deg,#3b82f6,#60a5fa);border-radius:3px;transition:width .2s;position:absolute;top:0;left:0}.progress-bar input[type=range]{z-index:1;background:0 0;height:16px;margin:-5px 0;position:relative}.progress-bar input[type=range]::-webkit-slider-runnable-track{background:0 0;border-radius:3px;height:6px}.progress-bar input[type=range]::-moz-range-track{background:0 0;border-radius:3px;height:6px}.progress-bar input[type=range]::-moz-range-progress{background:0 0}input[type=range]:disabled{cursor:not-allowed;opacity:.6}input[type=range]:disabled::-webkit-slider-thumb{cursor:not-allowed;background:#94a3b8}input[type=range]:disabled::-moz-range-thumb{cursor:not-allowed;background:#94a3b8}.date-cell{cursor:pointer;border:0;border-radius:0;height:100%;padding:0 9px}.date-cell input{color:#475569;cursor:pointer;font-size:13px}.row-actions{justify-content:center;align-items:center;padding:0 10px;display:flex}.empty-state{color:#64748b;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;min-height:calc(100vh - 320px);padding:40px 28px;animation:.4s slideUp;display:flex}.empty-state svg{color:#cbd5e1;margin-bottom:4px}.empty-state h2,.doc-empty h3{color:#1e293b;margin:0;font-size:18px;font-weight:700}.empty-state p,.doc-empty p{color:#64748b;max-width:430px;margin:0 0 8px;font-size:14px;line-height:1.65}.modal-backdrop{z-index:20;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a66;place-items:center;padding:20px;animation:.2s fadeIn;display:grid;position:fixed;inset:0}.modal-backdrop.elevated{z-index:40}.modal{background:#fff;border:1px solid #0000000d;border-radius:14px;width:min(700px,100%);max-height:min(800px,100vh - 40px);animation:.25s scaleIn;overflow:auto;box-shadow:0 4px 6px #00000005,0 20px 50px #0000001f,0 0 0 1px #00000005}.doc-modal{width:min(520px,100%)}.modal-header,.side-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:flex-start;gap:16px;padding:20px 24px;display:flex}.modal-header h2,.side-header h2{color:#0f172a;margin:4px 0 0;font-size:20px;font-weight:700;line-height:1.25}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;padding:24px;display:grid}.field{flex-direction:column;gap:7px;display:flex}.field span{color:#334155;font-size:13px;font-weight:650}.field input,.field select,.field textarea{box-sizing:border-box;background:#fff;border:1px solid #e2e8f0;border-radius:8px;min-height:42px;padding:9px 12px;font-size:14px;transition:border-color .18s,box-shadow .18s}.field input:focus,.field select:focus,.field textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.field textarea{resize:vertical;min-height:112px;line-height:1.55}.field small{color:#94a3b8;font-size:12px}.combo-row{gap:8px;display:flex}.combo-row select{flex:1}.full-field{grid-column:1/-1}.range-field{gap:10px}.range-field span{justify-content:space-between;align-items:center;display:flex}.option-manager{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:14px}.option-manager>div:first-child{flex-direction:column;gap:3px;margin-bottom:12px;display:flex}.option-manager strong{color:#1e293b;font-size:14px;font-weight:650}.option-manager span{color:#64748b;font-size:12px}.option-groups,.option-group,.option-group div{gap:8px;display:flex}.option-groups{flex-direction:column}.option-group{align-items:flex-start}.option-group>span{color:#334155;flex:0 0 34px;padding-top:5px;font-size:12px;font-weight:700}.option-group div{flex-wrap:wrap}.option-group button{color:#475569;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:999px;align-items:center;gap:5px;min-height:28px;padding:0 10px;font-size:13px;transition:border-color .15s,color .15s,background .15s;display:inline-flex}.option-group button:hover{color:#dc2626;background:#fef2f2;border-color:#fca5a5}.modal-actions{justify-content:flex-end;align-items:center;gap:10px;padding-top:8px;display:flex}.modal-spacer{flex:1}.side-panel{z-index:30;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a4d;justify-content:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.side-panel-inner{background:#fff;flex-direction:column;width:min(480px,100%);height:100%;animation:.28s slideInRight;display:flex;box-shadow:-8px 0 30px #00000014,-1px 0 #00000008}.wide-action{margin:16px 20px 10px}.doc-list{flex-direction:column;flex:1;gap:8px;padding:10px 20px 24px;display:flex;overflow:auto}.doc-item{background:#fff;border:1px solid #e2e8f0;border-radius:10px;grid-template-columns:1fr auto;align-items:center;gap:8px;padding:12px;transition:border-color .18s,box-shadow .18s;display:grid}.doc-item:hover{border-color:#cbd5e1;box-shadow:0 2px 8px #0000000a}.doc-item a{min-width:0;color:inherit;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;text-decoration:none;display:grid}.doc-item a:hover strong{color:#3b82f6}.doc-icon{color:#4f46e5;background:#eef2ff;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;display:inline-flex}.doc-item strong{color:#0f172a;text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;display:block;overflow:hidden}.doc-item time{color:#94a3b8;font-size:12px}.doc-actions{gap:4px;display:flex}.doc-actions .icon-button{width:30px;height:30px}.doc-empty{color:#64748b;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;min-height:260px;display:flex}.doc-empty svg{color:#cbd5e1;margin-bottom:4px}@media (width<=900px){.app-shell{padding:18px}.topbar{flex-direction:column;align-items:stretch;padding-bottom:16px}.topbar-actions{justify-content:stretch}.topbar-actions>button{flex:1 1 0}.overview-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.toolbar{border-radius:12px 12px 0 0;flex-direction:column;align-items:stretch}.search-box,.filter-control{box-sizing:border-box;width:100%}.form-grid{grid-template-columns:1fr;padding:18px}.side-panel-inner{width:100%}}@media (width<=520px){.app-shell{padding:12px}.topbar h1{font-size:22px}.overview-grid{grid-template-columns:1fr;gap:8px}.metric-tile{flex-direction:row;justify-content:space-between;align-items:center;min-height:64px}.metric-tile strong{font-size:22px}.modal-backdrop{padding:10px}.modal{border-radius:12px}.modal-actions{flex-direction:column;align-items:stretch}.modal-spacer{display:none}}
