@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--brand-50:#e0f0ff;--brand-100:#b3d5f7;--brand-200:#80baee;--brand-500:#0068b7;--brand-600:#0059a0;--brand-700:#004a85;--brand-900:#002d55;--accent-400:#ff8030;--accent-500:#e8590c;--accent-600:#c94d0a;--grey-0:#fff;--grey-50:#f8f9fc;--grey-100:#f1f3f7;--grey-150:#e8eaf0;--grey-200:#d8dce6;--grey-300:#b3bacb;--grey-400:#8892a8;--grey-500:#5c6478;--grey-600:#424a5c;--grey-700:#2e3444;--grey-800:#1e2333;--grey-900:#111624;--bg:var(--grey-50);--surface:var(--grey-0);--border:var(--grey-150);--text:var(--grey-800);--text-sub:var(--grey-500);--text-muted:var(--grey-400);--green-50:#ecfdf5;--green-600:#059669;--green-700:#047857;--red-50:#fef2f2;--red-600:#dc2626;--red-700:#b91c1c;--yellow-50:#fffbeb;--yellow-600:#d97706;--yellow-700:#b45309;--blue-50:#eff6ff;--blue-600:#2563eb;--blue-700:#1d4ed8;--orange-50:#fff7ed;--orange-600:#ea580c;--orange-700:#c2410c;--purple-50:#f5f3ff;--purple-600:#7c3aed;--purple-700:#6d28d9;--sidebar-bg:#0c2340;--sidebar-w:252px;--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;--sp-6:24px;--sp-8:32px;--sp-10:40px;--font:"Inter", system-ui, -apple-system, sans-serif;--mono:ui-monospace, "Cascadia Code", "Fira Code", monospace;--text-xs:11px;--lh-xs:1.5;--text-sm:13px;--lh-sm:1.55;--text-base:14px;--lh-base:1.6;--text-md:15px;--lh-md:1.55;--text-lg:17px;--text-xl:20px;--text-2xl:24px;--text-3xl:30px;--text-4xl:38px;--r-sm:4px;--r:8px;--r-lg:12px;--r-xl:16px;--r-full:9999px;--sh-xs:0 1px 2px #0000000f;--sh-sm:0 1px 4px #00000014, 0 2px 8px #0000000d;--sh:0 2px 8px #00000014, 0 4px 16px #0000000f;--sh-md:0 4px 16px #0000001a, 0 8px 32px #00000012;--sh-lg:0 8px 32px #0000001f, 0 16px 48px #00000014;--ease:cubic-bezier(.4,0,.2,1);--dur-fast:.12s;--dur:.18s}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:var(--text-base);-webkit-text-size-adjust:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:var(--lh-base);-webkit-font-smoothing:antialiased}a{color:var(--brand-500);text-decoration:none}a:hover{text-decoration:underline}ul[role=list]{list-style:none}img,svg{max-width:100%;display:block}input,select,textarea,button{font:inherit;color:inherit}button{cursor:pointer}.portal{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);scrollbar-width:none;flex-direction:column;flex-shrink:0;height:100vh;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar::-webkit-scrollbar{display:none}.sidebar-brand{padding:var(--sp-5) var(--sp-5) var(--sp-4);border-bottom:1px solid #ffffff12;flex-direction:column;align-items:flex-start;gap:4px;display:flex}.sidebar-logo-img{width:auto;height:36px;display:block}.sidebar-brand-icon{color:var(--accent-400);flex-shrink:0}.sidebar-logo{font-size:var(--text-md);color:#fff;font-weight:700;line-height:1.2;display:block}.sidebar-tagline{font-size:var(--text-xs);color:#fff6;letter-spacing:.05em;text-transform:uppercase;margin-top:1px}.sidebar-nav{padding:var(--sp-3) var(--sp-3);flex:1}.sidebar-nav ul{flex-direction:column;gap:2px;display:flex}.nav-link{align-items:center;gap:var(--sp-3);padding:9px var(--sp-3);border-radius:var(--r);color:#fff9;font-size:var(--text-sm);transition:background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);font-weight:500;display:flex;position:relative;text-decoration:none!important}.nav-link:hover{color:#ffffffe6;background:#ffffff12}.nav-link-active{background:#ffffff1a;color:#fff!important}.nav-link-active:before{content:"";background:var(--accent-400);border-radius:0 2px 2px 0;width:3px;position:absolute;top:6px;bottom:6px;left:0}.nav-icon{flex-shrink:0}.nav-label{flex:1}.nav-chevron{opacity:0;transition:opacity var(--dur-fast)}.nav-link:hover .nav-chevron,.nav-link-active .nav-chevron{opacity:.5}.sidebar-footer{padding:var(--sp-4) var(--sp-5);font-size:var(--text-xs);color:#ffffff4d;border-top:1px solid #ffffff12}.portal-main{background:var(--bg);flex-direction:column;flex:1;min-width:0;display:flex}.portal-content{flex:1}.page-content{padding:var(--sp-8) var(--sp-8);max-width:1180px}.page-header{justify-content:space-between;align-items:flex-start;gap:var(--sp-4);margin-bottom:var(--sp-6);flex-wrap:wrap;display:flex}.page-header h1{font-size:var(--text-2xl);color:var(--grey-900);font-weight:700;line-height:1.25}.page-header .subtitle{font-size:var(--text-sm);color:var(--text-sub);margin-top:var(--sp-1)}.page-header-actions{gap:var(--sp-2);align-items:center;display:flex}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-sm);padding:var(--sp-6);margin-bottom:var(--sp-5)}.card-no-pad{padding:0}.card-pad{padding:var(--sp-6)}.card-header{padding:var(--sp-4) var(--sp-6);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--text-md);color:var(--grey-800);font-weight:600}.card-subtitle{font-size:var(--text-xs);color:var(--text-sub);margin-top:2px}.stats-row{gap:var(--sp-4);margin-bottom:var(--sp-5);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-sm);padding:var(--sp-5) var(--sp-6);transition:box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);position:relative;overflow:hidden}.stat-card:before{content:"";opacity:.15;background:currentColor;height:3px;position:absolute;top:0;left:0;right:0}.stat-card:hover{box-shadow:var(--sh);transform:translateY(-1px)}.stat-card-top{margin-bottom:var(--sp-2);justify-content:flex-end;display:flex}.stat-icon-wrap{border-radius:var(--r);opacity:.12;background:currentColor;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.stat-icon-wrap>*{opacity:1}.stat-value{letter-spacing:-.03em;margin-bottom:var(--sp-1);font-size:2.4rem;font-weight:800;line-height:1}.stat-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.07em;color:var(--text-sub);font-weight:600}.stat-trend{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.db-widgets-grid{gap:var(--sp-4);margin-bottom:var(--sp-5);grid-template-columns:1fr 340px;display:grid}.db-widget{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-sm);padding:var(--sp-5) var(--sp-5)}.db-widget-open{padding:var(--sp-5);flex-direction:column;display:flex}.db-widget-side{padding:var(--sp-5)}.db-widget-stack{gap:var(--sp-4);flex-direction:column;display:flex}.db-widget-header{justify-content:space-between;align-items:flex-start;margin-bottom:0;display:flex}.db-kpi-box{flex-direction:column;gap:2px;display:flex}.db-kpi-num{letter-spacing:-.04em;color:var(--text);font-size:2.8rem;font-weight:800;line-height:1}.db-kpi-label{font-size:var(--text-sm);letter-spacing:.09em;text-transform:uppercase;color:var(--text-sub);margin-top:var(--sp-1);font-weight:700}.db-stages-tag{font-size:var(--text-xs);color:var(--text-muted);background:var(--surface-alt,#ffffff0f);border:1px solid var(--border);border-radius:var(--r);padding:3px 10px;font-weight:600}.db-stage-list{gap:var(--sp-3);padding-top:var(--sp-4);flex-direction:row;align-items:flex-start;margin-top:auto;margin-bottom:auto;display:flex}.db-stage-card{background:var(--surface-alt,#ffffff0a);border:1px solid var(--border);border-radius:var(--r);padding:var(--sp-3) var(--sp-4);flex:1;min-width:0}.db-stage-name{font-size:var(--text-sm);color:var(--text-sub);margin-bottom:var(--sp-1);text-transform:uppercase;letter-spacing:.07em;font-weight:700}.db-stage-count{margin-bottom:var(--sp-2);color:var(--text);letter-spacing:-.03em;font-size:1.6rem;font-weight:800;line-height:1}.db-sev-dots{font-size:var(--text-xs);color:var(--text-muted);padding-top:var(--sp-2);flex-wrap:wrap;align-items:center;gap:10px;display:flex}.db-sev-item{cursor:default;align-items:center;gap:4px;display:inline-flex;position:relative}.db-sev-item:after{content:attr(data-label);background:var(--text,#111);color:#fff;white-space:nowrap;pointer-events:none;opacity:0;z-index:10;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600;transition:opacity .15s;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%)}.db-sev-item:hover:after{opacity:1}.db-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.db-dot-high{background:#e03131}.db-dot-medium{background:#e8590c}.db-dot-low{background:#2f9e44}.db-sev-label{color:var(--text-muted)}.db-sev-dots strong{color:var(--text);font-weight:700;font-size:var(--text-sm)}@media (width<=820px){.db-widgets-grid{grid-template-columns:1fr}.db-widget-stack{flex-direction:row}.db-widget-side{flex:1}.db-stage-list{flex-direction:column}}.btn{align-items:center;gap:var(--sp-2);border-radius:var(--r);font-size:var(--text-sm);transition:background var(--dur-fast), color var(--dur-fast), border-color var(--dur-fast), box-shadow var(--dur-fast), opacity var(--dur-fast);cursor:pointer;white-space:nowrap;border:1px solid #0000;padding:8px 16px;font-weight:500;line-height:1.4;display:inline-flex;text-decoration:none!important}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn:focus-visible{outline:2px solid var(--brand-500);outline-offset:2px}.btn-primary{background:var(--brand-500);color:#fff;border-color:var(--brand-500);box-shadow:var(--sh-xs)}.btn-primary:hover{background:var(--brand-600);border-color:var(--brand-600);box-shadow:var(--sh-sm)}.btn-outline{color:var(--brand-500);border-color:var(--brand-200);background:0 0}.btn-outline:hover{background:var(--brand-50);border-color:var(--brand-500)}.btn-ghost{color:var(--grey-700);background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--grey-100)}.btn-danger{background:var(--red-600);color:#fff;border-color:var(--red-600)}.btn-danger:hover{background:var(--red-700);border-color:var(--red-700)}.btn-sm{font-size:var(--text-xs);gap:var(--sp-1);padding:5px 11px}.btn-lg{font-size:var(--text-md);padding:11px 22px}.btn-icon{gap:0;padding:7px}.btn-white{color:var(--brand-600);background:#fff;border-color:#fff;font-weight:600}.btn-white:hover{background:#ffffffeb}.btn-outline-white{color:#fff;background:0 0;border-color:#ffffff73}.btn-outline-white:hover{background:#ffffff1a;border-color:#ffffffbf}.btn-link{color:var(--brand-500);font-size:var(--text-sm);cursor:pointer;background:0 0;border:none;padding:0;text-decoration:underline}.btn-link:hover{color:var(--brand-600)}label{gap:var(--sp-1);font-size:var(--text-sm);color:var(--grey-700);flex-direction:column;font-weight:500;display:flex}input[type=text],input[type=email],input[type=number],input[type=date],input[type=datetime-local],input[type=password],input[type=search],select,textarea{border:1.5px solid var(--border);border-radius:var(--r);background:var(--surface);font-size:var(--text-sm);color:var(--text);transition:border-color var(--dur-fast), box-shadow var(--dur-fast);width:100%;padding:8px 11px;line-height:1.4}input:focus,select:focus,textarea:focus{border-color:var(--brand-500);outline:none;box-shadow:0 0 0 3px #1a5e961f}input::placeholder,textarea::placeholder{color:var(--grey-300)}textarea{resize:vertical;min-height:80px}select{cursor:pointer}.form-card{max-width:880px}.form-grid-2{gap:var(--sp-4);margin-bottom:var(--sp-4);grid-template-columns:1fr 1fr;display:grid}.form-grid-3{gap:var(--sp-4);margin-bottom:var(--sp-4);grid-template-columns:repeat(3,1fr);display:grid}.full-width{margin-bottom:var(--sp-4)}.form-actions{justify-content:flex-end;gap:var(--sp-2);padding-top:var(--sp-4);border-top:1px solid var(--border);margin-top:var(--sp-4);display:flex}.checkbox-label{align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-3);flex-direction:row;font-weight:400}.checkbox-label input[type=checkbox]{width:15px;height:15px;accent-color:var(--brand-500);flex-shrink:0}.input-with-icon{align-items:center;display:flex;position:relative}.input-with-icon .input-icon{color:var(--grey-400);pointer-events:none;position:absolute;left:10px}.input-with-icon select,.input-with-icon input{padding-left:32px}.badge{border-radius:var(--r-full);font-size:var(--text-xs);white-space:nowrap;align-items:center;gap:4px;padding:2px 8px;font-weight:600;line-height:1.6;display:inline-flex}.badge-grey{background:var(--grey-100);color:var(--grey-600)}.badge-blue{background:var(--blue-50);color:var(--blue-700)}.badge-green{background:var(--green-50);color:var(--green-700)}.badge-yellow{background:var(--yellow-50);color:var(--yellow-700)}.badge-orange{background:var(--orange-50);color:var(--orange-700)}.badge-red{background:var(--red-50);color:var(--red-700)}.badge-purple{background:var(--purple-50);color:var(--purple-700)}.badge-default{background:var(--grey-100);color:var(--grey-600)}.badge-outline{background:0 0;border:1px solid}.status-pill{border-radius:var(--r-full);font-size:var(--text-xs);letter-spacing:.01em;align-items:center;gap:5px;padding:3px 9px;font-weight:600;display:inline-flex}.status-pill:before{content:"";opacity:.8;background:currentColor;border-radius:50%;width:5px;height:5px;display:inline-block}.status-draft{background:var(--grey-100);color:var(--grey-600)}.status-open{background:var(--blue-50);color:var(--blue-700)}.status-in_investigation{background:var(--yellow-50);color:var(--yellow-700)}.status-pending_review{background:var(--orange-50);color:var(--orange-700)}.status-closed{background:var(--green-50);color:var(--green-700)}.status-cancelled{background:var(--red-50);color:var(--red-700)}.alert{align-items:flex-start;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-radius:var(--r);font-size:var(--text-sm);margin-bottom:var(--sp-4);border:1px solid #0000;line-height:1.5;display:flex}.alert-icon{flex-shrink:0;margin-top:1px}.alert>span{flex:1}.alert-close{cursor:pointer;border-radius:var(--r-sm);opacity:.6;width:20px;height:20px;transition:opacity var(--dur-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.alert-close:hover{opacity:1}.alert-error{background:var(--red-50);color:var(--red-700);border-color:#fecaca}.alert-success{background:var(--green-50);color:var(--green-700);border-color:#bbf7d0}.alert-warning{background:var(--yellow-50);color:var(--yellow-700);border-color:#fde68a}.alert-info{background:var(--blue-50);color:var(--blue-700);border-color:#bfdbfe}@keyframes spin{to{transform:rotate(360deg)}}.spinner{animation:.8s linear infinite spin;display:block}.loading-center{align-items:center;gap:var(--sp-3);padding:var(--sp-10) 0;color:var(--text-muted);flex-direction:column;display:flex}.empty-state{text-align:center;padding:var(--sp-10) var(--sp-6);align-items:center;gap:var(--sp-3);color:var(--grey-400);flex-direction:column;display:flex}.empty-state-icon{opacity:.4}.empty-state-title{font-size:var(--text-md);color:var(--grey-600);margin:0;font-weight:600}.empty-state-desc{font-size:var(--text-sm);color:var(--text-muted);margin:0}.empty-state-action{margin-top:var(--sp-1)}.table-wrap{overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}.data-table thead{z-index:1;position:sticky;top:0}.data-table th{text-align:left;padding:var(--sp-3) var(--sp-4);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.07em;color:var(--text-sub);background:var(--grey-50);border-bottom:1px solid var(--border);white-space:nowrap;font-weight:600}.data-table td{padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--grey-100);vertical-align:middle}.data-table tbody tr{cursor:pointer;transition:background var(--dur-fast)}.data-table tbody tr:hover{background:var(--brand-50)}.data-table tbody tr:last-child td{border-bottom:none}.cell-mono{font-family:var(--mono);font-size:var(--text-xs);color:var(--grey-500)}.cell-primary{color:var(--grey-800);font-weight:500}.cell-secondary{color:var(--text-sub);text-transform:capitalize}.cell-muted{font-size:var(--text-xs);color:var(--text-muted)}.cell-action{color:var(--grey-300);text-align:right;width:32px}.row-arrow{transition:transform var(--dur-fast), color var(--dur-fast)}.data-table tbody tr:hover .row-arrow{color:var(--brand-500);transform:translate(3px)}.cell-type{text-transform:capitalize}.toolbar{justify-content:space-between;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-4);flex-wrap:wrap;display:flex}.toolbar-left{align-items:center;gap:var(--sp-2);display:flex}.toolbar-count{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;font-weight:500}.tab-bar{border-bottom:2px solid var(--border);margin-bottom:var(--sp-5);gap:0;display:flex;overflow-x:auto}.tab-btn{padding:10px var(--sp-5);cursor:pointer;font-size:var(--text-sm);color:var(--text-sub);transition:color var(--dur-fast), border-color var(--dur-fast);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;font-weight:500}.tab-btn.active{color:var(--brand-500);border-bottom-color:var(--brand-500);font-weight:600}.info-grid{gap:var(--sp-3) var(--sp-4);grid-template-columns:140px 1fr;display:grid}.info-grid dt{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.07em;color:var(--text-sub);padding-top:3px;font-weight:600}.info-grid dd{font-size:var(--text-sm);color:var(--text)}.workflow-actions{gap:var(--sp-2);padding-top:var(--sp-3);border-top:1px solid var(--border);margin-top:var(--sp-3);flex-wrap:wrap;display:flex}.comment-thread{flex-direction:column;display:flex}.comment{padding:var(--sp-3) 0;border-bottom:1px solid var(--grey-100)}.comment:last-child{border-bottom:none}.comment.depth-1{padding-left:var(--sp-6)}.comment.depth-2{padding-left:calc(var(--sp-6) * 2)}.comment.depth-3{padding-left:calc(var(--sp-6) * 3)}.comment-meta{align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-1);display:flex}.comment-meta strong{font-size:var(--text-sm);font-weight:600}.comment-meta span{font-size:var(--text-xs);color:var(--text-muted)}.comment-body{font-size:var(--text-sm);color:var(--grey-700);line-height:1.55}.comment-compose textarea{width:100%;margin-bottom:var(--sp-2)}.attachment-list{gap:var(--sp-2);flex-direction:column;list-style:none;display:flex}.attachment-list li{align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);background:var(--grey-50);border:1px solid var(--border);border-radius:var(--r);font-size:var(--text-sm);display:flex}.attachment-icon{color:var(--brand-500)}.att-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-weight:500;overflow:hidden}.att-meta{font-size:var(--text-xs);flex-shrink:0}.att-error{font-size:var(--text-xs);color:var(--danger,#c92a2a);flex-shrink:0}.att-download-btn{flex-shrink:0;align-items:center;gap:4px;display:inline-flex}.att-actions{flex-shrink:0;align-items:center;gap:6px;margin-left:auto;display:flex}.att-confirm-label{font-size:var(--text-xs);color:var(--danger,#c92a2a);white-space:nowrap;font-weight:600}.att-thumb-btn{border:1px solid var(--border);border-radius:var(--r);cursor:pointer;background:0 0;flex-shrink:0;width:48px;height:48px;padding:0;position:relative;overflow:hidden}.att-thumb{object-fit:cover;width:100%;height:100%;display:block}.att-thumb-zoom{color:#fff;opacity:0;background:#00000059;justify-content:center;align-items:center;transition:opacity .15s;display:flex;position:absolute;inset:0}.att-thumb-btn:hover .att-thumb-zoom{opacity:1}.lightbox-overlay{z-index:9999;cursor:zoom-out;background:#000000d9;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.lightbox-img{object-fit:contain;cursor:default;border-radius:6px;max-width:100%;max-height:100%;box-shadow:0 8px 40px #0009}.lightbox-close{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s;display:flex;position:absolute;top:16px;right:16px}.lightbox-close:hover{background:#ffffff4d}.att-group{margin-bottom:var(--sp-4)}.att-group:last-child{margin-bottom:0}.att-group-title{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.07em;color:var(--text-sub);margin-bottom:var(--sp-2);align-items:center;font-weight:700;display:flex}.lock-notice{border-radius:var(--r);padding:10px var(--sp-4);font-size:var(--text-sm);color:#664d00;align-items:center;gap:var(--sp-2);margin-top:var(--sp-3);background:#fff3cd;border:1px solid #ffca2c;display:flex}.checkbox-label{align-items:center;gap:var(--sp-2);cursor:pointer;flex-direction:row;font-weight:500;display:flex}.checkbox-label input[type=checkbox]{flex-shrink:0;width:16px;height:16px;margin:0}.field-item-full{grid-column:1/-1}.field-editor-list{gap:var(--sp-2);margin-bottom:var(--sp-3);flex-direction:column;display:flex}.field-row-editor{gap:var(--sp-2);background:var(--grey-50);border:1px solid var(--border);border-radius:var(--r);padding:var(--sp-2) var(--sp-3);grid-template-columns:1fr 1fr 110px 1fr 1fr 58px 30px;align-items:center;display:grid}.field-row-editor input,.field-row-editor select{font-size:var(--text-xs);padding:5px 8px}.section-header{margin:var(--sp-5) 0 var(--sp-3);justify-content:space-between;align-items:center;display:flex}.section-title,.section-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text-sub);font-weight:700}.template-section{border:1px solid var(--border);border-radius:var(--r);padding:var(--sp-4);margin-top:var(--sp-4);background:var(--grey-50)}.card-header-row{margin-bottom:var(--sp-4);justify-content:space-between;align-items:center;display:flex}.card-header-row .card-title{margin-bottom:0}.field-grid{gap:var(--sp-4);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));display:grid}.field-item dt{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--text-sub);margin-bottom:2px;font-weight:600}.field-item dd{font-size:var(--text-sm);color:var(--text)}.muted{color:var(--text-muted);font-size:var(--text-sm)}.mt-1{margin-top:var(--sp-1)}.mt-2{margin-top:var(--sp-2)}.mt-3{margin-top:var(--sp-3)}.mt-4{margin-top:var(--sp-4)}.mb-1{margin-bottom:var(--sp-1)}.mb-2{margin-bottom:var(--sp-2)}.text-center{text-align:center}.row-actions{gap:var(--sp-2);justify-content:flex-end;display:flex}.landing{background:linear-gradient(#f4f9ff 0%,#fff 260px);flex-direction:column;min-height:100vh;display:flex}.landing-header{background:linear-gradient(100deg,#05284f 0%,#0b3f79 62%,#0d58a8 100%);border-bottom:1px solid #ffffff24}.landing-header-inner{max-width:1200px;padding:0 var(--sp-8);justify-content:space-between;align-items:center;height:64px;margin:0 auto;display:flex}.landing-brand{align-items:center;gap:var(--sp-4);display:flex}.landing-brand-logo{filter:drop-shadow(0 1px 2px #00000047);width:auto;height:28px;display:block}.landing-brand-icon{color:var(--accent-400)}.landing-brand-name{font-size:var(--text-md);color:#fff;letter-spacing:.02em;font-weight:700;line-height:1.1}.landing-brand-sub{font-size:var(--text-xs);color:#ffffffbd}.landing-header-actions{align-items:center;gap:var(--sp-2);display:flex}.hero{padding:80px var(--sp-8) 72px;background:linear-gradient(148deg,#062447 0%,#0d3f7a 56%,#006ab8 100%);position:relative;overflow:hidden}.hero:before{content:"";pointer-events:none;background:radial-gradient(circle at 30% 30%,#ffffff2e 0%,#ffffff08 58%,#fff0 72%);border-radius:50%;width:600px;height:600px;position:absolute;top:-200px;right:-100px}.hero:after{content:"";pointer-events:none;background:radial-gradient(circle at 62% 40%,#ffffff26 0%,#ffffff05 52%,#fff0 70%);border-radius:50%;width:400px;height:400px;position:absolute;bottom:-150px;left:10%}.hero-inner{text-align:center;z-index:1;max-width:740px;margin:0 auto;position:relative}.hero-eyebrow{align-items:center;gap:var(--sp-2);border-radius:var(--r-full);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:#fffc;margin-bottom:var(--sp-5);background:#ffffff1a;border:1px solid #ffffff26;padding:4px 13px;font-weight:600;display:inline-flex}.hero-eyebrow-logo{filter:drop-shadow(0 1px 1px #0000003d);width:auto;height:14px;display:block}.hero-heading{color:#fff;margin-bottom:var(--sp-5);font-size:clamp(2rem,5vw,3.2rem);font-weight:800;line-height:1.15}.hero-accent{color:var(--accent-400)}.hero-desc{font-size:var(--text-md);color:#ffffffc2;max-width:580px;margin:0 auto var(--sp-8);line-height:1.7}.hero-actions{gap:var(--sp-3);margin-bottom:var(--sp-8);flex-wrap:wrap;justify-content:center;display:flex}.hero-highlights{justify-content:center;gap:var(--sp-2) var(--sp-5);flex-wrap:wrap;margin:0;display:flex}.hero-highlights li{align-items:center;gap:var(--sp-2);font-size:var(--text-xs);color:#fff9;display:flex}.hero-highlights li svg{color:var(--accent-400);flex-shrink:0}.landing-features{background:var(--grey-0);padding:72px var(--sp-8)}.landing-section-inner{max-width:1080px;margin:0 auto}.landing-section-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--brand-500);margin-bottom:var(--sp-2);font-weight:700}.landing-section-heading{color:var(--grey-900);margin-bottom:var(--sp-3);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800}.landing-section-sub{font-size:var(--text-md);color:var(--text-sub);margin-bottom:var(--sp-8)}.features-grid{gap:var(--sp-5);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.feature-card{background:var(--grey-50);border:1.5px solid var(--border);border-radius:var(--r-lg);padding:var(--sp-6);gap:var(--sp-3);transition:border-color var(--dur), box-shadow var(--dur), transform var(--dur);flex-direction:column;display:flex}.feature-card:hover{border-color:var(--grey-300);box-shadow:var(--sh-sm);transform:translateY(-2px)}.feature-card-live{background:var(--grey-0);border-color:var(--brand-200)}.feature-card-live:hover{border-color:var(--brand-500);box-shadow:0 4px 20px #1a5e961a}.feature-icon-wrap{border-radius:var(--r-lg);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.feature-body{flex:1}.feature-card-header{justify-content:space-between;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-2);display:flex}.feature-card-header h3{font-size:var(--text-md);color:var(--grey-800);font-weight:600}.feature-card p{font-size:var(--text-sm);color:var(--text-sub);line-height:1.6}.feature-badge-live{background:var(--green-50);color:var(--green-700);border-radius:var(--r-full);font-size:var(--text-xs);letter-spacing:.03em;padding:2px 9px;font-weight:700}.feature-badge-soon{background:var(--grey-100);color:var(--grey-500);border-radius:var(--r-full);font-size:var(--text-xs);padding:2px 9px;font-weight:600}.feature-link{font-size:var(--text-sm);color:var(--brand-500);cursor:pointer;transition:gap var(--dur-fast);background:0 0;border:none;align-items:center;gap:5px;padding:0;font-weight:500;text-decoration:none;display:inline-flex}.feature-link:hover{gap:8px}.landing-cta{padding:56px var(--sp-8);background:linear-gradient(132deg,#06386a 0%,#0d58a8 62%,#0e78c3 100%)}.cta-inner{justify-content:space-between;align-items:center;gap:var(--sp-6);flex-wrap:wrap;display:flex}.cta-inner h2{font-size:var(--text-2xl);color:#fff;margin-bottom:var(--sp-1);font-weight:700}.cta-inner p{font-size:var(--text-md);color:#ffffffbf}.landing-footer{padding:var(--sp-6) var(--sp-8);background:#031a34;margin-top:auto}.landing-footer-inner{justify-content:space-between;align-items:center;gap:var(--sp-4);flex-wrap:wrap;max-width:1200px;margin:0 auto;display:flex}.landing-footer-brand{align-items:center;gap:var(--sp-2);color:#fff9;font-size:var(--text-sm);font-weight:500;display:flex}.landing-footer-logo{opacity:.9;width:auto;height:14px;display:block}.landing-footer p{font-size:var(--text-xs);color:#ffffff4d}@media (width<=900px){.portal{flex-direction:column}.sidebar{flex-direction:row;width:100%;height:auto;position:relative;overflow-x:auto}.sidebar-brand{padding:var(--sp-3) var(--sp-4);border-bottom:none;border-right:1px solid #ffffff12;flex-shrink:0}.sidebar-tagline{display:none}.sidebar-nav{padding:var(--sp-2);display:flex;overflow-x:auto}.sidebar-nav ul{gap:var(--sp-1);flex-direction:row}.nav-link{padding:7px var(--sp-3);white-space:nowrap}.nav-link-active:before,.nav-chevron,.sidebar-footer{display:none}.page-content{padding:var(--sp-4)}.form-grid-2,.form-grid-3{grid-template-columns:1fr}.field-row-editor{grid-template-columns:1fr 1fr}.hero{padding:48px var(--sp-5) 40px}.landing-header-inner,.landing-features .landing-section-inner,.landing-footer-inner{padding-left:var(--sp-4);padding-right:var(--sp-4)}.cta-inner{text-align:center;flex-direction:column}.info-grid{grid-template-columns:100px 1fr}}@media (width<=600px){.stats-row{grid-template-columns:1fr 1fr}.features-grid{grid-template-columns:1fr}.hero-actions{flex-direction:column;align-items:stretch}.page-header{flex-direction:column;align-items:flex-start}}.info-row{border-bottom:1px solid var(--grey-100);gap:var(--sp-4);font-size:var(--text-sm);grid-template-columns:140px 1fr;align-items:baseline;padding:6px 0;display:grid}.info-row:last-child{border-bottom:none}.info-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.07em;color:var(--text-sub);font-weight:600}.field-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--text-sub);margin-bottom:2px;font-weight:600;display:block}.field-value{font-size:var(--text-sm);color:var(--text);display:block}.tab-bar{border-bottom:2px solid var(--grey-100);margin-bottom:var(--sp-4);gap:4px;display:flex}.tab-btn{cursor:pointer;font-size:var(--text-sm);color:var(--text-sub);background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-2px;padding:8px 16px;font-weight:500;transition:color .15s,border-color .15s;display:inline-flex}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.tab-count{background:var(--grey-100);color:var(--text-sub);font-size:var(--text-xs);border-radius:10px;justify-content:center;align-items:center;padding:1px 7px;font-weight:600;display:inline-flex}.audit-subtabs{margin:var(--sp-2) 0 var(--sp-3);align-items:center;gap:6px;display:inline-flex}.audit-subtab-btn{border:1px solid var(--grey-200,#e0e0e0);background:var(--surface);color:var(--text-sub);font-size:var(--text-xs);cursor:pointer;border-radius:999px;padding:4px 10px;font-weight:600}.audit-subtab-btn:hover{border-color:var(--grey-300);color:var(--text)}.audit-subtab-btn.active{border-color:var(--primary);background:var(--primary-light,#e7f5ff);color:var(--primary)}.audit-timeline{padding:var(--sp-2) 0;flex-direction:column;gap:0;display:flex}.audit-event{gap:0 var(--sp-3);padding-bottom:var(--sp-4);grid-template-columns:32px 1fr;display:grid;position:relative}.audit-event:before{content:"";background:var(--grey-100);width:2px;position:absolute;top:16px;bottom:0;left:15px}.audit-event:last-child:before{display:none}.audit-dot{background:var(--primary);z-index:1;border-radius:50%;flex-shrink:0;justify-self:center;width:12px;height:12px;margin-top:4px;position:relative}.audit-event-flagged .audit-dot{background:#d9480f;box-shadow:0 0 0 3px #fff3bf}.audit-content{padding-top:2px}.audit-header{align-items:baseline;gap:var(--sp-3);flex-wrap:wrap;display:flex}.audit-type{font-size:var(--text-sm);color:var(--text);text-transform:capitalize;font-weight:600}.audit-time{font-size:var(--text-xs);color:var(--text-muted)}.audit-transition{align-items:center;gap:var(--sp-2);margin-top:4px;display:inline-flex}.audit-actor{font-size:var(--text-xs);color:var(--text-sub);align-items:center;gap:4px;margin-top:4px;display:inline-flex}.audit-flag-badge{color:#e67700;background:#fff3bf;border-radius:999px;align-items:center;gap:4px;margin-left:8px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-flex}.audit-meta-list{font-size:var(--text-xs);color:var(--text-sub);margin-top:4px}.audit-reason{font-size:var(--text-sm);color:var(--text-sub);margin-top:4px;font-style:italic}.modal-overlay{z-index:1000;padding:var(--sp-4);background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-box{background:var(--surface);border-radius:var(--radius-lg);padding:var(--sp-6);width:100%;max-width:460px;box-shadow:0 20px 60px #0003}.modal-title{font-size:var(--text-lg);color:var(--text);margin-bottom:var(--sp-3);font-weight:700}.modal-body{font-size:var(--text-sm);color:var(--text-sub);margin-bottom:var(--sp-3);line-height:1.6}.modal-actions{gap:var(--sp-3);margin-top:var(--sp-4);justify-content:flex-end;display:flex}.required{color:var(--danger,#c92a2a)}.comment-avatar{color:var(--text-muted);flex-shrink:0}.comment-author{font-size:var(--text-sm);color:var(--text);font-weight:600}.comment-role{font-size:var(--text-xs);background:var(--grey-50,#f8f9fa);border:1px solid var(--grey-200,#e0e0e0);border-radius:4px;padding:1px 6px}.compose-toolbar{align-items:center;gap:var(--sp-2);margin-top:var(--sp-2);flex-wrap:wrap;display:flex}.compose-attach{gap:4px}.text-danger{color:var(--danger,#c92a2a)}.badge-warn{font-size:var(--text-xs)}.topbar{padding:0 var(--sp-6);background:var(--surface);border-bottom:1px solid var(--grey-100);flex-shrink:0;justify-content:flex-end;align-items:center;height:52px;display:flex}.topbar-right{align-items:center;gap:var(--sp-3);display:flex}.tz-btn{background:var(--grey-50,#f8f9fa);border:1px solid var(--grey-200,#e0e0e0);border-radius:var(--radius);font-size:var(--text-sm);cursor:pointer;color:var(--text);white-space:nowrap;align-items:center;gap:6px;padding:6px 12px;transition:background .15s,border-color .15s;display:inline-flex}.tz-btn:hover{background:var(--grey-100);border-color:var(--grey-300)}.tz-name{font-size:var(--text-xs);color:var(--text-sub);text-overflow:ellipsis;max-width:140px;overflow:hidden}.tz-picker{position:relative}.tz-dropdown{background:var(--surface);border:1px solid var(--grey-200,#e0e0e0);border-radius:var(--radius-lg);z-index:500;flex-direction:column;min-width:220px;max-height:320px;display:flex;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden;box-shadow:0 8px 24px #0000001f}.tz-dropdown-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:10px 14px 6px;font-weight:700}.tz-list{flex:1;padding:4px;overflow-y:auto}.tz-option{text-align:left;cursor:pointer;width:100%;font-size:var(--text-sm);color:var(--text);border-radius:var(--radius);background:0 0;border:none;padding:8px 12px;transition:background .1s;display:block}.tz-option:hover{background:var(--grey-50,#f8f9fa)}.tz-option-active{background:var(--primary-light,#e7f5ff);color:var(--primary);font-weight:600}.tz-badge{font-size:var(--text-xs);color:var(--primary);background:var(--primary-light,#e7f5ff);vertical-align:middle;border-radius:4px;align-items:center;margin-left:6px;padding:1px 6px;font-weight:600;display:inline-flex}.template-banner{align-items:center;gap:var(--sp-3);background:var(--grey-50,#f8f9fa);border:1px solid var(--grey-200,#e0e0e0);border-radius:var(--radius);padding:var(--sp-3) var(--sp-4);margin-bottom:var(--sp-5);flex-wrap:wrap;display:flex}.template-banner-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.07em;color:var(--text-sub);font-weight:700}.template-select{flex:1;min-width:200px}.form-grid-full{grid-column:1/-1}.attach-section{gap:var(--sp-2);flex-direction:column;grid-column:1/-1;display:flex}.attach-header{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.07em;color:var(--text-sub);font-weight:700;display:block}.pending-files{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.pending-file{align-items:center;gap:var(--sp-3);background:var(--grey-50,#f8f9fa);border:1px solid var(--grey-100);border-radius:var(--radius);font-size:var(--text-sm);padding:8px 10px;display:flex}.pending-file-name{text-overflow:ellipsis;white-space:nowrap;color:var(--text);flex:1;overflow:hidden}.pending-file-size{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap}.options-editor{gap:var(--sp-2);flex-direction:column;display:flex}.option-chips{flex-wrap:wrap;gap:6px;min-height:28px;display:flex}.option-chip{background:var(--primary-light,#e7f5ff);color:var(--primary);font-size:var(--text-sm);border-radius:14px;align-items:center;gap:4px;padding:3px 10px 3px 12px;font-weight:500;display:inline-flex}.option-chip-remove{color:currentColor;cursor:pointer;opacity:.7;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;padding:0;font-size:14px;line-height:1;transition:opacity .15s;display:inline-flex}.option-chip-remove:hover{opacity:1}.option-add-row{gap:6px;display:flex}.option-add-input{flex:1}.filter-panel{margin-bottom:var(--sp-4)}.filter-grid{gap:var(--sp-3) var(--sp-4);grid-template-columns:repeat(3,1fr);display:grid}@media (width<=900px){.filter-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.filter-grid{grid-template-columns:1fr}}.filter-badge{background:var(--primary);color:#fff;border-radius:10px;justify-content:center;align-items:center;min-width:18px;height:18px;margin-left:4px;padding:0 5px;font-size:11px;font-weight:700;display:inline-flex}.perm-group{margin-bottom:var(--sp-6)}.perm-group-title{font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.07em;color:var(--text-sub);margin-bottom:var(--sp-3);font-weight:700}.perm-table-wrap{overflow-x:auto}.perm-table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}.perm-table th,.perm-table td{border:1px solid var(--grey-100);text-align:center;padding:10px 12px}.perm-table th{background:var(--grey-50,#f8f9fa);color:var(--text-sub);font-weight:600;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em}.perm-action-col{text-align:left!important}.perm-role-col{min-width:96px}.perm-action-label{color:var(--text);font-weight:500}.perm-cell input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:var(--primary)}.perm-cell input[type=checkbox]:disabled{cursor:not-allowed;opacity:.6}.notif-bell-wrap{position:relative}.notif-bell-btn{border:1px solid var(--grey-200,#e0e0e0);cursor:pointer;width:36px;height:36px;color:var(--text-sub);background:0 0;border-radius:50%;justify-content:center;align-items:center;transition:background .15s,border-color .15s;display:inline-flex;position:relative}.notif-bell-btn:hover{background:var(--grey-50,#f8f9fa);border-color:var(--grey-300)}.notif-bell-badge{background:var(--danger,#c92a2a);color:#fff;border:2px solid var(--surface);pointer-events:none;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-4px;right:-4px}.notif-dropdown{background:var(--surface);border:1px solid var(--grey-200,#e0e0e0);border-radius:var(--radius-lg);z-index:600;flex-direction:column;width:360px;max-width:calc(100vw - 16px);display:flex;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 12px 40px #00000026}.notif-dropdown-header{border-bottom:1px solid var(--grey-100);justify-content:space-between;align-items:center;padding:12px 16px 10px;display:flex}.notif-dropdown-title{font-size:var(--text-sm);color:var(--text);font-weight:700}.notif-mark-all{font-size:var(--text-xs);color:var(--primary);cursor:pointer;background:0 0;border:none;align-items:center;padding:0;display:inline-flex}.notif-mark-all:hover{text-decoration:underline}.btn-link{cursor:pointer;color:var(--primary);font-size:var(--text-xs);background:0 0;border:none;padding:0}.btn-link:hover{text-decoration:underline}.notif-dropdown-list{max-height:340px;overflow-y:auto}.notif-dropdown-footer{border-top:1px solid var(--grey-100);text-align:center;padding:10px 16px}.notif-empty{text-align:center;color:var(--text-muted);font-size:var(--text-sm);margin:0;padding:24px 16px}.notif-dd-item{cursor:pointer;border-bottom:1px solid var(--grey-50,#f8f9fa);align-items:flex-start;gap:10px;padding:11px 16px;transition:background .1s;display:flex}.notif-dd-item:last-child{border-bottom:none}.notif-dd-item:hover{background:var(--grey-50,#f8f9fa)}.notif-dd-item-unread{background:var(--primary-light,#e7f5ff)}.notif-dd-item-unread:hover{background:#d0eaff}.notif-dd-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;margin-top:1px;display:flex}.notif-dd-icon-assignment{color:#1971c2;background:#e7f5ff}.notif-dd-icon-status_change{color:#e67700;background:#fff3bf}.notif-dd-icon-workflow_regression{color:#d9480f;background:#fff4e6}.notif-dd-icon-escalation{color:#c92a2a;background:#fff5f5}.notif-dd-icon-comment{color:#2f9e44;background:#ebfbee}.notif-dd-content{flex:1;min-width:0}.notif-dd-title{font-size:var(--text-sm);color:var(--text);font-weight:500;line-height:1.3}.notif-dd-msg{font-size:var(--text-xs);color:var(--text-sub);text-overflow:ellipsis;white-space:nowrap;margin-top:2px;overflow:hidden}.notif-dd-time{font-size:var(--text-xs);color:var(--text-muted);margin-top:3px}.notif-unread-dot{background:var(--primary);border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:6px}.notif-filter-bar{margin-bottom:var(--sp-4)}.notif-list{padding:0;overflow:hidden}.notif-item{cursor:pointer;border-bottom:1px solid var(--grey-100);align-items:flex-start;gap:12px;padding:14px 20px;transition:background .1s;display:flex}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--grey-50,#f8f9fa)}.notif-item-unread{background:var(--primary-light,#e7f5ff)}.notif-item-unread:hover{background:#d0eaff}.notif-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.notif-icon-assignment{color:#1971c2;background:#e7f5ff}.notif-icon-status_change{color:#e67700;background:#fff3bf}.notif-icon-workflow_regression{color:#d9480f;background:#fff4e6}.notif-icon-escalation{color:#c92a2a;background:#fff5f5}.notif-icon-comment{color:#2f9e44;background:#ebfbee}.notif-body{flex:1;min-width:0}.notif-title{font-size:var(--text-sm);color:var(--text);font-weight:600}.notif-message{font-size:var(--text-sm);color:var(--text-sub);margin-top:2px}.notif-meta{align-items:center;gap:var(--sp-3);margin-top:4px;display:flex}.notif-type-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-weight:600}.notif-mark-btn{background:var(--surface);border:1px solid var(--grey-200,#e0e0e0);border-radius:var(--radius);font-size:var(--text-xs);cursor:pointer;color:var(--text-sub);white-space:nowrap;align-items:center;padding:4px 8px;transition:background .1s,color .1s;display:inline-flex}.notif-mark-btn:hover{background:var(--primary-light,#e7f5ff);color:var(--primary);border-color:var(--primary)}.assignees-list{margin:0 0 var(--sp-4);flex-direction:column;gap:8px;padding:0;list-style:none;display:flex}.assignee-item{background:var(--grey-50,#f8f9fa);border:1px solid var(--grey-100);border-radius:var(--radius);align-items:flex-start;gap:12px;padding:10px 14px;display:flex}.assignee-avatar{background:var(--primary);color:#fff;width:36px;height:36px;font-size:var(--text-sm);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.assignee-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.assignee-name{font-size:var(--text-sm);color:var(--text);font-weight:600}.assignee-meta{font-size:var(--text-xs);color:var(--text-muted)}.assignee-note{font-size:var(--text-xs);color:var(--text-sub);font-style:italic}.assignee-form{border-top:1px solid var(--grey-100);padding-top:var(--sp-4);margin-top:var(--sp-2)}.assignee-form-title{font-size:var(--text-sm);color:var(--text);margin-bottom:var(--sp-3);font-weight:700}.assignee-typeahead{position:relative}.assignee-typeahead-dropdown{z-index:40;background:var(--surface);border:1px solid var(--grey-200,#e0e0e0);border-radius:var(--r);box-shadow:var(--sh-sm);max-height:220px;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow-y:auto}.assignee-typeahead-option{text-align:left;width:100%;font-size:var(--text-sm);color:var(--text);background:0 0;border:none;padding:8px 10px}.assignee-typeahead-option:hover{background:var(--grey-50,#f8f9fa)}.btn-danger-outline{border-color:var(--danger,#c92a2a);color:var(--danger,#c92a2a)}.btn-danger-outline:hover{background:var(--danger,#c92a2a);color:#fff}.topbar-logout-btn{border:1px solid var(--grey-200,#e0e0e0);border-radius:var(--radius);font-size:var(--text-sm);cursor:pointer;color:var(--text-sub);white-space:nowrap;background:0 0;align-items:center;gap:6px;padding:6px 12px;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.topbar-logout-btn:hover{color:var(--danger,#c92a2a);background:#fff5f5;border-color:#ffa8a8}.access-denied-page{background:var(--bg,#f8f9fa);min-height:100vh;padding:var(--sp-6);justify-content:center;align-items:center;display:flex}.access-denied-card{background:var(--surface);border:1px solid var(--grey-200,#e0e0e0);border-radius:var(--radius-lg);text-align:center;width:100%;max-width:480px;padding:3rem 2.5rem;box-shadow:0 8px 30px #00000014}.access-denied-icon{color:var(--danger,#c92a2a);margin-bottom:1.25rem}.access-denied-title{color:var(--text);margin-bottom:.75rem;font-size:1.5rem;font-weight:800}.access-denied-reason{font-size:var(--text-sm);color:var(--danger,#c92a2a);border-radius:var(--radius);background:#fff5f5;border:1px solid #ffa8a8;margin-bottom:1rem;padding:10px 14px;line-height:1.5}.access-denied-help{font-size:var(--text-sm);color:var(--text-sub);margin-bottom:1.5rem;line-height:1.6}.users-page{gap:var(--sp-6);flex-direction:column;display:flex}.users-loading{justify-content:center;padding:3rem;display:flex}.users-table-wrapper{border:1px solid var(--grey-100);border-radius:var(--radius-lg);background:var(--surface);overflow-x:auto}.users-table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}.users-table thead tr{border-bottom:1px solid var(--grey-100);background:var(--grey-50,#f8f9fa)}.users-table th{text-align:left;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);white-space:nowrap;padding:12px 16px;font-weight:700}.users-table th.text-right{text-align:right}.users-table td{border-bottom:1px solid var(--grey-50,#f8f9fa);vertical-align:middle;color:var(--text);padding:12px 16px}.users-table td.text-right{text-align:right}.users-table tbody tr:last-child td{border-bottom:none}.users-table tbody tr:hover td{background:var(--grey-50,#f8f9fa)}.user-cell{align-items:center;gap:10px;display:flex}.user-avatar{color:#fff;width:34px;height:34px;font-size:var(--text-xs);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.user-name{color:var(--text);font-weight:600}.role-badge{font-size:var(--text-xs);background:var(--primary-light,#e7f5ff);color:var(--primary);border-radius:999px;padding:2px 10px;font-weight:600;display:inline-block}.ip-address{font-family:monospace;font-size:var(--text-xs);color:var(--text-sub)}.last-login{color:var(--text-sub)}.login-count{text-align:center;background:var(--grey-50,#f8f9fa);border:1px solid var(--grey-100);border-radius:var(--radius);min-width:28px;font-size:var(--text-xs);color:var(--text-sub);padding:2px 8px;font-weight:700;display:inline-block}.ca-list{gap:var(--sp-3);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.ca-item{background:var(--grey-50,#f8f9fa);border:1px solid var(--grey-100);border-radius:var(--radius);padding:.75rem 1rem}.ca-item-header{align-items:center;gap:var(--sp-2);flex-wrap:wrap;display:flex}.ca-status-badge{font-size:var(--text-xs);color:#fff;white-space:nowrap;border-radius:999px;flex-shrink:0;padding:2px 10px;font-weight:700;display:inline-block}.ca-title{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-weight:600;overflow:hidden}.ca-due{font-size:var(--text-xs);border-radius:var(--radius);flex-shrink:0;padding:2px 8px}.ca-due-ok{color:#2f9e44;background:#ebfbee}.ca-due-overdue{color:#c92a2a;background:#fff5f5;font-weight:700}.ca-item-actions{align-items:center;gap:var(--sp-1);flex-shrink:0;margin-left:auto;display:flex}.ca-desc{font-size:var(--text-sm);color:var(--text-sub);margin:.4rem 0 .2rem;line-height:1.5}.ca-meta{font-size:var(--text-xs);flex-wrap:wrap;gap:1rem;margin-top:.3rem;display:flex}.ca-meta span{align-items:center;gap:4px;display:inline-flex}.ca-form{border:1px solid var(--primary-light,#e7f5ff);border-radius:var(--radius);background:var(--surface);padding:1rem}.ca-status-select{font-size:var(--text-sm);border:1px solid var(--grey-100);border-radius:var(--radius);background:var(--surface);color:var(--text);padding:3px 6px}.card-inset{background:var(--grey-50,#f8f9fa);border:1px dashed var(--grey-200,#e0e0e0);border-radius:var(--radius);padding:1rem}.reports-page{gap:var(--sp-4);flex-direction:column;display:flex}.reports-summary-grid{gap:var(--sp-3);grid-template-columns:repeat(4,minmax(0,1fr));display:grid}.reports-kpi-card{border:1px solid var(--grey-100);border-radius:var(--radius);background:linear-gradient(180deg, #fff 0%, var(--grey-50,#f8f9fa) 100%);flex-direction:column;gap:4px;padding:.85rem 1rem;display:flex}.reports-kpi-success{background:linear-gradient(#f8fff9 0%,#eefaf1 100%);border-color:#c3e6cb}.reports-kpi-warn{background:linear-gradient(#fffdf6 0%,#fff7e6 100%);border-color:#ffe8b0}.reports-kpi-danger{background:linear-gradient(snow 0%,#fff0f0 100%);border-color:#ffc9c9}.reports-kpi-label{font-size:var(--text-xs);color:var(--text-sub);text-transform:uppercase;letter-spacing:.04em;font-weight:700}.reports-kpi-value{color:var(--text);font-size:1.45rem;line-height:1.2}.reports-grid{gap:var(--sp-4);grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);align-items:start;display:grid}.reports-card{gap:var(--sp-2);flex-direction:column;display:flex}.reports-section-head{justify-content:space-between;align-items:flex-start;gap:var(--sp-3);display:flex}.reports-subcopy{font-size:var(--text-xs);max-width:48ch;margin-top:2px}.reports-actions-row{justify-content:space-between;align-items:end;gap:var(--sp-3);margin-top:var(--sp-3);display:flex}.reports-format-select{min-width:210px}.reports-job-filter-row{gap:var(--sp-3);align-items:end;display:flex}.reports-job-filter-row label{min-width:180px}.reports-inline-actions{align-items:center;gap:var(--sp-2);flex-wrap:wrap;display:flex}.reports-config-panel{background:linear-gradient(180deg, #fff 0%, var(--grey-50,#f8f9fa) 100%)}.reports-config-grid{gap:var(--sp-2);grid-template-columns:repeat(3,minmax(0,1fr));display:grid}.reports-config-label{font-size:var(--text-xs)}.reports-config-value{font-size:var(--text-sm);color:var(--text);margin-top:2px;font-weight:700}.reports-dryrun-toggle{white-space:normal;text-align:right;min-width:0;max-width:100%;margin-left:auto;line-height:1.25}.reports-table tbody tr{cursor:default}.reports-error-cell{white-space:nowrap;text-overflow:ellipsis;max-width:220px;color:var(--red-700);font-size:var(--text-xs);overflow:hidden}.reports-retention-dryrun{align-self:center;margin-bottom:0}.reports-history-head{justify-content:space-between;align-items:center;gap:var(--sp-2);margin-top:var(--sp-2);display:flex}.reports-retention-table-wrap{max-height:420px;overflow-y:auto}.reports-settings-grid{gap:var(--sp-3);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}@media (width<=1140px){.reports-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.reports-grid,.reports-settings-grid{grid-template-columns:1fr}}@media (width<=820px){.reports-summary-grid{grid-template-columns:1fr}.reports-section-head,.reports-actions-row{flex-direction:column;align-items:stretch}.reports-format-select{min-width:100%}.reports-job-filter-row,.reports-inline-actions{flex-direction:column;align-items:stretch}.reports-dryrun-toggle{text-align:left;margin-left:0}.reports-history-head{flex-direction:column;align-items:flex-start}.reports-config-grid{grid-template-columns:1fr}}
