.bb-root{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;overflow:hidden;background:radial-gradient(1200px 800px at 50% -10%,rgba(124,92,255,.12),transparent 60%),var(--bg-0)}:root[data-theme=light] .bb-blob{opacity:.28;filter:blur(120px) saturate(140%)}:root[data-theme=light] .bb-vignette{background:radial-gradient(120% 80% at 50% 50%,transparent 50%,rgba(246,247,251,.7) 100%),linear-gradient(180deg,#f6f7fb00 60%,#f6f7fb99)}:root[data-theme=light] .bb-grain{opacity:.04;mix-blend-mode:multiply}.bb-blob{position:absolute;border-radius:50%;filter:blur(120px) saturate(160%);opacity:.45;will-change:transform;animation:bb-drift 28s ease-in-out infinite alternate}.bb-blob--1{width:720px;height:720px;left:-240px;top:-160px;background:radial-gradient(circle at 30% 30%,var(--brand-1),transparent 65%);animation-delay:0s}.bb-blob--2{width:640px;height:640px;right:-160px;top:10%;background:radial-gradient(circle at 70% 30%,var(--brand-2),transparent 65%);animation-delay:-8s}.bb-blob--3{width:820px;height:820px;left:20%;bottom:-260px;background:radial-gradient(circle at 50% 50%,var(--brand-3),transparent 65%);animation-delay:-14s}.bb-blob--4{width:560px;height:560px;right:8%;bottom:-160px;background:radial-gradient(circle at 40% 40%,var(--brand-4),transparent 65%);animation-delay:-20s;opacity:.32}.bb-vignette{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(120% 80% at 50% 50%,transparent 40%,rgba(4,5,12,.65) 100%),linear-gradient(180deg,#04050c00 60%,#04050cbf)}.bb-grain{position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160' viewBox='0 0 160 160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.6 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");opacity:.06;mix-blend-mode:overlay}.bb-vivid .bb-blob{opacity:.6}@keyframes bb-drift{0%{transform:translateZ(0) scale(1)}50%{transform:translate3d(40px,-30px,0) scale(1.08)}to{transform:translate3d(-30px,40px,0) scale(.96)}}@media (prefers-reduced-motion: reduce){.bb-blob{animation:none}}.logo{display:inline-flex;align-items:center;gap:10px}.logo-mark{width:var(--logo-size, 28px);height:var(--logo-size, 28px);border-radius:8px;object-fit:cover;background:var(--surface-2);box-shadow:inset 0 0 0 1px var(--hairline)}.logo-text{font-weight:600;letter-spacing:-.01em;color:var(--ink-0);font-size:15px}.logo-wordmark{display:inline-flex;align-items:center}.logo-wordmark-img{width:auto;display:block;max-width:100%;object-fit:contain}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:500;letter-spacing:-.005em;border-radius:var(--r-md);transition:transform .05s ease,background .15s ease,border-color .15s ease,box-shadow .15s ease,color .15s ease;text-decoration:none;-webkit-user-select:none;user-select:none}.btn:focus-visible{outline:2px solid color-mix(in srgb,var(--brand-1) 55%,transparent);outline-offset:2px}.btn-sm{padding:5px 11px;font-size:13px}.btn-md{padding:7px 14px;font-size:14px}.btn-lg{padding:10px 18px;font-size:14px}.btn-primary{background:var(--brand-1);color:#fff;box-shadow:0 1px 2px color-mix(in srgb,var(--brand-1) 25%,transparent)}.btn-primary:hover:not(:disabled){background:var(--brand-1-hover, var(--brand-1))}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-ghost{background:transparent;color:var(--ink-1);box-shadow:inset 0 0 0 1px var(--line)}.btn-ghost:hover:not(:disabled){color:var(--ink-0);box-shadow:inset 0 0 0 1px var(--line-strong);background:var(--surface-1)}.btn-subtle{background:var(--surface-2);color:var(--ink-1)}.btn-subtle:hover:not(:disabled){background:var(--surface-3);color:var(--ink-0)}.btn-danger{background:#f43f5e24;color:var(--bad);box-shadow:inset 0 0 0 1px #f43f5e66}.btn-danger:hover:not(:disabled){background:#f43f5e38;color:#fff}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-loading .btn-label{opacity:.6}.btn-icon{display:inline-flex;align-items:center;justify-content:center}.card{position:relative;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);overflow:hidden}.card-padded{padding:20px}.card-glow:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:inherit;background:linear-gradient(135deg,#7c5cff73,#22d3ee40);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;padding:1px;pointer-events:none}.section-title{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:12px}.section-title-text h2{margin:0;font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-1)}.section-title-text p{margin:4px 0 0;font-size:13px;color:var(--ink-2)}.field{display:flex;flex-direction:column;gap:6px}.field-label{font-size:12px;font-weight:500;color:var(--ink-2);letter-spacing:.04em;text-transform:uppercase}.field-hint{font-size:12px;color:var(--ink-3)}.field-error{font-size:12px;color:var(--bad)}.input{width:100%;padding:8px 12px;background:var(--surface-1);border:1px solid var(--line);border-radius:var(--r-md);color:var(--ink-0);font-size:14px;transition:border-color .15s ease,background .15s ease,box-shadow .15s ease}.input::placeholder{color:var(--ink-3)}.input:hover{border-color:var(--line-strong)}.input:focus{outline:none;border-color:var(--brand-1);box-shadow:0 0 0 3px color-mix(in srgb,var(--brand-1) 16%,transparent);background:var(--surface-2)}.input-invalid{border-color:var(--bad)}.input-invalid:focus{border-color:var(--bad);box-shadow:0 0 0 3px #f43f5e2e}.textarea{min-height:96px;resize:vertical;line-height:1.5}.spinner-wrap{display:inline-flex;align-items:center;gap:8px;color:var(--ink-2);font-size:13px}.spinner{display:inline-block;border:2px solid var(--surface-strong);border-top-color:var(--brand-2);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:48px 24px;color:var(--ink-2)}.empty-state-icon{font-size:36px;margin-bottom:8px;opacity:.6}.empty-state h3{margin:0 0 6px;color:var(--ink-0);font-size:16px;font-weight:600;letter-spacing:-.01em}.empty-state p{margin:0;font-size:14px;color:var(--ink-2);max-width:38ch;margin-inline:auto}.empty-state-action{margin-top:16px;display:inline-flex}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:var(--r-pill);font-size:11px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;background:var(--surface-2);color:var(--ink-1);box-shadow:inset 0 0 0 1px var(--hairline)}.badge-ok{background:#34d39924;color:var(--ok);box-shadow:inset 0 0 0 1px #34d3994d}.badge-warn{background:#f59e0b24;color:var(--warn);box-shadow:inset 0 0 0 1px #f59e0b4d}.badge-bad{background:#f43f5e24;color:var(--bad);box-shadow:inset 0 0 0 1px #f43f5e4d}.badge-info{background:#60a5fa24;color:var(--info);box-shadow:inset 0 0 0 1px #60a5fa4d}.badge-brand{background:#7c5cff24;color:#b9a8ff;box-shadow:inset 0 0 0 1px #7c5cff59}.shell{min-height:100vh;position:relative}.shell-sidebar{position:fixed;top:0;left:0;width:256px;height:100vh;z-index:20;overflow-y:auto;overscroll-behavior:contain;border-right:1px solid var(--glass-border);background:linear-gradient(180deg,var(--chrome-bg-a),var(--chrome-bg-b));backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);padding:20px 16px;display:flex;flex-direction:column;gap:6px}.shell-main{display:flex;flex-direction:column;min-height:100vh}.shell-with-sidebar .shell-main{margin-left:256px}.shell-header{position:sticky;top:0;z-index:5;padding:14px 28px;display:flex;align-items:center;justify-content:space-between;gap:16px;background:linear-gradient(180deg,var(--chrome-bg-a),var(--chrome-bg-b));backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--glass-border)}.shell-content{flex:1;padding:28px 32px 64px;max-width:1280px;width:100%;margin:0 auto}.page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:24px}.page-header h1{margin:0;font-size:24px;font-weight:600;letter-spacing:-.025em;color:var(--ink-0)}.page-header p{margin:6px 0 0;color:var(--ink-2);font-size:14px}@media (max-width: 880px){.shell-sidebar{position:static;width:100%;height:auto;border-right:0;border-bottom:1px solid var(--glass-border);flex-direction:row;flex-wrap:wrap;gap:8px}.shell-with-sidebar .shell-main{margin-left:0}.shell-content{padding:20px 16px 48px}}.theme-toggle{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;display:inline-flex;align-items:center;gap:4px;padding:4px;border:1px solid var(--line);background:var(--bg-2);border-radius:var(--r-pill);color:var(--ink-2);transition:border-color .15s ease,background .15s ease,color .15s ease;position:relative}.theme-toggle:hover{border-color:var(--line-strong);color:var(--ink-0)}.theme-toggle-icon{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;transition:background .15s ease,color .15s ease}.theme-toggle[data-theme-state=light] .theme-toggle-sun{background:#6a48ff29;color:var(--brand-1)}.theme-toggle[data-theme-state=dark] .theme-toggle-moon{background:#7c5cff2e;color:#b9a8ff}.theme-toggle:focus-visible{outline:2px solid rgba(124,92,255,.55);outline-offset:2px}.barchart{position:relative;width:100%;-webkit-user-select:none;user-select:none}.barchart-svg{width:100%;height:100%;display:block}.barchart-tooltip{position:absolute;bottom:calc(100% + 4px);transform:translate(-50%);pointer-events:none;background:var(--bg-1);color:var(--ink-0);border:1px solid var(--line);border-radius:var(--r-md);padding:4px 8px;font-size:11px;white-space:nowrap;display:flex;flex-direction:column;gap:1px;box-shadow:var(--shadow-md);z-index:2}.barchart-tooltip-label{color:var(--ink-2);font-size:10px;letter-spacing:.04em;text-transform:uppercase}.barchart-tooltip-value{font-weight:600;font-variant-numeric:tabular-nums}.barchart-empty{color:var(--ink-3);font-size:13px;padding:20px;text-align:center}.search-bar{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;background:var(--surface-1);border:1px solid var(--line);border-radius:var(--r-pill);width:100%;max-width:320px;transition:border-color .15s ease,background .15s ease,box-shadow .15s ease}.search-bar:focus-within{border-color:#7c5cffb3;background:var(--surface-2);box-shadow:0 0 0 3px #7c5cff24}.search-bar-icon{display:inline-flex;color:var(--ink-3);flex-shrink:0}.search-bar-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;outline:none;background:transparent;color:var(--ink-0);font-size:13.5px;width:100%;padding:0}.search-bar-input::placeholder{color:var(--ink-3)}.search-bar-count{font-size:11px;color:var(--ink-3);white-space:nowrap;letter-spacing:.04em}:root,:root[data-theme=dark]{color-scheme:dark;--brand-1: #6366f1;--brand-1-hover: #818cf8;--brand-2: #4fc3f7;--brand-3: #22d3ee;--brand-4: #ec4899;--bg-0: #06070d;--bg-1: #0b0d18;--bg-2: #11152263;--bg-3: #161b2eaa;--line: #232a44;--line-strong: #3a4574;--surface-1: rgba(255, 255, 255, .03);--surface-2: rgba(255, 255, 255, .045);--surface-3: rgba(255, 255, 255, .07);--surface-strong: rgba(255, 255, 255, .12);--hairline: rgba(255, 255, 255, .06);--row-hover: rgba(255, 255, 255, .04);--chrome-bg-a: rgba(11, 13, 24, .62);--chrome-bg-b: rgba(11, 13, 24, .24);--ink-0: #f3f5fb;--ink-1: #c7cce0;--ink-2: #8a91ad;--ink-3: #5b6385;--ok: #34d399;--warn: #f59e0b;--bad: #f43f5e;--info: #60a5fa;--glass-bg: rgba(20, 24, 42, .55);--glass-border: rgba(255, 255, 255, .06);--glass-blur: blur(18px) saturate(140%);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 8px 24px rgba(0, 0, 0, .32);--shadow-glow: 0 0 0 1px rgba(124, 92, 255, .35), 0 12px 40px rgba(124, 92, 255, .25)}:root[data-theme=light]{color-scheme:light;--brand-1: #4f46e5;--brand-1-hover: #6366f1;--brand-2: #1f9cd6;--brand-3: #0eb4c9;--brand-4: #d6438a;--bg-0: #eef0f6;--bg-1: #ffffff;--bg-2: rgba(255, 255, 255, .7);--bg-3: rgba(255, 255, 255, .88);--line: #d9def0;--line-strong: #b5bdd3;--surface-1: rgba(13, 18, 48, .04);--surface-2: rgba(13, 18, 48, .06);--surface-3: rgba(13, 18, 48, .085);--surface-strong: rgba(13, 18, 48, .14);--hairline: rgba(13, 18, 48, .07);--row-hover: rgba(13, 18, 48, .04);--chrome-bg-a: rgba(255, 255, 255, .85);--chrome-bg-b: rgba(255, 255, 255, .6);--ink-0: #0a0e22;--ink-1: #20284a;--ink-2: #4a5172;--ink-3: #6c739a;--ok: #0c9a6a;--warn: #b97309;--bad: #c92a4a;--info: #2563eb;--glass-bg: rgba(255, 255, 255, .85);--glass-border: rgba(13, 18, 48, .08);--glass-blur: blur(18px) saturate(160%);--shadow-sm: 0 1px 2px rgba(13, 18, 48, .06);--shadow-md: 0 12px 32px rgba(13, 18, 48, .12);--shadow-glow: 0 0 0 1px rgba(106, 72, 255, .22), 0 12px 40px rgba(106, 72, 255, .18)}:root{--r-sm: 6px;--r-md: 10px;--r-lg: 16px;--r-xl: 24px;--r-pill: 999px;--font-sans: "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Apple Color Emoji", "Segoe UI Emoji", sans-serif}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg-0);color:var(--ink-0);font-family:var(--font-sans);font-feature-settings:"cv11","ss01","ss03";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;overflow-x:hidden}body{position:relative;isolation:isolate}#root{min-height:100vh;position:relative;z-index:1}a{color:var(--brand-2);text-decoration:none}a:hover{color:var(--brand-3)}button{font-family:inherit}input,textarea,select{font-family:inherit;color:inherit}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:8px}::-webkit-scrollbar-thumb:hover{background:#ffffff29}::selection{background:#7c5cff66;color:var(--ink-0)}.stack{display:flex;flex-direction:column;gap:14px}.stack-lg{display:flex;flex-direction:column;gap:22px}.row-gap-sm{display:flex;gap:8px;align-items:center}.muted{color:var(--ink-2)}.section-h{margin:0;font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.kpi{display:flex;flex-direction:column;gap:4px}.kpi-label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-2)}.kpi-value{font-size:24px;font-weight:600;letter-spacing:-.02em;color:var(--ink-0);font-variant-numeric:tabular-nums}.kpi-foot{font-size:11px;color:var(--ink-3)}.table{width:100%;border-collapse:collapse;font-size:13px}.table thead th{text-align:left;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-2);padding:10px 14px;font-weight:500;border-bottom:1px solid var(--hairline);background:var(--surface-1)}.table tbody td{padding:10px 14px;border-bottom:1px solid var(--hairline);color:var(--ink-1);vertical-align:middle}.table tbody tr:hover td{background:var(--row-hover)}.table tbody tr:last-child td{border-bottom:0}.table .cell-num{text-align:right;font-variant-numeric:tabular-nums;color:var(--ink-0)}.table-tight tbody td{padding:8px 14px}.table-wrap{overflow-x:auto}.avatar{width:28px;height:28px;border-radius:50%;background:var(--surface-2);display:inline-flex;align-items:center;justify-content:center;color:var(--ink-1);font-size:12px;font-weight:600;overflow:hidden;flex-shrink:0}.avatar img{width:100%;height:100%;object-fit:cover}.avatar-lg{width:56px;height:56px;font-size:18px}.auth{min-height:100vh;display:grid;place-items:center;padding:24px;position:relative}.auth-theme-toggle{position:absolute;top:20px;right:24px}.auth-stack{display:flex;flex-direction:column;align-items:stretch;width:100%;max-width:420px;gap:20px}.auth-brand{display:flex;flex-direction:column;align-items:center;gap:4px}.auth-brand .logo-wordmark{color:var(--ink-0)}.auth-brand .logo-wordmark svg{max-width:100%;height:auto}.auth-brand-tag{margin:10px 0 0;font-size:12px;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-2)}.auth-brand-sub{margin:0;color:var(--ink-2);font-size:14px}.auth-card-card{width:100%}.auth-card-form{display:flex;flex-direction:column;gap:14px;padding:22px}.auth-field{display:flex;flex-direction:column;gap:6px}.auth-field-label{font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2)}.auth-input-wrap{position:relative;display:flex;align-items:center}.auth-input-icon{position:absolute;left:14px;color:var(--ink-3);pointer-events:none;display:inline-flex}.auth-input{width:100%;padding:12px 14px 12px 42px;background:var(--surface-1);border:1px solid var(--line);border-radius:var(--r-md);color:var(--ink-0);font-size:14px;font-family:inherit;transition:border-color .15s ease,background .15s ease,box-shadow .15s ease}.auth-input:hover{border-color:var(--line-strong)}.auth-input:focus{outline:none;border-color:#7c5cffb3;background:var(--surface-2);box-shadow:0 0 0 3px #7c5cff24}.auth-input::placeholder{color:var(--ink-3)}.auth-input-action{position:absolute;right:8px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:0;width:32px;height:32px;border-radius:var(--r-md);color:var(--ink-3);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .15s ease,color .15s ease}.auth-input-action:hover{color:var(--ink-0);background:var(--surface-2)}.auth-card-form .btn{width:100%}.auth-foot{margin:4px 0 0;text-align:center;font-size:12px;color:var(--ink-3)}.auth-error{font-size:13px;color:var(--bad);background:color-mix(in srgb,var(--bad) 12%,transparent);border:1px solid color-mix(in srgb,var(--bad) 35%,transparent);padding:8px 12px;border-radius:var(--r-md)}.auth-ok{font-size:13px;color:var(--ok);background:color-mix(in srgb,var(--ok) 12%,transparent);border:1px solid color-mix(in srgb,var(--ok) 35%,transparent);padding:8px 12px;border-radius:var(--r-md)}.settings-account{display:flex;align-items:center;justify-content:space-between;gap:16px}.settings-stack{display:flex;flex-direction:column;gap:16px;max-width:520px}.sidebar-brand{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:4px 8px 14px;border-bottom:1px solid var(--glass-border);margin-bottom:6px}.sidebar-brand .logo-wordmark-img{max-width:150px}.sidebar-link{display:flex;align-items:center;gap:12px;padding:8px 12px;border-radius:var(--r-md);color:var(--ink-2);font-size:13.5px;font-weight:500;text-decoration:none;transition:background .15s ease,color .15s ease}.sidebar-link:hover{color:var(--ink-0);background:var(--surface-1)}.sidebar-link.is-active{color:var(--ink-0);background:color-mix(in srgb,var(--brand-1) 16%,transparent);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--brand-1) 30%,transparent)}.sidebar-foot{margin-top:auto;padding-top:12px;border-top:1px solid var(--glass-border)}.user-chip{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:var(--r-md)}.user-chip-text{display:flex;flex-direction:column;min-width:0}.user-chip-text .name{font-size:12.5px;color:var(--ink-0);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-chip-text .email{font-size:11px;color:var(--ink-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-signout{margin-top:8px;width:100%;background:transparent;border:1px solid var(--line);color:var(--ink-2);padding:7px 10px;border-radius:var(--r-md);font-size:12px;cursor:pointer;font-family:inherit;transition:border-color .15s ease,color .15s ease,background .15s ease}.sidebar-signout:hover{border-color:var(--line-strong);color:var(--ink-0);background:var(--surface-1)}.dash-cols{display:grid;grid-template-columns:1.1fr 1fr;gap:16px}@media (max-width: 920px){.dash-cols{grid-template-columns:1fr}}.card-head{padding:14px 18px;border-bottom:1px solid var(--hairline);display:flex;align-items:center;justify-content:space-between;gap:12px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:color-mix(in srgb,var(--bg-0) 80%,transparent);backdrop-filter:blur(8px) saturate(140%);-webkit-backdrop-filter:blur(8px) saturate(140%);z-index:50;display:grid;place-items:start center;padding:48px 16px;overflow-y:auto}.modal-shell{width:100%;max-width:560px}.modal-shell.modal-wide{max-width:720px}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 20px;border-bottom:1px solid var(--glass-border)}.modal-header h2{margin:0;font-size:16px;font-weight:600;letter-spacing:-.01em;color:var(--ink-0)}.modal-close{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:0;color:var(--ink-2);font-size:18px;cursor:pointer;width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;transition:background .15s ease,color .15s ease}.modal-close:hover{background:var(--surface-2);color:var(--ink-0)}.modal-body{padding:18px 20px}.modal-foot{padding:14px 20px;border-top:1px solid var(--glass-border);display:flex;align-items:center;justify-content:flex-end;gap:8px}.photo-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:10px}.photo-tile{position:relative;aspect-ratio:1;border-radius:var(--r-md);overflow:hidden;background:var(--surface-2);box-shadow:inset 0 0 0 1px var(--hairline);display:grid;place-items:center}.photo-tile img{width:100%;height:100%;object-fit:cover}.photo-tile .photo-remove{position:absolute;top:6px;right:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:color-mix(in srgb,var(--bg-0) 80%,transparent);color:var(--ink-0);font-size:13px;width:22px;height:22px;border-radius:50%;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.photo-tile.photo-tile-uploader{cursor:pointer;color:var(--ink-2);border:1px dashed var(--line);background:var(--surface-1);font-size:22px;transition:border-color .15s ease,background .15s ease,color .15s ease}.photo-tile.photo-tile-uploader:hover{border-color:var(--line-strong);background:var(--surface-2);color:var(--ink-0)}.photo-tile.photo-tile-uploader input{display:none}.photo-tile .photo-progress{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:color-mix(in srgb,var(--bg-0) 70%,transparent);color:var(--ink-0);font-size:12px}.photo-single{width:128px;height:128px}.page-header h1{font-size:22px}.cell-actions{text-align:right;white-space:nowrap}
