@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&display=swap";:root{--bg-canvas: #f6f6f6;--bg-surface: #ffffff;--bg-muted: #f2f2f2;--ink-strong: #111111;--ink-normal: #292929;--ink-soft: #666666;--line-soft: #e2e2e2;--brand-strong: #111111;--brand-muted: #f0f0f0;--success-soft: #f2f9f3;--danger-soft: #fdf2f3;--warning-soft: #fdf8ef;--radius-lg: 16px;--radius-md: 12px;--shadow-soft: 0 12px 28px rgba(0, 0, 0, .06);--shadow-card: 0 8px 18px rgba(0, 0, 0, .05);--layout-width: 1360px}*,*:before,*:after{box-sizing:border-box}html,body,#root{min-height:100vh}body{margin:0;font-family:Manrope,Segoe UI,Arial,sans-serif;color:var(--ink-normal);background:linear-gradient(180deg,#fafafa 0%,var(--bg-canvas) 100%)}a{color:inherit}.app-layout{min-height:100vh;background:var(--bg-canvas)!important}.app-sider{overflow:auto;height:100vh;position:fixed!important;left:0;top:0;bottom:0;z-index:20;background:#fff!important;border-right:1px solid var(--line-soft);box-shadow:6px 0 16px #0000000a}.app-sider .ant-layout-sider-children{display:flex;flex-direction:column}.app-brand{height:72px;display:flex;align-items:center;justify-content:center;padding:0 16px;border-bottom:1px solid var(--line-soft)}.app-brand-text{color:var(--ink-strong)!important;margin:0;font-size:16px;letter-spacing:.01em}.app-menu.ant-menu-light,.app-menu.ant-menu-light .ant-menu-sub{background:transparent!important}.app-menu.ant-menu-inline{border-inline-end:0!important;padding:12px 10px}.app-menu .ant-menu-item{height:44px;line-height:44px;border-radius:10px;margin-inline:0;margin-block:6px;color:#333}.app-menu .ant-menu-item .ant-menu-item-icon{color:#555}.app-menu .ant-menu-item:not(.ant-menu-item-selected):hover{background:#f3f3f3!important;color:#111}.app-menu .ant-menu-item-selected{background:#ececec!important;color:#111!important;box-shadow:none;font-weight:700}.app-menu .ant-menu-item-selected .ant-menu-item-icon{color:#111!important}.app-main{min-height:100vh;transition:margin-left .24s ease}.app-main.mobile{margin-left:0!important}.app-header{position:sticky;top:0;z-index:15;height:72px;line-height:normal!important;padding:0 clamp(14px,2.2vw,30px)!important;display:flex!important;align-items:center;justify-content:space-between;flex-wrap:nowrap;background:#fff!important;border-bottom:1px solid var(--line-soft)}.app-header-left{display:flex;align-items:center;gap:12px}.menu-trigger{width:38px;height:38px;color:var(--ink-normal);border:1px solid var(--line-soft);border-radius:11px;background:#fff}.menu-trigger:hover{color:#111!important;border-color:#cfcfcf!important;background:#fff!important}.app-header-title-group{display:block}.app-header-title{margin:0;font-size:16px;font-weight:700;color:var(--ink-strong)!important}.app-header-subtitle{margin:0;font-size:12px;color:var(--ink-soft)!important}.header-user-trigger{cursor:pointer;border-radius:12px;padding:6px 10px;transition:background-color .2s ease}.header-user-trigger:hover{background:#f3f3f3}.app-content{padding:24px clamp(14px,2.2vw,30px) 34px}.page-shell{max-width:var(--layout-width);margin:0 auto}.page-header{margin-bottom:18px;display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.page-title-wrap{display:flex;flex-direction:column;gap:5px}.page-title{margin:0!important;font-size:clamp(21px,2.2vw,25px)!important;line-height:1.25!important;color:var(--ink-strong)!important;letter-spacing:-.02em}.page-subtitle{margin:0;color:var(--ink-soft);font-size:13px}.page-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.section-stack{display:flex;flex-direction:column;gap:16px}.soft-card.ant-card{border-radius:var(--radius-lg);border-color:#d1ddf0e6;box-shadow:var(--shadow-card)}.soft-card .ant-card-head{border-bottom-color:#dde6f4e6}.soft-card .ant-card-head-title{color:var(--ink-strong);font-weight:700}.stats-card.ant-card{border-radius:var(--radius-md);border:1px solid rgba(213,224,241,.94);box-shadow:var(--shadow-card)}.stats-card .ant-statistic-title{color:var(--ink-soft);font-size:12px}.stats-currency{font-size:24px;font-weight:800;line-height:1.1;margin-top:4px}.compact-progress-block{margin-bottom:12px}.compact-progress-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px;font-size:12px}.filter-card.ant-card{border-radius:var(--radius-md);border-color:#d4e0f1f0;box-shadow:var(--shadow-card)}.filter-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px}.filter-actions{display:flex;align-items:center;justify-content:flex-end}.request-table .ant-table-wrapper{border-radius:var(--radius-lg);overflow:hidden;border:1px solid rgba(214,225,242,.9);background:var(--bg-surface)}.request-table .ant-table-thead>tr>th{background:#f4f8ff;color:#304362;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.request-table .ant-table-row{transition:background-color .18s ease}.request-table .ant-table-row:hover{background:#f8fbff!important}.request-table-row{cursor:pointer}.note-muted{margin:0;color:var(--ink-soft);font-size:13px}.detail-hero-card .ant-card-body{padding:clamp(18px,2.5vw,28px)}.detail-hero-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:12px;padding-bottom:20px;border-bottom:1px solid var(--line-soft);margin-bottom:20px}.detail-req-number{background:var(--bg-muted)!important;border:none!important;color:var(--ink-soft)!important;font-size:12px;font-weight:600;border-radius:6px;padding:2px 8px}.detail-info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:24px}.detail-info-item{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border-radius:12px;background:var(--bg-muted);transition:background-color .18s ease}.detail-info-item:hover{background:#eaeaea}.detail-info-icon{width:36px;height:36px;min-width:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px}.detail-info-label{display:block;font-size:11px!important;line-height:1.3;margin-bottom:2px}.detail-info-value{display:block;font-size:13px;line-height:1.35;color:var(--ink-strong)}.detail-text-section{padding:14px 16px;border-radius:12px;background:var(--bg-muted);margin-bottom:12px}.detail-text-section.detail-text-danger{background:var(--danger-soft)}.detail-text-section.detail-text-danger .detail-text-heading{color:#dc3f57}.detail-text-heading{display:block;font-size:12px;color:var(--ink-soft);margin-bottom:6px;text-transform:uppercase;letter-spacing:.03em}.detail-text-body{margin:0;font-size:13px;line-height:1.6;color:var(--ink-normal)}.detail-link{color:#0f5ae8!important;font-size:13px;transition:opacity .15s ease}.detail-link:hover{opacity:.75}.detail-attachment{font-size:13px;color:var(--ink-normal)}.tpl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px}.tpl-card{background:var(--bg-surface);border:1px solid var(--line-soft);border-radius:var(--radius-lg);padding:20px;display:flex;flex-direction:column;transition:border-color .18s ease,box-shadow .18s ease}.tpl-card:hover{border-color:#c8c8c8;box-shadow:var(--shadow-card)}.tpl-card-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px}.tpl-card-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px}.tpl-card-actions{display:flex;gap:4px;opacity:0;transition:opacity .18s ease}.tpl-card:hover .tpl-card-actions{opacity:1}.tpl-action-btn{width:32px;height:32px;border:1px solid var(--line-soft);border-radius:8px;background:var(--bg-surface);color:var(--ink-soft);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;transition:all .15s ease}.tpl-action-btn:hover{color:var(--ink-strong);border-color:silver;background:var(--bg-muted)}.tpl-action-danger:hover{color:#dc3f57;border-color:#f5c6cb;background:var(--danger-soft)}.tpl-card-name{font-size:15px;font-weight:700;color:var(--ink-strong);margin-bottom:8px;line-height:1.35}.tpl-card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.tpl-tag-cat{font-size:11px;font-weight:600;border-radius:6px}.tpl-card-desc{font-size:13px;color:var(--ink-soft);line-height:1.55;margin:0 0 14px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1}.tpl-card-footer{display:flex;align-items:center;gap:12px;padding-top:14px;border-top:1px solid var(--line-soft)}.tpl-card-stat{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--ink-normal)}.tpl-card-stat .anticon{color:var(--ink-soft);font-size:14px}.tpl-card-divider{width:1px;height:16px;background:var(--line-soft)}.tpl-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;background:var(--bg-surface);border:2px dashed var(--line-soft);border-radius:var(--radius-lg);text-align:center}.tpl-empty-icon{width:56px;height:56px;border-radius:16px;background:var(--bg-muted);display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--ink-soft);margin-bottom:16px}.tpl-modal .ant-modal-body{padding:0!important;max-height:calc(100vh - 80px);overflow-y:auto}.tpl-modal .ant-modal-content{padding:0!important;border-radius:18px;overflow:hidden}.tpl-modal-head{padding:24px 28px 16px;border-bottom:1px solid var(--line-soft);position:sticky;top:0;background:var(--bg-surface);z-index:1}.tpl-modal .ant-form{padding:20px 28px 24px}.tpl-modal-actions{display:flex;justify-content:flex-end;gap:8px;position:sticky;bottom:0;background:var(--bg-surface);margin:0 -28px -24px;padding:14px 28px 20px;border-top:1px solid var(--line-soft)}.notification-item{border:1px solid rgba(212,224,241,.86);border-radius:12px;padding:12px 16px!important;margin-bottom:8px;transition:border-color .18s ease,background-color .18s ease,transform .16s ease}.notification-item.unread{background:#f3f8ff;border-color:#88b0ec94}.notification-item:hover{transform:translateY(-1px);border-color:#8badddbd}.timeline-item-title{font-weight:600;color:var(--ink-strong)}.timeline-item-meta{margin-top:4px;font-size:12px;color:var(--ink-soft)}.comment-item{border:none!important;padding:10px 0!important}.comment-system{width:100%;padding:9px 12px;border-radius:10px;background:var(--bg-muted);color:var(--ink-soft);font-style:italic;font-size:13px}.comment-bubble{margin-left:36px;background:#f8faff;border:1px solid rgba(216,226,241,.92);border-radius:10px;padding:10px 12px;color:var(--ink-normal)}.comment-form{margin-top:18px}.comment-form .ant-input-textarea-show-count{margin-bottom:22px}.comment-form .ant-input-data-count{color:var(--ink-soft)}.comment-form-actions{margin-top:4px;display:flex;justify-content:flex-end}.responsive-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.responsive-grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.responsive-grid-4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.link-row{display:flex;align-items:flex-start;gap:8px;margin-bottom:8px}.link-input{width:100%}.form-submit{min-width:170px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:clamp(16px,4vw,34px);background:#f0f0f0}.login-card-shell.ant-card{width:min(960px,100%);border-radius:24px;overflow:hidden;border:none;box-shadow:0 24px 48px #0000001a}.login-card-shell .ant-card-body{padding:0}.login-grid{display:grid;grid-template-columns:minmax(280px,1fr) minmax(320px,1.15fr)}.login-brand-panel{color:#fff;padding:clamp(28px,3.5vw,40px);background:#111;display:flex;flex-direction:column}.login-brand-logo{width:48px;height:48px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;background:#fff;color:#111}.login-brand-title{margin:20px 0 8px!important;color:#fff!important;font-size:22px!important}.login-brand-text{margin:0 0 24px;color:#fff9;font-size:14px;line-height:1.6}.demo-box{border:1px solid rgba(255,255,255,.12);background:#ffffff0f;border-radius:14px;padding:16px;margin-top:auto}.demo-box-title{display:block;margin-bottom:12px!important;color:#ffffff73!important;font-size:11px!important;text-transform:uppercase;letter-spacing:.06em}.demo-accounts{display:flex;flex-direction:column;gap:6px}.demo-account-btn{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border:1px solid rgba(255,255,255,.1);border-radius:10px;background:#ffffff0a;cursor:pointer;transition:background-color .18s ease,border-color .18s ease;text-align:left}.demo-account-btn:hover{background:#ffffff1a;border-color:#fff3}.demo-account-avatar{width:32px;height:32px;min-width:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}.demo-account-info{display:flex;flex-direction:column;min-width:0}.demo-account-user{font-size:13px;font-weight:600;color:#fff;line-height:1.3}.demo-account-role{font-size:11px;color:#ffffff73;line-height:1.3}.login-form-panel{background:#fff;padding:clamp(28px,3.5vw,44px);display:flex;flex-direction:column;justify-content:center}.login-form-title{margin:0 0 4px!important;color:var(--ink-strong)!important}.login-form-subtitle{margin:0 0 28px;color:var(--ink-soft)}.login-submit.ant-btn{height:46px;font-weight:700;border-radius:12px;margin-top:4px}@media(max-width:1200px){.filter-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:992px){.responsive-grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}.login-grid{grid-template-columns:1fr}}@media(max-width:768px){.app-header{height:66px}.page-header{flex-direction:column;align-items:stretch}.page-actions{justify-content:flex-start}.responsive-grid-3,.responsive-grid-2,.responsive-grid-4,.filter-grid{grid-template-columns:1fr}.comment-bubble{margin-left:0;margin-top:8px}.link-row{flex-direction:column;gap:6px}.detail-info-grid{grid-template-columns:1fr}.detail-hero-header{flex-direction:column}.tpl-grid{grid-template-columns:1fr}.tpl-card-actions{opacity:1}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#e7edf7}::-webkit-scrollbar-thumb{background:#bdcbe2;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:#a7b8d3}
