@import"https://fonts.googleapis.com/css2?family=Noto+Sans+Lao:wght@300;400;500;600;700&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--navy-900: #122844;--navy-800: #1e3a5f;--navy-700: #2a4a73;--navy-600: #3b5e8a;--navy-100: #e8eef5;--navy-50: #f3f6fa;--gold-600: #d97e0a;--gold-500: #f59e0b;--gold-400: #fbbf24;--gold-100: #fef3c7;--gold-50: #fffbeb;--bg: #f5f7fa;--surface: #ffffff;--border: #e4e8ee;--border-strong: #cdd4dd;--ink-900: #0f172a;--ink-700: #334155;--ink-500: #64748b;--ink-400: #94a3b8;--ink-300: #cbd5e1;--red-600: #dc2626;--red-500: #ef4444;--red-100: #fee2e2;--red-50: #fef2f2;--orange-600: #ea580c;--orange-500: #f97316;--orange-100: #ffedd5;--yellow-600: #ca8a04;--yellow-500: #eab308;--yellow-100: #fef9c3;--green-600: #16a34a;--green-500: #22c55e;--green-100: #dcfce7;--blue-600: #2563eb;--blue-500: #3b82f6;--blue-100: #dbeafe;--grey-200: #e2e8f0;--grey-300: #cbd5e1;--grey-500: #64748b;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .04);--shadow-md: 0 1px 3px rgba(15, 23, 42, .06), 0 1px 2px rgba(15, 23, 42, .04);--shadow-lg: 0 10px 30px rgba(15, 23, 42, .08), 0 2px 6px rgba(15, 23, 42, .04);--radius-sm: 4px;--radius: 6px;--radius-md: 8px;--radius-lg: 12px;--font-lao: "Noto Sans Lao", "Inter", system-ui, sans-serif;--font-en: "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);color:var(--ink-900);font-family:var(--font-lao);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:inherit;cursor:pointer;border:none;background:none}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}.en{font-family:var(--font-en)}.lao{font-family:var(--font-lao)}.mono{font-family:var(--font-mono)}.app{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.app.collapsed{grid-template-columns:64px 1fr}.sidebar{background:var(--navy-800);color:#fff;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow:hidden}.sidebar-brand{padding:18px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid rgba(255,255,255,.08);min-height:72px}.brand-mark{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--gold-400),var(--gold-600));display:grid;place-items:center;flex-shrink:0;position:relative;box-shadow:inset 0 0 0 2px #ffffff2e}.brand-mark:after{content:"";position:absolute;top:6px;right:6px;bottom:6px;left:6px;border-radius:50%;border:1.5px solid rgba(255,255,255,.4)}.brand-mark span{position:relative;font-family:var(--font-lao);font-weight:700;font-size:13px;color:var(--navy-900);line-height:1}.logo-mark{flex-shrink:0;width:36px;height:36px;border-radius:50%;background:#fff;border:none;display:grid;place-items:center;padding:3px;overflow:hidden;box-shadow:0 1px 4px #0000002e}.logo-mark img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;display:block}.brand-text{min-width:0;flex:1}.brand-text .title-lao{font-size:12.5px;font-weight:600;line-height:1.3;color:#fff}.brand-text .title-en{font-family:var(--font-en);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:#ffffff8c;margin-top:2px}.collapsed .brand-text{display:none}.collapsed .sidebar-brand{justify-content:center;padding:18px 0}.sidebar-nav{flex:1;padding:12px 8px;overflow-y:auto}.nav-section-label{font-family:var(--font-en);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:#fff6;padding:12px 12px 6px}.collapsed .nav-section-label{display:none}.nav-item{display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:var(--radius);color:#ffffffc7;font-size:13.5px;font-weight:500;width:100%;text-align:left;margin-bottom:2px;transition:background .12s,color .12s}.nav-item:hover{background:#ffffff0f;color:#fff}.nav-item.active{background:#f59e0b1f;color:#fff;box-shadow:inset 2px 0 0 var(--gold-500)}.nav-item svg{flex-shrink:0}.nav-item .nav-label-en{font-family:var(--font-en);font-size:10.5px;color:#ffffff73;margin-top:1px;display:block;font-weight:400;letter-spacing:.02em}.nav-item.active .nav-label-en{color:#fff9}.collapsed .nav-item{justify-content:center;padding:11px 0}.collapsed .nav-item-text{display:none}.sidebar-footer{padding:12px;border-top:1px solid rgba(255,255,255,.08)}.user-card{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--radius);background:#ffffff0a}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--navy-600);display:grid;place-items:center;font-family:var(--font-en);font-weight:600;font-size:12px;color:#fff;flex-shrink:0}.user-info{min-width:0;flex:1}.user-name{font-size:12.5px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-family:var(--font-en);font-size:10px;color:#ffffff80;text-transform:uppercase;letter-spacing:.06em}.collapsed .user-info,.collapsed .user-card-action{display:none}.collapsed .user-card{justify-content:center}.main{display:flex;flex-direction:column;min-width:0;background:var(--bg)}.topbar{height:60px;background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:16px;position:sticky;top:0;z-index:5}.topbar-toggle{width:32px;height:32px;border-radius:var(--radius);display:grid;place-items:center;color:var(--ink-500)}.topbar-toggle:hover{background:var(--navy-50);color:var(--navy-800)}.breadcrumb{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.breadcrumb-item{font-size:13px;color:var(--ink-500)}.breadcrumb-item.current{color:var(--ink-900);font-weight:600}.breadcrumb-sep{color:var(--ink-300);font-family:var(--font-en)}.topbar-actions{display:flex;align-items:center;gap:8px}.icon-btn{width:36px;height:36px;border-radius:var(--radius);display:grid;place-items:center;color:var(--ink-500);position:relative}.icon-btn:hover{background:var(--navy-50);color:var(--navy-800)}.icon-btn .dot{position:absolute;top:8px;right:8px;width:7px;height:7px;border-radius:50%;background:var(--red-500);border:1.5px solid #fff}.page{padding:24px 28px 48px;max-width:1400px;width:100%;margin:0 auto}.page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border)}.page-title{font-size:22px;font-weight:700;color:var(--ink-900);margin:0;line-height:1.2}.page-subtitle{font-family:var(--font-en);font-size:12px;color:var(--ink-500);letter-spacing:.04em;text-transform:uppercase;margin-top:4px}.page-meta{font-family:var(--font-en);font-size:12px;color:var(--ink-500)}.btn{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:var(--radius);font-size:13px;font-weight:500;border:1px solid transparent;transition:background .12s,border-color .12s,color .12s;white-space:nowrap}.btn-primary{background:var(--navy-800);color:#fff}.btn-primary:hover{background:var(--navy-900)}.btn-gold{background:var(--gold-500);color:var(--navy-900);font-weight:600}.btn-gold:hover{background:var(--gold-600);color:#fff}.btn-secondary{background:#fff;color:var(--ink-700);border-color:var(--border-strong)}.btn-secondary:hover{background:var(--navy-50);border-color:var(--navy-600);color:var(--navy-800)}.btn-ghost{color:var(--ink-700)}.btn-ghost:hover{background:var(--navy-50)}.btn-danger{background:var(--red-50);color:var(--red-600);border-color:var(--red-100)}.btn-danger:hover{background:var(--red-100)}.btn-sm{padding:5px 10px;font-size:12px}.btn:disabled{opacity:.5;cursor:not-allowed}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.card-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}.card-title{font-size:14px;font-weight:600;color:var(--ink-900);margin:0}.card-subtitle{font-family:var(--font-en);font-size:11px;color:var(--ink-500);text-transform:uppercase;letter-spacing:.05em}.card-body{padding:18px}.card-body.tight{padding:0}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:999px;font-size:11.5px;font-weight:600;font-family:var(--font-lao);white-space:nowrap;border:1px solid transparent}.badge .dot{width:6px;height:6px;border-radius:50%}.badge-grey{background:#f1f5f9;color:var(--ink-700);border-color:#e2e8f0}.badge-grey .dot{background:var(--ink-400)}.badge-blue{background:var(--blue-100);color:#1e40af;border-color:#bfdbfe}.badge-blue .dot{background:var(--blue-500)}.badge-yellow{background:var(--yellow-100);color:#854d0e;border-color:#fde68a}.badge-yellow .dot{background:var(--yellow-500)}.badge-orange{background:var(--orange-100);color:#9a3412;border-color:#fed7aa}.badge-orange .dot{background:var(--orange-500)}.badge-red{background:var(--red-100);color:#991b1b;border-color:#fecaca}.badge-red .dot{background:var(--red-500)}.badge-green{background:var(--green-100);color:#166534;border-color:#bbf7d0}.badge-green .dot{background:var(--green-500)}.badge-darkgrey{background:#334155;color:#fff}.summary-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:24px}.summary-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);padding:16px 18px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.summary-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent, var(--blue-500))}.summary-card .label{font-size:12.5px;color:var(--ink-500);font-weight:500;display:flex;align-items:center;gap:6px}.summary-card .label-en{font-family:var(--font-en);font-size:10px;color:var(--ink-400);text-transform:uppercase;letter-spacing:.06em;margin-top:1px}.summary-card .value{font-family:var(--font-en);font-size:30px;font-weight:700;color:var(--ink-900);margin-top:8px;line-height:1;font-variant-numeric:tabular-nums}.summary-card .delta{font-family:var(--font-en);font-size:11px;color:var(--ink-500);margin-top:6px;display:flex;align-items:center;gap:4px}.summary-card .delta.up{color:var(--green-600)}.summary-card .delta.down{color:var(--red-600)}.summary-icon{position:absolute;top:14px;right:14px;width:28px;height:28px;border-radius:var(--radius);display:grid;place-items:center;background:var(--accent-bg, var(--blue-100));color:var(--accent, var(--blue-500))}.sc-blue{--accent: var(--blue-500);--accent-bg: var(--blue-100)}.sc-yellow{--accent: var(--yellow-500);--accent-bg: var(--yellow-100)}.sc-orange{--accent: var(--orange-500);--accent-bg: var(--orange-100)}.sc-red{--accent: var(--red-500);--accent-bg: var(--red-100)}.sc-green{--accent: var(--green-500);--accent-bg: var(--green-100)}.dash-grid{display:grid;grid-template-columns:2fr 1fr;gap:18px}.dash-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px;margin-top:18px}.escalated-banner{background:linear-gradient(90deg,#fff1f1,#fff7f7);border:1px solid #fecaca;border-left:3px solid var(--red-500);border-radius:var(--radius-md);padding:14px 18px;margin-bottom:18px;display:flex;gap:16px;align-items:flex-start}.escalated-banner .icon{width:36px;height:36px;border-radius:50%;background:var(--red-100);color:var(--red-600);display:grid;place-items:center;flex-shrink:0}.escalated-banner .title{font-size:13.5px;font-weight:600;color:#991b1b;display:flex;align-items:center;gap:8px}.escalated-banner .title .count{font-family:var(--font-en);background:var(--red-500);color:#fff;font-size:11px;padding:1px 7px;border-radius:999px;font-weight:700}.escalated-banner .body{font-size:12.5px;color:var(--ink-700);margin-top:4px}.escalated-list{margin-top:10px;display:flex;flex-direction:column;gap:6px}.escalated-row{display:flex;align-items:center;gap:10px;background:#ffffffb3;border:1px solid #fecaca;border-radius:var(--radius);padding:8px 12px;font-size:12.5px;cursor:pointer}.escalated-row .num{font-family:var(--font-en);font-size:11px;color:var(--red-600);font-weight:600;width:24px}.escalated-row .task-name{flex:1;color:var(--ink-900);font-weight:500}.escalated-row .meta{font-family:var(--font-en);font-size:11px;color:var(--ink-500)}.list-row{display:flex;align-items:center;gap:12px;padding:12px 18px;border-bottom:1px solid var(--border);font-size:13px;cursor:pointer}.list-row:last-child{border-bottom:none}.list-row:hover{background:var(--navy-50)}.list-row .lr-icon{width:30px;height:30px;border-radius:var(--radius);display:grid;place-items:center;flex-shrink:0}.list-row .lr-main{flex:1;min-width:0}.list-row .lr-title{font-weight:500;color:var(--ink-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-row .lr-sub{font-family:var(--font-en);font-size:11px;color:var(--ink-500);margin-top:2px}.progress{width:100%;height:6px;background:var(--grey-200);border-radius:999px;overflow:hidden;position:relative}.progress>div{height:100%;border-radius:999px;transition:width .3s}.progress-lg{height:10px}.progress-row{display:flex;align-items:center;gap:10px;min-width:120px}.progress-row .pct{font-family:var(--font-en);font-size:12px;font-weight:600;color:var(--ink-700);font-variant-numeric:tabular-nums;min-width:36px;text-align:right}.table-wrap{background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm)}table.tasks-table{width:100%;border-collapse:collapse;font-size:13px}.tasks-table thead tr{background:#f8fafc;border-bottom:1px solid var(--border)}.tasks-table th{text-align:left;font-family:var(--font-en);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-500);padding:10px 12px;white-space:nowrap}.tasks-table td{padding:12px;border-bottom:1px solid var(--border);vertical-align:top}.tasks-table tr:last-child td{border-bottom:none}.tasks-table tbody tr{transition:background .12s;cursor:pointer}.tasks-table tbody tr:hover{background:var(--navy-50)}.tasks-table tbody tr.overdue{background:#fff5f5}.tasks-table tbody tr.overdue:hover{background:#ffeaea}.tasks-table tbody tr.escalated td:first-child{box-shadow:inset 3px 0 0 var(--red-500)}.tasks-table tbody tr.selected{background:var(--navy-50);box-shadow:inset 3px 0 0 var(--navy-800)}.task-num{font-family:var(--font-en);font-size:12px;color:var(--ink-500);font-weight:500}.task-title-cell{max-width:320px}.task-title{font-weight:600;color:var(--ink-900);line-height:1.35}.task-objective{font-size:12px;color:var(--ink-500);margin-top:3px;line-height:1.4}.task-cell-text{font-size:12.5px;color:var(--ink-700);max-width:200px}.row-actions{display:flex;gap:4px}.row-action{width:28px;height:28px;border-radius:var(--radius-sm);display:grid;place-items:center;color:var(--ink-500)}.row-action:hover{background:var(--navy-100);color:var(--navy-800)}.row-action.danger:hover{background:var(--red-100);color:var(--red-600)}.filter-bar{background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;margin-bottom:16px;display:grid;grid-template-columns:1fr repeat(4,minmax(0,160px)) auto;gap:10px;align-items:center;box-shadow:var(--shadow-sm)}.search-input{position:relative}.search-input input{width:100%;padding:8px 12px 8px 34px;border:1px solid var(--border-strong);border-radius:var(--radius);font-size:13px;background:#fff;outline:none}.search-input input:focus{border-color:var(--navy-600);box-shadow:0 0 0 3px #1e3a5f14}.search-input svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--ink-400)}.select-input{padding:8px 28px 8px 12px;border:1px solid var(--border-strong);border-radius:var(--radius);font-size:13px;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") no-repeat right 10px center;-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none;cursor:pointer}.select-input:focus{border-color:var(--navy-600)}.chart-card{padding:18px}.bar-chart{display:flex;flex-direction:column;gap:12px}.bar-row{display:grid;grid-template-columns:110px 1fr 40px;align-items:center;gap:10px;font-size:13px}.bar-row .bar-label{font-weight:500}.bar-row .bar-track{height:18px;background:var(--grey-200);border-radius:var(--radius-sm);overflow:hidden}.bar-row .bar-fill{height:100%;border-radius:var(--radius-sm);display:flex;align-items:center;padding:0 8px;color:#fff;font-family:var(--font-en);font-size:11px;font-weight:600}.bar-row .bar-num{font-family:var(--font-en);font-size:13px;font-weight:600;text-align:right}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;z-index:50;opacity:0;pointer-events:none;transition:opacity .2s}.overlay.open{opacity:1;pointer-events:auto}.detail-panel{position:fixed;top:0;right:0;bottom:0;width:640px;max-width:92vw;background:#fff;z-index:60;box-shadow:-10px 0 40px #0f172a29;transform:translate(100%);transition:transform .28s cubic-bezier(.32,.72,0,1);display:flex;flex-direction:column}.detail-panel.open{transform:translate(0)}.detail-header{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.detail-header h2{font-size:17px;font-weight:700;margin:0 0 4px;color:var(--ink-900);line-height:1.3}.detail-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.close-btn{width:32px;height:32px;border-radius:var(--radius);display:grid;place-items:center;color:var(--ink-500);flex-shrink:0}.close-btn:hover{background:var(--navy-50);color:var(--navy-800)}.detail-body{flex:1;overflow-y:auto;padding:22px}.detail-section{margin-bottom:22px}.detail-label{font-family:var(--font-en);font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-500);font-weight:600;margin-bottom:6px}.detail-value{font-size:13.5px;color:var(--ink-900);line-height:1.5}.kv-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 24px}.highlight-box{background:var(--gold-50);border:1px solid var(--gold-100);border-left:3px solid var(--gold-500);border-radius:var(--radius);padding:12px 14px;font-size:13px;line-height:1.55;color:#78350f}.highlight-box.danger{background:var(--red-50);border-color:var(--red-100);border-left-color:var(--red-500);color:#7f1d1d}.progress-detail{display:flex;align-items:center;gap:14px;padding:14px;background:var(--navy-50);border-radius:var(--radius-md)}.progress-detail .pct-big{font-family:var(--font-en);font-size:28px;font-weight:700;color:var(--navy-800);font-variant-numeric:tabular-nums;min-width:70px}.comments{display:flex;flex-direction:column;gap:14px}.comment{display:flex;gap:12px}.comment-avatar{width:34px;height:34px;border-radius:50%;background:var(--navy-600);color:#fff;display:grid;place-items:center;font-family:var(--font-en);font-weight:600;font-size:12px;flex-shrink:0}.comment-body{flex:1;background:#f8fafc;border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 14px}.comment-head{display:flex;align-items:baseline;gap:8px;margin-bottom:4px;flex-wrap:wrap}.comment-name{font-weight:600;font-size:13px}.comment-position{font-size:11.5px;color:var(--ink-500)}.comment-time{font-family:var(--font-en);font-size:11px;color:var(--ink-400);margin-left:auto}.comment-text{font-size:13px;color:var(--ink-700);line-height:1.55}.comment-input-wrap{border-top:1px solid var(--border);padding:14px 22px;background:#fff;display:flex;gap:10px;align-items:flex-end}.comment-input-wrap textarea{flex:1;border:1px solid var(--border-strong);border-radius:var(--radius);padding:9px 12px;resize:none;min-height:38px;max-height:120px;font-size:13px;outline:none;font-family:var(--font-lao)}.comment-input-wrap textarea:focus{border-color:var(--navy-600);box-shadow:0 0 0 3px #1e3a5f14}.month-nav{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);padding:4px}.month-nav .month-btn{padding:6px 10px;border-radius:var(--radius-sm);font-size:13px;color:var(--ink-700);display:grid;place-items:center}.month-nav .month-btn:hover{background:var(--navy-50)}.month-nav .month-current{padding:6px 14px;font-weight:600;font-size:13.5px;color:var(--ink-900);font-variant-numeric:tabular-nums;min-width:130px;text-align:center}.month-strip{display:grid;grid-template-columns:repeat(12,1fr);gap:6px;margin-bottom:22px}.month-chip{padding:10px 6px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);text-align:center;cursor:pointer;transition:all .12s;position:relative}.month-chip:hover{border-color:var(--navy-600)}.month-chip.active{background:var(--navy-800);border-color:var(--navy-800);color:#fff}.month-chip.current{border-color:var(--gold-500);border-width:2px}.month-chip .m-name{font-family:var(--font-en);font-size:10.5px;text-transform:uppercase;letter-spacing:.04em;font-weight:600}.month-chip .m-count{font-family:var(--font-en);font-size:11px;color:var(--ink-500);margin-top:2px}.month-chip.active .m-count{color:#ffffffb3}.priority-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.priority-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);padding:18px;box-shadow:var(--shadow-sm);position:relative;display:flex;flex-direction:column;gap:10px;transition:transform .12s,box-shadow .12s}.priority-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.priority-num{position:absolute;top:14px;right:14px;font-family:var(--font-en);font-size:32px;font-weight:700;color:var(--navy-100);line-height:1}.priority-card.featured{background:linear-gradient(135deg,var(--navy-800) 0%,var(--navy-900) 100%);color:#fff;border-color:var(--navy-800)}.priority-card.featured .priority-num{color:#f59e0b66}.priority-card.featured .pc-title{color:#fff}.priority-card.featured .pc-label{color:#ffffff80}.priority-card.featured .pc-text{color:#ffffffd9}.priority-card.featured .pc-meta{border-color:#ffffff1a}.pc-tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-en);font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--gold-600);font-weight:600;width:-moz-fit-content;width:fit-content}.priority-card.featured .pc-tag{color:var(--gold-400)}.pc-title{font-size:15px;font-weight:700;line-height:1.35;padding-right:50px;color:var(--ink-900)}.pc-text{font-size:13px;color:var(--ink-700);line-height:1.5}.pc-label{font-family:var(--font-en);font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-500);font-weight:600;margin-bottom:2px}.pc-meta{border-top:1px solid var(--border);margin-top:auto;padding-top:10px;display:flex;align-items:center;justify-content:space-between;font-size:12px}.pc-progress{display:flex;align-items:center;gap:8px;flex:1}.login-page{min-height:100vh;background:radial-gradient(circle at 15% 20%,rgba(245,158,11,.06) 0%,transparent 40%),radial-gradient(circle at 85% 80%,rgba(30,58,95,.06) 0%,transparent 50%),var(--bg);display:grid;grid-template-columns:1fr 480px;font-family:var(--font-lao)}.login-hero{padding:48px 60px;display:flex;flex-direction:column;justify-content:space-between;background:linear-gradient(160deg,var(--navy-900) 0%,var(--navy-800) 60%,var(--navy-700) 100%);color:#fff;position:relative;overflow:hidden}.login-hero:before{content:"";position:absolute;width:600px;height:600px;border:1px solid rgba(245,158,11,.12);border-radius:50%;top:-200px;right:-200px}.login-hero:after{content:"";position:absolute;width:800px;height:800px;border:1px solid rgba(245,158,11,.06);border-radius:50%;top:-300px;right:-300px}.login-brand{display:flex;align-items:center;gap:14px;position:relative}.login-brand .brand-mark{width:52px;height:52px}.login-brand .brand-mark span{font-size:18px}.login-brand .logo-mark{width:52px;height:52px;border-radius:50%;padding:4px}.login-brand-text .lao-name{font-size:17px;font-weight:600;line-height:1.3}.login-brand-text .en-name{font-family:var(--font-en);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#fff9;margin-top:4px}.login-headline{position:relative;max-width:500px}.login-headline .eyebrow{font-family:var(--font-en);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-400);font-weight:600;margin-bottom:12px}.login-headline h1{font-size:36px;font-weight:700;line-height:1.2;margin:0 0 16px}.login-headline p{font-size:15px;color:#ffffffbf;line-height:1.6;margin:0}.login-stats{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:18px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1)}.login-stat .num{font-family:var(--font-en);font-size:24px;font-weight:700;color:var(--gold-400)}.login-stat .lbl{font-size:12px;color:#ffffffb3;margin-top:2px}.login-stat .lbl-en{font-family:var(--font-en);font-size:10px;color:#fff6;text-transform:uppercase;letter-spacing:.06em}.login-form-wrap{display:flex;align-items:center;justify-content:center;padding:40px}.login-form{width:100%;max-width:360px}.login-form h2{font-size:22px;font-weight:700;margin:0 0 4px}.login-form .sub{font-size:13px;color:var(--ink-500);margin-bottom:28px}.field{margin-bottom:16px}.field label{display:block;font-size:12.5px;font-weight:500;color:var(--ink-700);margin-bottom:6px}.field label .en{font-family:var(--font-en);font-size:10.5px;color:var(--ink-400);margin-left:6px;text-transform:uppercase;letter-spacing:.04em;font-weight:400}.field input{width:100%;padding:10px 13px;border:1px solid var(--border-strong);border-radius:var(--radius);font-size:14px;background:#fff;outline:none;transition:border-color .12s,box-shadow .12s}.field input:focus{border-color:var(--navy-600);box-shadow:0 0 0 3px #1e3a5f14}.row-between{display:flex;align-items:center;justify-content:space-between;margin:18px 0 22px;font-size:12.5px}.row-between label{display:flex;gap:7px;align-items:center;color:var(--ink-700);cursor:pointer}.row-between a{color:var(--navy-700);text-decoration:none;font-weight:500}.btn-block{display:flex;width:100%;justify-content:center;padding:11px 16px;font-size:14px}.login-footer{font-family:var(--font-en);font-size:11px;color:var(--ink-400);text-align:center;margin-top:28px;letter-spacing:.04em}.login-error{background:var(--red-50);border:1px solid var(--red-100);border-radius:var(--radius);padding:10px 14px;font-size:13px;color:var(--red-600);margin-bottom:16px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 20px}.form-grid .full{grid-column:1 / -1}.field textarea{width:100%;padding:10px 13px;border:1px solid var(--border-strong);border-radius:var(--radius);font-size:13px;font-family:var(--font-lao);background:#fff;outline:none;resize:vertical;min-height:80px}.field textarea:focus{border-color:var(--navy-600);box-shadow:0 0 0 3px #1e3a5f14}.field select{width:100%;padding:10px 32px 10px 13px;border:1px solid var(--border-strong);border-radius:var(--radius);font-size:14px;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") no-repeat right 12px center;-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none;cursor:pointer}.slider-field{background:var(--navy-50);border:1px solid var(--navy-100);border-radius:var(--radius-md);padding:14px 16px}.slider-field .top{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.slider-field .top .label{font-size:13px;font-weight:600;color:var(--ink-900)}.slider-field .top .value{font-family:var(--font-en);font-size:22px;font-weight:700;color:var(--navy-800);font-variant-numeric:tabular-nums}input[type=range]{width:100%;-webkit-appearance:none;height:8px;background:var(--grey-200);border-radius:999px;outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:var(--navy-800);border-radius:50%;cursor:pointer;border:3px solid #fff;box-shadow:0 1px 3px #0003}.users-table th,.users-table td{padding:12px 14px}.empty{text-align:center;padding:48px 20px;color:var(--ink-500)}.empty svg{color:var(--ink-300);margin-bottom:12px}.empty .title{font-weight:600;color:var(--ink-700);font-size:14px}.empty .sub{font-size:12.5px;margin-top:4px}.loading{display:flex;align-items:center;justify-content:center;padding:60px;color:var(--ink-400);font-family:var(--font-en);font-size:13px;gap:10px}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.text-sm{font-size:12.5px}.text-muted{color:var(--ink-500)}.fade-in{animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
