:root{--navy: #0B2C5C;--blue: #185FA5;--blue-soft: #E6F1FB;--ink: #0F172A;--text: #1F2937;--muted: #64748B;--line: #E2E8F0;--bg: #F4F6FA;--surface: #FFFFFF;--green: #16A34A;--green-soft: #DCFCE7;--amber: #D97706;--amber-soft: #FEF3C7;--red: #DC2626;--red-soft: #FEE2E2;--slate-soft: #E5E7EB;--r-md: 8px;--r-lg: 12px}*{box-sizing:border-box}body{margin:0;font-family:Calibri,Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}a{color:var(--blue);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer}.btn-primary{background:var(--blue);color:#fff;border:none;padding:8px 16px;border-radius:var(--r-md);font-weight:500;font-size:14px}.btn-primary:hover{background:var(--navy)}.btn-secondary{background:transparent;color:var(--ink);border:1px solid var(--line);padding:8px 16px;border-radius:var(--r-md);font-size:14px}.btn-secondary:hover{background:var(--bg)}input,select{width:100%;padding:8px 12px;border:1px solid var(--line);border-radius:var(--r-md);font-size:14px;font-family:inherit;background:var(--surface)}input:focus,select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-soft)}.app-shell{min-height:100vh;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:var(--surface);border-bottom:1px solid var(--line)}.logo{display:flex;align-items:center;gap:10px;font-weight:500}.logo-mark{width:26px;height:26px;background:var(--blue);color:#fff;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;font-weight:500}.topnav{display:flex;gap:20px;color:var(--muted);font-size:14px}.topnav a.active{color:var(--ink);font-weight:500}.avatar{width:30px;height:30px;border-radius:50%;background:var(--blue-soft);color:var(--navy);display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:500}.page{padding:24px;max-width:1280px;margin:0 auto;width:100%}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.page-title{font-size:22px;font-weight:500;margin:0}.page-sub{font-size:13px;color:var(--muted);margin:4px 0 0}.kpi-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:24px}.kpi-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:10px 14px}.kpi-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:500}.kpi-value{font-size:22px;font-weight:500;margin-top:2px;line-height:1.1}.project-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.project-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:16px;text-decoration:none;color:inherit}.project-card:hover{border-color:var(--blue)}.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:500;padding:3px 10px;border-radius:999px;white-space:nowrap}.badge-ok{background:var(--green-soft);color:#14532d}.badge-am{background:var(--amber-soft);color:#78350f}.badge-rd{background:var(--red-soft);color:#7f1d1d}.badge-gr{background:var(--slate-soft);color:var(--muted)}.dot{width:6px;height:6px;border-radius:50%;display:inline-block}.dot-ok{background:#166534}.dot-am{background:#92400e}.dot-rd{background:#991b1b}.progress{height:6px;background:var(--blue-soft);border-radius:3px;overflow:hidden}.progress-bar{height:100%;background:var(--blue);border-radius:3px}.progress-bar-late{background:var(--red)}.tbl{width:100%;border-collapse:collapse;font-size:13px}.tbl th{text-align:left;padding:10px 12px;color:var(--muted);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--line);background:var(--bg)}.tbl td{padding:12px;border-bottom:1px solid var(--line)}.tbl tr:last-child td{border-bottom:none}.tbl.tbl-compact th{padding:6px 10px}.tbl.tbl-compact td{padding:6px 10px;font-size:13px}.surface{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.login-card{width:380px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:32px}.login-title{font-size:20px;font-weight:500;margin:0 0 4px;text-align:center}.login-sub{font-size:13px;color:var(--muted);margin:0 0 24px;text-align:center}.field{margin-bottom:14px}.field label{display:block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:500;margin-bottom:4px}.portal-hero{background:linear-gradient(180deg,var(--navy) 0%,var(--blue) 100%);color:#fff;padding:40px 32px;border-radius:var(--r-lg) var(--r-lg) 0 0}.portal-hero h1{font-size:24px;font-weight:500;margin:0 0 8px}.portal-hero p{color:#b5d4f4;margin:0}.portal-hero-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:24px}.tag-strip{font-size:11px;color:#85b7eb;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.active-time-widget{display:inline-flex;align-items:center;gap:8px;padding:4px 12px 4px 10px;border-radius:999px;font-size:12px;max-width:380px}.active-time-widget.atw-on{background:#dcfce7;border:1px solid #86EFAC;color:#14532d}.active-time-widget.atw-off{background:#fee2e2;border:1px solid #DC2626;color:#991b1b;font-weight:500;animation:atw-soft-pulse 2.4s infinite}@keyframes atw-soft-pulse{0%,to{box-shadow:0 0 #dc262666}50%{box-shadow:0 0 0 4px #dc262600}}.atw-pulse{font-size:10px;animation:atw-blink 1.4s infinite}.atw-pulse-green{color:#16a34a}.atw-pulse-red{color:#dc2626}@keyframes atw-blink{0%,40%{opacity:1}60%,to{opacity:.3}}.atw-alert-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.atw-link{display:inline-flex;flex-direction:column;text-decoration:none;color:inherit;line-height:1.1;max-width:200px}.atw-link:hover{text-decoration:underline}.atw-stage{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.atw-project{font-size:10px;opacity:.75;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.atw-time{font-family:monospace;font-weight:500;font-size:13px;margin-left:4px}.atw-stop{background:#dc2626;color:#fff;border:none;border-radius:50%;width:22px;height:22px;font-size:11px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0}.atw-stop:hover{background:#991b1b}.tbl tr.stage-being-tracked>td{background:#ecfdf5}.tbl tr.stage-being-tracked>td:first-child{border-left:3px solid #16A34A}.stage-live-badge{display:inline-flex;align-items:center;gap:4px;margin-left:8px;padding:2px 8px;background:#16a34a;color:#fff;font-size:10px;font-weight:500;border-radius:999px;text-transform:uppercase;letter-spacing:.05em;vertical-align:middle}.stage-live-dot{display:inline-block;width:6px;height:6px;background:#fff;border-radius:50%;animation:live-pulse 1.2s infinite}@keyframes live-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.4)}}.stage-track-btn{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:var(--surface);border:1px solid var(--line);border-radius:999px;font-size:12px;color:var(--text);cursor:pointer}.stage-track-btn:hover{border-color:var(--blue)}.stage-track-btn.active{background:#fee2e2;border-color:#dc2626;color:#991b1b;font-family:monospace}.stage-track-btn .play-icon{color:#16a34a;font-size:10px}.stage-track-btn.active .pause-icon{color:#dc2626;font-size:10px}.stage-expand-btn{background:transparent;border:1px solid var(--line);border-radius:var(--r-md);padding:2px 8px;font-size:12px;color:var(--muted);cursor:pointer;display:inline-flex;align-items:center;gap:4px;min-width:36px;justify-content:center}.stage-expand-btn:hover{background:var(--bg);color:var(--ink)}.stage-expand-count{background:var(--blue-soft);color:var(--navy);font-size:10px;font-weight:500;padding:0 5px;border-radius:999px;min-width:16px;text-align:center}.stage-expand-row>td{background:var(--bg);padding:0!important;border-bottom:1px solid var(--line)}.activities-panel{padding:12px 16px 16px}.activities-table{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);margin-bottom:12px}.activities-table th{background:var(--surface)}.activity-form-mini{display:flex;gap:8px;align-items:center;background:var(--surface);padding:8px;border:1px dashed var(--line);border-radius:var(--r-md)}.project-tabs{display:flex;gap:0;border-bottom:1px solid var(--line);margin-top:24px;overflow-x:auto;overflow-y:hidden}.project-tab{padding:12px 16px;font-size:14px;color:var(--muted);text-decoration:none;border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap;transition:color .15s,border-color .15s}.project-tab:hover{color:var(--ink);text-decoration:none}.project-tab.active{color:var(--blue);border-bottom-color:var(--blue);font-weight:500}.portal-shell{max-width:1400px;margin:0 auto;padding:24px;width:100%}.portal-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px;margin-top:16px}.portal-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 18px;min-width:0}.portal-col-5{grid-column:span 5}.portal-col-6{grid-column:span 6}.portal-col-7{grid-column:span 7}.portal-col-12{grid-column:span 12}.portal-section-title{font-size:13px;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 12px;display:flex;align-items:baseline;gap:6px}@media (max-width: 1100px){.portal-col-5,.portal-col-6,.portal-col-7{grid-column:span 12}}@media (max-width: 700px){.portal-shell{padding:12px}.portal-grid{gap:12px}}
