@import"https://fonts.googleapis.com/css2?family=Manrope:wght@500;600;700&display=swap";.analytics-dash{--ad-bg: #f8fbff;--ad-surface: #ffffff;--ad-surface-hover: #f8fbff;--ad-glass: #ffffff;--ad-glass-border: #dbeafe;--ad-text: #1e293b;--ad-text-muted: #64748b;--ad-primary: #2563eb;--ad-primary-dark: #1d4ed8;--ad-primary-glow: rgba(37, 99, 235, .16);--ad-success: #137f5d;--ad-warning: #b7791f;--ad-danger: #b12233;--ad-info: #0284c7;--ad-radius: 14px;--ad-shadow: 0 6px 16px rgba(37, 99, 235, .07);min-height:100vh;background:var(--ad-bg);padding:20px 24px 32px;display:grid;gap:16px;animation:analytics-dash-fadein .6s ease-out both}@keyframes analytics-dash-fadein{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.analytics-dash__header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;border:1px solid var(--ad-primary-dark);border-radius:12px;background:linear-gradient(135deg,var(--ad-primary) 0%,var(--ad-primary-dark) 100%);padding:14px 16px;box-shadow:var(--ad-shadow)}.analytics-dash__title{margin:0;font-size:clamp(20px,2vw,24px);font-weight:700;color:#fff;letter-spacing:0;display:flex;align-items:center;gap:10px}.analytics-dash__title-icon{width:32px;height:32px;border-radius:8px;background:#ffffff29;border:1px solid rgba(255,255,255,.28);display:inline-flex;align-items:center;justify-content:center;box-shadow:none}.analytics-dash__title-icon svg{width:18px;height:18px;fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.analytics-dash__subtitle{margin:4px 0 0;color:#dbeafe;font-size:13px}.analytics-dash__date-badge{border:1px solid rgba(255,255,255,.32);border-radius:8px;background:#ffffff29;padding:7px 10px;color:#fff;font-size:12px;font-weight:600;display:flex;align-items:center;gap:6px;white-space:nowrap}.analytics-dash__date-badge:before{content:"";width:8px;height:8px;border-radius:999px;background:var(--ad-success);animation:analytics-pulse 2s ease-in-out infinite}.analytics-derived-error,.analytics-empty-note{margin:0;color:var(--ad-text-muted);font-size:13px}.analytics-derived-error{border:1px solid #fecdd3;border-radius:10px;background:#fff1f2;color:#8f1e2d;padding:10px 12px;font-weight:700}.analytics-empty-note{padding:0 16px 16px}@keyframes analytics-pulse{0%,to{opacity:1;box-shadow:0 0 #137f5d47}50%{opacity:.72;box-shadow:0 0 0 6px #137f5d00}}.analytics-kpi-row{display:grid;gap:10px;grid-template-columns:repeat(4,1fr)}.analytics-kpi-card{border:1px solid var(--ad-glass-border);border-radius:10px;background:var(--ad-surface);padding:12px 14px;display:grid;gap:7px;box-shadow:var(--ad-shadow);transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease;animation:analytics-card-pop .5s ease-out both;position:relative;overflow:hidden}.analytics-kpi-card:before{content:"";position:absolute;inset:0 auto 0 0;width:3px;height:auto;background:var(--ad-primary);pointer-events:none}.analytics-kpi-card:nth-child(1){animation-delay:.08s}.analytics-kpi-card:nth-child(2){animation-delay:.16s}.analytics-kpi-card:nth-child(3){animation-delay:.24s}.analytics-kpi-card:nth-child(4){animation-delay:.32s}@keyframes analytics-card-pop{0%{opacity:0;transform:translateY(18px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.analytics-kpi-card:hover{transform:translateY(-1px);border-color:#bfdbfe;box-shadow:0 8px 18px #2563eb1a}.analytics-kpi-card--primary{border-left:3px solid var(--ad-primary)}.analytics-kpi-card--info{border-left:3px solid var(--ad-info)}.analytics-kpi-card--success{border-left:3px solid var(--ad-success)}.analytics-kpi-card--danger{border-left:3px solid var(--ad-danger)}.analytics-kpi-card--primary:before{background:var(--ad-primary)}.analytics-kpi-card--info:before{background:var(--ad-info)}.analytics-kpi-card--success:before{background:var(--ad-success)}.analytics-kpi-card--danger:before{background:var(--ad-danger)}.analytics-kpi-card__label{color:var(--ad-text-muted);font-size:12px;font-weight:600;text-transform:none;letter-spacing:0}.analytics-kpi-card__value-row{display:flex;align-items:baseline;gap:8px}.analytics-kpi-card__value{font-size:28px;font-weight:700;line-height:1;color:var(--ad-text)}.analytics-kpi-card--danger .analytics-kpi-card__value{color:var(--ad-danger)}.analytics-kpi-card__unit{color:var(--ad-text-muted);font-size:13px}.analytics-kpi-card__trend{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:2px 7px;border-radius:7px;width:fit-content}.analytics-kpi-card__trend--up{background:#137f5d1a;color:var(--ad-success)}.analytics-kpi-card__trend--down{background:#b122331a;color:var(--ad-danger)}.analytics-kpi-card__trend--neutral{background:#eff6ff;color:var(--ad-text-muted)}.analytics-charts-row{display:grid;gap:16px;grid-template-columns:1.6fr 1fr}.analytics-chart-card{border:1px solid var(--ad-glass-border);border-radius:var(--ad-radius);background:var(--ad-surface);padding:20px;box-shadow:var(--ad-shadow);animation:analytics-card-pop .55s ease-out both;animation-delay:.35s}.analytics-chart-card:nth-child(2){animation-delay:.45s}.analytics-chart-card__title{margin:0 0 16px;color:var(--ad-text);font-size:16px;font-weight:700;display:flex;align-items:center;gap:8px}.analytics-chart-card__title-dot{width:8px;height:8px;border-radius:999px;flex-shrink:0}.analytics-chart-card__title-dot--bar{background:var(--ad-primary)}.analytics-chart-card__title-dot--donut{background:var(--ad-warning)}.analytics-bar-legend{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px;padding-top:10px;border-top:1px solid var(--ad-glass-border)}.analytics-bar-legend__item{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--ad-text-muted)}.analytics-bar-legend__swatch{width:10px;height:10px;border-radius:3px;flex-shrink:0}.analytics-alerts-section{animation:analytics-card-pop .55s ease-out both;animation-delay:.52s}.analytics-alerts-card{border:1px solid var(--ad-glass-border);border-radius:var(--ad-radius);background:var(--ad-surface);padding:20px;box-shadow:var(--ad-shadow)}.analytics-alerts-card__header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.analytics-alerts-card__title{margin:0;color:var(--ad-text);font-size:16px;font-weight:700;display:flex;align-items:center;gap:8px}.analytics-alerts-card__badge{background:#fff1f2;color:var(--ad-danger);padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700;letter-spacing:0}.analytics-alerts-table{width:100%;border-collapse:separate;border-spacing:0 6px}.analytics-alerts-table thead th{background:transparent;color:var(--ad-text-muted);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0;padding:8px 12px;border:none;text-align:left}.analytics-alerts-table tbody tr{background:#f8fbff;border-radius:10px;transition:background .2s ease,transform .2s ease}.analytics-alerts-table tbody tr:hover{background:#eff6ff;transform:translate(2px)}.analytics-alerts-table tbody td{padding:12px;color:var(--ad-text);font-size:13px;border:none;border-bottom:1px solid #dbeafe}.analytics-alerts-table tbody td:first-child{border-radius:10px 0 0 10px}.analytics-alerts-table tbody td:last-child{border-radius:0 10px 10px 0}.analytics-alert-code{font-weight:700;color:var(--ad-primary);font-family:JetBrains Mono,Fira Code,monospace;font-size:12px}.analytics-severity{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0}.analytics-severity--critical{background:#fff1f2;color:var(--ad-danger)}.analytics-severity--high{background:#fff7ed;color:var(--ad-warning, #b7791f)}.analytics-severity--medium{background:#e0f2fe;color:var(--ad-info)}.analytics-severity__dot{width:6px;height:6px;border-radius:999px;animation:analytics-pulse 2s ease-in-out infinite}.analytics-severity--critical .analytics-severity__dot{background:var(--ad-danger)}.analytics-severity--high .analytics-severity__dot{background:var(--ad-warning)}.analytics-severity--medium .analytics-severity__dot{background:var(--ad-info)}.analytics-elapsed{color:var(--ad-text-muted);font-weight:600}.analytics-action-btn{border:1px solid #fecdd3;border-radius:8px;background:#fff1f2;color:var(--ad-danger);padding:6px 14px;font-size:12px;font-weight:700;cursor:pointer;transition:background .2s ease,transform .15s ease,box-shadow .2s ease;white-space:nowrap}.analytics-action-btn:hover{background:#ffe4e6;transform:scale(1.04);box-shadow:0 4px 12px #b1223324}.analytics-chart-card .recharts-cartesian-grid line{stroke:#dbeafe}.analytics-chart-card .recharts-text{fill:var(--ad-text-muted);font-size:11px}.analytics-chart-card .recharts-tooltip-wrapper{outline:none}.analytics-chart-card .recharts-default-tooltip{background:#fff!important;border:1px solid #bfdbfe!important;border-radius:10px!important;box-shadow:0 10px 24px #2563eb24!important;padding:10px 14px!important}.analytics-chart-card .recharts-tooltip-label{color:var(--ad-text)!important;font-weight:700!important;margin-bottom:4px!important}.analytics-chart-card .recharts-tooltip-item{color:var(--ad-text)!important;font-size:12px!important;padding:1px 0!important}@media (max-width: 1200px){.analytics-kpi-row{grid-template-columns:repeat(2,1fr)}.analytics-charts-row{grid-template-columns:1fr}}@media (max-width: 768px){.analytics-dash{padding:16px;gap:16px}.analytics-kpi-row{grid-template-columns:1fr}.analytics-kpi-card__value{font-size:28px}.analytics-alerts-table{display:block;overflow-x:auto}.analytics-dash__header{flex-direction:column;align-items:flex-start}}.coming-soon{min-height:70vh;display:flex;align-items:center;justify-content:center;padding:32px;animation:analytics-dash-fadein .6s ease-out both}.coming-soon__card{max-width:520px;width:100%;border:1px solid var(--ad-glass-border, #dbeafe);border-radius:16px;background:#fff;padding:48px 40px;text-align:center;display:grid;gap:20px;justify-items:center;box-shadow:0 18px 40px #2563eb1f;position:relative;overflow:hidden}.coming-soon__icon{width:72px;height:72px;border-radius:20px;background:linear-gradient(135deg,var(--ad-primary, #2563eb),var(--ad-primary-dark, #1d4ed8));display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px #2563eb38;animation:coming-soon-float 3s ease-in-out infinite}@keyframes coming-soon-float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.coming-soon__icon svg{width:36px;height:36px;fill:none;stroke:#fff;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.coming-soon__badge{display:inline-flex;align-items:center;gap:6px;padding:5px 14px;border-radius:999px;background:#fff7ed;border:1px solid #fed7aa;color:var(--ad-warning);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:0}.coming-soon__badge:before{content:"";width:6px;height:6px;border-radius:999px;background:var(--ad-warning, #b7791f);animation:analytics-pulse 2s ease-in-out infinite}.coming-soon__title{margin:0;color:var(--ad-text, #1e293b);font-size:24px;font-weight:700}.coming-soon__desc{margin:0;color:var(--ad-text-muted, #64748b);font-size:15px;line-height:1.6}.coming-soon__vision{margin:8px 0 0;border:1px solid #bfdbfe;border-radius:12px;background:#eff6ff;padding:14px 18px;color:#1d4ed8;font-size:13px;line-height:1.55;text-align:left}.coming-soon__vision strong{color:var(--ad-primary, #2563eb)}.coming-soon__phase{display:inline-flex;align-items:center;gap:6px;padding:6px 16px;border-radius:999px;background:#eff6ff;border:1px solid #bfdbfe;color:var(--ad-primary, #2563eb);font-size:12px;font-weight:600}.ops-dashboard{--dash-surface: #ffffff;--dash-surface-muted: #eef2ff;--dash-border: #e2e8f0;--dash-text: #334155;--dash-muted: #64748b;--dash-primary: #2563eb;--dash-primary-soft: #eef2ff;--dash-shadow: 0 8px 20px rgba(15, 23, 42, .06);display:grid;gap:14px}.ops-dashboard__hero{border:1px solid var(--dash-primary);border-radius:16px;padding:18px;background:var(--dash-primary);color:#fff;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;box-shadow:var(--dash-shadow)}.ops-dashboard__hero-nav{width:38px;height:38px;border-radius:999px;border:1px solid rgba(255,255,255,.45);background:#ffffff29;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:24px;line-height:1;padding:0}.ops-dashboard__hero-nav:hover{background:#ffffff42}.ops-dashboard__hero-content{text-align:center;display:grid;gap:8px}.ops-dashboard__hero-company{margin:0;font-size:clamp(26px,4vw,38px);letter-spacing:.08em;text-transform:uppercase;font-weight:700}.ops-dashboard__hero-title{margin:0;font-size:clamp(14px,1.8vw,18px);line-height:1.3;color:#fffffff2;letter-spacing:.1em;text-transform:uppercase}.ops-dashboard__hero-subtitle{margin:0;max-width:620px;justify-self:center;color:#ffffffd9;font-size:13px}.ops-dashboard__hero-dots{margin-top:4px;display:inline-flex;justify-self:center;gap:6px}.ops-dashboard__hero-dot{width:6px;height:6px;border-radius:999px;background:#ffffff73}.ops-dashboard__hero-dot--active{width:16px;background:#fff}.ops-dashboard__hero-badge{border:1px solid rgba(255,255,255,.4);border-radius:12px;background:#ffffff24;padding:10px 12px;min-width:150px;display:grid;gap:4px}.ops-dashboard__hero-badge small{color:#ffffffd1}.ops-dashboard__hero-badge strong{font-size:18px;color:#fff}.ops-dashboard__menu-layout{display:grid;gap:14px;grid-template-columns:minmax(0,1fr) 340px;align-items:start}.ops-dashboard__content{display:grid;gap:14px}.ops-dashboard__content--analytics{display:block}.ops-dashboard__content--analytics .analytics-dash{min-height:auto;border-radius:16px;overflow:hidden}.ops-dashboard__main,.ops-dashboard__menu-side{display:grid;gap:14px;align-content:start}.ops-card{border:1px solid var(--dash-border);border-radius:14px;background:var(--dash-surface);padding:14px;box-shadow:var(--dash-shadow)}.ops-card__header{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:10px}.ops-card__header h2,.ops-card__header h3{margin:0;color:var(--dash-text)}.ops-card__header-link{color:var(--dash-primary);font-size:13px;font-weight:600}.ops-dashboard__subtitle{margin:0;color:var(--dash-muted)}.ops-dashboard__function-groups{border:1px solid #d9dee6;border-radius:16px;background:#eceff3;padding:10px}.ops-dashboard__section-header{margin:2px 2px 12px}.ops-dashboard__section-header h3{margin:0;color:var(--dash-text);font-size:34px;line-height:1.1}.ops-menu-grid{display:grid;gap:10px;grid-template-columns:repeat(4,minmax(0,1fr))}.ops-menu-tile{--ops-menu-accent: #1d3f91;border:1px solid #d8dde5;border-radius:12px;background:#fff;color:#303845;padding:16px 10px;display:grid;justify-items:center;align-content:center;text-align:center;gap:10px;min-height:150px;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease,background-color .2s ease}.ops-menu-tile:hover{text-decoration:none;transform:translateY(-1px);border-color:#bbc3d1;box-shadow:0 6px 14px #0f172a14}.ops-menu-tile strong{font-size:17px;line-height:1.25}.ops-menu-tile__icon{width:58px;height:58px;color:#1d3f91;display:inline-flex;align-items:center;justify-content:center}.ops-menu-tile__icon svg{width:52px;height:52px}.ops-menu-tile--disabled{--ops-menu-accent: #c5cad2;border-color:#dde2ea;background:#f4f6f8;color:#9da5b1;box-shadow:none;cursor:not-allowed;pointer-events:none}.ops-menu-tile--disabled .ops-menu-tile__icon{color:#abb2bd}.ops-notification-list{margin:0;padding:0;list-style:none;display:grid;gap:0;color:var(--dash-text)}.ops-notification-item{padding:10px 0;border-bottom:1px solid var(--dash-border);display:grid;gap:8px}.ops-notification-item:last-child{border-bottom:0;padding-bottom:0}.ops-notification-tags{display:inline-flex;gap:6px;flex-wrap:wrap}.ops-notification-tag{border:1px solid #c7d2fe;background:#eef2ff;border-radius:999px;color:var(--dash-primary);font-size:11px;font-weight:600;line-height:1;padding:4px 8px}.ops-notification-item p{margin:0;line-height:1.35;font-size:13px}.ops-dashboard-filters{margin-top:12px;display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.ops-dashboard-filters input,.ops-dashboard-filters select{border:1px solid var(--dash-border);border-radius:10px;padding:8px 10px;background:var(--dash-surface);color:var(--dash-text)}.ops-dashboard-filters input,.ops-dashboard-filters select,.ops-dashboard-filters button{height:40px;border-radius:10px}.ops-dashboard-filters input:disabled,.ops-dashboard-filters select:disabled{background:var(--dash-surface-muted);color:var(--dash-muted)}.ops-dashboard-filters button{border:1px solid var(--dash-primary);border-radius:10px;padding:8px 12px;font-weight:600;color:#fff;background:var(--dash-primary);display:inline-flex;align-items:center;justify-content:center;line-height:1.2}.ops-dashboard-filters button[type=button]{border-color:var(--dash-border);background:var(--dash-surface);color:var(--dash-text)}.ops-kpi-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.ops-kpi-note{margin:0;grid-column:1 / -1;color:var(--dash-muted);font-size:13px}.ops-kpi-card{border:1px solid var(--dash-border);border-radius:12px;background:var(--dash-surface);padding:10px;display:grid;gap:8px}.ops-kpi-card small{color:var(--dash-muted);text-transform:capitalize}.ops-kpi-card strong{font-size:28px;line-height:1;color:var(--dash-primary)}.ops-dashboard__metric-block{display:grid;gap:8px}.ops-dashboard__metrics-grid{display:grid;gap:12px;grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.ops-metrics-table{width:100%;border-collapse:collapse}.ops-metrics-table th,.ops-metrics-table td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--dash-border)}.ops-metrics-table th{background:var(--dash-surface-muted)}.ops-bar-chart{display:grid;gap:8px}.ops-bar-chart__row{display:grid;grid-template-columns:110px minmax(0,1fr) 70px;gap:8px;align-items:center}.ops-bar-chart__row span{color:var(--dash-text)}.ops-bar-chart__row strong{color:var(--dash-primary);text-align:right}.ops-bar-chart__track{height:10px;border-radius:999px;background:#e0e7ff;overflow:hidden}.ops-bar-chart__fill{height:100%;border-radius:999px;background:var(--dash-primary)}.ops-trend-chart{border:1px solid var(--dash-border);border-radius:10px;padding:8px;background:var(--dash-surface-muted)}.ops-trend-chart svg{display:block;width:100%;height:180px}.ops-trend-chart polyline{fill:none;stroke:var(--dash-primary);stroke-width:2.2}.ops-trend-labels{margin-top:10px;display:grid;gap:6px;color:var(--dash-muted);font-size:13px}.ops-state{margin:8px 0 0;color:var(--dash-muted)}.ops-state--error{color:#b91c1c}.ops-hub-card{border:1px solid var(--dash-border);border-radius:12px;background:var(--dash-surface);padding:12px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.ops-hub-card small{display:block;color:var(--dash-muted);margin-bottom:4px}.ops-hub-card strong{color:var(--dash-text);line-height:1.35}.ops-shipper-tools{margin-bottom:10px}.ops-shipper-tools input{width:min(360px,100%);border:1px solid var(--dash-border);border-radius:10px;padding:8px 10px;background:var(--dash-surface);color:var(--dash-text)}.ops-shipper-table{width:100%;border-collapse:collapse;border:1px solid var(--dash-border);border-radius:10px;overflow:hidden;background:var(--dash-surface)}.ops-shipper-table th,.ops-shipper-table td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--dash-border)}.ops-shipper-table thead th{background:var(--dash-surface-muted);color:var(--dash-text);font-size:13px}.ops-shipper-table tbody tr:hover{background:var(--dash-primary-soft)}@media (max-width: 1200px){.ops-menu-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.ops-dashboard__hero{grid-template-columns:auto minmax(0,1fr) auto}}@media (max-width: 980px){.ops-dashboard__menu-layout{grid-template-columns:1fr}.ops-dashboard__hero{grid-template-columns:1fr;text-align:center}.ops-dashboard__hero-nav{justify-self:center}.ops-dashboard__hero-content{order:-1}.ops-dashboard__hero-badge{min-width:0;width:100%;justify-self:center;max-width:220px}.ops-menu-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.ops-dashboard__metrics-grid{grid-template-columns:1fr}.ops-bar-chart__row{grid-template-columns:90px minmax(0,1fr) 56px}}@media (max-width: 640px){.ops-menu-grid{grid-template-columns:1fr}.ops-dashboard__hero-company{font-size:24px}}:root{--ops-font-family: "Manrope", "Segoe UI", "Helvetica Neue", Arial, sans-serif;--ops-font-weight-regular: 500;--ops-font-weight-medium: 600;--ops-font-weight-bold: 700;--ops-bg: #eef2ff;--ops-surface: #ffffff;--ops-surface-soft: #eef2ff;--ops-text: #334155;--ops-text-muted: #64748b;--ops-border: #e2e8f0;--ops-primary: #4f46e5;--ops-primary-dark: #4f46e5;--ops-success: #137f5d;--ops-warning: #9f6a00;--ops-danger: #b12233;--ops-shadow: 0 8px 20px rgba(15, 23, 42, .06)}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{background:var(--ops-bg);color:var(--ops-text);font-family:var(--ops-font-family);font-weight:var(--ops-font-weight-regular)}h1,h2,h3,h4,h5,h6{font-family:var(--ops-font-family);font-weight:var(--ops-font-weight-bold);letter-spacing:.01em}a{color:var(--ops-primary);text-decoration:none;font-weight:var(--ops-font-weight-medium)}a:hover{text-decoration:underline}input,select,textarea,button{font:inherit;border-radius:11px}input,select,textarea{border:1px solid var(--ops-border);color:var(--ops-text);background:var(--ops-surface);padding:9px 11px}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--ops-primary);box-shadow:0 0 0 3px #4f46e529}button{border:1px solid var(--ops-primary);padding:8px 12px;background:var(--ops-primary);color:#fff;font-weight:600;cursor:pointer}button:disabled{opacity:.6;cursor:not-allowed}table{width:100%;border-collapse:collapse;background:var(--ops-surface)}th,td{border-bottom:1px solid var(--ops-border);padding:8px 10px;text-align:left;vertical-align:top}th{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--ops-text-muted);background:#eef2ff}::placeholder{color:var(--ops-text-muted)}.app-root-shell{min-height:100vh;display:grid;grid-template-rows:auto auto 1fr}.app-root-content{min-height:0}.app-crash{min-height:100vh;display:grid;place-items:center;padding:20px}.app-crash__panel{width:min(560px,100%);border:1px solid #fecdd3;border-radius:14px;background:#fff1f2;color:#7f1d1d;padding:18px;box-shadow:var(--ops-shadow)}.app-crash__panel h1{margin:0 0 8px;font-size:20px}.app-crash__panel p{margin:0;overflow-wrap:anywhere}.ops-route-loading{color:var(--ops-text-muted);font-weight:var(--ops-font-weight-medium);padding:16px}.global-banner{width:100%;border:0;text-align:left;padding:10px 16px;font-weight:var(--ops-font-weight-medium)}.global-banner-error{background:#ffe5e9;color:#8f1e2d}.global-banner-info{background:#eaf4ff;color:#1f5f97}.global-toast-stack{position:fixed;top:16px;right:16px;z-index:2000;display:grid;gap:10px;width:min(380px,calc(100vw - 32px))}.global-toast{display:grid;grid-template-columns:auto 1fr auto;align-items:start;gap:10px;border:1px solid;border-radius:12px;padding:12px;background:#fff;box-shadow:0 18px 40px #0f172a29;color:var(--ops-text);text-align:left;font:inherit;font-weight:var(--ops-font-weight-medium);cursor:pointer}.global-toast-icon{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:999px;font-size:13px;font-weight:var(--ops-font-weight-bold)}.global-toast-close{color:var(--ops-text-muted);font-size:18px;line-height:1}.global-toast-success{border-color:#86efac;background:#f0fdf4;color:#166534}.global-toast-success .global-toast-icon{background:#dcfce7;color:#166534}.global-toast-error{border-color:#fecaca;background:#fef2f2;color:#991b1b}.global-toast-error .global-toast-icon{background:#fee2e2;color:#991b1b}.global-toast-info{border-color:#bfdbfe;background:#eff6ff;color:#1e40af}.global-toast-info .global-toast-icon{background:#dbeafe;color:#1e40af}.ops-layout{min-height:100vh;display:block}.ops-layout--no-sidebar{display:block}.ops-sidebar{position:sticky;top:0;align-self:start;height:100vh;padding:16px;display:grid;align-content:start;gap:12px;background:#fff;color:var(--ops-text);border-right:1px solid var(--ops-border)}.ops-sidebar h1{margin:0;font-size:30px;line-height:1.05;font-family:var(--ops-font-family)}.ops-sidebar p{margin:4px 0 0;font-size:12px;color:var(--ops-text-muted)}.ops-sidebar-session{border:1px solid var(--ops-border);border-radius:12px;padding:10px;background:var(--ops-surface-soft);display:grid;gap:3px}.ops-sidebar-session strong{font-size:13px}.ops-sidebar-session small{font-size:11px;color:var(--ops-text-muted)}.ops-logout-btn{margin-top:4px;background:#fff;border-color:#cbd5e1;color:#475569;font-weight:600;box-shadow:0 1px 2px #0f172a14}.ops-logout-btn:hover{background:#eef2ff;border-color:#a5b4fc;color:#3730a3}.ops-nav-group{display:grid;gap:6px}.ops-nav-group h2{margin:2px 2px 4px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ops-text-muted)}.ops-nav-link{border-radius:11px;border-left:3px solid transparent;padding:8px 10px;color:var(--ops-text);font-weight:var(--ops-font-weight-regular);outline:none;transition:background-color .2s ease,color .2s ease,border-color .2s ease}.ops-nav-link:hover{text-decoration:none;background:var(--ops-surface-soft)}.ops-nav-link:focus{outline:none}.ops-nav-link:focus-visible{outline:none;box-shadow:0 0 0 2px #4f46e533}.ops-nav-link-active{background:#eef2ff;border-left-color:var(--ops-primary);color:var(--ops-primary);font-weight:var(--ops-font-weight-medium)}.ops-workspace{min-width:0;width:min(1400px,100%);margin:0 auto;padding:12px 16px 18px;display:grid;grid-template-rows:auto 1fr;gap:12px}.ops-workspace--full{width:min(1400px,100%)}.ops-topbar{position:sticky;top:0;z-index:30;border:1px solid var(--ops-border);border-radius:16px;background:#fff;box-shadow:var(--ops-shadow);padding:10px 14px;display:flex;align-items:center;justify-content:space-between;gap:12px}.ops-topbar--full{top:8px}.ops-topbar-brand{display:flex;align-items:center;gap:10px}.ops-topbar-brand--button{border:0;background:transparent;color:inherit;padding:0;cursor:pointer}.ops-topbar-logo{width:40px;height:40px;border-radius:12px;background:var(--ops-primary);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:var(--ops-font-weight-bold);letter-spacing:.08em}.ops-topbar-brand-text{display:grid;gap:1px}.ops-topbar-brand-text strong{color:var(--ops-text);font-size:14px;text-transform:uppercase;letter-spacing:.08em}.ops-topbar-brand-text span{color:var(--ops-text-muted);font-size:11px;text-transform:uppercase;letter-spacing:.06em}.ops-topbar-actions{display:flex;align-items:center;gap:8px;min-width:0;margin-left:auto}.ops-topbar-search{min-width:min(520px,58vw);border:1px solid var(--ops-border);border-radius:999px;background:#fff;display:flex;align-items:center;gap:6px;padding:4px 4px 4px 10px}.ops-topbar-search-icon{width:16px;height:16px;color:var(--ops-text-muted);display:inline-flex}.ops-topbar-search-icon svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.ops-topbar-search input{border:0;background:transparent;min-width:0;width:100%;padding:7px 4px}.ops-topbar-search input:focus{box-shadow:none}.ops-topbar-search-submit{border-radius:999px;border:1px solid var(--ops-primary);background:var(--ops-primary);color:#fff;padding:7px 12px;line-height:1}.ops-topbar-icon-btn{width:38px;height:38px;border:1px solid var(--ops-border);border-radius:10px;background:#fff;color:var(--ops-text-muted);display:inline-flex;align-items:center;justify-content:center;padding:0}.ops-topbar-icon-btn svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.ops-topbar-icon-btn:hover{border-color:#c7d2fe;color:var(--ops-primary);background:#eef2ff}.ops-topbar-profile{border:1px solid var(--ops-border);border-radius:999px;background:#fff;color:var(--ops-text);display:grid;grid-template-columns:28px minmax(0,1fr);column-gap:8px;row-gap:1px;align-items:center;padding:4px 10px 4px 4px;min-width:180px}.ops-topbar-avatar{width:28px;height:28px;border-radius:999px;background:#eef2ff;color:var(--ops-primary);display:inline-flex;align-items:center;justify-content:center;font-weight:var(--ops-font-weight-medium);font-size:12px;grid-column:1;grid-row:1 / span 2}.ops-topbar-user{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px;grid-column:2;grid-row:1}.ops-topbar-role{color:var(--ops-text-muted);font-size:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;grid-column:2;grid-row:2}.ops-logout-inline{border:1px solid #cbd5e1;background:#fff;color:#475569;box-shadow:0 1px 2px #0f172a14}.ops-logout-inline:hover{background:#eef2ff;border-color:#a5b4fc;color:#3730a3}.ops-main-panel{min-width:0;border:1px solid var(--ops-border);border-radius:18px;background:var(--ops-surface);box-shadow:var(--ops-shadow);padding:14px}.ops-main-panel--flat{border:0;border-radius:0;background:transparent;box-shadow:none;padding:0}.ops-func-shell{min-height:100vh;background:#f8fafc;display:flex;flex-direction:column}.ops-func-header{height:56px;border-bottom:1px solid #e2e8f0;background:#fff;padding:0 16px;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:16px;position:sticky;top:0;z-index:40}.ops-func-logo{color:#1d4ed8;font-size:24px;line-height:1;font-weight:700;letter-spacing:.01em}.ops-func-logo--button{border:0;background:transparent;padding:0;cursor:pointer}.ops-func-main-nav{height:100%;display:flex;align-items:stretch;justify-content:center;gap:4px;min-width:0}.ops-func-main-link{height:100%;display:inline-flex;align-items:center;padding:0 12px;color:#64748b;transition:color .2s ease,border-color .2s ease;white-space:nowrap;font-size:14px;background:transparent;border-top:0;border-left:0;border-right:0;border-bottom:2px solid transparent;border-radius:0}.ops-func-main-link:hover{color:#1d4ed8;text-decoration:none}.ops-func-main-link--active{color:#1d4ed8;border-bottom-color:#1d4ed8}.ops-func-actions{display:flex;align-items:center;gap:8px}.ops-func-search{width:260px;display:flex;align-items:center;gap:8px;background:#f1f5f9;border-radius:999px;padding:4px 10px}.ops-func-search svg{width:15px;height:15px;fill:none;stroke:#64748b;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}.ops-func-search input{border:0;background:transparent;width:100%;padding:4px 0;color:#334155}.ops-func-search input:focus{box-shadow:none}.ops-func-bell{width:34px;height:34px;border:1px solid #e2e8f0;border-radius:10px;background:#fff;color:#64748b;display:inline-flex;align-items:center;justify-content:center;padding:0}.ops-func-bell svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.ops-func-bell:hover{color:#1d4ed8;border-color:#bfdbfe;background:#eff6ff}.ops-func-user{display:inline-flex;align-items:center;gap:8px;border:1px solid #e2e8f0;border-radius:999px;background:#fff;padding:3px 10px 3px 4px}.ops-func-user-avatar{width:26px;height:26px;border-radius:999px;background:#eff6ff;color:#1d4ed8;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.ops-func-user-name{color:#334155;font-size:12px;white-space:nowrap}.ops-func-body{min-height:calc(100vh - 56px);display:flex}.ops-func-sidebar{width:16rem;flex-shrink:0;background:#fff;border-right:1px solid #e2e8f0;padding:14px 12px;display:flex;flex-direction:column;gap:12px;transition:width .22s ease}.ops-func-sidebar--expanded{width:22rem}.ops-func-sidebar-search{display:flex;align-items:center;gap:8px;background:#f1f5f9;border-radius:999px;padding:6px 10px}.ops-func-sidebar-search svg{width:15px;height:15px;fill:none;stroke:#64748b;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}.ops-func-sidebar-search input{border:0;background:transparent;width:100%;padding:2px 0;color:#334155}.ops-func-sidebar-search input:focus{box-shadow:none}.ops-func-sidebar-title{display:flex;align-items:center;gap:8px;color:#334155;font-size:14px;font-weight:700}.ops-func-sidebar-title span{width:3px;height:16px;border-radius:999px;background:#1d4ed8}.ops-func-sidebar-nav{display:grid;gap:4px}.ops-func-sidebar-nav--two-cols{grid-template-columns:minmax(0,1fr) minmax(150px,26%);column-gap:10px;align-items:start}.ops-func-sidebar-primary-list{display:grid;gap:4px}.ops-func-sidebar-section{color:#475569;font-size:11px;font-weight:800;letter-spacing:.02em;margin:10px 6px 2px;text-transform:uppercase}.ops-func-sidebar-section:first-child{margin-top:0}.ops-func-sidebar-group{display:grid;gap:6px}.ops-func-sidebar-item{border-radius:10px;color:#64748b;display:flex;align-items:center;gap:10px;padding:7px 8px;transition:background-color .2s ease,color .2s ease;width:100%;border:0;background:transparent;text-align:left}.ops-func-sidebar-item:hover{background:#f8fafc;color:#334155;text-decoration:none}.ops-func-sidebar-item--active{background:#eff6ff;color:#1d4ed8;font-weight:600}.ops-func-sidebar-icon{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center}.ops-func-sidebar-icon svg{width:18px;height:18px}.ops-func-sidebar-label{flex:0 1 130px;max-width:130px;min-width:0;font-size:13px;padding:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ops-func-sidebar-nav--two-cols .ops-func-sidebar-label{flex-basis:108px;max-width:108px}.ops-func-sidebar-chevron{width:16px;height:16px;color:currentColor;display:inline-flex;align-items:center;justify-content:center}.ops-func-sidebar-chevron svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.ops-func-sidebar-secondary-list{border:1px solid #e2e8f0;border-radius:10px;background:#f8fafc;padding:3px;display:grid;gap:3px;width:100%;max-width:22vw;justify-self:end}.ops-func-sidebar-secondary-title{margin:1px 3px 3px;color:#334155;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.ops-func-sidebar-secondary-item{width:100%;border:1px solid #dbe3ef;border-radius:8px;padding:6px 8px;background:#fff;color:#334155;text-align:left;font-size:13px;line-height:1.3;font-weight:600}.ops-func-sidebar-secondary-item:hover{border-color:#bfdbfe;background:#f8fbff;color:#1e3a8a}.ops-func-sidebar-secondary-item--active{border-color:#93c5fd;background:#eff6ff;color:#1d4ed8}.ops-func-main{flex:1;min-width:0;background:#f8fafc;padding:14px 16px 16px;display:grid;grid-template-rows:auto 1fr;gap:10px}.ops-func-tabs{display:flex;align-items:flex-end;padding:0 4px;border-bottom:1px solid #cbd5e1}.ops-func-tab{border:1px solid #e2e8f0;border-bottom-color:transparent;border-radius:10px 10px 0 0;background:#fff;color:#334155;padding:8px 14px;margin-bottom:-1px}.ops-func-tab--active{border-top:2px solid #1d4ed8;color:#1d4ed8;font-weight:600}.ops-func-canvas{border:1px solid #e2e8f0;border-radius:12px;background:#fff;box-shadow:0 1px 2px #0f172a0f;padding:24px;min-height:520px;display:block;overflow:auto}.ops-func-welcome{color:#1d4ed8;font-size:28px;font-weight:700;text-align:center}.auth-page{min-height:100vh;display:grid;place-items:center;padding:20px}.auth-card{width:min(460px,100%);border:1px solid var(--ops-border);border-radius:18px;background:#fffffff2;padding:22px;box-shadow:var(--ops-shadow)}.auth-kicker{margin:0;text-transform:uppercase;letter-spacing:.12em;font-size:11px;color:#46698e;font-weight:var(--ops-font-weight-bold)}.auth-title{margin:10px 0 4px;font-size:28px;line-height:1.08;font-family:var(--ops-font-family)}.auth-subtitle{margin:0 0 16px;color:var(--ops-text-muted)}.auth-form{display:grid;gap:8px}.auth-label{font-weight:var(--ops-font-weight-medium)}.auth-input{border:1px solid #c7d8ea;border-radius:11px;padding:10px 12px}.auth-error{color:#b12233;font-size:12px}.auth-error-banner{border:1px solid #f4bec6;background:#ffedf0;color:#a32030;border-radius:11px;padding:8px 10px;font-size:13px;font-weight:var(--ops-font-weight-medium)}.auth-submit{margin-top:8px;padding:10px 14px}@keyframes ops-notice-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1080px){.ops-workspace,.ops-workspace--full{width:100%}.ops-topbar{flex-direction:column;align-items:flex-start;top:0}.ops-topbar-actions{width:100%;gap:10px;justify-content:flex-start;flex-wrap:wrap}.ops-topbar-search{width:100%;min-width:0}.ops-topbar-search input{min-width:0;width:100%}.ops-topbar-profile,.ops-logout-inline{margin-left:auto}}@media (max-width: 1200px){.ops-func-main-nav{justify-content:flex-start;overflow-x:auto;scrollbar-width:thin}.ops-func-search{width:220px}}@media (max-width: 1024px){.ops-func-header{height:auto;padding:10px 12px;grid-template-columns:1fr;gap:10px}.ops-func-main-nav{order:2;height:auto}.ops-func-main-link{height:auto;padding:6px 8px}.ops-func-actions{order:3;width:100%;justify-content:flex-start;flex-wrap:wrap}.ops-func-search{width:min(360px,100%)}.ops-func-body{flex-direction:column}.ops-func-sidebar{width:100%;border-right:0;border-bottom:1px solid #e2e8f0}.ops-func-sidebar--expanded{width:100%}.ops-func-sidebar-nav--two-cols{grid-template-columns:1fr}.ops-func-sidebar-secondary-list{max-width:none;justify-self:stretch}.ops-func-main{padding:12px}.ops-func-canvas{min-height:360px}}
