:root{--teal:#2cc5c5;--teal-d:#23a3a3;--teal-bg:#2cc5c514;--bg:#f0f4f8;--white:#fff;--text:#111827;--sub:#374151;--muted:#6b7280;--border:#e5e7eb;--radius:10px;--shadow:0 1px 3px #00000012}*,:before,:after{box-sizing:border-box}body{color:var(--text);background:var(--bg);margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px}.portal-login-body{min-height:100vh}.login-wrap{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--white);border-radius:14px;width:100%;max-width:420px;overflow:hidden;box-shadow:0 8px 30px #0000001f}.login-head{text-align:center;color:#d1d5db;background:#111827;padding:28px}.login-head img{max-height:36px;margin-bottom:8px}.login-subtitle{letter-spacing:.5px;text-transform:uppercase;font-size:12px}.login-body{padding:28px}.login-body h2{margin:0 0 4px;font-size:20px}.login-body p{color:var(--muted);margin:0 0 18px}.login-label{color:var(--sub);letter-spacing:.3px;text-transform:uppercase;margin-bottom:6px;font-size:11px;font-weight:700;display:block}.login-input{border:1.5px solid var(--border);letter-spacing:3px;text-align:center;text-transform:uppercase;border-radius:8px;width:100%;padding:11px 14px;font-size:18px}.login-input.err{border-color:#ef4444}.login-hint{color:var(--muted);margin-top:6px;font-size:12px}.login-error{color:#b91c1c;font-size:12px}.btn-login{color:#fff;background:var(--teal);border:none;border-radius:8px;width:100%;margin-top:16px;padding:11px 12px;font-weight:600}.btn-login:hover{background:var(--teal-d)}.portal-wrap{min-height:100vh}.portal-header{z-index:10;background:#111827;justify-content:space-between;align-items:center;height:56px;padding:0 20px;display:flex;position:sticky;top:0}.portal-header img{max-height:32px}.portal-brand{color:#f3f4f6;font-size:16px;font-weight:700}.hdr-right{align-items:center;gap:10px;display:flex}.hdr-client{color:#d1d5db;font-size:13px}.btn-logout{color:#fff;background:#ffffff1f;border:none;border-radius:6px;padding:6px 10px;font-size:12px}.portal-tabs{border-bottom:1px solid var(--border);background:#fff;gap:4px;padding:0 16px;display:flex;overflow-x:auto}.p-tab{color:var(--muted);white-space:nowrap;border-bottom:2px solid #0000;align-items:center;padding:13px 12px;font-size:13px;font-weight:600;text-decoration:none;display:inline-flex}.p-tab:hover{color:var(--text)}.p-tab.active{color:var(--teal);border-bottom-color:var(--teal)}.portal-content{max-width:980px;margin:0 auto;padding:20px}.portal-alert{border:0;border-radius:8px}.card{border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);background:#fff;padding:18px}.card-head{justify-content:space-between;align-items:flex-start;margin-bottom:14px;display:flex}.card-title{font-size:16px;font-weight:700}.card-sub{color:var(--muted);margin-top:2px;font-size:12px}.stat-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.stat-card{border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);background:#fff;padding:14px}.stat-label{color:var(--muted);text-transform:uppercase;letter-spacing:.3px;font-size:11px}.stat-value{margin-top:4px;font-size:21px;font-weight:700}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}th{text-transform:uppercase;letter-spacing:.4px;color:var(--muted);text-align:left;border-bottom:1px solid var(--border);padding:8px 10px;font-size:11px}td{border-bottom:1px solid var(--border);vertical-align:top;padding:10px;font-size:13px}tr:last-child td{border-bottom:none}.tl-wrap{padding-left:24px;position:relative}.tl-wrap:before{content:"";background:var(--border);width:2px;position:absolute;top:4px;bottom:4px;left:8px}.tl-item{padding-bottom:14px;position:relative}.tl-dot{border:2px solid var(--border);background:#fff;border-radius:50%;width:12px;height:12px;position:absolute;top:3px;left:-20px}.tl-item.done .tl-dot{border-color:var(--teal);background:var(--teal)}.tl-item.in_progress .tl-dot{background:#6366f1;border-color:#6366f1}.tl-milestone{font-weight:600}.tl-meta{align-items:center;gap:8px;margin-top:4px;display:flex}.tl-date{color:var(--muted);font-size:12px}.del-list{flex-direction:column;gap:8px;display:flex}.del-item{border:1px solid var(--border);background:#f9fafb;border-radius:8px;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;display:flex}.del-title{font-weight:600}.upd-list{flex-direction:column;gap:12px;display:flex}.upd-item{border-bottom:1px solid var(--border);gap:10px;padding-bottom:12px;display:flex}.upd-item:last-child{border-bottom:none;padding-bottom:0}.upd-dot{background:var(--teal);border-radius:50%;width:8px;height:8px;margin-top:5px}.upd-title{font-weight:600}.upd-body{color:var(--sub);margin-top:2px}.upd-meta{color:var(--muted);margin-top:4px;font-size:12px}.notif-bell{color:#fff;background:#ffffff0f;border:none;border-radius:6px;width:34px;height:34px;position:relative}.notif-badge{color:#fff;background:#ef4444;border-radius:999px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;display:inline-flex;position:absolute;top:2px;right:2px}@media (width<=768px){.portal-content{padding:12px}.stat-row{grid-template-columns:1fr}.hdr-client{display:none}}
