*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Mulish,Trebuchet MS,Segoe UI,system-ui,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:Hanken Grotesk,ui-monospace,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.block{display:block}.flex{display:flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-full{height:100%}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.border{border-width:1px}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}@font-face{font-family:Hanken Grotesk;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/hanken-grotesk-400.woff2) format("woff2")}@font-face{font-family:Hanken Grotesk;font-style:normal;font-weight:500;font-display:swap;src:url(/fonts/hanken-grotesk-500.woff2) format("woff2")}@font-face{font-family:Hanken Grotesk;font-style:normal;font-weight:600;font-display:swap;src:url(/fonts/hanken-grotesk-600.woff2) format("woff2")}@font-face{font-family:Hanken Grotesk;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/hanken-grotesk-700.woff2) format("woff2")}@font-face{font-family:Hanken Grotesk;font-style:normal;font-weight:800;font-display:swap;src:url(/fonts/hanken-grotesk-800.woff2) format("woff2")}@font-face{font-family:Mulish;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/mulish-400.woff2) format("woff2")}@font-face{font-family:Mulish;font-style:normal;font-weight:500;font-display:swap;src:url(/fonts/mulish-500.woff2) format("woff2")}@font-face{font-family:Mulish;font-style:normal;font-weight:600;font-display:swap;src:url(/fonts/mulish-600.woff2) format("woff2")}@font-face{font-family:Mulish;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/mulish-700.woff2) format("woff2")}@font-face{font-family:Mulish;font-style:normal;font-weight:800;font-display:swap;src:url(/fonts/mulish-800.woff2) format("woff2")}:root{--ukb-slate: #4d5a60;--ukb-teal: #009bbb;--ukb-orange: #ed7100;--ukb-yellow: #fdc200;--ukb-green: #50ae30;--ukb-red: #dc2f0c;--slate-900: #222a2e;--slate-800: #313c41;--slate-700: #3c484d;--slate-600: #4d5a60;--slate-500: #6b777d;--slate-400: #8d979c;--slate-300: #b4bcbf;--slate-200: #d6dadc;--slate-100: #eceeef;--slate-50: #f6f7f7;--teal-700: #00748c;--teal-600: #0086a1;--teal-500: #009bbb;--teal-300: #6cccdd;--teal-100: #d4eff4;--teal-50: #ecf8fa;--bg: #ffffff;--bg-subtle: #f6f7f7;--bg-muted: #eceeef;--surface: #ffffff;--surface-tint: #ecf8fa;--ink: #222a2e;--ink-secondary: #4d5a60;--ink-tertiary: #6b777d;--border: #d6dadc;--border-strong: #b4bcbf;--border-subtle: #eceeef;--success-soft: rgba(80, 174, 48, .14);--warning-soft: rgba(253, 194, 0, .2);--danger-soft: rgba(220, 47, 12, .12);--radius-pill: 999px;--shadow-focus: 0 0 0 3px rgba(0, 155, 187, .28);--font-display: "Hanken Grotesk", "Trebuchet MS", "Segoe UI", system-ui, sans-serif;--font-body: "Mulish", "Trebuchet MS", "Segoe UI", system-ui, sans-serif;--sans: var(--font-body);--serif: var(--font-body);--mono: var(--font-display);--ink-900: #222a2e;--ink-800: #222a2e;--ink-700: #313c41;--ink-600: #3c484d;--ink-500: #4d5a60;--ink-400: #6b777d;--ink-300: #8d979c;--ink-200: #b4bcbf;--ink-100: #d6dadc;--ink-50: #eceeef;--paper: #f6f7f7;--paper-2: #eceeef;--paper-3: #d6dadc;--card: #ffffff;--line: #d6dadc;--line-2: #b4bcbf;--brand-900: #00748c;--brand-700: #0086a1;--brand-500: #009bbb;--brand-300: #6cccdd;--accent: #0086a1;--accent-2: #6cccdd;--ok: #357a1f;--ok-bg: rgba(80, 174, 48, .14);--warn: #9a5a00;--warn-bg: rgba(253, 194, 0, .2);--risk: #c0290b;--risk-bg: rgba(220, 47, 12, .12);--info: #0086a1;--info-bg: #ecf8fa;--muted: #6b777d;--muted-bg: #eceeef;--violet: #4d5a60;--violet-bg: #eceeef;--r-sm: 6px;--r-md: 10px;--r-lg: 16px;--r-xl: 24px;--sh-1: 0 1px 3px rgba(34, 42, 46, .08), 0 1px 2px rgba(34, 42, 46, .05);--sh-2: 0 4px 12px rgba(34, 42, 46, .09), 0 2px 4px rgba(34, 42, 46, .05)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;background:var(--bg-subtle);font-family:var(--font-body);color:var(--ink);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}::-moz-selection{background:var(--teal-100);color:var(--ink)}::selection{background:var(--teal-100);color:var(--ink)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--slate-200);border-radius:999px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:var(--slate-300)}.app{container-type:inline-size;container-name:app;background:var(--bg-subtle);color:var(--ink);font-size:13.5px;line-height:1.5;height:100%;width:100%}.shell{display:grid;grid-template-columns:1fr;grid-template-rows:auto 1fr auto;grid-template-areas:"top" "main" "tabs";height:100%;min-height:0}.sidebar{display:none}.tabbar{grid-area:tabs}.topbar{grid-area:top}.main{grid-area:main;min-width:0;min-height:0;overflow:auto}@container app (min-width: 768px){.shell{grid-template-columns:64px 1fr;grid-template-rows:auto 1fr;grid-template-areas:"side top" "side main"}.sidebar{display:flex;grid-area:side}.tabbar{display:none}}@container app (min-width: 1120px){.shell{grid-template-columns:248px 1fr}.sidebar.full{display:flex}.sidebar.rail{display:none}}.sidebar{background:var(--surface);color:var(--ink-secondary);flex-direction:column;padding:16px 12px;border-right:1px solid var(--border);gap:2px}.sidebar.full{padding:20px 16px 16px;gap:3px}.brand{display:flex;align-items:center;gap:11px;padding:2px 6px 16px;margin-bottom:8px}.brand-mark{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--teal-500),var(--teal-700));display:grid;place-items:center;color:#fff;font-family:var(--font-display);font-weight:800;font-size:18px;flex:0 0 34px;box-shadow:var(--shadow-focus);box-shadow:0 2px 6px #009bbb40}.brand-name{font-family:var(--font-display);font-weight:800;letter-spacing:-.02em;font-size:16px;color:var(--ink);line-height:1.05}.brand-sub{font-size:11px;color:var(--ink-tertiary);margin-top:2px}.sidebar.rail .brand-text{display:none}.sidebar.rail .brand{justify-content:center;padding-left:0;padding-right:0}.nav-section{font-family:var(--font-display);font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-tertiary);padding:14px 10px 6px}.sidebar.rail .nav-section{display:none}.nav-item{display:flex;align-items:center;gap:11px;padding:8px 10px;border-radius:var(--r-sm);color:var(--ink-secondary);font-family:var(--font-display);font-weight:600;font-size:13.5px;cursor:pointer;position:relative;text-decoration:none;transition:background .16s,color .16s}.nav-item:hover{background:var(--slate-50);color:var(--ink)}.nav-item.active{background:var(--surface-tint);color:var(--teal-700);font-weight:700}.nav-item .label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-item .badge{margin-left:auto;font-family:var(--font-display);font-weight:700;font-size:11px;background:var(--surface-tint);color:var(--teal-700);padding:1px 8px;border-radius:999px}.nav-item.active .badge{background:#fff}.sidebar.rail .nav-item{justify-content:center;padding:10px}.sidebar.rail .nav-item .label{display:none}.sidebar.rail .nav-item .badge{position:absolute;top:3px;right:3px;padding:0;min-width:7px;height:7px;background:var(--ukb-teal);color:transparent;border-radius:50%;font-size:0;line-height:0}.sidebar-foot{margin-top:auto;padding-top:14px;border-top:1px solid var(--border-subtle)}.user-chip{display:flex;align-items:center;gap:11px;padding:6px;border-radius:var(--r-sm);cursor:pointer}.user-chip:hover{background:var(--slate-50)}.avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--teal-500),var(--teal-700));display:grid;place-items:center;color:#fff;font-family:var(--font-display);font-weight:700;font-size:12px;flex:0 0 34px}.user-name{color:var(--ink);font-family:var(--font-display);font-size:13.5px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{color:var(--ink-tertiary);font-size:11.5px}.sidebar.rail .user-meta{display:none}.sidebar.rail .user-chip{justify-content:center;padding:4px}.signout-btn{margin-top:8px;width:100%;display:flex;align-items:center;gap:10px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--r-sm);background:transparent;color:var(--ink-secondary);font-family:var(--font-display);font-size:12.5px;font-weight:600;cursor:pointer;transition:background .16s,color .16s,border-color .16s}.signout-btn:hover{background:var(--surface-tint);border-color:var(--teal-300);color:var(--teal-700)}.signout-btn .ico{width:18px;height:18px;flex:0 0 18px}.sidebar.rail .signout-btn{justify-content:center;padding:8px 4px}.sidebar.rail .signout-btn .label{display:none}.topbar{height:60px;border-bottom:1px solid var(--border);background:#ffffffd9;backdrop-filter:saturate(140%) blur(8px);-webkit-backdrop-filter:saturate(140%) blur(8px);display:flex;align-items:center;gap:10px;padding:0 14px;position:sticky;top:0;z-index:20}@container app (min-width: 768px){.topbar{padding:0 24px;gap:14px}}.crumbs{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--ink-tertiary);min-width:0}.crumbs b{color:var(--ink);font-family:var(--font-display);font-weight:700;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.crumbs .sep{color:var(--slate-300)}.crumbs .hide-sm{display:none}@container app (min-width: 768px){.crumbs .hide-sm{display:inline}}.search{margin-left:auto;display:none;align-items:center;gap:8px;background:var(--slate-50);border:1px solid var(--border);padding:0 12px;height:38px;border-radius:var(--r-sm);width:300px;color:var(--ink-tertiary);font-size:13px}@container app (min-width: 1120px){.search{display:flex}}.search .kbd{margin-left:auto;font-family:var(--font-display);font-weight:600;font-size:10.5px;color:var(--ink-tertiary);border:1px solid var(--border);padding:1px 6px;border-radius:4px;background:#fff}.topbar-actions{display:flex;gap:8px;margin-left:auto;align-items:center}@container app (min-width: 1120px){.topbar-actions{margin-left:0}}.topbar-actions .hide-sm{display:none}@container app (min-width: 768px){.topbar-actions .hide-sm{display:inline-flex}}.iconbtn{width:38px;height:38px;border-radius:var(--r-sm);display:grid;place-items:center;border:1px solid var(--border);background:#fff;color:var(--ink-secondary);cursor:pointer;position:relative;transition:border-color .16s,background .16s}.iconbtn:hover{border-color:var(--border-strong);background:var(--slate-50)}.iconbtn .dot{position:absolute;top:8px;right:9px;width:7px;height:7px;border-radius:50%;background:var(--ukb-red);border:1.5px solid #fff}.tabbar{background:#fffffff5;backdrop-filter:saturate(140%) blur(10px);-webkit-backdrop-filter:saturate(140%) blur(10px);border-top:1px solid var(--border);display:flex;padding:6px 6px max(6px,env(safe-area-inset-bottom,6px));gap:2px;justify-content:space-around}.tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 4px;border-radius:var(--r-sm);color:var(--ink-tertiary);font-family:var(--font-display);font-size:10.5px;font-weight:700;cursor:pointer;text-decoration:none}.tab.active{color:var(--teal-700);background:var(--surface-tint)}.page{padding:18px 16px 28px;overflow:auto}@container app (min-width: 768px){.page{padding:24px 24px 32px}}@container app (min-width: 1120px){.page{padding:28px 32px 40px}}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap}.page-title{font-family:var(--font-display);font-weight:800;font-size:22px;letter-spacing:-.02em;color:var(--ink);line-height:1.1}@container app (min-width: 768px){.page-title{font-size:26px}}.page-sub{color:var(--ink-secondary);font-size:14px;margin-top:5px;max-width:64ch}.page-actions{display:flex;gap:8px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:var(--r-sm);font-family:var(--font-display);font-size:13px;font-weight:600;border:1px solid var(--border);background:#fff;color:var(--ink-secondary);cursor:pointer;white-space:nowrap;transition:border-color .16s,background .16s,color .16s}.btn:hover{border-color:var(--border-strong);background:var(--slate-50)}.btn:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.btn.primary{background:var(--ukb-teal);border-color:var(--ukb-teal);color:#fff}.btn.primary:hover{background:var(--teal-600);border-color:var(--teal-600)}.btn.accent{background:var(--teal-700);border-color:var(--teal-700);color:#fff}.btn.accent:hover{background:var(--teal-600);border-color:var(--teal-600)}.btn.ghost{background:transparent;border-color:transparent;color:var(--ink-secondary)}.btn.ghost:hover{background:var(--slate-50)}.btn.sm{padding:5px 10px;font-size:12px}.btn.lg{padding:11px 18px;font-size:14px}.btn.block{width:100%;justify-content:center}.btn:disabled{opacity:.5;cursor:not-allowed}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-1)}.card.accent-top{border-top:3px solid var(--ukb-teal)}.card-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-subtle);gap:10px;flex-wrap:wrap}.card-title{font-family:var(--font-display);font-weight:700;font-size:15.5px;color:var(--ink);letter-spacing:-.01em}.card-sub{font-family:var(--font-display);font-size:11px;font-weight:700;color:var(--ink-tertiary);text-transform:uppercase;letter-spacing:.06em}.card-body{padding:18px 20px}.card-body.flush{padding:0}.card-body.tight{padding:10px 16px}.pill{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-display);font-size:11.5px;font-weight:700;padding:2px 9px;border-radius:999px;background:var(--slate-100);color:var(--ink-secondary);border:1px solid transparent;white-space:nowrap}.pill .dot{width:6px;height:6px;border-radius:50%;background:currentColor}.pill.ok{color:#357a1f;background:var(--success-soft)}.pill.warn{color:#9a5a00;background:var(--warning-soft)}.pill.risk{color:#c0290b;background:var(--danger-soft)}.pill.info{color:var(--teal-700);background:var(--surface-tint)}.pill.violet{color:var(--slate-600);background:var(--slate-100)}.pill.ghost{color:var(--ink-tertiary);background:var(--slate-100)}.pill.sm{font-size:10.5px;padding:1px 7px}.tag{font-family:var(--font-display);font-weight:600;font-size:10.5px;letter-spacing:.04em;padding:2px 7px;border-radius:4px;background:var(--slate-50);color:var(--ink-secondary);border:1px solid var(--border);text-transform:uppercase}.tbl{width:100%;border-collapse:collapse;font-size:13px}.tbl th{text-align:left;font-family:var(--font-display);font-weight:700;color:var(--ink-tertiary);padding:11px 16px;border-bottom:1px solid var(--border-subtle);font-size:11px;text-transform:uppercase;letter-spacing:.05em;background:var(--slate-50)}.tbl td{padding:13px 16px;border-bottom:1px solid var(--border-subtle);color:var(--ink-secondary);vertical-align:middle}.tbl tbody tr{transition:background .12s}.tbl tbody tr:hover{background:var(--slate-50)}.tbl tr:last-child td{border-bottom:none}.kpis{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}@container app (min-width: 640px){.kpis{grid-template-columns:repeat(4,1fr);gap:16px}}.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 18px;box-shadow:var(--sh-1)}.kpi .l{font-family:var(--font-display);font-size:11px;font-weight:700;color:var(--ink-tertiary);text-transform:uppercase;letter-spacing:.06em}.kpi .v{font-family:var(--font-display);font-size:26px;font-weight:800;color:var(--ink);letter-spacing:-.02em;margin-top:6px;line-height:1.05}@container app (min-width: 768px){.kpi .v{font-size:30px}}.kpi .s{font-size:12.5px;color:var(--ink-secondary);margin-top:6px}.col-2{display:grid;grid-template-columns:1fr;gap:16px}@container app (min-width: 900px){.col-2{grid-template-columns:1.6fr 1fr}}.col-3{display:grid;grid-template-columns:1fr;gap:16px}@container app (min-width: 900px){.col-3{grid-template-columns:repeat(3,1fr)}}.col-2-eq{display:grid;grid-template-columns:1fr;gap:16px}@container app (min-width: 900px){.col-2-eq{grid-template-columns:1fr 1fr}}.stack{display:flex;flex-direction:column;gap:16px}.row{display:flex;align-items:center;gap:10px}.muted{color:var(--ink-tertiary)}.mono{font-family:var(--font-display);font-variant-numeric:tabular-nums}.divider{height:1px;background:var(--border-subtle);margin:14px 0}.role-chip{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--border);border-radius:999px;padding:4px 4px 4px 12px;font-family:var(--font-display);font-weight:600;font-size:12px;color:var(--ink-secondary);cursor:pointer;transition:border-color .16s}.role-chip:hover{border-color:var(--border-strong)}.role-chip .role-av{width:24px;height:24px;border-radius:50%;background:var(--teal-600);color:#fff;font-size:10px;font-weight:700;display:grid;place-items:center}.bar{height:6px;background:var(--slate-100);border-radius:99px;overflow:hidden}.bar .fill{height:100%;background:var(--ukb-teal);border-radius:99px;transition:width .25s}.bar .fill.ok{background:var(--ukb-green)}.bar .fill.warn{background:var(--ukb-orange)}.bar .fill.risk{background:var(--ukb-red)}.bar.thick{height:8px}.empty-grid{display:grid;grid-template-columns:1fr;gap:14px}@container app (min-width: 640px){.empty-grid{grid-template-columns:repeat(2,1fr)}}@container app (min-width: 1024px){.empty-grid{grid-template-columns:repeat(3,1fr)}}.onboard{border:1px dashed var(--border-strong);background:var(--surface);border-radius:var(--r-lg);padding:16px;display:flex;flex-direction:column;gap:6px;min-height:130px}.onboard .num{font-family:var(--font-display);font-weight:700;font-size:11px;color:var(--teal-600);letter-spacing:.06em}.onboard .t{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:14.5px}.onboard .d{color:var(--ink-secondary);font-size:13px}.onboard .a{margin-top:auto;color:var(--teal-600);font-family:var(--font-display);font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:4px;cursor:pointer}.activity{display:flex;flex-direction:column}.activity .row{padding:11px 0;border-bottom:1px solid var(--border-subtle);font-size:13px;gap:10px}.activity .row:last-child{border-bottom:none}.activity .time{font-family:var(--font-display);font-variant-numeric:tabular-nums;font-size:11.5px;color:var(--ink-tertiary);width:70px;flex:0 0 70px}.activity .what{color:var(--ink-secondary)}.activity .what b{color:var(--ink);font-weight:700}.ai-msg-q{display:flex;gap:11px;margin-bottom:16px}.ai-msg-q .av{width:28px;height:28px;border-radius:50%;background:var(--teal-700);color:#fff;font-family:var(--font-display);font-size:11px;display:grid;place-items:center;font-weight:700;flex:0 0 28px}.ai-msg-q .body{font-size:14px;color:var(--ink);padding-top:4px}.ai-msg-a{display:flex;gap:11px;margin-bottom:18px}.ai-msg-a .av{width:28px;height:28px;border-radius:8px;flex:0 0 28px;background:linear-gradient(135deg,var(--teal-500),var(--teal-700));color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:13px}.ai-msg-a .body{flex:1;font-size:13.5px;color:var(--ink-secondary);min-width:0}.ai-msg-a h4{font-family:var(--font-display);font-size:10.5px;color:var(--ink-tertiary);text-transform:uppercase;letter-spacing:.08em;margin:14px 0 7px;font-weight:700}.ai-msg-a h4:first-child{margin-top:0}.ai-msg-a p{margin:0 0 6px;line-height:1.55}.ai-msg-a .src{border:1px solid var(--border);border-radius:var(--r-sm);padding:9px 11px;margin-bottom:6px;display:flex;gap:10px;background:var(--slate-50)}.ai-msg-a .src .num{font-family:var(--font-display);font-weight:700;font-size:11px;color:var(--teal-600);width:22px;flex:0 0 22px}.ai-msg-a .src .t{font-family:var(--font-display);font-size:12.5px;color:var(--ink);font-weight:600}.ai-msg-a .src .x{font-size:11.5px;color:var(--ink-tertiary);margin-top:2px}.ai-msg-a .gap-callout{background:var(--warning-soft);border-left:3px solid var(--ukb-orange);padding:9px 11px;border-radius:4px;font-size:12.5px;color:var(--ink-secondary);margin:4px 0}.field{display:flex;flex-direction:column;gap:6px}.field label{font-family:var(--font-display);font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-tertiary)}.field input,.field select,.field textarea{border:1px solid var(--border);border-radius:var(--r-sm);padding:9px 11px;background:#fff;font-family:var(--font-body);font-size:13.5px;color:var(--ink);outline:none;transition:border-color .16s,box-shadow .16s}.field input::-moz-placeholder,.field textarea::-moz-placeholder{color:var(--slate-400)}.field input::placeholder,.field textarea::placeholder{color:var(--slate-400)}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--teal-300);box-shadow:var(--shadow-focus)}.field .hint{font-size:11.5px;color:var(--ink-tertiary)}.fieldset{display:grid;grid-template-columns:1fr;gap:14px}@container app (min-width: 640px){.fieldset.cols-2{grid-template-columns:1fr 1fr}}.login-wrap{height:100%;display:flex;background:#fff;overflow:hidden}.login-form-panel{flex:0 0 46%;min-width:0;background:#fff;display:flex;flex-direction:column;justify-content:center;overflow-y:auto;padding:40px 56px}.login-form-inner{width:100%;max-width:400px;margin:0 auto}.login-hero{flex:1;position:relative;background:linear-gradient(150deg,var(--teal-500) 0%,var(--teal-700) 70%,var(--slate-900) 140%);overflow:hidden}.login-hero .wave{position:absolute;left:-1px;top:0;bottom:0;width:88px;height:100%}.login-hero .hero-copy{position:absolute;left:56px;bottom:52px;right:48px;color:#fff}@media(max-width:900px){.login-hero{display:none}.login-form-panel{flex:1;padding:32px 24px}}svg.ico{width:18px;height:18px;flex:0 0 18px;stroke:currentColor}.btn svg.ico{width:15px;height:15px;flex:0 0 15px}.iconbtn svg.ico{width:18px;height:18px;flex:0 0 18px}.tab svg.ico{width:21px;height:21px;flex:0 0 21px}
