.app{min-height:100vh;display:flex;flex-direction:column}.appHeader{background:var(--q4-primary);color:var(--q4-surface);padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;box-shadow:0 1px 3px #0000001f}.appHeaderRight{flex-shrink:0}.appLogo{font-weight:700;font-size:1.25rem;letter-spacing:-.02em}.appLogo span{color:var(--q4-accent)}.appBody{flex:1;display:flex;min-height:0}.sidebar{width:220px;flex-shrink:0;background:var(--q4-primary-light);border-right:1px solid var(--q4-primary-dark);padding:1rem 0}.sidebarList{list-style:none;margin:0;padding:0}.sidebarList li{margin:0}.sidebarLink{display:block;padding:.65rem 1.25rem;color:#ffffffd9;text-decoration:none;font-weight:500;font-size:.9375rem;transition:background .15s,color .15s}.sidebarLink:hover{background:#ffffff0f;color:var(--q4-surface)}.sidebarLinkActive{background:var(--q4-accent);color:var(--q4-primary)}.sidebarGroupLabel{display:block;padding:.5rem 1.25rem .25rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:#ffffff80}.sidebarSublist{list-style:none;margin:0 0 .5rem;padding:0}.sidebarSublist li{margin:0}.sidebarLinkSub{padding-left:2rem;font-size:.875rem}.main{flex:1;display:flex;flex-direction:column;min-height:0;padding:1.5rem;max-width:1400px;width:100%;box-sizing:border-box;overflow:auto}.dashboardPage{display:flex;flex-direction:column;flex:1;min-height:100%}.dashboardPageSpacer{flex:1;min-height:.5rem}.pageTitle{font-size:1.5rem;font-weight:700;color:var(--q4-primary);margin:0 0 1rem}.slaBox{background:var(--q4-surface);border:1px solid var(--q4-border);border-radius:10px;padding:1.25rem 1.5rem;margin-bottom:1.5rem;max-width:420px;box-shadow:0 1px 3px #0000000f;border-left:3px solid var(--q4-accent)}.slaBoxRow{display:flex;gap:2rem;flex-wrap:wrap;align-items:flex-end}.slaBoxItem{display:flex;flex-direction:column;gap:.25rem}.slaBoxItemExpected .slaBoxLabel{font-size:.6875rem}.slaBoxItemExpected .slaBoxValue{font-size:1.125rem;font-weight:600;color:var(--q4-text-secondary)}.slaBoxLabel{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--q4-text-muted)}.slaBoxValue{font-size:1.5rem;font-weight:700;color:var(--q4-primary)}.kpiCards{display:flex;flex-direction:column;gap:1.5rem;max-width:900px}.kpiCard{background:var(--q4-surface);border:1px solid var(--q4-border);border-radius:10px;padding:1.25rem 1.5rem;box-shadow:0 1px 3px #0000000f}.kpiCardUptime{border-left:4px solid var(--q4-accent)}.kpiCardOnTarget{border-left-color:var(--q4-success)}.kpiCardBelowTarget{border-left-color:var(--q4-warning)}.kpiCardTitle{margin:0 0 .25rem;font-size:1.125rem;font-weight:700;color:var(--q4-primary)}.kpiCardSubtitle{margin:0 0 1rem;font-size:.8125rem;color:var(--q4-text-muted)}.kpiCardRow{display:flex;flex-wrap:wrap;align-items:flex-end;gap:1.5rem}.kpiCardValue,.kpiCardTarget{display:flex;flex-direction:column;gap:.2rem}.kpiCardNumber{font-size:1.75rem;font-weight:700;color:var(--q4-primary)}.kpiCardNumberSmall{font-size:1.25rem;color:var(--q4-text-secondary)}.kpiCardLabel{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--q4-text-muted)}.kpiCardBadge{padding:.35rem .75rem;font-size:.8125rem;font-weight:600;border-radius:6px;margin-left:auto}.kpiCardBadgeSuccess{background:#38a16926;color:var(--q4-success)}.kpiCardBadgeWarning{background:#d69e2e26;color:var(--q4-warning)}.kpiCardDetection{border-left:4px solid var(--q4-accent)}.kpiQuarterGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}.kpiQuarterEmpty{margin:0;font-size:.875rem;color:var(--q4-text-muted)}.kpiQuarterItem{background:var(--q4-bg);border:1px solid var(--q4-border);border-radius:8px;padding:.75rem 1.25rem .75rem 1rem;overflow:visible}.kpiQuarterItemCurrent{border-color:var(--q4-accent);background:var(--q4-accent-muted)}.kpiQuarterOnTarget{border-left:3px solid var(--q4-success)}.kpiQuarterBelowTarget{border-left:3px solid var(--q4-warning)}.kpiQuarterHeader{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.35rem;flex-wrap:nowrap;min-width:0}.kpiQuarterLabel{font-size:.875rem;font-weight:600;color:var(--q4-primary);white-space:nowrap;flex-shrink:0}.kpiQuarterCurrentBadge{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--q4-accent);flex-shrink:0;padding-left:.25rem;max-width:100px;text-align:right}.kpiQuarterPercent{display:block;font-size:1.25rem;font-weight:700;color:var(--q4-primary)}.kpiQuarterTargetBadge{display:inline-block;margin-top:.35rem;padding:.2rem .5rem;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;border-radius:4px}.kpiQuarterTargetBadgeOn{background:#38a16926;color:var(--q4-success)}.kpiQuarterTargetBadgeBelow{background:#d69e2e26;color:var(--q4-warning)}.kpiQuarterDetail{display:block;margin-top:.25rem;font-size:.75rem;color:var(--q4-text-muted)}.section{background:var(--q4-surface);border-radius:8px;border:1px solid var(--q4-border);padding:1.25rem 1.5rem;margin-bottom:1.5rem}.sectionHeaderRow{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--q4-accent-muted)}.sectionTitle{font-size:1rem;font-weight:600;color:var(--q4-primary);margin:0 0 1rem;padding-bottom:.5rem;border-bottom:2px solid var(--q4-accent-muted)}.sectionHeaderRow .sectionTitle{margin:0;padding-bottom:0;border-bottom:none}.uptimeRefreshWrap{display:flex;align-items:center;gap:.5rem}.uptimeRefreshLabel{font-size:.75rem;color:var(--q4-text-muted)}.uptimeRefreshBtn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:1px solid var(--q4-border);border-radius:6px;background:var(--q4-surface);color:var(--q4-primary);cursor:pointer;transition:background .15s,border-color .15s}.uptimeRefreshBtn:hover:not(:disabled){background:var(--q4-accent-muted);border-color:var(--q4-accent)}.uptimeRefreshBtn:disabled{cursor:not-allowed;opacity:.7}.uptimeRefreshIcon{flex-shrink:0}.uptimeRefreshIcon.spinning{animation:uptimeRefreshSpin .8s linear infinite}@keyframes uptimeRefreshSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.uptimePrintBar{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.uptimePrintBtn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.9375rem;font-weight:500;color:var(--q4-primary);background:var(--q4-surface);border:1px solid var(--q4-border);border-radius:6px;cursor:pointer}.uptimePrintBtn:hover{background:var(--q4-accent-muted);border-color:var(--q4-accent)}.uptimePrintIcon{flex-shrink:0}.errorBox{background:#fff5f5;border:1px solid #feb2b2;color:var(--q4-error);padding:.75rem 1rem;border-radius:6px;font-size:.875rem}.tableWrap{overflow-x:auto}.dataTable{width:100%;border-collapse:collapse;font-size:.875rem}.dataTable th,.dataTable td{padding:.625rem .75rem;text-align:left;border-bottom:1px solid var(--q4-border)}.dataTable th{font-weight:600;color:var(--q4-text-secondary);background:var(--q4-bg)}.dataTable tr:hover td{background:var(--q4-accent-muted)}.cacheNote{font-size:.75rem;color:var(--q4-text-muted);margin-top:.5rem}.chartContainer{height:260px;margin:.5rem 0}.incidentsTableTitle{font-size:.9375rem;font-weight:600;color:var(--q4-text);margin:1.25rem 0 .5rem}.statusBadge{display:inline-block;padding:.2em .5em;border-radius:4px;font-size:.75rem;font-weight:500}.statusBadge.operational{background:#c6f6d5;color:#276749}.statusBadge.degraded{background:#feebc8;color:#c05621}.statusBadge.outage{background:#fed7d7;color:#c53030}.statusBadge.major_outage{background:#fc8181;color:#742a2a}.statusBadge.default{background:var(--q4-border);color:var(--q4-text-secondary)}.uptimeParentRow{cursor:pointer}.uptimeParentRow:hover{background:var(--q4-accent-muted)}.uptimeToggle{display:inline-block;width:1.25em;margin-right:.25rem;color:var(--q4-text-secondary);font-size:.75rem}.uptimeChildCount{font-weight:400;color:var(--q4-text-muted);font-size:.875rem}.mnpiPage{padding:1rem 1.5rem;max-width:900px}.mnpiIntro{color:var(--q4-text-secondary);font-size:.9375rem;margin:0 0 1rem}.mnpiSearchRow{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-bottom:.5rem}.mnpiSearchInput{width:100%;max-width:320px;padding:.5rem .75rem;font-size:1rem;border:1px solid var(--q4-border);border-radius:6px;background:var(--q4-surface);color:var(--q4-text)}.mnpiSearchInput:focus{outline:none;border-color:var(--q4-accent);box-shadow:0 0 0 2px var(--q4-accent-muted)}.mnpiSearchInput--error{border-color:var(--q4-error)}.mnpiSearchBtn{padding:.5rem 1rem;font-size:.9375rem;font-weight:600;color:var(--q4-primary);background:var(--q4-accent);border:1px solid var(--q4-accent);border-radius:6px;cursor:pointer}.mnpiSearchBtn:hover:not(:disabled){background:var(--q4-accent-hover);border-color:var(--q4-accent-hover)}.mnpiSearchBtn:disabled{opacity:.6;cursor:not-allowed}.mnpiInputError{color:var(--q4-error);font-size:.875rem;margin:0 0 1rem}.mnpiResults{margin-top:1.5rem}.mnpiSection{margin-bottom:1.5rem}.mnpiSectionTitle{font-size:1.125rem;font-weight:600;color:var(--q4-text);margin:0 0 .75rem}.mnpiSectionGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.mnpiSectionGrid--wide{grid-template-columns:repeat(2,1fr)}.mnpiResultBox{background:var(--q4-surface);border:1px solid var(--q4-border);border-radius:8px;padding:1rem;min-height:72px}.mnpiResultBox--withSites{min-height:96px}.mnpiResultBoxTitle{font-size:.875rem;font-weight:600;color:var(--q4-text-secondary);margin-bottom:.5rem}.mnpiResultValue{font-size:1rem;font-weight:600}.mnpiResultValue--yes{color:var(--q4-success)}.mnpiResultValue--no{color:var(--q4-text-muted)}.mnpiResultSites{margin-top:.5rem;font-size:.8125rem;color:var(--q4-text-secondary)}.mnpiResultSitesLabel{font-weight:500}@media print{.appHeader,.sidebar,.cacheNote{display:none!important}.appBody{display:block}.main{max-width:none;padding:0}.uptimePrintBar{display:none!important}.uptimeReportFirstBlock{break-inside:avoid!important;page-break-inside:avoid!important}.uptimeReportHeader{break-after:avoid!important;page-break-after:avoid!important}.sectionContent{break-inside:avoid!important;page-break-inside:avoid!important;overflow:hidden}.section{break-after:avoid;page-break-after:avoid}.section.printBreakAfter{break-after:page!important;page-break-after:always!important}.section:first-of-type{break-before:avoid;page-break-before:avoid}.chartContainer,.tableWrap,.dataTable{break-inside:avoid!important;page-break-inside:avoid!important}}.appHeaderUser{display:flex;align-items:center;gap:1rem}.appHeaderUserName{font-size:.875rem;color:#ffffffe6}.appHeaderLogout{padding:.35rem .75rem;font-size:.8125rem;background:#fff3;color:var(--q4-surface);border:1px solid rgba(255,255,255,.3);border-radius:6px;cursor:pointer}.appHeaderLogout:hover{background:#ffffff4d}.profileMenu{position:relative}.profileMenuTrigger{display:flex;align-items:center;justify-content:center;width:40px;height:40px;min-width:40px;min-height:40px;padding:0;background:#fff3;color:var(--q4-surface);border:1px solid rgba(255,255,255,.4);border-radius:50%;cursor:pointer}.profileMenuTrigger:hover{background:#ffffff4d;border-color:#fff9}.profileMenuTrigger:focus{outline:2px solid var(--q4-accent);outline-offset:2px}.profileMenuInitials{font-size:.875rem;font-weight:700;letter-spacing:-.02em;line-height:1}.profileMenuDropdown{position:absolute;top:100%;right:0;margin-top:.5rem;min-width:200px;background:var(--q4-surface);border:1px solid var(--q4-border);border-radius:8px;box-shadow:0 4px 16px #00000026;padding:.5rem 0;z-index:50}.profileMenuUserName{padding:.5rem 1rem;font-size:.875rem;font-weight:600;color:var(--q4-primary);border-bottom:1px solid var(--q4-border)}.profileMenuItem{display:block;width:100%;padding:.5rem 1rem;font-size:.875rem;text-align:left;background:none;border:none;color:var(--q4-text-secondary);cursor:pointer}.profileMenuItem:hover{background:var(--q4-accent-muted);color:var(--q4-primary)}.profileModalOverlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.profileModal{background:var(--q4-surface);border-radius:10px;padding:1.5rem;width:100%;max-width:400px;box-shadow:0 4px 24px #00000026}.profileModal h2{margin:0 0 .5rem;font-size:1.25rem;color:var(--q4-primary)}.profileModalHint{margin:0 0 1rem;font-size:.8125rem;color:var(--q4-text-muted)}.profileModalError{margin:0 0 1rem;padding:.5rem .75rem;background:#fef2f2;color:#b91c1c;border-radius:6px;font-size:.875rem}.profileModal label{display:block;margin-bottom:1rem;font-size:.875rem;font-weight:500;color:var(--q4-text-secondary)}.profileModal label input{display:block;width:100%;margin-top:.35rem;padding:.5rem .75rem;font-size:1rem;border:1px solid var(--q4-border);border-radius:6px;box-sizing:border-box}.profileModalActions{margin-top:1.25rem;display:flex;gap:.75rem}.profileModalActions button{padding:.5rem 1rem;font-size:.875rem;border-radius:6px;cursor:pointer}.profileModalActions button[type=submit]{background:var(--q4-accent);color:var(--q4-primary);border:none;font-weight:600}.profileModalActions button[type=button]{background:var(--q4-surface);color:var(--q4-text-secondary);border:1px solid var(--q4-border)}.profileModalActions button:disabled{opacity:.7;cursor:not-allowed}.loginPage{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--q4-primary-light);padding:1.5rem}.loginCard{background:var(--q4-surface);border-radius:10px;box-shadow:0 4px 20px #0000001a;padding:2rem;width:100%;max-width:380px}.loginCard h1{margin:0 0 .25rem;font-size:1.5rem;color:var(--q4-primary);text-align:center}.loginSub{margin:0 0 1.5rem;font-size:.875rem;color:var(--q4-text-muted);text-align:center}.loginError{margin:0 0 1rem;padding:.5rem .75rem;background:#fef2f2;color:#b91c1c;border-radius:6px;font-size:.875rem}.loginCard label{display:block;margin-bottom:1rem;font-size:.875rem;font-weight:500;color:var(--q4-text-secondary)}.loginCard label input{display:block;width:100%;margin-top:.35rem;padding:.5rem .75rem;font-size:1rem;border:1px solid var(--q4-border);border-radius:6px;box-sizing:border-box}.loginCard button{margin-top:.5rem;padding:.6rem 1.25rem;font-size:1rem;font-weight:600;background:var(--q4-accent);color:var(--q4-primary);border:none;border-radius:6px;cursor:pointer}.loginCard button:disabled{opacity:.7;cursor:not-allowed}.authLoading{padding:1.5rem}.adminPage{padding:0}.adminHeader{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.adminHeader h1{margin:0;font-size:1.5rem;color:var(--q4-primary)}.adminAddBtn{padding:.5rem 1rem;font-size:.875rem;font-weight:600;background:var(--q4-accent);color:var(--q4-primary);border:none;border-radius:6px;cursor:pointer}.adminError{margin:0 0 1rem;padding:.5rem .75rem;background:#fef2f2;color:#b91c1c;border-radius:6px;font-size:.875rem}.adminTable{width:100%;border-collapse:collapse;background:var(--q4-surface);border:1px solid var(--q4-border);border-radius:8px;overflow:hidden}.adminTable th,.adminTable td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--q4-border)}.adminTable th{background:var(--q4-primary-light);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--q4-text-muted)}.adminTable tbody tr:last-child td{border-bottom:none}.adminTable button{margin-right:.5rem;padding:.35rem .65rem;font-size:.8125rem;background:var(--q4-primary);color:var(--q4-surface);border:none;border-radius:4px;cursor:pointer}.adminDeleteBtn{background:transparent!important;color:#b91c1c!important;border:1px solid #b91c1c!important}.adminModal{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.adminModalContent{background:var(--q4-surface);border-radius:10px;padding:1.5rem;width:100%;max-width:400px;box-shadow:0 4px 24px #00000026}.adminModalContent h2{margin:0 0 1rem;font-size:1.25rem;color:var(--q4-primary)}.adminModalContent label{display:block;margin-bottom:1rem;font-size:.875rem;font-weight:500;color:var(--q4-text-secondary)}.adminModalContent label input[type=text],.adminModalContent label input[type=email],.adminModalContent label input[type=password]{display:block;width:100%;margin-top:.35rem;padding:.5rem .75rem;font-size:1rem;border:1px solid var(--q4-border);border-radius:6px;box-sizing:border-box}.adminModalContent .adminRoleSelect{display:block;width:100%;margin-top:.35rem;padding:.5rem .75rem;font-size:1rem;border:1px solid var(--q4-border);border-radius:6px;box-sizing:border-box;background:var(--q4-surface);color:var(--q4-text)}.adminCheckLabel{display:flex!important;align-items:center;gap:.5rem}.adminCheckLabel input{margin-top:0!important;width:auto!important}.adminFormActions{margin-top:1.25rem;display:flex;gap:.75rem}.adminFormActions button{padding:.5rem 1rem;font-size:.875rem;border-radius:6px;cursor:pointer}.adminFormActions button[type=submit]{background:var(--q4-accent);color:var(--q4-primary);border:none;font-weight:600}.adminFormActions button[type=button]{background:var(--q4-surface);color:var(--q4-text-secondary);border:1px solid var(--q4-border)}.adminFormActions button:disabled{opacity:.7;cursor:not-allowed}.forecastRangeBar{display:flex;align-items:center;flex-wrap:wrap;gap:1rem 1.5rem;margin-bottom:.25rem;padding-bottom:1rem;border-bottom:1px solid var(--q4-border)}.forecastRangeLabel{display:flex;align-items:center;gap:.75rem}.forecastRangeLabelText{font-weight:600;font-size:.9375rem}.forecastDaysSelect{padding:.4rem .65rem;border-radius:6px;border:1px solid var(--q4-border);background:var(--q4-surface);color:var(--q4-text);font-size:.9375rem;min-width:12rem}.forecastRangeMeta{font-size:.875rem;color:var(--q4-text-secondary)}.forecastChartTypeToggle{display:flex;gap:0;border-radius:6px;overflow:hidden;border:1px solid var(--q4-border)}.forecastChartTypeBtn{padding:.5rem;display:inline-flex;align-items:center;justify-content:center;background:var(--q4-surface);color:var(--q4-text-secondary);border:none;cursor:pointer;transition:background .15s,color .15s}.forecastChartTypeBtn:not(:last-child){border-right:1px solid var(--q4-border)}.forecastChartTypeBtn:hover{background:var(--q4-bg-muted, #f0f0f0);color:var(--q4-text)}.forecastChartTypeBtn--active{background:var(--q4-accent);color:var(--q4-primary)}.forecastPageTitle{margin-top:1rem}.forecastAccountGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-bottom:2rem;margin-top:.5rem}.forecastAccountCard{border:1px solid var(--q4-border);border-radius:8px;padding:1rem;background:var(--q4-surface)}.forecastAccountHeader{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.forecastAccountTitle{margin:0;font-size:1rem;font-weight:600}.forecastAccountMetrics{display:flex;flex-direction:column;align-items:flex-end;gap:.35rem;text-align:right}.forecastAccountTotal{font-size:.9375rem;font-weight:600;color:var(--q4-accent);white-space:nowrap}.forecastAccountForecast{font-size:.8125rem;font-weight:600;color:var(--q4-text-secondary);white-space:normal;max-width:16rem;line-height:1.35}.forecastChartWrap--account{min-height:240px}.forecastChartBlock--snowflake{margin-top:1rem}.forecastChartBlock{margin-bottom:2rem}.forecastChartTitle{font-size:1.05rem;margin:0 0 .75rem}.forecastChartWrap{width:100%;min-height:280px}.forecastEmpty{color:var(--q4-text-secondary);margin:0}.forecastQueryError .forecastQueryPreview{margin:.75rem 0 0;font-size:.75rem;overflow-x:auto;white-space:pre-wrap;word-break:break-all}.forecastTooltip{background:var(--q4-surface);border:1px solid var(--q4-border);border-radius:8px;padding:.6rem .75rem;box-shadow:0 4px 12px #0000001f}.forecastTooltipTitle{font-weight:600;margin-bottom:.35rem}.forecastTooltipList{list-style:none;margin:0;padding:0}.forecastTooltipList li{display:flex;align-items:center;gap:.35rem;font-size:.8125rem;margin-top:.25rem}.forecastTooltipSwatch{width:8px;height:8px;border-radius:2px;flex-shrink:0}:root{--q4-primary: #0d1b2a;--q4-primary-light: #1b2838;--q4-primary-dark: #061018;--q4-accent: #00a3e0;--q4-accent-hover: #008fc7;--q4-accent-muted: rgba(0, 163, 224, .12);--q4-bg: #f5f7fa;--q4-surface: #ffffff;--q4-border: #e2e8f0;--q4-text: #1a202c;--q4-text-secondary: #4a5568;--q4-text-muted: #718096;--q4-success: #38a169;--q4-warning: #d69e2e;--q4-error: #e53e3e;--q4-info: #3182ce;--q4-font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}body{margin:0;font-family:var(--q4-font-sans);font-size:14px;line-height:1.5;color:var(--q4-text);background:var(--q4-bg);-webkit-font-smoothing:antialiased}#root{min-height:100vh}
