:root{--surface:#fff;--surface-subtle:#f4f7f5;--surface-muted:#f0f4f2;--border:#dfe7e2;--text:#17231f;--text-muted:#66766f;--text-soft:#8a9992;--green:#178860;--blue:#185fa5;--amber:#c97b00;--red:#b83232;color:var(--text);background:var(--surface-subtle);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Avenir Next,Avenir,Trebuchet MS,Segoe UI,sans-serif}*{box-sizing:border-box}html{background:var(--surface-subtle);min-width:320px}body{min-width:320px;min-height:100vh;margin:0}button,input{font:inherit}button{-webkit-tap-highlight-color:transparent}h1,h2,p{margin:0}#root{min-height:100vh}.app-shell{background:var(--surface-subtle);grid-template-columns:248px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;display:flex}.brand{border-bottom:1px solid var(--border);align-items:center;gap:11px;min-height:72px;padding:16px 18px;display:flex}.brand-mark,.avatar{color:#fff;background:var(--green);place-items:center;display:grid}.brand-mark{border-radius:8px;width:34px;height:34px;font-weight:700}.brand-name{color:var(--text);font-weight:700}.brand-subtitle,.avatar-copy small,.kpi-card small,td:first-child,td:last-child{color:var(--text-muted)}.nav{flex:1;padding:14px 10px}.nav-section{color:var(--text-soft);letter-spacing:.08em;text-transform:uppercase;margin:14px 10px 6px;font-size:.68rem;font-weight:700;display:block}.nav-item{width:100%;min-height:38px;color:var(--text-muted);font:inherit;text-align:left;cursor:pointer;background:0 0;border:0;border-radius:7px;align-items:center;gap:10px;padding:8px 10px;font-size:.9rem;text-decoration:none;display:flex}.nav-item:hover,.nav-item.is-active{color:var(--green);background:#e7f4ee}.nav-badge{color:#fff;background:var(--amber);text-align:center;border-radius:999px;min-width:24px;margin-left:auto;padding:2px 7px;font-size:.68rem}.nav-badge.red{background:var(--red)}.sidebar-footer{border-top:1px solid var(--border);align-items:center;gap:10px;min-height:68px;padding:14px;display:flex}.mobile-close{margin-left:auto;display:none}.sidebar-backdrop{display:none}.avatar{border-radius:999px;flex:none;width:34px;height:34px;font-size:.8rem;font-weight:700}.avatar-copy{min-width:0;color:var(--text);flex:1;gap:2px;font-size:.82rem;display:grid}.main{flex-direction:column;min-width:0;display:flex}.topbar{background:var(--surface);border-bottom:1px solid var(--border);align-items:center;gap:12px;height:64px;padding:0 22px;display:flex}.topbar h1{color:var(--text);flex:1;font-size:1.05rem;line-height:1}.mobile-menu{display:none}.search-field{border:1px solid var(--border);background:var(--surface-muted);width:min(340px,35vw);height:36px;color:var(--text-muted);border-radius:7px;align-items:center;gap:8px;padding:0 12px;display:flex}.search-field input{min-width:0;color:var(--text);font:inherit;background:0 0;border:0;outline:0;flex:1;font-size:.82rem}.icon-button,.mobile-menu{border:1px solid var(--border);background:var(--surface);width:36px;height:36px;color:var(--text-muted);cursor:pointer;border-radius:7px;place-items:center;display:grid}.has-dot{position:relative}.has-dot:after{content:"";border:2px solid var(--surface);background:var(--red);border-radius:50%;width:7px;height:7px;position:absolute;top:8px;right:8px}.content{min-width:0;padding:22px}.page-header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;display:flex}.page-header h2{color:var(--text);font-size:1.45rem}.eyebrow{color:var(--green);letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px;font-size:.74rem;font-weight:800}.empty-panel{text-align:center;place-content:center;gap:8px;min-height:220px;display:grid}.empty-panel strong{color:var(--text);font-size:1rem}.empty-panel span{color:var(--text-muted)}.empty-action{margin-top:12px}.skeleton-block{gap:10px;display:grid}.skeleton-block span,.skeleton-card{background:linear-gradient(90deg,#edf2ef 25%,#f8fbf9 50%,#edf2ef 75%) 0 0/200% 100%;animation:1.1s linear infinite shimmer;overflow:hidden}.skeleton-block span{border-radius:999px;height:14px}.skeleton-block span:first-child{width:54%}.skeleton-card{min-height:150px}.kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px;display:grid}.kpi-card,.panel{border:1px solid var(--border);background:var(--surface);border-radius:8px}.kpi-card{gap:8px;padding:16px;display:grid}.kpi-card span{color:var(--text-muted);align-items:center;gap:7px;font-size:.78rem;display:flex}.kpi-card strong{color:var(--text);font-size:1.8rem;line-height:1}.positive{color:var(--green)!important}.warning{color:var(--amber)!important}.dashboard-grid{grid-template-columns:minmax(0,1fr) 340px;gap:14px;margin-bottom:14px;display:grid}.bottom-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.side-stack{gap:14px;display:grid}.panel{min-width:0;padding:16px}.panel-head{justify-content:space-between;align-items:center;gap:12px;min-height:28px;margin-bottom:12px;display:flex}.panel-head h2{color:var(--text);font-size:.92rem}.panel-head button,.panel-head a{color:var(--green);font:inherit;cursor:pointer;background:0 0;border:0;font-size:.78rem;text-decoration:none}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:760px}th,td{border-bottom:1px solid var(--border);text-align:left;white-space:nowrap;padding:11px 9px;font-size:.82rem}th{color:var(--text-muted);font-size:.72rem;font-weight:700}tbody tr:last-child td{border-bottom:0}.service-pill{color:var(--text-muted);align-items:center;gap:7px;display:inline-flex}.table-link{color:var(--green);font-weight:800;text-decoration:none}.icon-link{width:30px;height:30px;color:var(--green);border-radius:7px;place-items:center;text-decoration:none;display:inline-grid}.icon-link:hover{background:#e7f4ee}.service-pill i{border-radius:50%;width:7px;height:7px}.badge{border-radius:999px;align-items:center;padding:3px 9px;font-size:.72rem;font-weight:700;display:inline-flex}.badge-green{color:var(--green);background:#e8f4ef}.badge-amber{color:var(--amber);background:#fff4de}.badge-orange{color:#b85d00;background:#fff0e6}.badge-violet{color:#534ab7;background:#eeedfe}.badge-blue{color:var(--blue);background:#e6f1fb}.badge-red{color:var(--red);background:#fcebeb}.badge-gray{background:var(--surface-muted);color:var(--text-muted)}.table-select{border:1px solid var(--border);background:var(--surface);min-width:150px;color:var(--text);font:inherit;border-radius:12px;padding:8px 10px}.card-actions{flex-wrap:wrap;gap:10px;margin-top:12px;display:flex}.danger-button{color:var(--red);border-color:#e24b4a59}.danger-button:disabled{cursor:not-allowed;opacity:.55}.chart-box{height:180px}.quick-stats{gap:8px;display:grid}.quick-stats span{background:var(--surface-muted);color:var(--text-muted);border-radius:7px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;font-size:.82rem;display:flex}.quick-stats strong,.service-row b{color:var(--text)}.list{display:grid}.list-item{border-bottom:1px solid var(--border);align-items:center;gap:11px;min-height:54px;padding:10px 0;display:flex}.list-item:last-child{border-bottom:0}.list-item div{flex:1;gap:2px;min-width:0;display:grid}.list-item strong{color:var(--text);font-size:.84rem;font-weight:600}.list-item small{color:var(--text-muted);font-size:.74rem}.tone-icon{border-radius:7px;flex:none;place-items:center;width:34px;height:34px;display:grid}.tone-icon.green{color:var(--green);background:#e8f4ef}.tone-icon.amber{color:var(--amber);background:#fff4de}.tone-icon.violet{color:#534ab7;background:#eeedfe}.tone-icon.blue{color:var(--blue);background:#e6f1fb}.tone-icon.red{color:var(--red);background:#fcebeb}.unread-dot{background:var(--red);border-radius:50%;flex:none;width:7px;height:7px}.data-table{gap:12px;display:grid}.table-empty{border-top:1px solid var(--border);color:var(--text-muted);text-align:center;padding:34px}.skeleton-line{background:linear-gradient(90deg, var(--surface-muted), #e7eee9, var(--surface-muted));background-size:200% 100%;border-radius:999px;width:min(120px,80%);height:12px;animation:1.3s ease-in-out infinite shimmer;display:block}.pagination{color:var(--text-muted);justify-content:flex-end;align-items:center;gap:12px;font-size:.82rem;display:flex}.pagination button,.secondary-button{border:1px solid var(--border);background:var(--surface);min-height:34px;color:var(--text);cursor:pointer;border-radius:7px;justify-content:center;align-items:center;gap:8px;padding:0 12px;display:inline-flex}.pagination button:disabled,.secondary-button:disabled,.danger-button:disabled{cursor:not-allowed;opacity:.6}.dialog-backdrop{z-index:50;background:#0c18126b;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.confirm-dialog{border:1px solid var(--border);background:var(--surface);border-radius:8px;gap:12px;width:min(420px,100%);padding:20px;display:grid}.confirm-dialog h2{color:var(--text);font-size:1.1rem}.confirm-dialog p{color:var(--text-muted)}.service-dialog{border:1px solid var(--border);background:var(--surface);border-radius:10px;gap:14px;width:min(520px,100%);padding:20px;display:grid;box-shadow:0 22px 60px #0c181238}.dialog-title-row{justify-content:space-between;align-items:flex-start;gap:14px;display:flex}.service-dialog h2{color:var(--text);font-size:1.2rem}.service-dialog label{color:var(--text);gap:7px;font-size:.82rem;font-weight:800;display:grid}.service-dialog input,.service-dialog textarea,.service-dialog select{border:1px solid var(--border);background:var(--surface);width:100%;min-height:40px;color:var(--text);font:inherit;border-radius:7px;padding:8px 10px}.service-dialog textarea{resize:vertical}.request-dialog{width:min(860px,100%);max-height:min(860px,92vh);overflow-y:auto}.request-form{gap:14px;display:grid}.category-list{gap:8px;max-height:220px;padding-right:4px;display:grid;overflow-y:auto}.category-row{border:1px solid var(--border);background:var(--surface-muted);width:100%;min-height:56px;color:var(--text-muted);font:inherit;text-align:left;cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}.category-row:hover{color:var(--green);background:#f7fbf9;border-color:#17886073}.category-row span{gap:2px;min-width:0;display:grid}.category-row strong{color:var(--text);font-size:.86rem}.category-row small{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:.74rem;overflow:hidden}.dialog-actions{justify-content:flex-end;gap:10px;margin-top:8px;display:flex}.danger-button{background:var(--red);color:#fff;cursor:pointer;border:0;border-radius:7px;min-height:34px;padding:0 12px}.header-actions{align-items:center;gap:10px;display:flex}.primary-link-button{background:var(--green);color:#fff;min-height:38px;font:inherit;cursor:pointer;border:0;border-radius:7px;justify-content:center;align-items:center;gap:8px;padding:0 14px;font-weight:800;text-decoration:none;display:inline-flex}.primary-link-button:disabled{cursor:not-allowed;opacity:.72}.service-toolbar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.toolbar-search{border:1px solid var(--border);background:var(--surface-muted);min-height:40px;color:var(--text-muted);border-radius:7px;flex:1;align-items:center;gap:8px;padding:0 12px;display:flex}.toolbar-search input,.service-toolbar select,.field-editor input,.field-editor textarea,.dynamic-form input,.dynamic-form textarea,.dynamic-form select{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);font:inherit;border-radius:7px}.toolbar-search input{background:0 0;border:0;outline:0;min-width:0;height:38px}.service-toolbar select{width:220px;height:40px;padding:0 10px}.inline-note{color:#8b5a00;background:#fff8e8;border:1px solid #f4d18c;border-radius:7px;margin-bottom:14px;padding:10px 12px;font-size:.84rem;font-weight:700}.service-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:14px;display:grid}.service-card{border:1px solid var(--border);background:var(--surface);border-radius:8px;min-width:0;overflow:hidden}.service-image{background:linear-gradient(135deg, #1788601f, #185fa514), var(--surface-muted);height:122px;color:var(--green);place-items:center;display:grid}.service-image img{-o-object-fit:cover;object-fit:cover;width:100%;height:100%}.service-card-body{gap:14px;padding:15px;display:grid}.service-category{color:var(--green);text-transform:uppercase;margin-bottom:6px;font-size:.72rem;font-weight:800;display:inline-block}.service-card h3{color:var(--text);margin:0 0 6px;font-size:1rem}.service-card p{color:var(--text-muted);font-size:.82rem;line-height:1.5}.service-meta{color:var(--text-muted);justify-content:space-between;gap:10px;font-size:.78rem;font-weight:700;display:flex}.request-detail-grid{grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);align-items:start;gap:14px;display:grid}.detail-list,.key-value-grid{gap:10px;display:grid}.detail-list{grid-template-columns:repeat(2,minmax(0,1fr))}.detail-list span,.key-value-grid span{background:var(--surface-muted);border-radius:8px;gap:4px;min-width:0;padding:10px 12px;display:grid}.detail-list small,.key-value-grid small{color:var(--text-muted);text-transform:capitalize;font-size:.72rem;font-weight:800}.detail-list strong,.key-value-grid strong{overflow-wrap:anywhere;color:var(--text);font-size:.88rem}.operation-form{gap:14px;display:grid}.operation-form label{color:var(--text);gap:7px;font-size:.82rem;font-weight:800;display:grid}.operation-form input,.operation-form textarea,.operation-form select{border:1px solid var(--border);background:var(--surface);width:100%;min-height:40px;color:var(--text);font:inherit;border-radius:7px;padding:8px 10px}.operation-form textarea{resize:vertical}.compact-empty{padding:22px}.task-tabs{flex-wrap:wrap;gap:8px;margin-bottom:14px;display:flex}.task-tabs button{border:1px solid var(--border);background:var(--surface);min-height:34px;color:var(--text-muted);font:inherit;cursor:pointer;text-transform:capitalize;border-radius:999px;padding:0 14px}.task-tabs button.active{color:var(--green);background:#e7f4ee;border-color:#17886059;font-weight:800}.task-pill,.task-priority{white-space:nowrap;border-radius:999px;align-items:center;gap:6px;padding:4px 9px;font-size:.72rem;font-weight:800;display:inline-flex}.task-pill i{border-radius:50%;width:7px;height:7px}.task-priority{border:1px solid var(--border);background:var(--surface);color:var(--text-muted)}.avatar-stack{align-items:center;display:inline-flex}.mini-avatar{border:2px solid var(--surface);background:var(--green);color:#fff;border-radius:999px;place-items:center;width:28px;height:28px;margin-left:-7px;font-size:.66rem;font-weight:800;display:grid;overflow:hidden}.mini-avatar:first-child{margin-left:0}.mini-avatar img{-o-object-fit:cover;object-fit:cover;width:100%;height:100%}.mini-avatar.more{background:var(--surface-muted);color:var(--text-muted)}.task-card{border:1px solid var(--border);border-left:4px solid var(--green);background:var(--surface);cursor:pointer;border-radius:10px;gap:10px;padding:13px;display:grid}.task-card.is-overdue{border-left-color:var(--red)}.task-card-head,.task-card-foot,.task-meta-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.task-title{color:var(--text);font-weight:800;text-decoration:none}.task-card p,.task-detail-description{color:var(--text-muted);line-height:1.55}.tag-row{flex-wrap:wrap;gap:6px;display:flex}.tag-row span{background:var(--surface-muted);color:var(--text-muted);border-radius:999px;padding:3px 8px;font-size:.7rem;font-weight:800}.task-card-foot{color:var(--text-muted);font-size:.74rem}.task-card-foot span:not(.avatar-stack){align-items:center;gap:4px;display:inline-flex}.danger-text{color:var(--red)!important}.kanban-board{grid-template-columns:repeat(6,minmax(250px,1fr));gap:14px;padding-bottom:8px;display:grid;overflow-x:auto}.kanban-column{border:1px solid var(--border);background:#f8fbf9;border-radius:10px;grid-template-rows:auto 1fr;gap:10px;min-height:520px;padding:12px;display:grid}.kanban-column-head,.kanban-column-head span{justify-content:space-between;align-items:center;gap:8px;display:flex}.kanban-column-head span{color:var(--text);font-weight:800}.kanban-column-head i{border-radius:50%;width:8px;height:8px}.kanban-column-head b{background:var(--surface-muted);min-width:22px;color:var(--text-muted);text-align:center;border-radius:999px;font-size:.72rem}.kanban-stack{align-content:start;gap:10px;display:grid}.task-calendar{grid-template-columns:repeat(7,minmax(140px,1fr));gap:8px;display:grid;overflow-x:auto}.calendar-day{border:1px solid var(--border);background:var(--surface);border-radius:8px;align-content:start;gap:6px;min-height:130px;padding:10px;display:grid}.calendar-day button{color:var(--green);font:inherit;text-align:left;cursor:pointer;background:#e7f4ee;border:0;border-radius:6px;padding:6px 8px;font-size:.74rem}.task-form,.task-section{gap:12px;display:grid}.task-form label,.inline-form{color:var(--text);gap:7px;font-size:.82rem;font-weight:800;display:grid}.task-form input,.task-form textarea,.task-form select,.inline-form input{border:1px solid var(--border);background:var(--surface);width:100%;min-height:40px;color:var(--text);font:inherit;border-radius:7px;padding:8px 10px}.inline-form{grid-template-columns:1fr auto;align-items:end}.drawer-backdrop{z-index:45;background:#0c181238;position:fixed;inset:0}.task-drawer{background:var(--surface);align-content:start;gap:16px;width:min(460px,92vw);padding:24px;display:grid;position:fixed;inset:0 0 0 auto;box-shadow:-18px 0 55px #0c18122e}.drawer-close{justify-self:end}.module-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;display:grid}.module-card{border:1px solid var(--border);background:var(--surface);border-radius:10px;gap:10px;padding:16px;display:grid}.accent-card{border-top:5px solid var(--accent)}.module-card h3{color:var(--text);font-size:1rem}.module-card p,.module-card span{color:var(--text-muted)}.mini-stats{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}.mini-stats span{background:var(--surface-muted);border-radius:8px;gap:4px;padding:10px;display:grid}.mini-stats strong{color:var(--text)}.permissions-matrix,.member-picker,.comment-list,.attachment-list,.activity-feed{gap:8px;display:grid}.permissions-matrix section{border:1px solid var(--border);border-radius:8px;padding:12px}.permissions-matrix label,.member-picker label,.check-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:8px 0;display:flex}.roles-page{gap:18px}.roles-hero{border:1px solid var(--border);background:radial-gradient(circle at 16% 12%,#17886029,#0000 34%),linear-gradient(135deg,#fff 0%,#f3f7f4 100%);border-radius:22px;justify-content:space-between;align-items:center;gap:18px;padding:24px;display:flex}.roles-hero h2{color:var(--text);letter-spacing:-.05em;font-size:clamp(1.8rem,3vw,2.6rem)}.roles-hero span,.role-section-title small,.permissions-toolbar small,.permission-group-head small,.permission-option small{color:var(--text-muted)}.roles-overview-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.roles-overview-grid article{border:1px solid var(--border);background:var(--surface);border-radius:16px;gap:5px;padding:16px;display:grid}.roles-overview-grid strong{color:var(--text);font-size:1.45rem}.roles-overview-grid small{color:var(--text-muted)}.roles-grid{grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:14px;display:grid}.role-card{border:1px solid var(--border);background:linear-gradient(180deg, #fffffff5, #f9fcfaf5), radial-gradient(circle at top right, color-mix(in srgb, var(--accent) 18%, transparent), transparent 38%);border-radius:20px;gap:14px;padding:18px;display:grid;position:relative;overflow:hidden;box-shadow:0 16px 38px #14231c12}.role-card:before{content:"";background:var(--accent);height:5px;position:absolute;inset:0 0 auto}.role-card-head{align-items:center;gap:12px;display:flex}.role-card-head h3{color:var(--text);font-size:1.08rem}.role-card-head b{background:var(--surface-muted);color:var(--text-muted);border-radius:999px;margin-left:auto;padding:5px 9px;font-size:.72rem}.role-color-dot{background:var(--accent);border-radius:13px;flex:none;width:36px;height:36px;box-shadow:inset 0 0 0 6px #ffffff52}.role-card p{min-height:44px;color:var(--text-muted)}.role-card-metrics{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.role-card-metrics span{background:var(--surface-muted);color:var(--text-muted);border-radius:14px;gap:4px;padding:10px;display:grid}.role-card-metrics strong{color:var(--text);font-size:1.05rem}.role-permission-preview{flex-wrap:wrap;gap:7px;display:flex}.role-permission-preview span{background:color-mix(in srgb, var(--accent) 12%, white);color:var(--text);border-radius:999px;padding:5px 9px;font-size:.74rem;font-weight:800}.role-dialog{width:min(980px,94vw);max-height:min(88vh,980px);overflow:auto}.role-builder-form{gap:18px;display:grid}.role-presets,.role-builder-panel,.permission-group-card,.permissions-toolbar,.role-impact-strip{border:1px solid var(--border);background:var(--surface);border-radius:18px;padding:16px}.role-section-title,.permissions-toolbar,.permission-group-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.role-section-title{justify-content:flex-start;margin-bottom:14px}.role-section-title strong,.permissions-toolbar strong,.permission-group-head h4{color:var(--text)}.role-preset-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.role-preset-card{border:1px solid var(--border);background:var(--surface-muted);color:var(--text);text-align:left;cursor:pointer;border-radius:16px;gap:7px;padding:14px;display:grid}.role-preset-card:hover{border-color:var(--green);background:#eef8f3}.role-preset-card i{border-radius:11px;width:30px;height:30px}.color-input-row{border:1px solid var(--border);background:var(--surface);min-height:44px;color:var(--text-muted);border-radius:12px;align-items:center;gap:10px;padding:6px 10px;display:flex}.color-input-row input{border:0;width:52px;min-height:32px;padding:0}.wide-field{grid-column:1/-1}.role-impact-strip{border-color:color-mix(in srgb, var(--accent) 35%, var(--border));background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 10%, white), #fff);grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.role-impact-strip span{gap:2px;display:grid}.role-impact-strip strong{color:var(--text);font-size:1.35rem}.permissions-builder{gap:12px;display:grid}.permission-options{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:12px;display:grid}.permission-option{border:1px solid var(--border);min-height:86px;color:var(--text);text-align:left;cursor:pointer;background:#fff;border-radius:16px;grid-template-columns:auto 1fr auto;align-items:center;gap:11px;padding:12px;display:grid}.permission-option:hover{border-color:color-mix(in srgb, var(--green) 50%, var(--border))}.permission-option.is-selected{border-color:var(--green);background:#edf8f3}.permission-option.risk-high.is-selected{background:#fff6f6;border-color:#e24b4a73}.permission-check{border:1px solid var(--border);width:28px;height:28px;color:var(--green);background:var(--surface);border-radius:10px;place-items:center;display:grid}.permission-option.is-selected .permission-check{border-color:var(--green);background:var(--green);color:#fff}.permission-option strong,.permission-option small{display:block}.permission-option em{color:var(--red);background:#fff0f0;border-radius:999px;align-items:center;gap:5px;padding:5px 8px;font-size:.7rem;font-style:normal;font-weight:900;display:flex}.sticky-footer{z-index:2;border-top:1px solid var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff0;margin:0 -16px -16px;padding:14px 16px;position:sticky;bottom:-16px}.comment-list article,.activity-feed article,.time-log,.subtask-row{background:var(--surface-muted);color:var(--text-muted);border-radius:8px;gap:4px;padding:10px 12px;text-decoration:none;display:grid}.file-drop{border:1px dashed var(--border);background:var(--surface-muted);min-height:58px;color:var(--green);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:8px;font-weight:800;display:flex}.load-bar{background:var(--surface-muted);color:var(--text);border-radius:999px;padding:6px 10px;font-size:.78rem;font-weight:800;position:relative;overflow:hidden}.load-bar:before{content:"";width:var(--load);opacity:.25;position:absolute;inset:0 auto 0 0}.load-bar.green:before{background:var(--green)}.load-bar.amber:before{background:var(--amber)}.load-bar.red:before{background:var(--red)}.builder-grid{grid-template-columns:minmax(260px,330px) minmax(220px,280px) minmax(280px,1fr);align-items:start;gap:14px;display:grid}.preview-panel{grid-column:1/-1}.muted-label{color:var(--text-muted);font-size:.76rem;font-weight:800}.field-list-head{margin-top:18px}.locked-fields,.sortable-list{gap:8px;display:grid}.field-row{border:1px solid var(--border);background:var(--surface);border-radius:7px;align-items:center;gap:9px;min-height:54px;padding:8px;display:flex}.field-row.is-selected{border-color:#17886073;box-shadow:0 0 0 3px #17886017}.field-row.is-locked{background:var(--surface-muted);color:var(--green)}.field-row-main{min-width:0;color:inherit;font:inherit;text-align:left;cursor:pointer;background:0 0;border:0;flex:1;gap:2px;display:grid}.field-row strong{color:var(--text);font-size:.84rem}.field-row small{color:var(--text-muted);font-size:.72rem}.drag-handle{background:var(--surface-muted);width:28px;height:32px;color:var(--text-muted);cursor:grab;border:0;border-radius:6px;place-items:center;display:grid}.field-type-grid{gap:8px;display:grid}.field-type-grid button{border:1px solid var(--border);background:var(--surface);min-height:62px;color:var(--text);font:inherit;text-align:left;cursor:pointer;border-radius:7px;grid-template-columns:20px 1fr;align-items:center;gap:4px 8px;padding:10px;display:grid}.field-type-grid button:hover{background:#f7fbf9;border-color:#17886073}.field-type-grid small{color:var(--text-muted);grid-column:2;font-size:.72rem}.field-editor{gap:12px;display:grid}.field-editor label,.dynamic-form label{color:var(--text);gap:7px;font-size:.82rem;font-weight:800;display:grid}.field-editor input,.field-editor textarea,.dynamic-form input,.dynamic-form textarea,.dynamic-form select{min-height:39px;padding:8px 10px}.field-editor textarea,.dynamic-form textarea{resize:vertical}.toggle-row{grid-template-columns:auto 1fr;align-items:center}.toggle-row input{width:auto}.editor-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.empty-panel.compact{min-height:150px}.dynamic-form{gap:16px;display:grid}.form-group{border:1px solid var(--border);border-radius:8px;gap:12px;margin:0;padding:14px;display:grid}.form-group legend{color:var(--green);padding:0 6px;font-size:.78rem;font-weight:800}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.form-field.is-full{grid-column:1/-1}.field-help{color:var(--text-muted);font-size:.76rem;font-weight:600}.form-field b{color:var(--red);margin-left:3px}.checkbox-stack{flex-wrap:wrap;gap:8px;display:flex}.checkbox-stack label{border:1px solid var(--border);min-height:34px;color:var(--text-muted);border-radius:999px;align-items:center;gap:6px;padding:0 10px;font-weight:700;display:inline-flex}.checkbox-stack input{width:auto}.notification-summary-grid,.category-admin-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;display:grid}.notification-summary-grid article,.category-admin-card,.notification-card{border:1px solid var(--border);background:var(--surface);border-radius:16px;padding:16px}.notification-summary-grid article{gap:5px;display:grid}.notification-summary-grid strong{color:var(--text);font-size:1.35rem}.notification-summary-grid small,.category-admin-card p,.notification-card small{color:var(--text-muted)}.notification-list{gap:10px;display:grid}.notification-card{grid-template-columns:auto 1fr auto;align-items:center;gap:14px;display:grid}.notification-card.is-unread{background:#f2faf6;border-color:#17886059}.notification-icon{background:var(--surface-muted);width:40px;height:40px;color:var(--green);border-radius:14px;place-items:center;display:grid}.category-admin-card{gap:14px;display:grid}.category-admin-card h3{color:var(--text)}.category-order{width:fit-content;color:var(--green);background:#edf8f3;border-radius:999px;margin-bottom:8px;padding:4px 8px;font-size:.74rem;font-weight:900;display:inline-flex}.vendor-layout{grid-template-columns:minmax(280px,.9fr) minmax(420px,1.4fr);align-items:start;gap:16px;display:grid}.tabs-row{border:1px solid var(--border);background:var(--surface);border-radius:16px;gap:8px;width:fit-content;padding:6px;display:flex}.tabs-row button{color:var(--text-muted);font:inherit;cursor:pointer;background:0 0;border:0;border-radius:12px;padding:10px 16px;font-weight:900}.tabs-row button.is-active{color:var(--green);background:#e5f4ee}.vendor-grid,.code-list{gap:12px;display:grid}.vendor-card{border:1px solid var(--border);background:var(--surface);border-radius:18px;gap:12px;padding:14px;display:grid}.vendor-card.is-selected{border-color:#17886073;box-shadow:0 16px 36px #1788601a}.vendor-card>button{color:var(--text);text-align:left;cursor:pointer;background:0 0;border:0;grid-template-columns:auto 1fr;align-items:center;gap:10px;display:grid}.vendor-card>button small{color:var(--text-muted);grid-column:2}.vendor-avatar{background:var(--green);color:#fff;border-radius:15px;grid-row:span 2;place-items:center;width:44px;height:44px;font-weight:900;display:grid}.vendor-stats{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.vendor-stats span{background:var(--surface-muted);border-radius:12px;gap:2px;padding:9px;display:grid}.vendor-stats b{color:var(--text)}.vendor-stats small{color:var(--text-muted);font-size:.72rem}.vendor-code-panel{min-height:420px}.code-toolbar{align-items:center;gap:12px;margin:14px 0;display:flex}.code-toolbar .toolbar-search{flex:1}.code-toolbar select{border:1px solid var(--border);background:var(--surface);min-height:42px;color:var(--text);font:inherit;border-radius:12px;padding:0 12px}.code-list article{border:1px solid var(--border);background:var(--surface);border-radius:14px;grid-template-columns:auto 1fr auto auto;align-items:center;gap:10px;padding:12px;display:grid}.code-list article.is-used{opacity:.72;background:var(--surface-muted)}.code-list strong{color:var(--text);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.clients-panel{gap:14px;display:grid}.client-list{gap:10px;display:grid}.client-card{border:1px solid var(--border);background:var(--surface);border-radius:16px;grid-template-columns:auto 1fr auto auto;align-items:center;gap:12px;padding:14px;display:grid}.client-card strong{color:var(--text);display:block}.client-card small{color:var(--text-muted);display:block}.pagination-row{color:var(--text-muted);justify-content:flex-end;align-items:center;gap:12px;margin-top:14px;display:flex}@media (width<=1100px){.app-shell{grid-template-columns:1fr}.sidebar{z-index:20;width:min(300px,88vw);transition:transform .18s;display:flex;position:fixed;inset:0 auto 0 0;transform:translate(-102%);box-shadow:12px 0 30px #14231c26}.sidebar.is-open{transform:translate(0)}.sidebar-backdrop{z-index:10;background:#0c181261;border:0;display:block;position:fixed;inset:0}.mobile-menu,.mobile-close{display:grid}.dashboard-grid,.bottom-grid,.builder-grid,.request-detail-grid,.vendor-layout,.client-card,.roles-overview-grid,.role-preset-grid,.role-impact-strip,.permission-options{grid-template-columns:1fr}.preview-panel{grid-column:auto}.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=680px){.topbar{padding:0 14px}.search-field{display:none}.content{padding:14px}.kpi-grid{grid-template-columns:1fr}.service-toolbar,.code-toolbar,.header-actions,.roles-hero,.role-section-title,.permissions-toolbar,.permission-group-head{flex-direction:column;align-items:stretch}.service-toolbar select{width:100%}.form-grid{grid-template-columns:1fr}}.auth-page{background:linear-gradient(135deg, #1788601f, transparent 42%), var(--surface-subtle);place-items:center;min-height:100vh;padding:24px;display:grid}.auth-card{border:1px solid var(--border);background:var(--surface);border-radius:8px;width:min(420px,100%);padding:24px}.auth-brand{min-height:auto;margin-bottom:22px;padding:0 0 18px}.auth-form{gap:16px;display:grid}.auth-form label{color:var(--text);gap:7px;font-size:.86rem;font-weight:700;display:grid}.field-error{color:var(--red);font-size:.74rem;font-weight:700}.auth-form input{border:1px solid var(--border);background:var(--surface);width:100%;height:42px;color:var(--text);border-radius:7px;padding:0 12px}.password-field{position:relative}.password-field button{width:30px;height:30px;color:var(--text-muted);cursor:pointer;background:0 0;border:0;place-items:center;display:grid;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.primary-button{background:var(--green);color:#fff;cursor:pointer;border:0;border-radius:7px;justify-content:center;align-items:center;gap:8px;height:42px;font-weight:800;display:inline-flex}.primary-button:disabled{opacity:.72}.auth-link{color:var(--green);text-align:center;font-size:.84rem;font-weight:700;text-decoration:none}.spin{animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{to{background-position-x:-200%}}
