
/* OPPFINDER V1.2 FRONTEND STYLES */
:root{
  --bg:#0f172a;--surface:#111827;--surface-2:#182236;--text:#e5e7eb;--muted:#94a3b8;
  --primary:#0b3d91;--secondary:#1e6fb7;--accent:#4fb3d9;--danger:#d33c3c;--success:#4caf50;
  --border:rgba(255,255,255,.1);--shadow:0 10px 30px rgba(0,0,0,.22);--grid-color:rgba(79,179,217,.12);--grid-size:12px;
  --app-vh:1vh
}
body.theme-light{--bg:#f7fbff;--surface:#fff;--surface-2:#eef6fb;--text:#183047;--muted:#667789;--border:rgba(24,48,71,.13);--shadow:0 14px 34px rgba(68,92,116,.13);--grid-color:rgba(90,145,190,.14)}
*{box-sizing:border-box}
html,body{height:calc(var(--app-vh, 1vh) * 100);min-height:100dvh;width:100%;max-width:100%;margin:0;font-family:Inter,Arial,sans-serif;background:var(--bg);color:var(--text)}
body{overflow:hidden}
a:not(.button-link){color:#2563eb}
a:not(.button-link):visited{color:#2563eb}
a:not(.button-link):hover{color:#1d4ed8}
.app-boot-overlay{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:24px;background:
radial-gradient(circle at top, rgba(79,179,217,.18), transparent 42%),
linear-gradient(180deg, rgba(3,20,27,.96), rgba(4,26,34,.98));z-index:2000}
.app-boot-card{max-width:560px;padding:28px 32px;border:1px solid var(--border);border-radius:24px;background:linear-gradient(180deg,var(--surface),rgba(255,255,255,.04));box-shadow:var(--shadow)}
.app-boot-eyebrow{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.app-boot-card h1{margin:0 0 10px 0;font-size:32px;line-height:1.05}
.app-boot-card p{margin:0;color:var(--muted);font-size:15px;line-height:1.5}
.app-boot-progress,.inline-progress{position:relative;overflow:hidden;height:9px;margin-top:18px;border-radius:999px;background:rgba(255,255,255,.09);border:1px solid var(--border)}
.app-boot-progress span,.inline-progress span{position:absolute;inset:0 auto 0 0;width:42%;border-radius:999px;background:linear-gradient(90deg,var(--primary),var(--accent),var(--secondary));animation:quill-progress 1.15s ease-in-out infinite}
.app-boot-status{margin-top:10px;color:var(--muted);font-size:12px}
.app-boot-actions{margin-top:12px;display:flex;gap:8px;flex-wrap:wrap}
.app-boot-actions button{padding:8px 10px;border-radius:10px;border:1px solid var(--border);background:rgba(255,255,255,.06);color:var(--text);cursor:pointer}
.app-boot-actions button:hover{background:rgba(255,255,255,.12)}
.inline-progress{height:7px;margin:0;min-width:120px;flex:1}
.login-activity{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:12px}
.login-activity.hidden{display:none}
.feedback-link{position:fixed;left:18px;bottom:18px;z-index:860;border:1px solid rgba(79,179,217,.5);border-radius:999px;background:linear-gradient(90deg,var(--secondary),var(--accent));color:#fff;padding:10px 16px;font-weight:800;box-shadow:var(--shadow);cursor:pointer}
.feedback-link:hover{filter:brightness(1.08)}
.feedback-dialog{position:fixed;inset:0;z-index:1900;display:flex;align-items:center;justify-content:center;padding:18px;background:rgba(3,10,18,.52);backdrop-filter:blur(6px)}
.feedback-dialog.hidden{display:none}
.feedback-card{width:min(620px,calc(100vw - 28px));max-height:calc(100vh - 36px);overflow:auto;border:1px solid var(--border);border-radius:22px;background:linear-gradient(180deg,var(--surface),var(--surface-2));box-shadow:0 24px 80px rgba(0,0,0,.42);padding:18px;display:grid;gap:12px}
.feedback-header{display:flex;align-items:center;justify-content:space-between;gap:10px}
.feedback-card p{margin:0;color:var(--muted);line-height:1.45}
.inline-link-btn{border:0;background:transparent;color:#2563eb;text-decoration:underline;padding:0;font:inherit;cursor:pointer}
@keyframes quill-progress{0%{transform:translateX(-110%)}55%{transform:translateX(85%)}100%{transform:translateX(255%)}}
body.app-booting .app-boot-overlay{display:flex}
body.app-booting .app-shell{visibility:hidden}
.app-shell{display:grid;grid-template-columns:260px 1fr 0;height:calc(var(--app-vh, 1vh) * 100)}
.app-shell{height:100dvh;min-height:calc(var(--app-vh, 1vh) * 100)}
.sidebar{background:linear-gradient(180deg,var(--surface),var(--surface-2));border-right:1px solid var(--border);position:relative;display:flex;flex-direction:column;width:var(--rail-width);min-width:0;transition:width .18s ease}
.sidebar.collapsed{width:76px}
.sidebar-header{padding:16px 14px 8px}
.brand-mini{display:flex;gap:10px;align-items:center}
.brand-mini img{width:42px;height:42px;object-fit:contain;background:rgba(255,255,255,.06);border-radius:10px;padding:4px}
.brand-name{font-weight:700}
.brand-subtitle{font-size:12px;color:var(--muted)}
.rail-identity-row{position:relative;margin-top:8px;display:grid;grid-template-columns:minmax(0,1fr) 32px;gap:6px;align-items:stretch}
.rail-identity{width:100%;display:grid;grid-template-columns:24px minmax(0,1fr);align-items:center;gap:7px;border:1px solid var(--border);border-radius:10px;background:rgba(255,255,255,.035);color:var(--text);padding:6px 7px;text-align:left;cursor:pointer}
.rail-identity:hover{background:rgba(255,255,255,.07)}
.rail-identity-avatar{width:24px;height:24px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 24px;background:var(--primary);color:#fff;font-size:13px;font-weight:800;line-height:1}
.rail-identity-copy{display:grid;gap:0;min-width:0;line-height:1.05}
.rail-identity-name{font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rail-identity-role{font-size:10px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-transform:capitalize}
.rail-profile-menu-btn{border:1px solid var(--border);border-radius:10px;background:rgba(255,255,255,.035);color:var(--text);cursor:pointer;font-size:14px}
.rail-profile-menu-btn:hover{background:rgba(255,255,255,.08)}
.profile-menu{position:absolute;left:0;right:0;top:calc(100% + 6px);z-index:1500;border:1px solid var(--border);border-radius:14px;background:linear-gradient(180deg,var(--surface),var(--surface-2));box-shadow:var(--shadow);padding:10px;display:grid;gap:8px}
.profile-menu-title{font-size:12px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.profile-menu button,.profile-menu select{font-size:12px}
.profile-menu-row{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted)}
.profile-menu-row input{width:auto}
.sidebar-nav{padding:12px;display:flex;flex-direction:column;gap:8px;overflow-y:auto}
.nav-item{width:100%;text-align:left;padding:12px;border-radius:12px;background:transparent;border:1px solid transparent;color:var(--text);cursor:pointer;font-size:14px;display:flex;align-items:center;gap:10px}
.nav-item:hover{background:rgba(255,255,255,.06)}
.nav-item.active{background:rgba(79,179,217,.14);border-color:rgba(79,179,217,.25)}
.nav-item.locked{opacity:.45;cursor:not-allowed;filter:grayscale(.1)}
.nav-icon{display:inline-flex;width:18px;justify-content:center;flex:0 0 18px}
.nav-label{white-space:nowrap}
.rail-search-hit{background:color-mix(in srgb,var(--accent) 38%,#fef08a 62%);color:#101820;border-radius:4px;padding:0 2px;font-weight:800}
.sidebar.collapsed .brand-name,.sidebar.collapsed .brand-subtitle{display:none}
.sidebar.collapsed .nav-label{display:none}
.sidebar.collapsed .nav-item{justify-content:center;padding:12px 0}
.sidebar.collapsed .nav-icon{margin-right:0}
.sidebar-footer{margin-top:auto;padding:12px;display:flex;flex-direction:column;gap:8px}
.tier-chip{background:linear-gradient(90deg,var(--primary),var(--accent));color:#fff;font-size:12px;border-radius:999px;padding:9px 12px;text-align:center}
.version-chip{font-size:12px;color:var(--muted);text-align:center}
.version-link-btn{font-size:12px;padding:6px 8px;border-radius:8px;background:transparent;border:1px solid var(--border);color:var(--muted)}
.version-link-btn:hover{color:var(--text);border-color:color-mix(in srgb,var(--accent) 40%,var(--border))}
.main-shell{display:grid;grid-template-rows:auto minmax(0,1fr) auto;min-width:0;min-height:calc(var(--app-vh, 1vh) * 100);overflow:hidden}
.topbar{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--surface) 82%,transparent);gap:12px;position:relative;color:var(--text)}
.topbar-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.maintenance-broadcast-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border-bottom:1px solid rgba(248,113,113,.34);background:linear-gradient(90deg,rgba(127,29,29,.92),rgba(153,27,27,.9));color:#fff;position:relative;z-index:6}
.maintenance-broadcast-banner.hidden{display:none}
.maintenance-broadcast-banner.active{border-bottom-color:rgba(251,191,36,.42);background:linear-gradient(90deg,rgba(120,53,15,.9),rgba(146,64,14,.9))}
.maintenance-broadcast-banner.warning{border-bottom-color:rgba(252,165,165,.55);background:linear-gradient(90deg,rgba(153,27,27,.95),rgba(185,28,28,.95))}
.maintenance-broadcast-banner.critical{border-bottom-color:rgba(254,240,138,.78);background:linear-gradient(90deg,rgba(127,29,29,.98),rgba(220,38,38,.98))}
.maintenance-broadcast-copy{display:flex;flex-direction:column;gap:2px;min-width:0}
.maintenance-broadcast-title{font-size:13px;font-weight:700;line-height:1.3}
.maintenance-broadcast-meta{font-size:11px;opacity:.9;line-height:1.2}
.maintenance-broadcast-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.maintenance-broadcast-actions button{padding:6px 10px;border-radius:10px;border:1px solid rgba(255,255,255,.28);background:rgba(255,255,255,.12);color:#fff;font-size:11px}
.maintenance-broadcast-actions button:hover{background:rgba(255,255,255,.2)}
@media (max-width:900px){
  .maintenance-broadcast-banner{flex-direction:column;align-items:flex-start}
  .maintenance-broadcast-actions{width:100%}
}
.saved-state{font-size:12px;color:var(--muted);min-width:94px}
.saved-state.dirty,#saveLayoutBtn.dirty,#editToolboxSaveBtn.dirty,#editToolboxSaveCloseBtn.dirty{color:#1b1200;background:linear-gradient(90deg,#f6c244,#ffdf7a);border-color:rgba(246,194,68,.75);box-shadow:0 0 0 2px rgba(246,194,68,.18)}
.shell-resize-handle{position:absolute;display:none;z-index:120;background:rgba(79,179,217,.55);transition:background .18s ease,opacity .18s ease,box-shadow .18s ease;opacity:.95;box-shadow:0 0 0 1px rgba(255,255,255,.16) inset}
.shell-resize-handle:hover{background:rgba(79,179,217,.82);opacity:1;box-shadow:0 0 0 1px rgba(255,255,255,.3) inset,0 0 14px rgba(79,179,217,.28)}
.edit-mode .shell-resize-handle{display:block}
.shell-resize-handle-header,.shell-resize-handle-footer{left:0;right:0;height:12px;cursor:ns-resize}
.shell-resize-handle-header{bottom:0}
.shell-resize-handle-footer{top:0}
.shell-resize-handle-rail{top:0;right:0;bottom:0;width:12px;cursor:ew-resize}
.rail-divider-toggle{
  position:absolute;
  top:50%;
  right:-13px;
  transform:translateY(-50%);
  width:26px;
  height:44px;
  border-radius:12px;
  border:1px solid color-mix(in srgb,var(--accent) 36%,var(--border));
  background:color-mix(in srgb,var(--surface) 86%,var(--secondary) 14%);
  color:var(--text);
  box-shadow:var(--shadow);
  z-index:60;
  display:none;
  align-items:center;
  justify-content:center;
  font-weight:700;
}
.rail-divider-toggle:hover{background:color-mix(in srgb,var(--surface) 72%,var(--accent) 28%)}
.page-content{min-height:0;height:100%;overflow:auto}
.dashboard-container{height:100%;display:grid;grid-template-columns:1fr;min-height:100%}
.dashboard-container.editing{grid-template-columns:1fr}
.widget-palette{display:none}
.dashboard-grid{position:relative;overflow:auto;padding:16px;min-height:100%;height:100%;width:100%;touch-action:pan-x pan-y}
.dashboard-grid.editing{background-image:linear-gradient(to right,var(--grid-color) 1px,transparent 1px),linear-gradient(to bottom,var(--grid-color) 1px,transparent 1px);background-size:var(--grid-size) var(--grid-size);outline:2px solid rgba(211,60,60,.45)}
.widget{position:absolute;display:flex;flex-direction:column;background:linear-gradient(180deg,var(--surface),rgba(255,255,255,.03));border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);overflow:hidden;min-width:260px;min-height:180px}
body.edit-mode .widget{overflow:visible}
.widget.dragging{border-color:var(--danger)}
.widget.widget-raised{box-shadow:0 20px 60px rgba(0,0,0,.28),0 0 0 1px color-mix(in srgb,var(--accent) 14%,transparent),var(--shadow)}
.widget.widget-focused{border-color:color-mix(in srgb,var(--accent) 86%,white 14%);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 28%,transparent),0 0 28px color-mix(in srgb,var(--accent) 22%,transparent),var(--shadow)}
.widget.widget-selected{border-color:color-mix(in srgb,var(--accent) 74%,white 16%);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 22%,transparent),var(--shadow)}
.widget.single-card-tour-focus{border-color:rgba(79,179,217,.95);box-shadow:0 0 0 2px rgba(79,179,217,.35),0 24px 70px rgba(0,0,0,.36),var(--shadow)}
.widget.single-card-tour-hidden{display:none}
.widget-header{display:flex;justify-content:space-between;align-items:center;padding:4px 10px;min-height:var(--widget-header-height);border-bottom:1px solid var(--border);background:rgba(255,255,255,.03);cursor:move;gap:8px;position:relative}
.widget-title{font-weight:700}
.widget-actions{display:flex;gap:6px}
.widget-tour-btn{margin-left:auto;display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 7px;border-radius:999px;border:1px solid var(--border);background:rgba(255,255,255,.08);color:var(--text);font-weight:800;line-height:1}
.widget-tour-btn:hover{background:rgba(79,179,217,.18);border-color:rgba(79,179,217,.5)}
.widget-body{padding:12px 14px;flex:1;min-height:0;overflow:auto}
.widget-edit-pill{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;padding:5px 8px;border-radius:999px;background:linear-gradient(90deg,rgba(211,60,60,.95),rgba(170,32,32,.92));color:#fff;box-shadow:0 6px 18px rgba(0,0,0,.18)}
.widget-edit-pill-title{font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.widget-edit-pill-actions{display:flex;align-items:center;gap:6px}
.widget-header-actions-inline{display:flex;align-items:center;gap:8px}
.widget-pill-btn{display:inline-flex;align-items:center;justify-content:center;min-width:26px;height:24px;padding:0 7px;border-radius:999px;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.12);color:#fff;font-size:13px}
.widget-pill-btn:hover{background:rgba(255,255,255,.2)}
.widget-autorefresh-toggle{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:999px;border:1px solid var(--border);background:rgba(255,255,255,.08);font-size:11px;color:var(--muted);cursor:pointer}
.widget-autorefresh-toggle input{accent-color:var(--accent)}
.maximized-widget{inset:12px auto auto 12px;z-index:1200}
.maximized-widget .widget-body{overflow:auto}
.resize-handle{position:absolute;width:18px;height:18px;opacity:0;border:2px solid var(--accent);background:color-mix(in srgb, var(--accent) 14%, transparent);box-shadow:0 0 0 1px rgba(255,255,255,.12) inset;border-radius:999px;transition:opacity .15s ease,background .15s ease,transform .15s ease}
.resize-handle:hover{background:color-mix(in srgb, var(--accent) 26%, transparent);transform:scale(1.06)}
.resize-handle-se{right:5px;bottom:5px;border-left-color:transparent;border-top-color:transparent;cursor:nwse-resize}
.resize-handle-sw{left:5px;bottom:5px;border-right-color:transparent;border-top-color:transparent;cursor:nesw-resize}
.resize-handle-ne{right:5px;top:5px;border-left-color:transparent;border-bottom-color:transparent;cursor:nesw-resize}
.resize-handle-nw{left:5px;top:5px;border-right-color:transparent;border-bottom-color:transparent;cursor:nwse-resize}
.dashboard-grid.editing .resize-handle,.dashboard-grid.single-card-focus .resize-handle{opacity:1}
.alignment-line{position:absolute;background:rgba(211,60,60,.9);z-index:999;pointer-events:none}
.alignment-line.vertical{width:2px;top:0;bottom:0}
.alignment-line.horizontal{height:2px;left:0;right:0}
.workspace-arrow{position:absolute;z-index:30;display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:999px;border:1px solid rgba(79,179,217,.28);background:var(--nav-tool-bg);color:var(--nav-tool-text);box-shadow:var(--shadow);opacity:.82;transition:opacity .18s ease,transform .18s ease}
.workspace-arrow:hover{opacity:1;transform:scale(1.04)}
.workspace-arrow-up{top:16px;left:50%;transform:translateX(-50%)}
.workspace-arrow-home{top:16px;right:16px}
.workspace-arrow-right{top:50%;right:16px;transform:translateY(-50%)}
.workspace-arrow-down{bottom:16px;left:50%;transform:translateX(-50%)}
.workspace-arrow-left{top:50%;left:16px;transform:translateY(-50%)}
.workspace-nav-dock{position:absolute;right:18px;bottom:18px;z-index:32;display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:16px;background:color-mix(in srgb, var(--nav-tool-bg) 30%, transparent);border:1px solid rgba(79,179,217,.14);backdrop-filter:blur(8px);opacity:.18;transition:opacity .2s ease, background .2s ease, border-color .2s ease}
.workspace-nav-dock:hover,.workspace-nav-dock.active{opacity:1;background:var(--nav-tool-bg);border-color:rgba(79,179,217,.35)}
.workspace-nav-dock button{padding:8px 10px;border-radius:10px;background:color-mix(in srgb, var(--nav-tool-bg) 82%, white 18%);color:var(--nav-tool-text)}
.workspace-assistant-btn{font-weight:700;letter-spacing:.01em}
.workspace-zoom-tools{position:relative;display:flex;align-items:center;gap:6px}
.workspace-mini-map-toggle{min-width:46px}
.workspace-mini-map-toggle.active{border-color:color-mix(in srgb,var(--accent) 70%,white 10%);background:color-mix(in srgb,var(--accent) 20%,transparent)}
.workspace-mini-map{position:absolute;right:0;bottom:calc(100% + 8px);width:170px;height:116px;border-radius:12px;border:1px solid rgba(79,179,217,.36);background:color-mix(in srgb,var(--nav-tool-bg) 84%,#050b14 16%);box-shadow:var(--shadow);overflow:hidden;cursor:crosshair}
.workspace-mini-map-canvas{position:absolute;inset:0}
.workspace-mini-map-card{position:absolute;display:block;border-radius:2px;background:color-mix(in srgb,var(--accent) 46%,rgba(255,255,255,.16));border:1px solid color-mix(in srgb,var(--accent) 72%,white 10%);opacity:.82}
.workspace-mini-map-viewport{position:absolute;border:1px solid #fff;border-radius:2px;box-shadow:0 0 0 1px rgba(0,0,0,.35) inset;pointer-events:none}
.workspace-focus-back-btn{position:fixed;left:18px;bottom:72px;z-index:840;border:1px solid rgba(79,179,217,.5);border-radius:999px;background:var(--nav-tool-bg);color:var(--nav-tool-text);padding:11px 16px;font-weight:800;box-shadow:var(--shadow)}
.workspace-back-btn-inline{font-weight:800}
.workspace-zoom-readout{min-width:48px;text-align:center;font-size:12px;color:var(--muted)}
.workspace-fit-wrap{position:relative}
.workspace-fit-wrap .widget-menu{top:auto;bottom:44px;right:0}
.node-analysis-zoom-input{width:72px;min-width:72px;padding:6px 8px;font-size:12px;text-align:center}
.node-analysis-zoom-input::-webkit-outer-spin-button,
.node-analysis-zoom-input::-webkit-inner-spin-button{
  opacity:1;
  filter:none;
}
body.theme-light .node-analysis-zoom-input::-webkit-outer-spin-button,
body.theme-light .node-analysis-zoom-input::-webkit-inner-spin-button{
  opacity:1;
}
.node-analysis-zoom-input{
  color:var(--text);
  caret-color:var(--text);
}
.workspace-zoom-readout.armed{color:var(--text);font-weight:700}
.chat-box{display:flex;flex-direction:column;height:100%}
.chat-history{flex:1;min-height:160px;overflow:auto;border:1px solid var(--border);border-radius:12px;padding:10px;background:rgba(255,255,255,.02)}
.chat-message{padding:10px;margin-bottom:8px;border-radius:10px}
.chat-message.user{background:rgba(79,179,217,.12)}
.chat-message.assistant{background:rgba(255,255,255,.06)}
.quill-chat-result-card{margin-top:10px;padding:10px;border:1px solid var(--border);border-radius:12px;background:rgba(255,255,255,.05)}
.quill-chat-result-card a,.opportunity-interested-table a{color:#2563eb;text-decoration:underline;text-underline-offset:2px}
body:not(.theme-light) .quill-chat-result-card a,body:not(.theme-light) .opportunity-interested-table a{color:#7dd3fc}
.chat-input-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:8px;margin-top:10px}
.control-input,textarea,select,input[type="color"]{width:100%;padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:rgba(255,255,255,.04);color:var(--text)}
body.theme-light .control-input,body.theme-light textarea,body.theme-light select{background:#fff}
body.glass-effects-soft .control-input,
body.glass-effects-soft textarea,
body.glass-effects-soft select,
body.glass-effects-soft input[type="color"]{
  background:color-mix(in srgb,var(--surface) 64%,transparent);
  border-color:color-mix(in srgb,var(--accent) 22%,var(--border));
  -webkit-backdrop-filter:blur(8px) saturate(125%);
  backdrop-filter:blur(8px) saturate(125%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
body.theme-light.glass-effects-soft .control-input,
body.theme-light.glass-effects-soft textarea,
body.theme-light.glass-effects-soft select,
body.theme-light.glass-effects-soft input[type="color"]{background:rgba(255,255,255,.72)}
body.glass-effects-full .control-input,
body.glass-effects-full textarea,
body.glass-effects-full select,
body.glass-effects-full input[type="color"]{
  background:color-mix(in srgb,var(--surface) 48%,transparent);
  border-color:color-mix(in srgb,var(--accent) 36%,var(--border));
  -webkit-backdrop-filter:blur(14px) saturate(150%);
  backdrop-filter:blur(14px) saturate(150%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 10px 30px rgba(0,0,0,.12);
}
body.theme-light.glass-effects-full .control-input,
body.theme-light.glass-effects-full textarea,
body.theme-light.glass-effects-full select,
body.theme-light.glass-effects-full input[type="color"]{background:rgba(255,255,255,.58)}
select, select option{background:#0f172a;color:#f8fafc}
body.theme-light select, body.theme-light select option{background:#ffffff;color:#142033}
.compact{width:auto}
button{border-radius:10px;border:1px solid var(--border);padding:10px 12px;background:rgba(255,255,255,.06);color:var(--text);cursor:pointer}
button:hover{filter:brightness(1.06)}
button:disabled{opacity:.58;cursor:not-allowed;filter:none}
.primary-btn{background:linear-gradient(90deg,var(--primary),var(--secondary));color:#fff}
.ghost-btn{background:transparent}
.ghost-btn.active{border-color:color-mix(in srgb,var(--accent) 70%,white 12%);background:color-mix(in srgb,var(--accent) 18%,transparent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 14%,transparent)}
.danger-outline{border-color:rgba(211,60,60,.65);color:#fff;background:rgba(211,60,60,.12)}
body.theme-light .danger-outline{color:#7a1f1f;background:rgba(211,60,60,.08)}
.table-list{width:100%;border-collapse:collapse}
.table-list th,.table-list td{border-bottom:1px solid var(--border);padding:8px 6px;text-align:left;vertical-align:top}
.table-list th{color:var(--muted);font-weight:600}
.table-actions{display:flex;gap:6px;flex-wrap:wrap}
.table-actions button{padding:6px 8px;font-size:12px}
.upload-age-badge{display:inline-flex;margin:8px 0 12px;padding:9px 12px;border-radius:12px;background:linear-gradient(90deg,#f6c244,#ffdf7a);color:#1b1200;font-weight:800;box-shadow:0 0 0 2px rgba(246,194,68,.18)}
.analytics-bars{display:grid;gap:7px;margin-top:8px}
.analytics-bar-row{position:relative;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center;min-height:26px;padding:5px 8px;border-radius:10px;background:rgba(255,255,255,.04);overflow:hidden}
.analytics-bar-row span,.analytics-bar-row strong{position:relative;z-index:1;font-size:12px}
.analytics-bar-row span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.analytics-bar-row i{position:absolute;left:0;top:0;bottom:0;border-radius:10px;background:linear-gradient(90deg,color-mix(in srgb,var(--accent) 32%,transparent),color-mix(in srgb,var(--secondary) 18%,transparent));z-index:0}
.badge{display:inline-block;min-width:20px;padding:2px 8px;border-radius:999px;background:var(--danger);color:#fff;font-size:11px;text-align:center}
.badge.hidden{display:none}
.govcon-filter-group{margin-top:12px;border:1px solid var(--border);border-radius:14px;background:rgba(255,255,255,.03);overflow:hidden}
.kanban-intro{margin-bottom:8px}
.kanban-add-task{display:grid;grid-template-columns:minmax(180px,1.4fr) minmax(120px,.75fr) minmax(180px,1.2fr) minmax(150px,.8fr) auto auto;gap:8px;align-items:center;margin:8px 0}
.kanban-add-task .control-input{min-height:34px;padding:6px 9px}
.kanban-add-task button{min-height:34px;white-space:nowrap;padding:6px 10px}
.kanban-add-task-expanded{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:8px;margin:6px 0 10px 0;padding:10px;border:.75px solid var(--border);border-radius:12px;background:rgba(255,255,255,.03)}
.kanban-add-task-expanded label{display:grid;gap:6px;font-size:12px;color:var(--muted)}
.kanban-add-task-expanded .check-row{align-content:center}
.kanban-add-task-expanded .table-actions{align-self:end}
.kanban-toolbar{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;margin:8px 0}
.kanban-toolbar-left,.kanban-toolbar-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.kanban-view-toggle{display:inline-flex;align-items:center;gap:4px;padding:2px;border:1px solid var(--border);border-radius:10px;background:rgba(255,255,255,.04)}
.kanban-view-toggle button{min-height:30px;padding:5px 10px;border-radius:8px}
.kanban-view-toggle button.active{background:var(--button-bg);color:#fff}
.kanban-grid-shell{position:relative;max-height:min(62vh,680px);overflow:auto;border:.75px solid var(--border);border-radius:12px;padding:6px;background:rgba(255,255,255,.02)}
.kanban-scroll-cue{position:sticky;left:50%;transform:translateX(-50%);z-index:3;width:18px;height:18px;min-height:18px;padding:0;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:9px;line-height:1;border:1px solid color-mix(in srgb,var(--accent) 65%,white 10%);background:rgba(6,16,28,.82);color:color-mix(in srgb,var(--accent) 86%,white 14%);box-shadow:0 0 8px color-mix(in srgb,var(--accent) 34%,transparent)}
.kanban-scroll-cue.up{top:2px;margin-bottom:4px}
.kanban-scroll-cue.down{bottom:2px;margin-top:4px}
.kanban-scroll-cue.is-hidden{opacity:0;pointer-events:none}
.kanban-board{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin-top:10px}
.kanban-column{border:.75px solid var(--border);border-radius:14px;padding:9px;background:rgba(255,255,255,.03)}
.kanban-column.kanban-drop-active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent)}
.kanban-column-header{margin:0 0 8px 0;display:flex;justify-content:space-between;align-items:center;gap:8px}
.kanban-column-header h3{margin:0;font-size:14px;display:flex;align-items:center;gap:6px}
.kanban-column-actions{position:relative}
.kanban-column-menu-btn{width:28px;height:28px;min-height:28px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:9px}
.kanban-column-menu{right:0;top:32px;min-width:190px}
.kanban-task-card{border:.75px solid var(--border);border-radius:10px;padding:8px;background:rgba(255,255,255,.04);display:flex;flex-direction:column;gap:6px;margin-bottom:8px}
.kanban-task-card[draggable=true]{cursor:grab}
.kanban-task-card[draggable=true]:active{cursor:grabbing}
.kanban-task-card.kanban-card-drop-active{border-color:var(--accent);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 70%,transparent)}
.kanban-task-title{font-size:13px}
.kanban-task-card .notice{margin:0;line-height:1.25}
.kanban-task-card .table-actions{gap:6px}
.kanban-task-card .table-actions button{min-height:30px;padding:5px 9px}
.kanban-task-card .control-input.compact{min-height:30px;padding:5px 8px}
.kanban-card-meta-row{display:flex;align-items:center;justify-content:flex-start;gap:8px}
.kanban-sequence-field{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--muted)}
.kanban-sequence-input{max-width:82px}
.kanban-list{margin-top:2px;border:.75px solid var(--border);border-radius:12px;overflow:hidden}
.kanban-list-head,.kanban-list-row{display:grid;grid-template-columns:28px minmax(72px,.6fr) minmax(180px,2fr) minmax(120px,1fr) minmax(120px,1fr) minmax(220px,2fr) auto;gap:8px;align-items:center;padding:7px 9px}
.kanban-list-head{background:rgba(255,255,255,.05);font-size:12px;font-weight:700}
.kanban-list-row{border-top:.75px solid var(--border);background:rgba(255,255,255,.02)}
.kanban-list-row[draggable=true]{cursor:grab}
.kanban-list-row.dragging{opacity:.58}
.kanban-list-row .control-input.compact{min-height:30px;padding:5px 8px}
.kanban-list-notes{font-size:12px;color:var(--muted);line-height:1.25}
.kanban-drag-handle{opacity:.7;text-align:center}
.calendar-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:10px 0}
.calendar-view-toggle{display:inline-flex;align-items:center;gap:4px;padding:2px;border:1px solid var(--border);border-radius:10px;background:rgba(255,255,255,.04)}
.calendar-view-toggle button{min-height:30px;padding:5px 10px;border-radius:8px}
.calendar-view-toggle button.active{background:var(--button-bg);color:#fff}
.calendar-month-nav{display:flex;align-items:center;gap:8px;margin:10px 0}
.calendar-month-shell{border:.75px solid var(--border);border-radius:12px;overflow:hidden;background:rgba(255,255,255,.02)}
.calendar-week-head{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));background:rgba(255,255,255,.05);font-size:12px;font-weight:700}
.calendar-week-head div{padding:8px;border-right:.75px solid var(--border)}
.calendar-week-head div:last-child{border-right:0}
.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr))}
.calendar-day{min-height:120px;border-right:.75px solid var(--border);border-top:.75px solid var(--border);padding:6px;display:flex;flex-direction:column;gap:6px}
.calendar-day:nth-child(7n){border-right:0}
.calendar-day.is-out-month{opacity:.55}
.calendar-day-header{font-size:12px;font-weight:700}
.calendar-day-events{display:grid;gap:4px}
.calendar-event-pill{font-size:11px;line-height:1.2;padding:5px 6px;border-radius:8px;text-align:left}
.calendar-event-pill.opp{background:color-mix(in srgb,var(--accent) 22%,transparent);border:1px solid color-mix(in srgb,var(--accent) 45%,var(--border))}
.calendar-event-pill.manual{background:color-mix(in srgb,var(--primary) 18%,transparent);border:1px solid color-mix(in srgb,var(--primary) 40%,var(--border))}
.calendar-event-pill.is-selected{outline:2px solid color-mix(in srgb,var(--accent) 78%,white 8%);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 62%,transparent)}
.calendar-list-row.is-selected{background:color-mix(in srgb,var(--accent) 14%,transparent)}
.workflow-tutorial-shell{display:grid;gap:14px}
.workflow-tutorial-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}
.workflow-tutorial-step{position:relative;border:1px solid var(--border);border-radius:18px;padding:16px;background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.025));box-shadow:var(--shadow);display:grid;grid-template-columns:42px minmax(0,1fr);gap:12px}
.workflow-step-number{width:34px;height:34px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:var(--accent);color:#041316;font-weight:900}
.workflow-tutorial-step h3{margin:0 0 6px;font-size:18px}
.workflow-tutorial-step p{margin:0 0 12px;color:var(--muted);line-height:1.45}
.home-edit-card{display:flex;flex-direction:column;gap:10px}
.home-edit-preview{border:1px dashed var(--border);border-radius:12px;padding:12px;background:rgba(255,255,255,.03)}
.govcon-filter-group summary{display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer;list-style:none}
.govcon-filter-group summary::-webkit-details-marker{display:none}
.govcon-filter-summary-main{display:flex;align-items:center;gap:8px;min-width:0}
.govcon-filter-summary-indicator{flex:0 0 auto;width:10px;height:10px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);opacity:.8;transition:transform .18s ease, opacity .18s ease}
.govcon-filter-group[open] .govcon-filter-summary-indicator{transform:rotate(225deg);opacity:1}
.govcon-filter-health{border-left-color:var(--accent);margin:0}
.govcon-filter-warning{border-left-color:#f6c244;background:rgba(246,194,68,.08)}
.govcon-missing-warning{margin:10px 12px 0 12px}
.govcon-missing-badge{background:#475569;color:#e2e8f0}
.govcon-missing-row td{color:#9ca3af}
.govcon-missing-row .tri-state-pill{opacity:.82}
.govcon-prefilter-rail{position:fixed;right:18px;bottom:18px;z-index:40;width:min(640px,calc(100vw - 24px));margin:0;border:1px solid var(--border);border-radius:14px;background:rgba(7,12,20,.96);backdrop-filter:blur(10px);box-shadow:0 12px 28px rgba(0,0,0,.3)}
.govcon-prefilter-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border:0;background:transparent;color:inherit;text-align:left;cursor:pointer;list-style:none}
.govcon-prefilter-toggle::-webkit-details-marker{display:none}
.govcon-prefilter-toggle-label{flex:0 0 auto;font-weight:700;color:var(--accent)}
.govcon-prefilter-summary{min-width:0;flex:1 1 auto}
.govcon-prefilter-hint{margin:8px 0 0 0}
.govcon-prefilter-body{padding:0 14px 14px 14px}
.widget[data-id="apps-filters"] .widget-body{padding-bottom:140px}
@media (max-width:900px){.govcon-prefilter-rail{left:12px;right:12px;bottom:12px;width:auto}}
.govcon-prefilter-rail[open] .govcon-filter-summary-indicator{transform:rotate(225deg);opacity:1}
.govcon-analytics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-top:12px}
.govcon-analytics-card{min-height:0}
.govcon-deadline-block{margin-top:10px}
.govcon-filter-bottom-actions{padding-bottom:4px}
.govcon-filter-group summary{cursor:pointer;list-style:none;padding:12px 14px;font-weight:700;display:flex;justify-content:space-between;align-items:center;background:rgba(255,255,255,.03)}
.govcon-filter-group summary::-webkit-details-marker{display:none}
.govcon-filter-group[open] summary{border-bottom:1px solid var(--border)}
.govcon-filter-group[draggable="true"] summary{cursor:grab}
.govcon-filter-group.dragging{opacity:.58}
.govcon-filter-search-wrap{padding:12px 14px 0}
.govcon-filter-search{max-width:420px}
.govcon-sort-btn{margin-left:8px;padding:4px 8px;font-size:11px;border-radius:999px;background:rgba(255,255,255,.06)}
.sam-selection-table{margin:0}
.tri-state-group{display:flex;flex-wrap:wrap;gap:6px}
.tri-state-pill{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);border-radius:999px;padding:4px 8px;background:rgba(255,255,255,.04);cursor:pointer}
.tri-state-pill input{width:auto;margin:0}
.tri-state-pill.active{background:rgba(79,179,217,.16);border-color:rgba(79,179,217,.34)}
.notice{font-size:12px;color:var(--muted);margin-top:6px}
.callout{border-left:3px solid var(--accent);padding-left:10px;margin:10px 0;color:var(--muted)}
.appearance-action-bar{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;padding:12px 14px;margin:12px 0;border:1px solid var(--border);border-radius:14px;background:rgba(255,255,255,.03)}
.appearance-action-bar.dirty{border-color:rgba(246,194,68,.5);background:rgba(246,194,68,.08)}
.appearance-action-copy{display:grid;gap:4px;min-width:240px}
.appearance-action-bar button[disabled]{opacity:.45;cursor:not-allowed;filter:none}
body.home-landing-mode .sidebar{display:none !important}
body.home-chrome-hidden .topbar,body.home-chrome-hidden .app-footer,body.home-chrome-hidden .sidebar{display:none !important}
body.home-landing-mode .main-shell,body.home-chrome-hidden .main-shell{margin-left:0 !important;height:100vh}
body.home-chrome-hidden .page-content{height:100vh;overflow:auto}
body.launcher-mode .sidebar,body.launcher-mode .topbar,body.launcher-mode .app-footer,body.launcher-mode .focus-rail-tab{display:none !important}
body.launcher-mode .main-shell{margin-left:0 !important;height:100vh}
body.launcher-mode .page-content{height:100vh;overflow:auto}
.home-landing-page{min-height:100vh;padding:0;overflow:auto;position:relative;background:#041522;}
.home-landing-page::before{content:"";position:fixed;inset:-8vh 0;background-image:linear-gradient(180deg,rgba(3,12,22,.18),rgba(3,12,22,.42)),var(--home-background-image,url("/assets/graphics/workspaces/quill-home-background.png"));background-size:cover;background-position:center top;background-repeat:no-repeat;transform:translate3d(0,var(--home-background-shift,0px),0);will-change:transform;pointer-events:none;z-index:0}
.home-landing-page::after{content:"";position:fixed;inset:0;background:radial-gradient(circle at top right, rgba(79,179,217,.18), transparent 36%),linear-gradient(180deg, rgba(255,255,255,.02), rgba(0,0,0,.18));pointer-events:none;z-index:0}
.home-dashboard-grid{min-height:100vh;height:auto;padding:32px 24px 48px;overflow:visible;position:relative;z-index:1}
.home-landing-shell{display:grid;gap:20px;max-width:1320px;margin:20px auto 0;position:relative;z-index:1}
.home-landing-shell .home-spotlight-stack{margin-top:var(--home-hero-gap, 110px)}
.home-launch-modal-overlay{position:fixed;inset:0;z-index:2100;display:flex;align-items:center;justify-content:center;padding:28px 20px 24px;background:linear-gradient(180deg,rgba(2,10,18,.56),rgba(1,6,12,.74));backdrop-filter:blur(2px)}
.home-launch-modal-overlay.is-hidden{display:none}
.home-launch-modal-frame{position:relative;width:min(1160px,calc(100vw - 34px));max-height:calc(100vh - 40px);overflow:auto;padding-top:4px}
.home-launch-dismiss-btn{position:absolute;right:12px;top:12px;z-index:3;width:62px;height:56px;display:flex;align-items:center;justify-content:center;border:none;border-radius:999px;background:rgba(1,10,20,.58);cursor:pointer;box-shadow:0 0 0 1px rgba(255,255,255,.14),0 0 22px rgba(63,228,225,.22)}
.home-launch-dismiss-btn span{width:44px;height:44px;display:block;position:relative;opacity:.88;filter:drop-shadow(0 0 12px rgba(63,228,225,.34));animation:homeScrollCuePulse 2s ease-in-out infinite}
.home-launch-dismiss-btn span::before,.home-launch-dismiss-btn span::after{content:"";position:absolute;left:50%;top:50%;width:28px;border-top:3px solid color-mix(in srgb,var(--accent) 84%,white 16%);border-radius:999px;transform-origin:center}
.home-launch-dismiss-btn span::before{transform:translate(-50%,-50%) rotate(45deg)}
.home-launch-dismiss-btn span::after{transform:translate(-50%,-50%) rotate(-45deg)}
.home-launch-dismiss-btn:hover{background:rgba(1,10,20,.76);box-shadow:0 0 0 1px rgba(255,255,255,.2),0 0 26px rgba(63,228,225,.34)}
.home-launch-gate{display:grid;grid-template-columns:1fr;min-height:auto}
.home-launch-gate-card{display:flex;align-items:stretch;min-height:min(760px,calc(100vh - 80px));background:linear-gradient(165deg,rgba(9,26,38,.86),rgba(6,18,32,.88));border:1px solid color-mix(in srgb,var(--accent) 22%,var(--border));border-radius:24px;box-shadow:0 30px 60px rgba(1,8,16,.36),inset 0 0 0 1px rgba(255,255,255,.04)}
.home-launch-gate-inner{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(260px,.85fr);gap:20px;width:100%;padding:28px}
.home-launch-gate-copy h2{margin:8px 0 10px;font-size:clamp(30px,5vw,54px);line-height:1.04}
.home-launch-meta{margin:12px 0;color:var(--muted);font-size:13px}
.home-launch-points{display:grid;gap:8px;margin:14px 0 18px;padding-left:18px;color:var(--muted)}
.home-launch-countdown-wrap{display:flex;align-items:center;justify-content:center}
.home-launch-countdown{width:100%;max-width:380px;padding:18px;border-radius:18px;border:1px solid color-mix(in srgb,var(--accent) 30%,var(--border));background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));box-shadow:inset 0 0 0 1px rgba(255,255,255,.04)}
.home-launch-countdown-title{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);font-weight:800}
.home-launch-countdown-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:12px}
.home-launch-countdown-cell{display:grid;gap:4px;justify-items:center;padding:10px;border-radius:12px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08)}
.home-launch-countdown-cell span{font-size:clamp(22px,4vw,34px);line-height:1;font-weight:900;color:var(--text)}
.home-launch-countdown-cell small{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.home-launch-countdown-hint{margin-top:12px;font-size:12px;color:var(--muted)}
.home-hero-card{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(360px,.92fr);gap:24px;align-items:stretch;background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.01));border:1px solid var(--border);border-radius:22px;padding:28px;box-shadow:var(--shadow)}
.home-mini-nav{display:flex;gap:14px;flex-wrap:wrap;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.08em}
.home-registration-card .home-mini-nav{position:relative;z-index:8}
.home-mini-nav button{appearance:none;border:none;background:none;color:inherit;font:inherit;letter-spacing:inherit;text-transform:inherit;cursor:pointer;padding:0}
.home-mini-nav button:hover{text-decoration:underline;color:var(--text)}
.home-bottom-nav{margin-top:14px;padding-top:12px;border-top:1px solid var(--border)}
.home-hero-copy h2{margin:6px 0 10px;font-size:32px;line-height:1.08}
.home-hero-lead{font-size:17px;color:var(--text)}
.home-hero-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.home-version-label{margin-top:14px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);opacity:.72}
.home-hero-art-stack{display:flex;align-items:center;justify-content:center;min-height:100%;min-width:0;padding:18px 18px 18px 18px;border-radius:20px;background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));min-height:420px}
.home-hero-card,.home-hero-copy,.home-hero-main-art{transition:transform 160ms linear;will-change:transform}
.home-hero-main-art{width:100%;height:100%;max-width:500px;max-height:500px;border-radius:18px;border:none;box-shadow:none;object-fit:contain;object-position:center center;background:transparent}
.home-scroll-cue{position:fixed;left:50%;bottom:26px;z-index:12;display:flex;justify-content:center;align-items:center;width:64px;height:54px;margin:0;pointer-events:none;transform:translateX(-50%);opacity:1;transition:opacity .34s ease, transform .34s ease}
.home-scroll-cue.is-hidden{opacity:0;transform:translateX(-50%) translateY(12px);visibility:hidden}
.home-scroll-cue span{width:48px;height:48px;display:block;position:relative;opacity:.72;filter:drop-shadow(0 0 12px rgba(63,228,225,.34));animation:homeScrollCuePulse 2s ease-in-out infinite}
.home-scroll-cue span::before{content:"";position:absolute;left:50%;top:9px;width:28px;height:28px;border-right:3px solid color-mix(in srgb,var(--accent) 84%,white 16%);border-bottom:3px solid color-mix(in srgb,var(--accent) 84%,white 16%);border-radius:0 0 7px 0;transform:translateX(-50%) rotate(45deg)}
@keyframes homeScrollCuePulse{0%,100%{transform:translateY(0) scale(.96);opacity:.46}50%{transform:translateY(8px) scale(1.04);opacity:.92}}
@media (max-width:900px){
  .home-launch-modal-overlay{padding:16px 10px 12px}
  .home-launch-modal-frame{width:min(1160px,calc(100vw - 14px));max-height:calc(100vh - 20px)}
  .home-launch-dismiss-btn{right:8px;top:8px}
}
.home-feature-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.home-parallax-card{display:grid;gap:14px;min-height:260px;transform:translate3d(0,var(--panel-shift, 0px),0);opacity:var(--panel-fade, 1);transition:transform 160ms linear, opacity 160ms linear;position:relative;overflow:hidden;will-change:transform}
.home-parallax-copy{position:relative;z-index:1;transition:transform 160ms linear;will-change:transform}
.home-parallax-art{display:flex;align-items:flex-end;justify-content:center;min-height:140px}
.home-parallax-art img{width:100%;max-height:180px;object-fit:contain;border-radius:16px;border:none;background:transparent;transition:transform 160ms linear;will-change:transform}
.home-spotlight-stack{display:grid;gap:var(--home-spotlight-gap, 96px)}
.home-spotlight-panel{display:grid;grid-template-columns:minmax(0,.9fr) minmax(320px,1.1fr);gap:20px;align-items:center;min-height:70vh;position:relative;overflow:hidden;transform:translate3d(0,var(--panel-shift, 0px),0);opacity:var(--panel-fade, 1);transition:transform 160ms linear, opacity 160ms linear;will-change:transform}
.home-spotlight-panel::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at top right, rgba(79,179,217,.14), transparent 38%);pointer-events:none}
.home-spotlight-copy,.home-spotlight-art{position:relative;z-index:1}
.home-spotlight-art{display:flex;align-items:center;justify-content:center;padding:12px}
.home-spotlight-art img{width:100%;max-width:760px;max-height:60vh;object-fit:contain;border-radius:20px;border:none;background:transparent;box-shadow:none}
.home-registration-shell{max-width:1040px;margin:0 auto;padding:18px 0}
.home-registration-page{min-height:100vh;display:flex;align-items:flex-start;justify-content:center;padding:32px 18px 48px;background-image:radial-gradient(circle at top right, rgba(79,179,217,.18), transparent 34%),linear-gradient(180deg, rgba(4,16,34,.74), rgba(4,16,34,.86)),var(--home-background-image, url("/assets/graphics/workspaces/quill-home-background.png"));background-size:auto,auto,cover;background-position:center top;background-attachment:scroll;}
.home-registration-card{min-height:0;border-radius:22px;padding:26px}
.interview-header-block{display:grid;grid-template-columns:1fr;gap:12px;align-items:start;margin:0 0 12px}
.interview-header-block h2{margin:0 0 6px}
.interview-progress-card{display:grid;gap:6px;padding:10px;border:1px solid var(--border);border-radius:16px;background:rgba(255,255,255,.04)}
.interview-progress-card strong{font-size:28px;color:var(--accent)}
.interview-progress-track{position:relative;height:10px;border-radius:999px;background:rgba(255,255,255,.12);overflow:hidden}
.interview-progress-track span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--secondary),var(--accent))}
.interview-progress-track span.minimums-pending{background:linear-gradient(90deg,#f472b6,#ec4899)}
.interview-progress-track span.minimums-met{background:linear-gradient(90deg,#3b82f6,#06b6d4)}
.interview-progress-minimum{position:absolute;left:60%;top:0;height:100%;border-left:2px dashed rgba(255,255,255,.72);opacity:.88}
.interview-progress-dock{position:static;z-index:auto;width:100%;margin-top:14px}
.interview-geo-preview{display:grid;gap:8px}
.geo-art{height:150px;border-radius:14px;border:1px solid var(--border);position:relative;overflow:hidden;background:rgba(255,255,255,.03)}
.geo-art svg{display:block;width:100%;height:100%}
.geo-art::before,.geo-art::after{display:none}
.interview-chunk-list{display:grid;gap:12px;margin-top:12px}
.interview-wizard-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}
.interview-step-btn{border:1px solid var(--border);background:rgba(255,255,255,.04);color:var(--text)}
.interview-step-btn.active{background:rgba(59,130,246,.2);border-color:rgba(59,130,246,.6)}
.interview-step-btn.locked{opacity:.52;filter:saturate(.72);cursor:not-allowed}
.interview-wizard-step.hidden{display:none}
.interview-chunk{border:1px solid var(--border);border-radius:18px;background:rgba(255,255,255,.035);overflow:hidden}
.interview-chunk summary{cursor:pointer;padding:13px 15px;font-weight:800;color:var(--text);display:flex;justify-content:space-between;gap:12px;align-items:center}
.interview-chunk summary span{font-size:12px;font-weight:500;color:var(--muted)}
.interview-chunk .home-account-grid{padding:0 15px 15px}
.login-logo-frame{display:flex;align-items:center;justify-content:center;min-height:132px;border-radius:20px;background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.02));border:1px solid var(--border);margin-bottom:18px}
.login-logo-frame img{max-width:260px;max-height:96px;object-fit:contain}
.launcher-page{min-height:100vh;padding:34px;background:#041522;background-image:linear-gradient(90deg,rgba(2,6,23,.82),rgba(2,12,24,.50),rgba(2,6,23,.70)),var(--home-background-image,url("/assets/graphics/workspaces/quill-home-background.png"));background-size:cover;background-position:center top;color:var(--text)}
.launcher-shell{display:grid;grid-template-columns:minmax(280px,360px) minmax(0,1fr);gap:26px;max-width:1320px;margin:0 auto;min-height:calc(100vh - 68px);align-items:stretch}
.launcher-app-list,.launcher-main{border:1px solid var(--border);border-radius:26px;background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.03));box-shadow:var(--shadow);backdrop-filter:blur(12px)}
.launcher-app-list{padding:22px;align-self:stretch;display:flex;flex-direction:column;min-height:0}
.launcher-main{display:flex;flex-direction:column;justify-content:flex-start;padding:30px 36px 36px 36px;position:relative;overflow:hidden}
.launcher-main::after{content:"";position:absolute;inset:auto -8% -20% 30%;height:46%;background:radial-gradient(circle,rgba(63,228,225,.16),transparent 65%);pointer-events:none}
.launcher-eyebrow{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-weight:800}
.launcher-app-list h2,.launcher-main h1{margin:8px 0 10px}
.launcher-edit-row{display:flex;justify-content:flex-end;margin-top:10px}
.launcher-edit-btn{border:1px solid var(--border);background:rgba(255,255,255,.06);color:var(--text);border-radius:11px;padding:7px 10px;font-size:12px;cursor:pointer}
.launcher-edit-btn:hover{background:rgba(255,255,255,.12)}
.launcher-edit-btn.active{border-color:color-mix(in srgb,var(--accent) 55%,var(--border));background:color-mix(in srgb,var(--accent) 18%,transparent)}
.launcher-card-stack{display:grid;gap:10px;margin-top:18px;overflow:auto;min-height:0;flex:1;padding-right:4px}
.launcher-card-stack.drag-enabled .launcher-app-card{cursor:grab}
.launcher-card-stack.drag-enabled .launcher-app-card:active{cursor:grabbing}
.launcher-app-card{position:relative;display:grid;gap:5px;width:100%;text-align:left;border:1px solid color-mix(in srgb,var(--border) 78%,transparent);border-radius:18px;padding:14px 15px;background:rgba(255,255,255,.055);color:var(--text);cursor:pointer;transition:transform .16s ease,border-color .16s ease,background .16s ease}
.launcher-app-card:hover{transform:translateX(5px);border-color:color-mix(in srgb,var(--accent) 46%,var(--border));background:rgba(63,228,225,.10)}
.launcher-app-card.selected{border-color:color-mix(in srgb,var(--accent) 62%,var(--border));background:rgba(63,228,225,.11);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 14%,transparent)}
.launcher-app-card.drag-over{border-color:color-mix(in srgb,var(--accent) 68%,white 10%);background:color-mix(in srgb,var(--accent) 14%,transparent)}
.launcher-app-card.dragging{opacity:.6}
.launcher-app-card.hidden-card{opacity:.58;border-style:dashed}
.launcher-card-controls{display:flex;justify-content:flex-end}
.launcher-card-visibility-btn{border:1px solid var(--border);background:rgba(255,255,255,.08);color:var(--text);border-radius:10px;padding:4px 8px;font-size:11px;cursor:pointer}
.launcher-card-visibility-btn:hover{background:rgba(255,255,255,.16)}
.launcher-app-name{font-size:17px;font-weight:800}
.launcher-app-meta{font-size:12px;color:var(--muted)}
.launcher-app-copy{font-size:13px;line-height:1.35;color:color-mix(in srgb,var(--text) 84%,var(--muted))}
.launcher-logo-frame{width:132px;height:132px;display:flex;align-items:center;justify-content:center;border-radius:28px;background:rgba(255,255,255,.08);border:1px solid var(--border);margin-bottom:18px}
.launcher-logo-frame img{max-width:104px;max-height:104px;object-fit:contain}
.launcher-selected-app{position:relative;z-index:1;display:flex;flex-direction:column;min-height:360px;margin-top:16px;padding:18px;border:1px solid color-mix(in srgb,var(--accent) 22%,var(--border));border-radius:22px;background:linear-gradient(180deg,rgba(63,228,225,.10),rgba(255,255,255,.045))}
.launcher-selected-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:10px}
.launcher-selected-app h2{margin:4px 0 2px;font-size:clamp(24px,4vw,38px)}
.launcher-selected-app h3{margin:0 0 10px;color:color-mix(in srgb,var(--text) 86%,var(--accent));font-size:18px}
.launcher-selected-app p{margin:0 0 12px;color:color-mix(in srgb,var(--text) 86%,var(--muted));line-height:1.5}
.launcher-selected-app ul{display:grid;gap:6px;margin:0 0 14px;padding-left:20px;color:var(--muted)}
.launcher-open-btn{position:relative;flex:0 0 auto;min-width:240px;min-height:58px;padding:16px 26px;border-radius:20px;font-size:18px;font-weight:900;overflow:hidden;box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 28%,transparent),0 18px 38px rgba(0,0,0,.22)}
.launcher-open-btn::after{content:"";position:absolute;inset:-45%;background:conic-gradient(from 0deg,transparent 0 68%,rgba(255,255,255,.34) 76%,transparent 86%);animation:launcherCtaSweep 3.4s linear infinite;pointer-events:none}
.launcher-open-btn:hover{transform:translateY(-1px)}
.launcher-progress-wrap{margin-top:26px;position:relative;z-index:1}
.launcher-progress-track{position:relative;height:12px;border-radius:999px;background:rgba(255,255,255,.10);overflow:hidden;border:1px solid rgba(255,255,255,.12);box-shadow:inset 0 0 18px rgba(0,0,0,.18)}
.launcher-progress-track::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent 0 18%,rgba(255,255,255,.26) 34%,transparent 52%);transform:translateX(-120%);opacity:.75;pointer-events:none}
.launcher-progress-track.loading::after{animation:launcherProgressSheen 1.45s ease-in-out infinite}
.launcher-progress-track.minimum-ready{border-color:rgba(255,255,255,.55)}
.launcher-progress-track.minimum-ready::before{content:"";position:absolute;inset:2px;border-radius:999px;border:1px dashed rgba(255,255,255,.72);pointer-events:none;animation:launcherDashFlow 1.6s linear infinite}
.launcher-progress-track.background-loading::before{animation-duration:1.0s}
.launcher-progress-track span{display:block;width:10%;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--secondary),var(--accent),color-mix(in srgb,var(--accent) 72%,white 20%));box-shadow:0 0 18px color-mix(in srgb,var(--accent) 48%,transparent);transition:width .34s ease}
.launcher-progress-track.loading span{animation:launcherProgressGlow 1.65s ease-in-out infinite}
.launcher-progress-track.minimum-ready span{animation:launcherProgressGlow 2.8s ease-in-out infinite}
.launcher-progress-track.background-loading span{animation-duration:1.8s}
.launcher-narrative{margin-top:10px;color:color-mix(in srgb,var(--text) 82%,var(--muted));font-size:13px;line-height:1.35;min-height:18px}
.launcher-status-list{display:grid;gap:8px;margin-top:16px;position:relative;z-index:1}
.launcher-status-row{display:flex;gap:9px;align-items:center;font-size:13px;color:var(--muted)}
.launcher-status-dot{width:10px;height:10px;border-radius:999px;background:var(--muted);box-shadow:0 0 0 4px rgba(255,255,255,.04)}
.launcher-status-dot.loading{background:var(--accent);animation:launcherPulse 1.3s ease-in-out infinite}
.launcher-status-dot.ready{background:#22c55e}
.launcher-status-dot.warn{background:#f59e0b}
@keyframes launcherPulse{0%,100%{opacity:.45;transform:scale(.9)}50%{opacity:1;transform:scale(1.08)}}
@keyframes launcherProgressSheen{0%{transform:translateX(-125%)}55%{transform:translateX(35%)}100%{transform:translateX(130%)}}
@keyframes launcherProgressGlow{0%,100%{filter:saturate(1);box-shadow:0 0 12px color-mix(in srgb,var(--accent) 32%,transparent)}50%{filter:saturate(1.35);box-shadow:0 0 24px color-mix(in srgb,var(--accent) 62%,transparent)}}
@keyframes launcherDashFlow{from{background-position:0 0}to{background-position:26px 0}}
@keyframes launcherCtaSweep{to{transform:rotate(360deg)}}
@media (max-width:900px){.launcher-page{padding:18px}.launcher-shell{grid-template-columns:1fr}.launcher-main{padding:24px}}
.login-grid{display:grid;grid-template-columns:minmax(0,.9fr) minmax(320px,1.1fr);gap:18px;align-items:stretch}
.login-panel{display:grid;gap:10px}
.login-provider-row{display:flex;gap:10px;flex-wrap:wrap}
.home-account-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.home-account-grid label{display:grid;gap:6px;font-size:13px;color:var(--muted)}
.home-account-wide{grid-column:1 / -1}
.home-story-section{display:grid;grid-template-columns:1fr;gap:12px;margin-top:24px}
.home-about-section{display:grid;grid-template-columns:1.2fr .8fr;gap:16px;margin-top:24px;margin-bottom:var(--home-about-bottom-space,14vh)}
.home-about-box,.home-contact-box{transition:transform 160ms linear;will-change:transform}
.home-about-section .card,.home-account-section .card{min-height:0}
.home-faq-list{display:grid;gap:10px;margin-top:10px}
.home-faq-root{margin-top:8px;border:1px solid var(--border);border-radius:12px;background:rgba(255,255,255,.03);padding:10px 12px}
.home-faq-root > summary{cursor:pointer;font-weight:700}
.home-faq-item{border:1px solid var(--border);border-radius:12px;background:rgba(255,255,255,.03);padding:10px 12px}
.home-faq-item summary{cursor:pointer;font-weight:600}
.home-faq-item p{margin:10px 0 0;color:var(--muted)}
.faq-modal-card{width:min(920px,96vw)}
.faq-modal-body{max-height:min(72vh,780px);overflow:auto}
.full-page-module{padding:18px;overflow:auto;height:100%}
.section-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:14px;min-height:180px}
.oppfinder-workflow-shell{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(220px,.9fr);gap:18px;align-items:start;min-height:100%}
.oppfinder-workflow-header{grid-column:1 / -1}
.oppfinder-workflow-header h3{margin:8px 0 6px;font-size:24px}
.oppfinder-workflow-copy{grid-column:1}
.oppfinder-step-list{display:grid;gap:8px;margin-top:14px}
.oppfinder-step-list button{text-align:left;display:grid;gap:2px;border-radius:14px;background:color-mix(in srgb,var(--surface-2) 74%,transparent)}
.oppfinder-step-list span{font-size:12px;color:var(--muted)}
.oppfinder-radar{grid-column:2;position:relative;justify-self:center;align-self:start;width:min(260px,100%);aspect-ratio:1;border-radius:50%;overflow:visible;border:1px solid color-mix(in srgb,var(--accent) 38%,var(--border));background:radial-gradient(circle,color-mix(in srgb,var(--accent) 16%,transparent),transparent 62%),repeating-radial-gradient(circle,color-mix(in srgb,var(--accent) 28%,transparent) 0 1px,transparent 1px 48px),linear-gradient(135deg,color-mix(in srgb,var(--primary) 26%,transparent),transparent);box-shadow:0 0 36px color-mix(in srgb,var(--accent) 16%,transparent),inset 0 0 42px rgba(0,0,0,.14)}
.oppfinder-radar::before,.oppfinder-radar::after{content:"";position:absolute;inset:50% 0 auto 0;border-top:1px solid color-mix(in srgb,var(--accent) 28%,transparent)}
.oppfinder-radar::after{transform:rotate(90deg)}
.radar-sweep{position:absolute;inset:0;border-radius:50%;background:conic-gradient(from var(--radar-sweep-from,104deg),color-mix(in srgb,var(--accent) 10%,transparent) 0deg,color-mix(in srgb,var(--accent) 54%,transparent) 76deg,transparent 77deg 360deg);transform-origin:center}
.radar-ring{position:absolute;border:1px solid color-mix(in srgb,var(--accent) 28%,transparent);border-radius:50%;inset:18%}
.radar-ring.r2{inset:34%}.radar-ring.r3{inset:48%}
.radar-blip{position:absolute;width:var(--radar-dot-size,8px);height:var(--radar-dot-size,8px);border-radius:999px;opacity:0;pointer-events:none;transform:translate(-50%,-50%)}
.radar-blip-live{opacity:0;pointer-events:auto;z-index:4;background:color-mix(in srgb,var(--accent) 84%,#fff);box-shadow:0 0 8px color-mix(in srgb,var(--accent) 40%,transparent)}
.radar-blip-live::before{content:"";position:absolute;left:50%;bottom:6px;width:1px;height:18px;transform:translateX(-50%);background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 80%,#fff),transparent);opacity:0;pointer-events:none;transition:opacity 140ms ease}
.radar-blip-live::after{content:attr(data-callout);position:absolute;left:8px;bottom:24px;min-width:120px;max-width:210px;padding:5px 7px;border-radius:8px;border:1px solid color-mix(in srgb,var(--accent) 54%,var(--border));background:rgba(4,16,24,.94);color:#e9fbff;font-size:11px;line-height:1.2;white-space:normal;opacity:0;transform:translateY(2px);pointer-events:none;transition:opacity 140ms ease,transform 140ms ease;box-shadow:0 8px 16px rgba(0,0,0,.28)}
.radar-blip-live:hover::before,.radar-blip-live:hover::after{opacity:1}
.radar-blip-live:hover::after{transform:translateY(0)}
.radar-return{--radar-opacity:0;--radar-scale:.56;--radar-glow:0px;--radar-filter:.65;position:absolute;width:8px;height:8px;border-radius:999px;background:var(--accent);box-shadow:0 0 4px color-mix(in srgb,var(--accent) 28%,transparent),0 0 var(--radar-glow) var(--accent);opacity:var(--radar-opacity);pointer-events:auto;z-index:5;transform:translate(-50%,-50%) scale(var(--radar-scale));filter:brightness(var(--radar-filter))}
.radar-return.callout-active{box-shadow:0 0 6px color-mix(in srgb,var(--accent) 42%,transparent),0 0 14px color-mix(in srgb,var(--accent) 52%,transparent)}
.radar-callout{position:absolute;max-width:220px;min-width:120px;padding:5px 7px;border-radius:8px;border:1px solid color-mix(in srgb,var(--accent) 54%,var(--border));background:rgba(4,16,24,.94);color:#e9fbff;font-size:11px;line-height:1.2;white-space:normal;opacity:0;pointer-events:none;transform:translateY(2px);transition:opacity 140ms ease,transform 140ms ease;box-shadow:0 8px 16px rgba(0,0,0,.28);z-index:9}
.radar-callout.visible{opacity:1;transform:translateY(0)}
.radar-callout::before{content:"";position:absolute;width:1px;height:18px;background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 80%,#fff),transparent)}
.radar-callout[data-side="right"]{transform-origin:left center}
.radar-callout[data-side="left"]{transform-origin:right center}
.radar-callout[data-side="right"][data-vertical="above"]{transform:translate(0,-100%)}
.radar-callout[data-side="left"][data-vertical="above"]{transform:translate(-100%,-100%)}
.radar-callout[data-side="right"][data-vertical="below"]{transform:translate(0,0)}
.radar-callout[data-side="left"][data-vertical="below"]{transform:translate(-100%,0)}
.radar-callout.visible[data-side="right"][data-vertical="above"]{transform:translate(0,calc(-100% - 2px))}
.radar-callout.visible[data-side="left"][data-vertical="above"]{transform:translate(-100%,calc(-100% - 2px))}
.radar-callout.visible[data-side="right"][data-vertical="below"]{transform:translate(0,2px)}
.radar-callout.visible[data-side="left"][data-vertical="below"]{transform:translate(-100%,2px)}
.radar-callout[data-side="right"][data-vertical="above"]::before{left:0;bottom:-18px}
.radar-callout[data-side="left"][data-vertical="above"]::before{right:0;bottom:-18px}
.radar-callout[data-side="right"][data-vertical="below"]::before{left:0;top:-18px;transform:scaleY(-1)}
.radar-callout[data-side="left"][data-vertical="below"]::before{right:0;top:-18px;transform:scaleY(-1)}
.radar-blip.b1{left:68%;top:28%;animation:radarBlipPath1 48s linear infinite}
.radar-blip.b2{left:42%;top:62%;animation:radarBlipPath2 56s linear infinite 1.25s}
.radar-blip.b3{left:74%;top:70%;animation:radarBlipPath3 64s linear infinite 2.35s}
.quill-logo-preview-shell .oppfinder-workflow-copy h3{margin-bottom:10px}
.quill-logo-radar{isolation:isolate}
.quill-v2-compare{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;align-items:center}
.quill-variant-label{
  position:absolute;
  left:8px;
  top:8px;
  z-index:20;
  font-size:12px;
  font-weight:700;
  line-height:1;
  padding:4px 6px;
  border-radius:999px;
  background:rgba(2,14,24,.92);
  border:1px solid color-mix(in srgb,var(--accent) 48%,transparent);
  color:#f4ffff;
  text-shadow:0 1px 2px rgba(0,0,0,.65);
  pointer-events:none;
}
.quill-radar-logo{
  position:absolute;
  inset:14%;
  width:72%;
  height:72%;
  object-fit:contain;
  z-index:2;
  pointer-events:none;
  opacity:.9;
  filter:drop-shadow(0 0 10px color-mix(in srgb,var(--accent) 34%,transparent)) drop-shadow(0 0 18px color-mix(in srgb,var(--accent) 22%,transparent));
  mix-blend-mode:screen;
  animation:quillLogoRadarPulse 4s ease-in-out infinite;
}
.quill-logo-radar-v2 .quill-radar-logo-v2{
  inset:12%;
  width:76%;
  height:76%;
  filter:drop-shadow(0 0 12px color-mix(in srgb,var(--accent) 42%,transparent)) drop-shadow(0 0 24px color-mix(in srgb,var(--accent) 26%,transparent));
}
.quill-logo-radar-v2-masked::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:50%;
  background:radial-gradient(circle at 50% 50%,transparent 0 16%,rgba(2,10,18,.88) 16.5% 100%);
  z-index:1;
  pointer-events:none;
}
.quill-logo-radar-v2-masked .radar-sweep,
.quill-logo-radar-v2-masked .radar-ring,
.quill-logo-radar-v2-masked .radar-blip,
.quill-logo-radar-v2-masked .radar-return,
.quill-logo-radar-v2-masked .quill-radar-logo{z-index:2}
.quill-logo-radar-v2-clipimg .quill-radar-logo-v2{
  -webkit-clip-path:circle(37% at 50% 50%);
  clip-path:circle(37% at 50% 50%);
  border-radius:50%;
  transform:translateY(2px);
}
.quill-logo-radar-v2-clipimg-24 .quill-radar-logo-v2{
  -webkit-clip-path:circle(49% at 50% 50%);
  clip-path:circle(49% at 50% 50%);
  transform:translateY(20px);
}
.quill-logo-radar-v2-clipimg-25 .quill-radar-logo-v2{
  -webkit-clip-path:circle(52% at 50% 50%);
  clip-path:circle(52% at 50% 50%);
  transform:translateY(20px) scale(.9);
  box-shadow:0 0 0 26px #061a28;
}
.quill-logo-radar-v2-clipimg-26 .quill-radar-logo-v2{
  -webkit-clip-path:circle(52% at 50% 50%);
  clip-path:circle(52% at 50% 50%);
  transform:translateY(20px) scale(.9);
  box-shadow:0 0 0 26px #040608;
}
.quill-v3-compare{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;align-items:center}
.quill-v3-item{display:grid;gap:8px;justify-items:stretch}
.quill-logo-radar-v3 .quill-code-logo{
  position:absolute;
  left:50%;
  top:50%;
  width:74%;
  height:74%;
  border-radius:50%;
  border:clamp(4px, .55vw, 7px) solid rgba(255,255,255,.96);
  transform:translate(-50%,-50%);
  z-index:2;
  box-shadow:0 0 12px rgba(255,255,255,.12);
}
.quill-logo-radar-v3 .quill-code-tail{
  position:absolute;
  right:-10%;
  bottom:7%;
  width:36%;
  height:22%;
  border-radius:100% 0 100% 0;
  border:clamp(3px, .45vw, 6px) solid rgba(255,255,255,.96);
  border-left:0;
  border-top:0;
  transform:rotate(-34deg);
  box-shadow:0 0 10px color-mix(in srgb,var(--accent) 24%,transparent);
}
.quill-logo-radar-v3 .quill-code-feather{
  position:absolute;
  right:-8%;
  bottom:2%;
  width:28%;
  height:18%;
  background:rgba(255,255,255,.96);
  border-radius:100% 0 100% 0;
  transform:rotate(-32deg) skewX(-8deg);
  box-shadow:0 0 10px color-mix(in srgb,var(--accent) 24%,transparent);
}
.quill-logo-radar-v3 .quill-code-feather::before{
  content:"";
  position:absolute;
  right:20%;
  top:12%;
  width:56%;
  height:2px;
  background:rgba(8,18,30,.32);
  transform:rotate(-18deg);
  border-radius:999px;
}
.quill-logo-radar-v3b .quill-code-tail{
  right:-6%;
  bottom:6%;
  width:34%;
  height:20%;
  transform:rotate(-30deg);
}
.quill-logo-radar-v3b .quill-code-feather{
  right:-2%;
  bottom:17%;
  width:36%;
  height:15%;
  border-radius:100% 0 100% 0;
  transform:rotate(-8deg) skewX(-10deg);
}
.quill-logo-radar-v3b .quill-code-feather::before{
  right:14%;
  top:46%;
  width:68%;
  transform:rotate(-2deg);
}
.quill-logo-radar-v3c .quill-code-tail{
  right:-4%;
  bottom:9%;
  width:38%;
  height:18%;
  transform:rotate(-22deg);
}
.quill-logo-radar-v3c .quill-code-feather{
  right:0%;
  bottom:22%;
  width:34%;
  height:14%;
  transform:rotate(6deg) skewX(-8deg);
}
.quill-logo-radar-v3c .quill-code-feather::before{
  right:12%;
  top:52%;
  width:70%;
  transform:rotate(6deg);
}
.quill-logo-radar-v3d .quill-code-tail{
  right:-8%;
  bottom:5%;
  width:34%;
  height:20%;
  transform:rotate(-36deg);
}
.quill-logo-radar-v3d .quill-code-feather{
  right:-3%;
  bottom:12%;
  width:38%;
  height:16%;
  transform:rotate(-14deg) skewX(-12deg);
}
.quill-logo-radar-v3d .quill-code-feather::before{
  right:18%;
  top:44%;
  width:64%;
  transform:rotate(-10deg);
}
.quill-logo-radar-v3e .quill-code-tail{
  right:-2%;
  bottom:8%;
  width:42%;
  height:16%;
  transform:rotate(-10deg);
}
.quill-logo-radar-v3e .quill-code-feather{
  right:4%;
  bottom:24%;
  width:33%;
  height:13%;
  transform:rotate(14deg) skewX(-6deg);
}
.quill-logo-radar-v3e .quill-code-feather::before{
  right:10%;
  top:54%;
  width:72%;
  transform:rotate(12deg);
}
@media (max-width:900px){
  .quill-v2-compare{grid-template-columns:1fr}
  .quill-v3-compare{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@keyframes quillLogoRadarPulse{
  0%,100%{transform:scale(.992);opacity:.84}
  50%{transform:scale(1.02);opacity:.98}
}
@keyframes radarBlipPath1{
  0%,100%{left:68%;top:28%}
  34%{left:74%;top:40%}
  58%{left:58%;top:50%}
  82%{left:51%;top:33%}
}
@keyframes radarBlipPath2{
  0%,100%{left:42%;top:62%}
  34%{left:30%;top:54%}
  65%{left:39%;top:37%}
  88%{left:55%;top:48%}
}
@keyframes radarBlipPath3{
  0%,100%{left:74%;top:70%}
  26%{left:72%;top:71%}
  48%{left:48%;top:68%}
  54%{left:51%;top:66%}
  80%{left:63%;top:56%}
}
.home-hero-widget{position:relative !important;left:auto !important;top:auto !important;width:100% !important;height:auto !important;min-height:auto;border:none;background:transparent;box-shadow:none;overflow:visible}
.home-hero-widget .widget-header{display:none}
.home-hero-widget .widget-body{padding:0;overflow:visible;position:relative;border-radius:24px;background-color:#041522;background-image:linear-gradient(180deg,rgba(3,12,22,.12),rgba(3,12,22,.38)),var(--home-background-image,url("/assets/graphics/workspaces/quill-home-background.png"));background-size:cover;background-position:center calc(0px + var(--home-background-shift,0px));background-repeat:no-repeat}
.sr-only{position:absolute !important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.card h3{margin-top:0}
.app-footer{display:flex;align-items:center;justify-content:center;gap:14px;padding:10px 16px;border-top:1px solid var(--border);position:relative;overflow:hidden}
.app-footer img{max-height:var(--footer-logo-height);max-width:100%;object-fit:contain;opacity:.88}
.footer-text{color:var(--muted)}
.footer-text span{color:inherit}
.footer-legal-links{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.footer-legal-link{border:1px solid var(--border);background:rgba(255,255,255,.08);color:var(--footer-text-color);padding:6px 9px;font-size:12px}
.footer-legal-link:hover{background:rgba(255,255,255,.16)}
.legal-trust-strip{margin-top:12px;padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:rgba(255,255,255,.03);font-size:13px;color:var(--muted)}
.legal-trust-strip button{margin-left:6px;padding:4px 8px;font-size:12px}
.legal-page{padding:24px}
.legal-shell{max-width:960px;margin:0 auto;display:grid;gap:12px}
.legal-hero h2{margin:4px 0 8px 0}
.legal-section p{margin:8px 0;line-height:1.5}
.restore-chrome-btn{position:fixed;left:8px;top:50%;transform:translateY(-50%);z-index:4000;display:inline-flex;align-items:center;justify-content:center;writing-mode:vertical-rl;text-orientation:mixed;letter-spacing:.08em;gap:8px;padding:16px 10px;border-radius:0 14px 14px 0;border:1px solid rgba(79,179,217,.35);background:rgba(17,24,39,.92);color:#fff;box-shadow:var(--shadow);backdrop-filter:blur(10px)}
.focus-rail-tab{position:fixed;left:0;top:50%;transform:translateY(-50%);z-index:4105;display:none;align-items:center;justify-content:center;writing-mode:vertical-rl;text-orientation:mixed;padding:18px 14px 18px 12px;min-width:40px;border-radius:0 16px 16px 0;border:1px solid rgba(79,179,217,.42);background:rgba(17,24,39,.92);color:#fff;box-shadow:var(--shadow);backdrop-filter:blur(10px)}
.focus-exit-tab{position:fixed;right:8px;top:10px;z-index:4106;display:none;align-items:center;justify-content:center;padding:10px 12px;border-radius:10px;border:1px solid rgba(79,179,217,.42);background:rgba(17,24,39,.94);color:#fff;box-shadow:var(--shadow);backdrop-filter:blur(10px);font-size:12px;font-weight:700}
.admin-nav-panel{
  position:fixed;
  right:12px;
  bottom:12px;
  z-index:4106;
  width:min(260px,calc(100vw - 24px));
  border:1px solid rgba(79,179,217,.42);
  border-radius:12px;
  background:rgba(17,24,39,.95);
  color:#fff;
  box-shadow:var(--shadow);
  backdrop-filter:blur(10px);
}
.admin-nav-panel-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  cursor:move;
  user-select:none;
  font-size:12px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
  padding:9px 10px 7px;
  border-bottom:1px solid rgba(79,179,217,.24);
}
.admin-nav-close-btn{
  cursor:pointer;
  user-select:none;
  min-width:24px;
  height:24px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.24);
  background:rgba(255,255,255,.08);
  color:#fff;
  font-size:12px;
  font-weight:800;
  line-height:1;
}
.admin-nav-close-btn:hover{background:rgba(255,255,255,.18)}
.admin-nav-panel-body{padding:10px}
.admin-nav-panel-actions{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
}
.admin-nav-panel-actions button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  min-height:30px;
  padding:6px 8px;
  border-radius:8px;
  border:1px solid rgba(79,179,217,.30);
  background:rgba(255,255,255,.06);
  color:#fff;
  font-size:12px;
  font-weight:700;
}
.admin-nav-panel-actions button:hover{background:rgba(255,255,255,.14)}
.admin-nav-panel-actions button[aria-current="page"]{border-color:rgba(63,228,225,.62);background:rgba(63,228,225,.16)}
.admin-nav-panel-actions #adminFloatingEditBtn.active{border-color:rgba(246,194,68,.75);background:rgba(246,194,68,.20)}
body.focus-mode .admin-nav-panel{right:8px}
body.header-hidden .topbar,body.footer-hidden .app-footer,body.rail-hidden .sidebar{display:none !important}
body.focus-mode .topbar,body.focus-mode .app-footer,body.focus-mode .sidebar{display:none !important}
body.focus-mode.focus-rail-open .sidebar{display:flex !important}
body.edit-mode.header-hidden .topbar{display:flex !important;min-height:12px;height:12px;padding:0;background:rgba(211,60,60,.22);border-bottom:1px solid rgba(211,60,60,.45)}
body.edit-mode.header-hidden .topbar > :not(.shell-resize-handle-header){display:none}
body.edit-mode.header-hidden .topbar .shell-resize-handle-header{display:block;bottom:0;height:12px}
body.edit-mode.footer-hidden .app-footer{display:flex !important;min-height:12px;height:12px;padding:0;background:rgba(211,60,60,.22);border-top:1px solid rgba(211,60,60,.45)}
body.edit-mode.footer-hidden .app-footer img,body.edit-mode.footer-hidden .app-footer .footer-text{display:none}
body.edit-mode.footer-hidden .app-footer .shell-resize-handle-footer{display:block;top:0;height:12px}
body.rail-hidden .main-shell,body.focus-mode .main-shell{margin-left:0 !important}
body.focus-mode .page-content,body.focus-mode .dashboard-container,body.focus-mode .dashboard-grid{height:100%;min-height:100%}
body.focus-mode .dashboard-grid{padding-top:16px}
body.focus-mode.focus-layout-mode .shell-resize-handle{display:block;opacity:.42}
body.focus-mode #focusRailTab{display:inline-flex !important}
body.focus-mode #focusExitTab{display:inline-flex !important}
.app-shell:fullscreen,.app-shell:-webkit-full-screen{background:var(--bg);height:100vh;width:100vw}
.app-shell:fullscreen .main-shell,.app-shell:-webkit-full-screen .main-shell{height:100vh;margin-left:0}
.app-shell:fullscreen .restore-chrome-btn,.app-shell:-webkit-full-screen .restore-chrome-btn{position:fixed}
.log-drawer{width:420px;border-left:1px solid var(--border);background:var(--surface);overflow:auto}
.log-drawer.hidden{display:none}
.log-drawer{position:fixed;right:0;top:0;bottom:0;z-index:2500;max-width:min(92vw,520px);box-shadow:-18px 0 36px rgba(0,0,0,.28)}
.drawer-header{display:flex;justify-content:space-between;padding:14px;border-bottom:1px solid var(--border)}
.topbar-pill{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 6px;border-radius:999px;background:linear-gradient(90deg,#f6c244,#ffdf7a);color:#1b1200;font-size:11px;font-weight:800;margin-left:6px;box-shadow:0 0 0 2px rgba(246,194,68,.18)}
.messages-center-body{padding:12px;display:grid;gap:10px}
.message-unread-row td:first-child strong{color:var(--accent)}
.log-details{white-space:pre-wrap;padding:14px;margin:0;font-family:ui-monospace,monospace;font-size:12px}
.edit-mode .topbar{border-bottom-color:rgba(211,60,60,.5);background:rgba(211,60,60,.09)}
.edit-mode #editModeBtn{background:rgba(211,60,60,.16)}
.hidden{display:none!important}
.status-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:6px}
.status-good{background:#4caf50}.status-warn{background:#f6c244}.status-bad{background:#d33c3c}.status-refresh{background:#4fb3d9}
@media (max-width:1100px){.section-grid{grid-template-columns:1fr}.topbar{align-items:flex-start}.app-shell{grid-template-columns:76px 1fr 0}}
@media (max-width:900px){.home-hero-card,.home-about-section,.home-feature-strip,.home-spotlight-panel,.login-grid,.interview-header-block{grid-template-columns:1fr}.home-account-grid{grid-template-columns:1fr}.home-launch-gate-inner{grid-template-columns:1fr;padding:18px}.home-launch-gate-card{min-height:auto}.home-launch-countdown{max-width:none}}


/* --- v1.3 Command Rail floating behavior --- */
.app-shell{display:block;position:relative}
.sidebar{
  position:fixed;
  left:12px;
  top:12px;
  bottom:12px;
  z-index:50;
  border:1px solid var(--border);
  box-shadow: var(--shadow);
  border-radius:16px;
  overflow:visible;
}
.main-shell{
  margin-left:calc(min(64px, var(--rail-width)) + 24px);
  height:100vh;
  overflow:hidden;
}
.sidebar.rail-docked{width:min(64px, var(--rail-width))}
.sidebar.rail-compact{width:min(84px, var(--rail-width))}
.sidebar.rail-expanded{width:var(--rail-width)}
.sidebar.rail-docked .sidebar-header .brand-mini > div,
.sidebar.rail-compact .sidebar-header .brand-mini > div,
.sidebar.rail-docked .rail-identity-copy,
.sidebar.rail-compact .rail-identity-copy,
.sidebar.rail-docked .nav-label,
.sidebar.rail-compact .nav-label,
.sidebar.rail-docked .rail-control-label,
.sidebar.rail-compact .rail-control-label{
  display:none;
}
.sidebar.rail-docked .nav-item,
.sidebar.rail-compact .nav-item{
  justify-content:center;
}
.sidebar.rail-docked .nav-icon,
.sidebar.rail-compact .nav-icon{margin-right:0}
.sidebar.rail-docked .sidebar-nav,
.sidebar.rail-compact .sidebar-nav{padding:12px 8px}
.sidebar.rail-docked .brand-mini,
.sidebar.rail-compact .brand-mini{justify-content:center}
.sidebar.rail-docked .brand-mini img,
.sidebar.rail-compact .brand-mini img{margin:0 auto}
.sidebar.rail-docked .rail-identity-row,
.sidebar.rail-compact .rail-identity-row{grid-template-columns:1fr}
.sidebar.rail-docked .rail-profile-menu-btn,
.sidebar.rail-compact .rail-profile-menu-btn{height:28px}
.sidebar.rail-docked .rail-identity,
.sidebar.rail-compact .rail-identity{display:flex;justify-content:center;padding:6px;width:38px;margin:8px auto 0}
.sidebar.rail-docked .profile-menu,
.sidebar.rail-compact .profile-menu{left:calc(100% + 8px);right:auto;top:0;width:min(320px, calc(100vw - 92px));max-height:min(78vh, 520px);overflow:auto}
.rail-controls{
  padding:8px 10px 6px;
  display:flex;
  flex-direction:column;
  gap:8px;
  border-top:1px solid var(--border);
}
.rail-btn{
  display:flex;
  align-items:center;
  gap:10px;
  width:100%;
  justify-content:flex-start;
  background:var(--rail-button-bg);
  color:var(--rail-button-text);
}
.rail-tools-wrap{position:relative}
.rail-tools-menu{right:0;top:auto;bottom:84px;min-width:300px;max-height:min(78vh,640px);overflow:auto;z-index:120}
.rail-tools-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.rail-tools-menu .rail-btn{width:100%;justify-content:flex-start;min-height:40px;padding:10px 12px;font-size:13px}
.rail-tools-menu .rail-btn.is-saving{opacity:.85}
.rail-tools-menu .rail-btn.is-saved{border-color:color-mix(in srgb,var(--success) 72%,white 10%);background:color-mix(in srgb,var(--success) 18%,transparent)}
.rail-tools-menu .rail-btn.is-error{border-color:color-mix(in srgb,var(--danger) 72%,white 10%);background:color-mix(in srgb,var(--danger) 16%,transparent)}
.rail-tools-menu .rail-control-label{display:inline !important}
.sidebar.rail-docked .rail-tools-menu .rail-control-label,
.sidebar.rail-compact .rail-tools-menu .rail-control-label{display:inline !important}
.env-badge-wrap{display:flex;justify-content:flex-start}
.sidebar.rail-docked .env-badge-wrap,
.sidebar.rail-compact .env-badge-wrap{justify-content:center}
.sidebar.rail-docked .tier-chip,
.sidebar.rail-compact .tier-chip{
  padding:8px;
  width:36px;
  height:36px;
  overflow:hidden;
  text-indent:-9999px;
  position:relative;
}
.sidebar.rail-docked .tier-chip::after,
.sidebar.rail-compact .tier-chip::after{
  content:"◉";
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  text-indent:0;
  color:white;
}
.sidebar.rail-docked .version-chip,
.sidebar.rail-compact .version-chip{display:none}
.sidebar-float-hint{
  position:fixed;
  left:8px;
  top:50%;
  transform:translateY(-50%);
  z-index:40;
}
.topbar-actions{margin-left:auto}
.topbar{margin-left:0}
.page-content, .app-footer{padding-left:0}
.layout-label{
  position:absolute;
  top:6px;
  left:8px;
  z-index:8;
  background:rgba(211,60,60,.9);
  color:#fff;
  font-size:11px;
  font-weight:700;
  padding:3px 8px;
  border-radius:999px;
  box-shadow:0 4px 10px rgba(0,0,0,.18);
}
.workspace-label{
  position:absolute;
  top:6px;
  left:8px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  pointer-events:auto;
}
.dashboard-grid .workspace-label{background:rgba(17,24,39,.78)}
.edit-mode .dashboard-grid .workspace-label{background:rgba(211,60,60,.9)}
.workspace-label-actions button{padding:3px 8px;border-radius:999px;font-size:11px;background:rgba(255,255,255,.10);color:#fff;border:1px solid rgba(255,255,255,.24)}
.workspace-label-actions button:hover{background:rgba(255,255,255,.18)}
.workspace-label-actions .workspace-nav-btn{min-width:24px;padding:2px 6px;font-size:11px;font-weight:700}
.workspace-label-actions .workspace-nav-btn:disabled{opacity:.45;cursor:not-allowed}
#softRefreshBtn{display:none !important}
.workspace-id-chip{
  position:absolute;
  top:6px;
  right:8px;
  z-index:8;
  display:inline-flex;
  align-items:center;
  max-width:min(45vw,460px);
  padding:3px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.24);
  background:rgba(17,24,39,.78);
  color:#fff;
  font-size:11px;
  font-weight:700;
  letter-spacing:.01em;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  pointer-events:none;
}
.edit-mode .dashboard-grid .workspace-id-chip{background:rgba(211,60,60,.9)}
.workspace-id-trace{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:2px;
  max-width:min(58vw,620px);
  white-space:normal;
  text-overflow:clip;
  line-height:1.2;
  pointer-events:auto;
  user-select:text;
}
.workspace-id-trace span{display:flex;align-items:center;gap:6px;justify-content:flex-end}
.workspace-trace-link-btn{
  border:1px solid rgba(255,255,255,.28);
  background:rgba(255,255,255,.12);
  color:#fff;
  border-radius:999px;
  padding:1px 7px;
  font-size:10px;
  font-weight:700;
  line-height:1.2;
  cursor:pointer;
}
.workspace-trace-link-btn:hover{background:rgba(255,255,255,.22)}
.workspace-trace-link-btn:focus-visible{outline:2px solid color-mix(in srgb,var(--accent) 58%,white 10%);outline-offset:1px}
.workspace-id-trace, .workspace-id-trace *{
  -webkit-user-select:text;
  user-select:text;
}
.auth-view-trace{
  position:relative;
  top:auto;
  right:auto;
  margin:0 0 10px auto;
  max-width:min(92%,620px);
}
.launcher-main .auth-view-trace{
  margin-bottom:14px;
}
.workspace-mission-band{
  position:absolute;
  z-index:3;
  pointer-events:none;
  border-top:1px dashed color-mix(in srgb,var(--accent) 52%,rgba(255,255,255,.22));
}
.workspace-mission-band.editable{pointer-events:auto}
.workspace-mission-band-label{
  position:absolute;
  top:-12px;
  left:0;
  display:inline-flex;
  align-items:center;
  padding:2px 9px;
  border-radius:999px;
  border:1px solid color-mix(in srgb,var(--accent) 40%,var(--border));
  background:color-mix(in srgb,var(--surface) 82%,transparent);
  color:var(--muted);
  font-size:10px;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.workspace-mission-band-handle{
  position:absolute;
  right:-4px;
  top:-11px;
  min-width:28px;
  height:20px;
  padding:0 6px;
  border-radius:999px;
  border:1px solid color-mix(in srgb,var(--accent) 56%,var(--border));
  background:color-mix(in srgb,var(--surface) 82%,transparent);
  color:var(--text);
  cursor:ns-resize;
  font-size:11px;
  line-height:1;
}
.workspace-mission-band-handle:hover{background:color-mix(in srgb,var(--accent) 16%,transparent)}
.command-rail-label{
  position:absolute;
  top:8px;
  left:8px;
}
.sidebar.editing-shell{
  outline:2px solid rgba(211,60,60,.5);
}
.dashboard-grid{padding-top:30px}
.widget-label{
  position:absolute;
  top:10px;
  right:10px;
}
@media (max-width:1100px){
  .main-shell{margin-left:76px}
  .sidebar.rail-expanded{width:240px}
}

/* Test Mode floating console */
.test-console{
  position:fixed;
  top:90px;
  right:24px;
  width:420px;
  max-width:calc(100vw - 32px);
  max-height:calc(100vh - 120px);
  background:var(--surface);
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  border-radius:16px;
  z-index:2000;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
.test-console.hidden{display:none}
.test-console.minimized .test-console-body{display:none}
.test-console-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  padding:12px 14px;
  cursor:move;
  background:linear-gradient(90deg, rgba(79,179,217,.16), rgba(11,61,145,.12));
  border-bottom:1px solid var(--border);
}
.test-console-body{
  padding:12px 14px;
  overflow:auto;
}
.edit-toolbox{
  position:fixed;
  top:50%;
  left:calc(min(var(--rail-width), 320px) + clamp(56px, 7vw, 120px));
  transform:translateY(-50%);
  width:332px;
  max-width:calc(100vw - 32px);
  background:var(--surface);
  border:1px solid rgba(211,60,60,.45);
  box-shadow:0 0 0 2px rgba(211,60,60,.24),0 0 14px rgba(211,60,60,.22),var(--shadow);
  border-radius:16px;
  z-index:2100;
  overflow:hidden;
  max-height:calc(100vh - 28px);
}
.edit-toolbox:not(.hidden){
  animation:editToolboxEdgeGlow 2.2s ease-in-out infinite;
}
@keyframes editToolboxEdgeGlow{
  0%,100%{
    box-shadow:0 0 0 2px rgba(211,60,60,.22),0 0 12px rgba(211,60,60,.30),var(--shadow);
  }
  50%{
    box-shadow:0 0 0 4px rgba(211,60,60,.42),0 0 26px rgba(211,60,60,.52),var(--shadow);
  }
}
body.glass-effects-soft .modal-overlay,
body.glass-effects-soft .feedback-dialog{
  background:rgba(3,10,18,.44);
  -webkit-backdrop-filter:blur(10px) saturate(125%);
  backdrop-filter:blur(10px) saturate(125%);
}
body.glass-effects-full .modal-overlay,
body.glass-effects-full .feedback-dialog{
  background:rgba(3,10,18,.36);
  -webkit-backdrop-filter:blur(18px) saturate(155%);
  backdrop-filter:blur(18px) saturate(155%);
}
body.glass-effects-soft .modal-card,
body.glass-effects-soft .profile-menu,
body.glass-effects-soft .edit-toolbox,
body.glass-effects-soft .feedback-card,
body.glass-effects-soft .home-registration-card,
body.glass-effects-soft .interview-sticky-header,
body.glass-effects-soft .interview-chunk,
body.glass-effects-soft .appearance-group,
body.glass-effects-soft .branding-asset-control,
body.glass-effects-soft .glass-preview-card{
  background:color-mix(in srgb,var(--surface) 76%,transparent);
  border-color:color-mix(in srgb,var(--accent) 24%,var(--border));
  -webkit-backdrop-filter:blur(11px) saturate(130%);
  backdrop-filter:blur(11px) saturate(130%);
  box-shadow:0 18px 56px rgba(0,0,0,.26),inset 0 1px 0 rgba(255,255,255,.08);
}
body.glass-effects-full .modal-card,
body.glass-effects-full .profile-menu,
body.glass-effects-full .edit-toolbox,
body.glass-effects-full .feedback-card,
body.glass-effects-full .home-registration-card,
body.glass-effects-full .interview-sticky-header,
body.glass-effects-full .interview-chunk,
body.glass-effects-full .appearance-group,
body.glass-effects-full .branding-asset-control,
body.glass-effects-full .glass-preview-card{
  background:color-mix(in srgb,var(--surface) 58%,transparent);
  border-color:color-mix(in srgb,var(--accent) 38%,var(--border));
  -webkit-backdrop-filter:blur(18px) saturate(165%);
  backdrop-filter:blur(18px) saturate(165%);
  box-shadow:0 24px 80px rgba(0,0,0,.34),0 0 0 1px color-mix(in srgb,var(--accent) 12%,transparent),inset 0 1px 0 rgba(255,255,255,.14);
}
body.theme-light.glass-effects-soft .modal-card,
body.theme-light.glass-effects-soft .profile-menu,
body.theme-light.glass-effects-soft .edit-toolbox,
body.theme-light.glass-effects-soft .feedback-card,
body.theme-light.glass-effects-soft .home-registration-card,
body.theme-light.glass-effects-soft .interview-sticky-header,
body.theme-light.glass-effects-soft .interview-chunk,
body.theme-light.glass-effects-soft .appearance-group,
body.theme-light.glass-effects-soft .branding-asset-control,
body.theme-light.glass-effects-soft .glass-preview-card{background:rgba(255,255,255,.72)}
body.theme-light.glass-effects-full .modal-card,
body.theme-light.glass-effects-full .profile-menu,
body.theme-light.glass-effects-full .edit-toolbox,
body.theme-light.glass-effects-full .feedback-card,
body.theme-light.glass-effects-full .home-registration-card,
body.theme-light.glass-effects-full .interview-sticky-header,
body.theme-light.glass-effects-full .interview-chunk,
body.theme-light.glass-effects-full .appearance-group,
body.theme-light.glass-effects-full .branding-asset-control,
body.theme-light.glass-effects-full .glass-preview-card{background:rgba(255,255,255,.58)}
.edit-toolbox-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  padding:12px 14px;
  cursor:move;
  background:linear-gradient(90deg, rgba(211,60,60,.16), rgba(79,179,217,.12));
  border-bottom:1px solid var(--border);
}
.edit-toolbox-body{padding:12px 14px;max-height:calc(100vh - 110px);overflow:auto}
.edit-toolbox .table-actions button{flex:1 1 120px}
.edit-toolbox-baseline-section{margin-top:10px;padding-top:10px;border-top:1px solid var(--border);display:grid;gap:8px}
.edit-toolbox-baseline-toggle{width:100%;justify-content:flex-start;font-weight:700}
.edit-toolbox-baseline-body{display:grid;gap:8px}
body.edit-clean-view .resize-handle{display:none !important}
body.edit-clean-view .dashboard-grid.editing{outline:none}
.home-graphic-control{margin:12px 0}
.home-graphic-preview-row{display:grid;grid-template-columns:96px minmax(0,1fr);gap:10px;align-items:start}
.home-graphic-preview{width:96px;height:72px;object-fit:cover;border:1px solid var(--border);border-radius:14px;background:rgba(255,255,255,.06)}
.home-graphic-fields{display:grid;gap:8px}
.branding-asset-grid{display:grid;gap:10px}
.branding-asset-control{padding:10px;border:1px solid var(--border);border-radius:16px;background:rgba(255,255,255,.03)}
.branding-preview{object-fit:contain}
.glass-preview-card{display:grid;gap:10px;padding:12px;border:1px solid var(--border);border-radius:18px;background:rgba(255,255,255,.035)}
.glass-preview-sample{display:grid;gap:8px;padding:12px;border:1px solid color-mix(in srgb,var(--accent) 20%,var(--border));border-radius:16px;background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.02))}
.compact-actions{margin-top:0}
.tour-target-pick-mode{cursor:crosshair}
.tour-target-pick-mode *{cursor:crosshair!important}
.tour-pick-candidate{outline:2px dashed var(--accent)!important;outline-offset:4px;box-shadow:0 0 0 6px rgba(246,194,68,.14)!important}
.test-history-row{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin:8px 0;
}
.test-pill{
  padding:4px 8px;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.04);
  font-size:12px;
}
.test-pill.current{border-color:rgba(79,179,217,.5);background:rgba(79,179,217,.16)}
.test-outline-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:8px;align-items:center;margin:6px 0 10px}
@media (max-width:760px){.test-outline-row{grid-template-columns:1fr}}
.test-case-details{border:1px solid var(--border);border-radius:12px;padding:8px 10px;background:rgba(255,255,255,.025);margin:8px 0}
.test-case-details summary{cursor:pointer;font-weight:700}
.test-case-details .callout{max-height:180px;overflow:auto}
.test-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin:10px 0 12px}
.test-summary-card{padding:8px 10px;border:1px solid var(--border);border-radius:12px;background:rgba(255,255,255,.03)}
.test-summary-card strong{display:block;font-size:18px}
.test-case-meta{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0}
.test-tag{font-size:11px;padding:3px 8px;border-radius:999px;background:rgba(79,179,217,.16);color:var(--text)}
.test-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:10px;
}
.guided-overlay{position:fixed;inset:0;z-index:120;pointer-events:none}
.guided-overlay.hidden{display:none}
.guided-spotlight{position:absolute;border-radius:18px;border:2px solid color-mix(in srgb, var(--accent) 84%, white 16%);box-shadow:0 0 0 9999px rgba(5,10,20,.58),0 0 0 8px rgba(79,179,217,.22),0 0 30px color-mix(in srgb,var(--accent) 42%,transparent);background:transparent;transition:all .18s ease;animation:guidedSpotlightGlow 1.8s ease-in-out infinite}
@keyframes guidedSpotlightGlow{0%,100%{box-shadow:0 0 0 9999px rgba(5,10,20,.58),0 0 0 8px rgba(79,179,217,.18),0 0 22px color-mix(in srgb,var(--accent) 30%,transparent)}50%{box-shadow:0 0 0 9999px rgba(5,10,20,.52),0 0 0 10px rgba(79,179,217,.28),0 0 40px color-mix(in srgb,var(--accent) 52%,transparent)}}
.guided-popover{position:absolute;max-width:340px;background:var(--surface);color:var(--text);border:2px solid rgba(79,179,217,.92);border-radius:18px;box-shadow:0 0 0 4px rgba(79,179,217,.18),0 18px 55px rgba(0,0,0,.38),var(--shadow);padding:16px;pointer-events:auto}
.guided-popover::before{content:"";position:absolute;inset:-7px;border:1px solid rgba(79,179,217,.42);border-radius:22px;pointer-events:none}
.guided-popover-handle{position:absolute;top:8px;right:10px;padding:4px 8px;border-radius:999px;border:1px solid rgba(79,179,217,.5);background:rgba(79,179,217,.16);color:var(--text);font-size:11px;cursor:grab}
.guided-popover-handle:active{cursor:grabbing}
.guided-eyebrow{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.guided-popover h3{margin:0 0 8px}
.guided-popover p{margin:0 0 12px;color:var(--text)}
.guided-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}
.guided-edit-controls{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}
.guided-edit-controls.hidden{display:none}
.guided-edit-controls button{padding:6px 8px;font-size:12px}
.guided-order-control{grid-column:span 4;display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted)}
.guided-order-control input{max-width:88px;padding:6px 8px;border-radius:8px;border:1px solid var(--border);background:rgba(255,255,255,.04);color:var(--text)}
.guided-overlay.guided-editing .guided-spotlight{border-style:dashed;border-color:var(--accent);box-shadow:0 0 0 9999px rgba(5,10,20,.42),0 0 0 8px rgba(246,194,68,.16)}
.guided-overlay.self-tour .guided-popover{max-width:300px;padding:13px 14px}
.guided-overlay.self-tour .guided-eyebrow::after{content:" · hover help"}
.guided-overlay.self-tour .guided-actions,
.guided-overlay.self-tour .guided-edit-controls{display:none}
.guided-overlay.self-tour.self-tour-parked .guided-eyebrow::after{content:" · parked"}
.guided-overlay.self-tour.self-tour-parked .guided-actions{display:flex}
.guided-overlay.self-tour.self-tour-parked.guided-editing .guided-edit-controls{display:grid}
.guided-overlay.self-tour.self-tour-parked .guided-spotlight{border-style:dashed}
.guided-overlay.self-tour .guided-spotlight{border-color:color-mix(in srgb,var(--accent) 78%,white 14%);box-shadow:0 0 0 9999px rgba(5,10,20,.30),0 0 0 6px color-mix(in srgb,var(--accent) 16%,transparent)}
.opportunity-snapshot-nav{display:grid;gap:8px;margin-top:10px;padding:10px;border:1px solid var(--border);border-radius:14px;background:rgba(255,255,255,.03)}
.opportunity-snapshot-nav-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.opportunity-snapshot-nav button{padding:7px 10px;font-size:12px}
.snapshot-scroll-step-label,.snapshot-jump-label,.snapshot-scroll-range-label{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted)}
.snapshot-scroll-step-label select{width:auto;min-width:108px;padding:6px 8px}
.snapshot-jump-label select{min-width:190px;padding:6px 8px}
.snapshot-scroll-range-label{width:100%;align-items:center}
.snapshot-scroll-range-label input{flex:1;accent-color:var(--accent)}
.opportunity-snapshot-table-wrap{max-height:520px;overflow:auto;border:1px solid var(--border);border-radius:12px;margin-top:10px;scrollbar-gutter:stable both-edges;scrollbar-color:var(--accent) rgba(255,255,255,.08);scrollbar-width:thin}
.opportunity-snapshot-table-wrap::-webkit-scrollbar{height:16px;width:14px}
.opportunity-snapshot-table-wrap::-webkit-scrollbar-track{background:rgba(255,255,255,.07);border-radius:999px}
.opportunity-snapshot-table-wrap::-webkit-scrollbar-thumb{background:linear-gradient(90deg,var(--secondary),var(--accent));border-radius:999px;border:3px solid rgba(15,23,42,.72)}
.opportunity-snapshot-table-wrap::-webkit-scrollbar-thumb:hover{background:linear-gradient(90deg,var(--primary),var(--accent))}
.opportunity-snapshot-table{min-width:1400px;font-size:11px;line-height:1.25}
.opportunity-snapshot-table th,.opportunity-snapshot-table td{padding:5px 5px}
.opportunity-snapshot-table th{position:sticky;top:0;background:var(--surface);z-index:2}
.opportunity-snapshot-table th{position:sticky}
.opportunity-snapshot-table th[draggable="true"]{cursor:grab}
.opportunity-snapshot-table th[draggable="true"]:active{cursor:grabbing}
.column-resize-handle{position:absolute;right:0;top:0;width:8px;height:100%;cursor:col-resize;background:transparent}
.column-resize-handle:hover{background:rgba(79,179,217,.35)}
.opportunity-snapshot-table th:first-child,.opportunity-snapshot-table td:first-child{position:sticky;left:0;background:var(--surface);z-index:3}
.opportunity-snapshot-title{min-width:260px}
.snapshot-cell-text{white-space:pre-wrap}
.snapshot-cell-clamped{display:-webkit-box;-webkit-line-clamp:14;-webkit-box-orient:vertical;overflow:hidden}
.snapshot-cell-text.expanded{display:block;max-height:none;overflow:visible}
.snapshot-cell-toggle{margin-top:5px;padding:4px 7px;font-size:11px}
.opp-intel-v2{font-size:12px;line-height:1.32}
.opp-intel-v2 .callout{margin-bottom:10px}
.opp-intel-v2-summary{font-size:12px}
.opp-intel-v2-card strong{font-size:13px}
.opp-intel-v2-meta{color:var(--muted);font-size:11px;margin:4px 0}
.matching-readiness-card{display:grid;gap:10px}
.readiness-score-block{display:grid;grid-template-columns:minmax(110px,160px) 1fr;gap:14px;align-items:center}
.readiness-score{font-size:34px;font-weight:800;color:var(--accent);line-height:1}
.readiness-row-list{display:grid;gap:8px}
.readiness-row{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center;padding:10px;border:1px solid var(--border);border-radius:14px;background:rgba(255,255,255,.03)}
.readiness-row-score{font-weight:800;color:var(--accent);min-width:52px;text-align:right}
.result-buttons{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin:8px 0;
}
.result-btn.active{
  outline:2px solid var(--accent);
}
.result-btn.regression-active{
  outline:2px solid var(--danger);
}
.page-widget-list{max-height:35vh; overflow:auto;}

.color-preview-row{display:grid;grid-template-columns:20px 70px 1fr;gap:10px;align-items:center}
.color-swatch{display:inline-block;width:20px;height:20px;border-radius:6px;border:1px solid var(--border)}
.app-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px;margin-top:12px}
.app-card{border:1px solid var(--border);background:linear-gradient(180deg,var(--surface),rgba(255,255,255,.03));border-radius:14px;padding:14px;text-align:left;color:var(--text);cursor:pointer;box-shadow:var(--shadow)}
.app-card.active{border-color:rgba(79,179,217,.45);background:rgba(79,179,217,.10)}
.app-card-highlight,.app-card-experimental{border-color:rgba(255,184,77,.36);background:linear-gradient(180deg,rgba(255,184,77,.10),rgba(255,255,255,.03))}
.app-card-new{border-color:rgba(79,179,217,.38);background:linear-gradient(180deg,rgba(79,179,217,.12),rgba(255,255,255,.03))}
.app-card-open{display:block;width:100%;padding:0;border:0;background:transparent;color:inherit;text-align:left}
.app-card-admin-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}
.app-card-admin-actions button{font-size:11px;padding:6px 8px}
.app-card-title{font-weight:700;margin-bottom:4px}
.app-card-meta{font-size:12px;color:var(--muted);margin-bottom:8px}
.app-card-copy{font-size:13px;color:var(--text);margin-bottom:10px}
.app-card-tags{display:flex;gap:6px;flex-wrap:wrap}
.apps-grid{align-items:start}

:root{--rail-bg:#111827;--widget-bg:#111827;--workspace-bg:#0f172a;--header-bg:#182236;--footer-bg:#182236;--button-bg:#1e6fb7;--header-text:#e5e7eb;--header-button-bg:rgba(255,255,255,.06);--header-button-text:#e5e7eb;--footer-text-color:#94a3b8;--footer-graphic-bg:rgba(255,255,255,.06);--nav-tool-bg:rgba(17,24,39,.88);--nav-tool-text:#e5e7eb;--rail-button-bg:rgba(255,255,255,.06);--rail-button-text:#e5e7eb;--rail-nav-text:#e5e7eb;--rail-width:280px;--header-height:64px;--footer-height:130px;--widget-header-height:34px;--header-radius:18px;--footer-radius:18px;--footer-logo-height:110px;--header-scale:1;--header-icon-scale:1;--header-content-opacity:1;--header-inner-padding:6px;--footer-scale:1;--footer-icon-scale:1;--footer-content-opacity:1;--footer-inner-padding:10px;--rail-controls-gap:104px}
.sidebar{background:linear-gradient(180deg,color-mix(in srgb, var(--rail-bg) 94%, white 6%),color-mix(in srgb, var(--rail-bg) 68%, var(--secondary) 32%));}
.widget{background:linear-gradient(180deg,color-mix(in srgb, var(--widget-bg) 92%, white 8%),color-mix(in srgb, var(--widget-bg) 82%, transparent));}
.dashboard-grid{background-color:var(--workspace-bg);}
.topbar{background:linear-gradient(90deg,color-mix(in srgb, var(--header-bg) 88%, var(--primary) 12%),color-mix(in srgb, var(--header-bg) 72%, var(--secondary) 28%));color:var(--header-text);min-height:var(--header-height);height:var(--header-height);padding-block:var(--header-inner-padding);overflow:hidden;border-radius:0 0 var(--header-radius) var(--header-radius)}
.topbar-left,.topbar-actions{transform-origin:left center;transform:scale(var(--header-scale));opacity:1}
.topbar h1,.topbar .saved-state{color:var(--header-text);text-shadow:0 1px 4px rgba(0,0,0,.34);filter:brightness(1.08)}
.page-title-focus-link{cursor:pointer;transition:opacity .2s ease,text-shadow .2s ease}
.page-title-focus-link:hover{opacity:.92;text-shadow:0 2px 8px rgba(0,0,0,.42)}
.page-title-focus-link:focus-visible{outline:2px solid color-mix(in srgb,var(--accent) 72%,white 16%);outline-offset:3px;border-radius:8px}
.rail-section-spotlight{box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 64%,white 14%) inset,0 0 18px color-mix(in srgb,var(--accent) 28%,transparent);border-radius:14px}
.topbar .ghost-btn,.topbar .primary-btn,.topbar button{background:var(--header-button-bg);color:var(--header-button-text)}
.topbar-refresh-note{display:inline-flex;align-items:center;max-width:min(540px,44vw);padding:6px 10px;border-radius:10px;border:1px solid color-mix(in srgb,var(--accent) 52%,var(--border));background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--header-text);font-size:11px;line-height:1.35}
.topbar .ghost-btn.refresh-recommended{border-color:color-mix(in srgb,var(--accent) 80%,white 12%);background:linear-gradient(90deg,color-mix(in srgb,var(--accent) 34%,var(--header-button-bg)),color-mix(in srgb,var(--secondary) 38%,var(--header-button-bg)));box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 22%,transparent),0 0 18px color-mix(in srgb,var(--accent) 28%,transparent);animation:refreshPulse 1.3s ease-in-out infinite}
@keyframes refreshPulse{0%,100%{transform:translateY(0)}50%{transform:translateY(-1px)}}
.topbar .saved-state.dirty,
#saveLayoutBtn.dirty,
#editToolboxSaveBtn.dirty,
#editToolboxSaveCloseBtn.dirty{
  color:#15110a !important;
  text-shadow:none !important;
  filter:none !important;
  background:linear-gradient(90deg,#f6c244,#ffdf7a) !important;
  border-color:rgba(246,194,68,.75) !important;
  box-shadow:0 0 0 2px rgba(246,194,68,.18) !important;
}
.topbar .ghost-btn.active{opacity:1;border-color:color-mix(in srgb,var(--accent) 74%,white 14%);background:color-mix(in srgb,var(--accent) 24%,var(--header-button-bg));box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 18%,transparent)}
.tour-help-cluster{position:relative;display:inline-flex;align-items:center}
.tour-help-btn{min-width:148px;transition:transform .18s ease, box-shadow .18s ease, background .18s ease}
.tour-help-btn.menu-open{transform:scale(1.035);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 20%,transparent),0 10px 24px rgba(0,0,0,.22)}
.tour-help-menu{position:fixed;z-index:1200;display:grid;gap:6px;min-width:190px;padding:8px;border-radius:16px;background:color-mix(in srgb,var(--header-bg) 88%,#020617 12%);border:1px solid color-mix(in srgb,var(--accent) 32%,var(--border));box-shadow:0 18px 44px rgba(0,0,0,.38);transform-origin:top right;animation:tourHelpOpen .18s ease both}
.tour-help-menu.hidden{display:none}
.tour-help-menu button{width:100%;text-align:left;border-radius:12px;background:rgba(255,255,255,.06)}
.tour-help-menu button:hover{background:color-mix(in srgb,var(--accent) 18%,rgba(255,255,255,.08))}
@keyframes tourHelpOpen{from{opacity:0;transform:translateY(-6px) scale(.94)}to{opacity:1;transform:translateY(0) scale(1)}}
.app-footer{background:linear-gradient(90deg,color-mix(in srgb, var(--footer-bg) 88%, var(--secondary) 12%),color-mix(in srgb, var(--footer-bg) 74%, var(--accent) 26%));min-height:var(--footer-height);height:var(--footer-height);padding-block:var(--footer-inner-padding);overflow:hidden;border-radius:var(--footer-radius) var(--footer-radius) 0 0}
.app-footer img{transform:scale(var(--footer-icon-scale));transform-origin:center center;opacity:var(--footer-content-opacity);background:var(--footer-graphic-bg);border-radius:14px;padding:8px}
.footer-text{transform:scale(var(--footer-scale));transform-origin:center center;opacity:1;color:var(--footer-text-color);font-weight:700;text-shadow:0 1px 4px rgba(0,0,0,.34);filter:brightness(1.08)}
.footer-text span{color:var(--footer-text-color)}
.primary-btn{background:linear-gradient(90deg,color-mix(in srgb, var(--button-bg) 76%, var(--primary) 24%),color-mix(in srgb, var(--button-bg) 70%, var(--secondary) 30%));color:#fff}
.button-link{display:inline-flex;align-items:center;justify-content:center;padding:6px 8px;border-radius:10px;border:1px solid var(--border);background:rgba(255,255,255,.06);color:var(--text);text-decoration:none;font-size:12px}
.rail-controls{margin-top:auto;display:grid;gap:8px;padding:10px 12px 6px;margin-bottom:0}
.rail-controls .rail-btn{width:100%;justify-content:flex-start}
.rail-controls-gap-handle{height:0;margin:0 12px var(--rail-controls-gap) 12px;border-radius:999px;pointer-events:none}
.edit-mode .rail-controls-gap-handle{height:10px;pointer-events:auto;cursor:ns-resize;border:1px dashed color-mix(in srgb,var(--accent) 62%,white 8%);background:color-mix(in srgb,var(--accent) 28%,transparent);box-shadow:0 0 0 1px rgba(255,255,255,.14) inset;opacity:.9}
.rail-assistant-btn{border-radius:16px;padding:11px 12px;box-shadow:0 10px 22px rgba(31,175,200,.16)}
.quill-assistant-panel{position:fixed;left:calc(min(var(--rail-width), 320px) + 22px);bottom:22px;width:min(430px, calc(100vw - 48px));height:auto;min-width:300px;min-height:280px;max-width:calc(100vw - 28px);max-height:min(720px, calc(100vh - 32px));resize:both;z-index:2200;border:1px solid rgba(79,179,217,.28);border-radius:20px;background:linear-gradient(180deg,color-mix(in srgb,var(--surface) 94%,white 6%),color-mix(in srgb,var(--surface-2) 92%,var(--secondary) 8%));box-shadow:0 18px 46px rgba(0,0,0,.34);overflow:auto}
.quill-assistant-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border);cursor:move;background:rgba(255,255,255,.04)}
.quill-assistant-body{display:grid;gap:10px;padding:12px}
.quill-assistant-menu{display:grid;gap:8px;padding:10px;border:1px solid var(--border);border-radius:14px;background:rgba(255,255,255,.05)}
.quill-assistant-history{height:260px;overflow:auto;border:1px solid var(--border);border-radius:14px;padding:10px;background:rgba(0,0,0,.12)}
.quill-assistant-panel.minimized .quill-assistant-body{display:none}
.quill-assistant-panel.minimized{width:280px}
body.rail-pinned-expanded .main-shell{margin-left:calc(var(--rail-width) + 28px)}
body.rail-pinned-docked .main-shell{margin-left:calc(min(64px, var(--rail-width)) + 24px)}
.sidebar.rail-unpinned:hover{width:var(--rail-width)}
.test-console{border:1px solid rgba(211,60,60,.55);box-shadow:0 0 0 1px rgba(211,60,60,.2),0 0 24px rgba(211,60,60,.15),var(--shadow)}
.widget-menu-btn{position:relative}
.widget-menu{position:absolute;right:12px;top:44px;z-index:40;display:flex;flex-direction:column;gap:6px;padding:8px;border-radius:12px;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);min-width:170px;max-height:min(60vh,420px);overflow:auto}
.rail-function-menu{z-index:3200}
.widget-menu.widget-menu-above{top:auto;bottom:44px}
.widget-menu button{width:100%;text-align:left}
.widget-menu-title{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding:4px 2px 2px}
.widget-menu-toggle{display:flex;align-items:center;gap:8px;padding:6px 4px;font-size:13px;color:var(--text)}
.minimized-widget .widget-body,.minimized-widget .resize-handle{display:none}
.minimized-widget{height:auto !important;min-height:0}
.minimized-widget .widget-header{border-bottom:none}
.allow-overlap{outline:1px dashed rgba(79,179,217,.55)}
.color-control-block{margin-bottom:10px}
.color-picker-btn{width:42px;padding:10px 0}
.color-input-inline{max-width:60px;padding:4px;border:none;background:transparent}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;z-index:3000}
.modal-card{width:min(680px,92vw);background:var(--surface);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);overflow:hidden}
.modal-body{padding:16px}
.user-edit-modal{width:min(860px,94vw)}
.release-notes-modal{width:min(920px,94vw)}
.release-notes-shell{max-height:min(68vh,680px);overflow:auto;display:grid;gap:10px;padding-right:2px}
.release-notes-entry{border:1px solid var(--border);border-radius:12px;background:rgba(255,255,255,.03)}
.release-notes-entry>summary{cursor:pointer;padding:10px 12px;font-weight:700;list-style:none}
.release-notes-entry>summary::-webkit-details-marker{display:none}
.release-notes-content{padding:0 12px 12px;display:grid;gap:8px}
.release-notes-content p{margin:0;color:var(--muted);line-height:1.4}
.release-notes-content ul{margin:0 0 0 18px;padding:0;display:grid;gap:6px}
.release-notes-content li{line-height:1.4}
.permission-grid-wrap{overflow:auto;max-height:440px;border:1px solid var(--border);border-radius:14px}
.permission-grid th,.permission-grid td{text-align:center;vertical-align:middle}
.permission-grid th:first-child,.permission-grid td:first-child{text-align:left;min-width:240px;position:sticky;left:0;background:var(--surface);z-index:1}
.advanced-color-preview{height:160px;border-radius:14px;border:1px solid var(--border);margin-bottom:12px}
.advanced-color-field{position:relative;height:160px;border-radius:14px;border:1px solid var(--border);cursor:crosshair;overflow:hidden;margin-bottom:12px;background:linear-gradient(to top, black, transparent), linear-gradient(to right, white, #4fb3d9)}
.advanced-color-field-handle{position:absolute;left:50%;top:50%;width:16px;height:16px;border-radius:999px;border:2px solid #fff;box-shadow:0 0 0 1px rgba(15,23,42,.65);transform:translate(-50%,-50%)}
.three-col-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.nested-app-link{font-size:13px;padding:10px 12px}
.govcon-actions button{min-width:140px}
.match-gauge-wrap{margin:8px 0 10px}
.match-gauge-head{display:flex;justify-content:space-between;gap:8px;font-size:12px;color:var(--muted);margin-bottom:4px}
.match-gauge{height:12px;border-radius:999px;background:linear-gradient(90deg,#b91c1c 0%,#f59e0b 50%,#16a34a 100%);position:relative}
.match-gauge::after{content:"";position:absolute;inset:2px;border-radius:999px;background:rgba(15,23,42,.24)}
.match-gauge-fill{position:absolute;left:0;top:0;bottom:0;border-radius:999px;background:linear-gradient(90deg,rgba(255,255,255,.15),rgba(255,255,255,.55));z-index:1}
.match-gauge-marker{position:absolute;top:50%;width:12px;height:12px;border-radius:3px;background:#050505;border:1px solid rgba(255,255,255,.82);box-shadow:0 0 0 2px rgba(0,0,0,.18);transform:translate(-50%,-50%);z-index:3}
.match-gauge-marker::after{content:"";position:absolute;left:50%;top:-7px;bottom:-7px;width:2px;background:#050505;transform:translateX(-50%);border-radius:999px}
@media (max-width:900px){
  .main-shell{margin-left:calc(min(64px, var(--rail-width)) + 24px)}
  body.rail-pinned-expanded .main-shell{margin-left:calc(min(64px, var(--rail-width)) + 24px)}
  .sidebar{left:0;top:0;bottom:0;border-radius:0}
  .sidebar.rail-expanded{width:min(220px, var(--rail-width))}
  .sidebar.rail-docked,.sidebar.rail-compact{width:min(64px, var(--rail-width))}
  .sidebar .nav-label,.sidebar .rail-control-label,.sidebar .brand-mini > div,.version-chip{display:none !important}
  .sidebar .nav-item{justify-content:center;padding:12px 8px}
  .sidebar .nav-icon{margin-right:0}
  .topbar h1{font-size:1.2rem}
  .table-actions{gap:8px}
  .table-actions button,.table-actions .button-link{flex:1 1 140px}
  .three-col-grid{grid-template-columns:1fr}
  .quill-assistant-panel{left:12px;right:12px;bottom:12px;width:auto}
}

@media (max-width:760px){
  body{overflow:hidden;overscroll-behavior:none}
  .app-shell,.main-shell,.page-content,.dashboard-container,.dashboard-grid{min-width:0;max-width:100vw}
  .main-shell{margin-left:60px;height:100dvh}
  body.rail-pinned-expanded .main-shell,
  body.rail-pinned-docked .main-shell{margin-left:60px}
  .sidebar.rail-docked,.sidebar.rail-compact,.sidebar{width:56px}
  .sidebar.rail-expanded{width:min(78vw,280px)}
  .sidebar-header{padding:10px 7px 6px}
  .brand-mini{justify-content:center}
  .brand-mini img{width:34px;height:34px;border-radius:9px}
  .rail-identity-row{grid-template-columns:1fr;margin-top:7px}
  .rail-identity{grid-template-columns:1fr;justify-items:center;padding:6px 4px}
  .rail-profile-menu-btn{min-height:34px}
  .sidebar.rail-docked .rail-identity-copy,
  .sidebar.rail-compact .rail-identity-copy{display:none}
  .sidebar .nav-item{min-height:42px;padding:9px 6px}
  .rail-controls{gap:6px;padding:8px 7px 6px}
  .rail-controls .rail-btn{min-height:40px;justify-content:center;padding:8px 6px;font-size:13px}
  .topbar{padding:9px 10px;gap:8px;align-items:flex-start}
  .topbar h1{font-size:17px;line-height:1.15}
  .topbar-actions{gap:6px;justify-content:flex-end}
  .topbar-actions button{padding:7px 8px;font-size:11px;line-height:1.15;max-width:118px;white-space:normal}
  .saved-state{min-width:0;font-size:11px}
  .page-content{overflow:auto;max-width:calc(100vw - 60px)}
  .dashboard-grid:not(.editing):not(.single-card-focus){display:flex;flex-direction:column;gap:12px;align-items:stretch;padding:12px;overflow-x:hidden;overflow-y:auto;height:auto;min-height:100%}
  .dashboard-grid:not(.editing):not(.single-card-focus) .workspace-label{position:relative;left:auto;top:auto;margin-bottom:0}
  .dashboard-grid:not(.editing):not(.single-card-focus) .widget{position:relative !important;left:auto !important;top:auto !important;width:100% !important;max-width:100% !important;height:auto !important;min-width:0;min-height:220px}
  .dashboard-grid:not(.editing):not(.single-card-focus) .widget-body{max-height:none;overflow:auto}
  .dashboard-grid.editing .widget{max-width:calc(100vw - 84px);min-width:min(220px, calc(100vw - 84px))}
  .workspace-nav-dock{right:8px;bottom:8px;gap:5px;padding:7px 8px;transform:scale(.86);transform-origin:bottom right}
  .launcher-page{padding:14px;min-height:100dvh}
  .launcher-shell{display:grid;grid-template-columns:1fr;gap:14px;min-height:auto}
  .launcher-main{order:1;padding:20px;border-radius:22px}
  .launcher-app-list{order:2;padding:16px;border-radius:22px}
  .launcher-logo-frame{width:92px;height:92px;border-radius:22px;margin-bottom:12px}
  .launcher-logo-frame img{max-width:74px;max-height:74px}
  .launcher-main h1{font-size:clamp(26px,8vw,34px);line-height:1.05;margin:6px 0 8px}
  .launcher-selected-app{min-height:0;padding:14px;border-radius:18px}
  .launcher-selected-head{display:grid;grid-template-columns:1fr;gap:10px}
  .launcher-selected-app h2{font-size:24px}
  .launcher-selected-app h3{font-size:16px}
  .launcher-open-btn{width:100%;min-width:0;min-height:50px;align-self:stretch;font-size:16px}
  .launcher-card-stack{gap:8px;margin-top:12px}
  .launcher-app-card{padding:12px 13px;border-radius:15px}
  .launcher-app-name{font-size:15px}
  .launcher-app-copy{font-size:12px}
}


.rail-section{display:flex;flex-direction:column;gap:6px}
.rail-search-wrap{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:6px;margin:0 0 8px}
.rail-search-input{min-width:0}
.rail-search-clear{padding:8px 10px}
.sidebar.rail-docked .rail-search-wrap,
.sidebar.rail-compact .rail-search-wrap{display:none}
.rail-section.experimental,.rail-section.highlight{padding:8px;border:1px solid rgba(255,184,77,.28);border-radius:16px;background:linear-gradient(180deg,rgba(255,184,77,.10),rgba(255,255,255,.03))}
.rail-section.new{padding:8px;border:1px solid rgba(79,179,217,.36);border-radius:16px;background:linear-gradient(180deg,rgba(79,179,217,.12),rgba(255,255,255,.03))}
.rail-section.updated{padding:8px;border:1px solid rgba(96,211,177,.32);border-radius:16px;background:linear-gradient(180deg,rgba(96,211,177,.10),rgba(255,255,255,.03))}
.rail-section.rail-section-hidden{opacity:.58;border-style:dashed}
.rail-section-row{display:grid;grid-template-columns:1fr auto;gap:6px;align-items:center}
.rail-page-btn{padding:12px;border-radius:12px;color:var(--rail-nav-text)}
.rail-page-copy{display:flex;flex-direction:column;align-items:flex-start;gap:2px;min-width:0;flex:1}
.rail-page-title-row{display:flex;align-items:center;gap:4px;min-width:0;max-width:100%}
.rail-page-title-row .nav-label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rail-page-target{font-size:11px;line-height:1.15;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.rail-page-expander{display:inline-flex;align-items:center;justify-content:center;width:31px;height:31px;padding:0;border-radius:10px;border:1px solid var(--border);background:rgba(255,255,255,.04);color:var(--text);cursor:pointer}
.rail-page-expander:hover{background:rgba(255,255,255,.1)}
.rail-page-caret{display:inline-flex;align-items:center;justify-content:center;min-width:14px;margin:0;color:var(--muted);font-size:14px;line-height:1;pointer-events:none}
.rail-page-expander .rail-page-caret,.rail-page-btn.active + .rail-row-actions .rail-page-caret{color:var(--text)}
.rail-section-uptrace{padding:8px;border-radius:16px;border:1px solid color-mix(in srgb,var(--accent) 38%,var(--border));background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 12%,transparent),rgba(255,255,255,.02))}
.rail-page-btn-uptrace{border-color:color-mix(in srgb,var(--accent) 68%,white 10%);background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 30%,transparent),color-mix(in srgb,var(--accent) 16%,transparent));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--accent) 36%,transparent)}
.rail-page-tag,.rail-function-tag{display:inline-flex;align-items:center;justify-content:center;padding:1px 6px;border-radius:999px;background:rgba(255,184,77,.18);border:1px solid rgba(255,184,77,.35);color:#ffd58a;font-size:9.5px;font-weight:700;letter-spacing:.02em;text-transform:uppercase;flex:0 0 auto}
.rail-page-tag-new,.rail-function-tag-new{background:rgba(79,179,217,.18);border-color:rgba(79,179,217,.38);color:#a7f3ff}
.rail-page-tag-updated,.rail-function-tag-updated{background:rgba(96,211,177,.16);border-color:rgba(96,211,177,.38);color:#b8ffe7}
.rail-page-tag{margin-left:0}
.rail-page-tag-action{cursor:pointer}
.rail-page-tag-action:hover{background:rgba(255,184,77,.28)}
.rail-page-tag-action:focus-visible{outline:2px solid color-mix(in srgb,var(--accent) 72%,white 16%);outline-offset:2px}
.rail-inline-menu{margin-left:auto;padding-left:8px;opacity:.75}
.rail-row-actions{display:inline-flex;align-items:center;gap:6px}
.rail-menu-btn{display:inline-flex;align-items:center;justify-content:center;width:31px;height:31px;padding:0;border-radius:11px;background:var(--rail-button-bg);color:var(--rail-button-text)}
.rail-nested{display:flex;flex-direction:column;gap:6px;padding:0 0 4px 10px;border-left:1px solid rgba(255,255,255,.08);margin-left:10px;overflow:hidden;max-height:900px;opacity:1;transform:translateY(0);transition:max-height .2s ease,opacity .18s ease,transform .18s ease}
.rail-nested.is-collapsed{max-height:0;opacity:0;transform:translateY(-4px);pointer-events:none;margin-bottom:0;padding-bottom:0}
.rail-mission-nav{display:grid;gap:6px;padding:8px;border:1px solid color-mix(in srgb,var(--accent) 26%,var(--border));border-radius:12px;background:color-mix(in srgb,var(--accent) 8%,transparent)}
.rail-mission-nav-list{display:flex;flex-wrap:wrap;gap:6px}
.rail-mission-nav-btn{border:1px solid var(--border);background:rgba(255,255,255,.04);color:var(--text);padding:6px 9px;border-radius:999px;font-size:11px;font-weight:700;cursor:pointer}
.rail-mission-nav-btn:hover{background:rgba(255,255,255,.1)}
.rail-mission-nav-btn.active{border-color:color-mix(in srgb,var(--accent) 64%,white 10%);background:color-mix(in srgb,var(--accent) 18%,transparent)}
.rail-subcategory-controls{display:flex;align-items:center;justify-content:flex-start}
.rail-subcategory-control-btn{padding:6px 10px;border-radius:10px;border:1px solid var(--border);background:rgba(255,255,255,.04);color:var(--text);font-size:11px;font-weight:700}
.rail-subcategory-control-btn:hover{background:rgba(255,255,255,.1)}
.rail-subcategory-control-btn.active{border-color:color-mix(in srgb,var(--accent) 62%,white 10%);background:color-mix(in srgb,var(--accent) 14%,transparent)}
.rail-subcategory-row{display:grid;gap:4px;position:relative;padding-left:8px}
.rail-subcategory-row.expanded::before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:1px;background:color-mix(in srgb,var(--accent) 36%,rgba(255,255,255,.16))}
.rail-subcategory-row.rail-subcategory-uptrace::before{width:2px;background:color-mix(in srgb,var(--accent) 74%,white 8%)}
.rail-subcategory-head{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:4px;align-items:center}
.rail-subcategory-btn{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;padding:7px 9px;border-radius:10px;border:1px solid color-mix(in srgb,var(--accent) 26%,var(--border));background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 10%,transparent),rgba(255,255,255,.03));color:var(--muted);font-size:11px;font-weight:700;text-align:left;cursor:pointer}
.rail-subcategory-btn:hover{background:rgba(255,255,255,.08);color:var(--text)}
.rail-subcategory-btn.active{border-color:color-mix(in srgb,var(--accent) 62%,white 10%);background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--text)}
.rail-subcategory-btn-uptrace{border-color:color-mix(in srgb,var(--accent) 72%,white 12%);background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 24%,transparent),color-mix(in srgb,var(--accent) 12%,transparent));color:var(--text)}
.rail-subcategory-highlight .rail-subcategory-btn{border-color:rgba(96,211,177,.32);background:linear-gradient(180deg,rgba(96,211,177,.10),rgba(255,255,255,.03))}
.rail-subcategory-label{display:inline-flex;align-items:center;gap:6px;min-width:0}
.rail-subcategory-label::before{content:"◧";display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:4px;background:color-mix(in srgb,var(--accent) 22%,transparent);color:color-mix(in srgb,var(--accent) 72%,white 12%);font-size:10px;line-height:1}
.rail-subcategory-menu-btn{display:inline-flex;align-items:center;justify-content:center;width:29px;height:29px;padding:0;border-radius:9px;border:1px solid var(--border);background:rgba(255,255,255,.04);color:var(--text);cursor:pointer}
.rail-subcategory-menu-btn:hover{background:rgba(255,255,255,.1)}
.rail-subcategory-expander{display:inline-flex;align-items:center;justify-content:center;width:29px;height:29px;padding:0;border-radius:9px;border:1px solid var(--border);background:rgba(255,255,255,.04);color:var(--text);cursor:pointer}
.rail-subcategory-expander:hover{background:rgba(255,255,255,.1)}
.rail-subcategory-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:20px;padding:0 7px;border-radius:999px;border:1px solid rgba(79,179,217,.32);font-size:11px;color:var(--muted)}
.rail-subcategory-btn.active .rail-subcategory-count{color:var(--text);border-color:color-mix(in srgb,var(--accent) 58%,white 12%)}
.rail-subcategory-cards{display:grid;gap:4px;padding-left:10px}
.rail-subcategory-cards.hidden{display:none}
.mission-set-placeholder-card{display:grid;justify-items:start;gap:10px;min-height:220px}
.mission-set-placeholder-radar{display:inline-flex;align-items:center;justify-content:center;width:58px;height:58px;border-radius:999px;border:1px solid rgba(79,179,217,.35);background:rgba(79,179,217,.08)}
.rail-function-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:4px;align-items:center;position:relative}
.rail-function-row-hidden{opacity:.78}
.rail-function{display:flex;align-items:center;gap:7px;width:100%;padding:7px 9px;border-radius:10px;border:1px dashed rgba(255,255,255,.08);background:rgba(255,255,255,.025);color:var(--text);cursor:pointer;font-size:12px;text-align:left}
.rail-function:hover{background:rgba(255,255,255,.08);border-color:rgba(79,179,217,.28)}
.rail-function.in-workspace{border-style:solid;border-color:rgba(79,179,217,.22)}
.rail-function-focused{border-style:solid;border-color:color-mix(in srgb,var(--accent) 72%,white 8%);background:color-mix(in srgb,var(--accent) 16%,transparent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 18%,transparent)}
.rail-function-uptrace{border-style:solid;border-color:color-mix(in srgb,var(--accent) 82%,white 12%);background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 36%,transparent),color-mix(in srgb,var(--accent) 20%,transparent));box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 24%,transparent)}
.rail-function-hidden{opacity:.72;border-style:solid;border-color:rgba(255,255,255,.1)}
.rail-function-experimental,.rail-function-highlight{border-color:rgba(255,184,77,.26);background:rgba(255,184,77,.08)}
.rail-function-new{border-color:rgba(79,179,217,.28);background:rgba(79,179,217,.08)}
.rail-function-updated{border-color:rgba(96,211,177,.28);background:rgba(96,211,177,.08)}
.rail-visibility-btn{min-width:47px;padding:7px 9px;border-radius:10px;background:rgba(255,255,255,.05);font-size:12px}
.experimental-note{border-color:rgba(255,184,77,.24);background:rgba(255,184,77,.08)}
.rail-section.dragging{opacity:.55}
.rail-subcategory-row.dragging{opacity:.58}
.rail-function.dragging{opacity:.58}
.rail-add-workspace{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;margin-top:10px;padding:12px;border-radius:14px;border:1px dashed rgba(79,179,217,.35);background:rgba(255,255,255,.04);color:var(--text)}
.rail-add-workspace-icon{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:999px;border:1px solid rgba(79,179,217,.35)}
.rail-function-dot{opacity:.75}
.rail-function-label{flex:1;min-width:0}
.rail-function-state{font-size:11px;color:var(--muted)}
.rail-function-menu-btn{display:inline-flex;align-items:center;justify-content:center;width:29px;height:29px;border:1px solid var(--border);background:rgba(255,255,255,.04);color:var(--text);border-radius:9px;padding:0;cursor:pointer}
.rail-function-menu-btn:hover{background:rgba(255,255,255,.08)}
.rail-density-comfortable .rail-menu-btn{width:34px;height:34px;border-radius:12px}
.rail-density-comfortable .rail-subcategory-menu-btn{width:34px;height:34px}
.rail-density-comfortable .rail-visibility-btn{min-width:52px;padding:8px 10px}
.rail-density-comfortable .rail-function-menu-btn{width:34px;height:34px}
.rail-function-menu{min-width:180px;z-index:3200}
.rail-function-menu .widget-menu-title{font-size:10px;padding:3px 2px 1px}
.rail-function-menu button{font-size:11px;padding:5px 7px}
.rail-floating-menu{box-shadow:0 20px 44px rgba(0,0,0,.42), var(--shadow)}
.rail-floating-menu-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:7px 8px;margin:-8px -8px 6px -8px;border-bottom:1px solid var(--border);background:linear-gradient(90deg,color-mix(in srgb,var(--surface) 84%,var(--accent) 16%),color-mix(in srgb,var(--surface-2) 86%,var(--secondary) 14%));cursor:move;border-radius:12px 12px 0 0}
.rail-floating-menu-title{font-size:11px;font-weight:800;letter-spacing:.03em;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:230px}
.rail-floating-menu-header .rail-floating-menu-close{display:inline-flex;align-items:center;justify-content:center;width:22px !important;min-width:22px;max-width:22px;height:22px;border-radius:8px;border:1px solid var(--border);background:rgba(255,255,255,.06);color:var(--text);padding:0;cursor:pointer;flex:0 0 22px}
.rail-floating-menu-close:hover{background:rgba(255,255,255,.14)}
.rail-function-menu.menu-open-up{top:auto;bottom:calc(100% + 4px)}
.sidebar.rail-docked .rail-nested,.sidebar.rail-compact .rail-nested{display:none}
.sidebar.rail-docked .rail-row-actions,.sidebar.rail-compact .rail-row-actions{display:none}
.sidebar.rail-docked .rail-section-row,.sidebar.rail-compact .rail-section-row{grid-template-columns:1fr}
.sidebar.rail-docked .rail-page-btn,.sidebar.rail-compact .rail-page-btn{justify-content:center;padding:12px 0}
.sidebar.rail-docked .rail-page-btn .rail-page-copy,.sidebar.rail-compact .rail-page-btn .rail-page-copy,.sidebar.rail-docked .rail-page-btn .rail-page-caret,.sidebar.rail-compact .rail-page-btn .rail-page-caret,.sidebar.rail-docked .rail-page-btn .rail-page-tag,.sidebar.rail-compact .rail-page-btn .rail-page-tag{display:none}
.sidebar.rail-docked .rail-page-btn .nav-label,.sidebar.rail-compact .rail-page-btn .nav-label{display:none}
  .sidebar.rail-docked .rail-page-btn .badge,.sidebar.rail-compact .rail-page-btn .badge{display:none !important}

/* Public/auth surfaces own the whole viewport. Keep this late so responsive
   shell rules cannot leave invisible Control Rail chrome intercepting clicks. */
body.home-chrome-hidden .sidebar,
body.home-chrome-hidden .topbar,
body.home-chrome-hidden .app-footer,
body.home-chrome-hidden .focus-rail-tab{
  display:none !important;
  visibility:hidden !important;
  pointer-events:none !important;
}
body.home-chrome-hidden .main-shell{
  margin-left:0 !important;
  width:100vw !important;
  max-width:100vw !important;
}
body.home-chrome-hidden .page-content{
  width:100vw !important;
  max-width:100vw !important;
}
.workspace-drop-target{outline:2px dashed rgba(79,179,217,.55);outline-offset:-8px}
.notice.compact{padding:8px 10px;font-size:12px}
.edit-mode .rail-function{cursor:grab}
.edit-mode .rail-function:active{cursor:grabbing}

.experimental-widget-shell{display:flex;flex-direction:column;gap:12px}
.experimental-widget-badge{display:inline-flex;align-items:center;justify-content:center;align-self:flex-start;padding:4px 10px;border-radius:999px;background:rgba(255,184,77,.18);border:1px solid rgba(255,184,77,.35);color:#ffd58a;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.experimental-lanes{align-items:start}
.sam-status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;align-items:start}
.sam-mini-card{min-height:0;padding:12px 14px}
.sam-profile-table td strong{font-size:13px}
.sam-link-list{display:flex;flex-wrap:wrap;gap:8px}
.two-col-check-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.check-row{display:flex;align-items:center;gap:8px;margin:8px 0;font-size:13px;color:var(--text)}


.settings-page .section-grid{align-items:start}
.appearance-studio-card{padding:16px 18px}
.appearance-studio-header{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;flex-wrap:wrap;margin-bottom:14px}
.appearance-studio-board{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;align-items:start}
.appearance-group{position:relative;border:1px solid var(--border);border-radius:18px;padding:16px;background:linear-gradient(180deg,var(--surface),rgba(255,255,255,.03));box-shadow:var(--shadow);min-height:120px}
.appearance-group.dragging{opacity:.6;outline:2px dashed rgba(79,179,217,.45)}
.appearance-group-handle{position:absolute;top:10px;right:12px;color:var(--muted);cursor:grab;user-select:none}
.appearance-group h4{margin:0 0 12px}
.appearance-presets{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}
.appearance-preset-btn{display:flex;flex-direction:column;align-items:flex-start;gap:8px;padding:10px 12px;border-radius:16px;text-align:left;min-height:72px}
.appearance-preset-swatches{display:flex;gap:6px;flex-wrap:wrap}
.appearance-preset-swatches span{width:18px;height:18px;border-radius:999px;border:1px solid rgba(255,255,255,.18)}
.appearance-inline-toggle{display:flex;align-items:center;gap:8px;margin-top:10px}
.color-control-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}
.color-preview-row{display:grid;grid-template-columns:44px minmax(92px,.75fr) minmax(120px,1fr) auto;gap:8px;align-items:center}
.color-swatch-button{display:inline-flex;align-items:center;justify-content:center;width:44px;height:40px;border-radius:12px;border:1px solid var(--border);background:rgba(255,255,255,.05);cursor:pointer}
.color-swatch-button:hover{background:rgba(255,255,255,.08)}
.color-swatch{width:22px;height:22px;border-radius:8px;border:1px solid rgba(255,255,255,.25)}
.color-hex-input,.color-rgb-input{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace;font-size:12px}
.minimal-icon-btn{white-space:nowrap}
.help-dot{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:999px;border:1px solid var(--border);font-size:12px;color:var(--muted);cursor:help;background:rgba(255,255,255,.04)}
.sr-only-color-input{position:absolute !important;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap}
.advanced-color-card{max-width:860px}
.advanced-color-top{display:grid;grid-template-columns:minmax(240px,300px) 1fr;gap:16px;align-items:start}
.advanced-color-live{display:flex;flex-direction:column;gap:12px}
.advanced-color-preview{height:160px}
.advanced-spectrum-input{width:100%;height:56px;border:none;background:transparent;padding:0;cursor:pointer}
.advanced-spectrum-input::-webkit-color-swatch-wrapper{padding:0}
.advanced-spectrum-input::-webkit-color-swatch{border:none;border-radius:14px}
.advanced-spectrum-input::-moz-color-swatch{border:none;border-radius:14px}
@media (max-width:900px){
  .appearance-studio-board{grid-template-columns:1fr}
  .advanced-color-top{grid-template-columns:1fr}
  .color-preview-row{grid-template-columns:44px 1fr 1fr}
  .color-preview-row .minimal-icon-btn{grid-column:2 / -1}
  .two-col-check-grid{grid-template-columns:1fr}
}

.settings-widget-board{grid-template-columns:1fr;gap:12px}
.settings-widget-board .appearance-group{min-height:0}

/* Final mobile shell overrides live at the end so they win over the older
   floating command-rail rules above. Phone users get a narrow rail plus a
   stacked workspace instead of a desktop canvas squeezed into the viewport. */
@media (max-width:760px){
  html,body{overflow:hidden;max-width:100vw}
  .main-shell{margin-left:58px !important;height:100dvh;max-width:calc(100vw - 58px);overflow:hidden}
  .sidebar{left:0;top:0;bottom:0;width:54px !important;border-radius:0 16px 16px 0}
  .sidebar.rail-expanded{width:min(54vw,210px) !important}
  .sidebar.rail-expanded + .main-shell,
  body.rail-pinned-expanded .main-shell{margin-left:58px !important}
  .sidebar.rail-expanded .brand-mini{justify-content:flex-start}
  .sidebar.rail-expanded .brand-mini > div,
  .sidebar.rail-expanded .rail-identity-copy,
  .sidebar.rail-expanded .nav-label,
  .sidebar.rail-expanded .rail-control-label{display:block !important}
  .sidebar.rail-expanded .version-chip{display:block !important}
  .sidebar.rail-expanded .nav-item,
  .sidebar.rail-expanded .rail-controls .rail-btn{justify-content:flex-start}
  .rail-section-row{grid-template-columns:minmax(0,1fr) auto}
  .rail-function-row{grid-template-columns:minmax(0,1fr) auto}
  .rail-function-menu-btn{min-width:34px}
  .sidebar.rail-docked .profile-menu,
  .sidebar.rail-compact .profile-menu,
  .profile-menu{left:calc(100% + 8px);right:auto;top:0;width:min(280px, calc(100vw - 72px))}
  .page-content{max-width:calc(100vw - 58px);overflow:auto;touch-action:pan-x pan-y pinch-zoom}
  .dashboard-grid:not(.editing):not(.single-card-focus){display:flex;flex-direction:column;gap:12px;align-items:stretch;width:100%;max-width:100%;padding:10px;overflow-x:hidden;overflow-y:auto}
  .dashboard-grid:not(.editing):not(.single-card-focus) .widget{position:relative !important;left:auto !important;top:auto !important;width:100% !important;max-width:100% !important;height:auto !important;min-width:0}
  .widget,.widget-body,.card,.callout,.notice{min-width:0;max-width:100%}
  .widget-body{overflow-x:auto}
  .kanban-add-task{grid-template-columns:1fr}
  .kanban-add-task button{width:100%}
  .kanban-add-task-expanded{grid-template-columns:1fr}
  .kanban-grid-shell{max-height:min(68vh,600px)}
  .calendar-week-head{font-size:11px}
  .calendar-day{min-height:96px}
  .table-actions{display:grid;grid-template-columns:1fr;gap:8px}
  .table-actions button,.table-actions .button-link,.govcon-actions button{width:100%;min-width:0}
  .control-input,input[type="file"],select,textarea{min-width:0;max-width:100%}
  .upload-age-badge{max-width:100%;white-space:normal;font-size:15px;line-height:1.15}
  .table-list{display:block;max-width:100%;overflow-x:auto}
  .home-landing-shell,.home-dashboard-grid,.home-hero-card,.home-feature-strip,.home-spotlight-stack,.home-spotlight-panel{max-width:100%;overflow:hidden}
  .home-hero-card{padding:22px 20px}
  .home-hero-card h1{font-size:clamp(34px,11vw,54px);line-height:1.04}
  .home-hero-actions{display:grid;grid-template-columns:1fr;gap:10px}
  .home-hero-actions button{width:100%}
  .topbar{max-width:100%;height:auto !important;min-height:76px;overflow:visible;align-items:flex-start}
  .topbar-left{min-width:0}
  .topbar-actions{max-width:100%;overflow-x:auto;justify-content:flex-start}
  .topbar-actions button{max-width:none;flex:0 0 auto}
  #saveLayoutBtn{display:inline-flex}
  .tour-help-menu{left:8px !important;right:8px !important;top:72px !important;max-width:calc(100vw - 16px);min-width:0}
  .workspace-nav-dock{right:6px;bottom:6px;max-width:calc(100vw - 74px);overflow:auto}
}

/* Mobile usability pass.
   Keep this last: the shell had older mobile rules plus final overrides, so this block is
   intentionally specific and late. Quill owns these constraints because every app should
   inherit the same phone behavior instead of solving mobile layout card-by-card. */
@media (max-width:760px){
  body.home-landing-mode .main-shell{margin-left:0 !important;width:100vw !important;max-width:100vw !important}
  body.home-landing-mode .page-content{width:100vw !important;max-width:100vw !important;overflow-x:hidden !important}
  body.home-landing-mode .home-dashboard-grid{width:100% !important;max-width:100vw !important;padding:16px 10px 42px !important;box-sizing:border-box}
  body.home-landing-mode .home-landing-shell{width:100% !important;max-width:100% !important;margin:10px 0 0 !important;box-sizing:border-box}
  body.home-landing-mode .home-hero-card,
  body.home-landing-mode .home-spotlight-panel,
  body.home-landing-mode .home-feature-card,
  body.home-landing-mode .home-contact-card{width:100% !important;max-width:100% !important;box-sizing:border-box}
  body.home-landing-mode .feedback-link{left:calc(10px + env(safe-area-inset-left)) !important;right:auto !important;bottom:calc(10px + env(safe-area-inset-bottom)) !important;padding:8px 12px;font-size:12px;max-width:calc(100vw - 20px)}

  .main-shell{margin-left:50px !important;width:calc(100vw - 50px) !important;max-width:calc(100vw - 50px) !important}
  .sidebar{width:48px !important;border-radius:0 14px 14px 0;padding:8px 5px}
  .sidebar.rail-expanded{width:min(64vw,220px) !important}
  .sidebar.rail-expanded + .main-shell,
  body.rail-pinned-expanded .main-shell{margin-left:50px !important}
  .brand-mini img{width:34px;height:34px}
  .rail-avatar{width:34px;height:34px;font-size:15px}
  .rail-identity{gap:5px;padding:6px}
  .rail-profile-menu-btn{width:34px;height:34px}
  .nav-section,.rail-controls{gap:6px}
  .nav-item,.rail-page-btn,.rail-btn{min-height:38px;border-radius:13px;padding:6px 2px;gap:3px}
  body.rail-density-comfortable .nav-item,body.rail-density-comfortable .rail-page-btn,body.rail-density-comfortable .rail-btn{min-height:42px}
  .nav-icon{font-size:16px}
  .sidebar.rail-docked .rail-page-btn,
  .sidebar.rail-compact .rail-page-btn{display:flex;flex-direction:column;align-items:center;justify-content:center}
  .sidebar.rail-docked .rail-page-btn .nav-label,
  .sidebar.rail-compact .rail-page-btn .nav-label{display:block !important;max-width:42px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center;font-size:8.5px;line-height:1.05;color:var(--rail-nav-text)}
  .sidebar.rail-docked .rail-control-label,
  .sidebar.rail-compact .rail-control-label{display:none !important}

  .page-content{width:100% !important;max-width:100% !important;overflow:auto !important;-webkit-overflow-scrolling:touch;touch-action:pan-x pan-y pinch-zoom}
  .topbar{min-height:54px !important;padding:8px 10px !important;border-radius:0 0 18px 18px}
  .topbar h1{font-size:18px;line-height:1.1}
  .topbar-actions{gap:6px}
  .topbar-actions button,.tour-help-main{min-height:32px;padding:6px 9px;font-size:12px;border-radius:12px}
  .app-footer{min-height:48px !important;padding:6px 10px !important;border-radius:18px 18px 0 0}
  .app-footer img{max-height:24px}
  .app-footer-title,.app-footer-subtitle{font-size:12px}

  .dashboard-grid:not(.editing):not(.single-card-focus){padding:8px !important;gap:10px !important}
  .dashboard-grid:not(.editing):not(.single-card-focus) .widget{border-radius:18px !important}
  .widget-title-row{padding:10px 12px}
  .widget-title{font-size:18px;line-height:1.1}
  .widget-body{padding:10px 12px;overflow-x:auto !important;-webkit-overflow-scrolling:touch}
  .card,.callout,.notice{border-radius:14px;padding:10px 12px}
  .table-list,.opportunity-snapshot-grid-shell{max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .opportunity-snapshot-table{min-width:760px}
  .govcon-actions,.table-actions{grid-template-columns:1fr !important}
  .govcon-actions .button-link,.govcon-actions button,.table-actions button,.table-actions .button-link{min-height:36px;padding:8px 10px;font-size:13px}
  .control-input,input[type="file"],select,textarea{font-size:14px}
  .workspace-nav-dock{transform:scale(.88);transform-origin:bottom right}
}

.mobile-preview-widget{display:flex;flex-direction:column;gap:12px}
.mobile-preview-frame{display:grid;grid-template-columns:46px 1fr;gap:0;max-width:320px;min-height:430px;border:1px solid var(--border);border-radius:28px;overflow:hidden;background:linear-gradient(180deg,rgba(0,0,0,.28),rgba(255,255,255,.04));box-shadow:var(--shadow)}
.mobile-preview-rail{display:flex;flex-direction:column;align-items:center;gap:12px;padding:14px 6px;background:color-mix(in srgb,var(--rail) 88%,black 8%)}
.mobile-preview-rail span{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:12px;background:rgba(255,255,255,.08);color:var(--rail-nav-text)}
.mobile-preview-screen{display:flex;flex-direction:column;gap:9px;padding:10px;background:var(--workspace)}
.mobile-preview-header,.mobile-preview-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:34px;border-radius:14px;padding:7px 9px;background:var(--header-area);color:var(--header-text)}
.mobile-preview-header button{padding:4px 8px;border-radius:10px;font-size:11px}
.mobile-preview-card{border:1px solid var(--border);border-radius:16px;padding:10px;background:var(--widget);color:var(--text)}
.mobile-preview-card p{margin:6px 0 0;color:var(--muted);font-size:12px;line-height:1.35}
.mobile-preview-wide{box-shadow:inset -28px 0 22px -28px var(--accent)}

:root{
  --node-analysis-overlay-top:color-mix(in srgb,var(--accent) 22%,transparent);
  --node-analysis-overlay-bottom:color-mix(in srgb,var(--workspace-bg) 84%,var(--bg) 16%);
  --node-analysis-panel-bg:color-mix(in srgb,var(--surface) 88%,var(--workspace-bg) 12%);
  --node-analysis-edge-default:color-mix(in srgb,var(--muted) 68%,transparent);
  --node-analysis-edge-up:color-mix(in srgb,var(--secondary) 70%,#f59e0b 30%);
  --node-analysis-edge-down:color-mix(in srgb,var(--accent) 76%,#22d3ee 24%);
  --node-analysis-edge-active:color-mix(in srgb,var(--accent) 80%,white 14%);
  --node-analysis-edge-connected:color-mix(in srgb,var(--secondary) 66%,white 10%);
  --node-analysis-node-subject-border:color-mix(in srgb,var(--accent) 72%,white 10%);
  --node-analysis-node-workspace-border:color-mix(in srgb,var(--secondary) 60%,var(--border));
  --node-analysis-node-mission-border:color-mix(in srgb,var(--primary) 56%,var(--border));
  --node-analysis-node-card-border:color-mix(in srgb,var(--accent) 58%,var(--border));
  --node-analysis-node-instance-border:color-mix(in srgb,var(--muted) 62%,var(--border));
  --node-analysis-anchor-border:color-mix(in srgb,var(--accent) 66%,white 12%);
  --node-analysis-anchor-fill:color-mix(in srgb,var(--surface) 84%,var(--accent) 16%);
  --node-analysis-edge-label-fill:var(--text);
  --node-analysis-edge-label-stroke:rgba(0,0,0,.45);
}
body.theme-light{
  --node-analysis-overlay-top:color-mix(in srgb,var(--accent) 15%,transparent);
  --node-analysis-overlay-bottom:color-mix(in srgb,var(--workspace-bg) 93%,white 7%);
  --node-analysis-panel-bg:color-mix(in srgb,var(--surface) 94%,var(--workspace-bg) 6%);
  --node-analysis-edge-label-stroke:rgba(255,255,255,.9);
}

.node-analysis-overlay{position:fixed;inset:0;z-index:5000;background:radial-gradient(circle at 20% 10%,var(--node-analysis-overlay-top),transparent 46%),linear-gradient(180deg,var(--node-analysis-overlay-bottom),color-mix(in srgb,var(--node-analysis-overlay-bottom) 82%,black 18%));display:flex;flex-direction:column}
.node-analysis-overlay.hidden{display:none}
.node-analysis-shell{display:grid;grid-template-columns:minmax(300px,360px) minmax(0,1fr);height:100%;width:100%}
.node-analysis-sidebar{border-right:1px solid color-mix(in srgb,var(--accent) 35%,var(--border));background:var(--node-analysis-panel-bg);padding:14px;display:grid;grid-template-rows:auto auto auto auto minmax(140px,1fr) minmax(200px,1fr);gap:10px;overflow:auto}
.node-analysis-search-row{display:grid}
.node-analysis-search-row .control-input{height:34px}
.node-analysis-mode-row{display:grid;gap:6px}
.node-analysis-bpmn-controls{display:grid;grid-template-columns:1fr;gap:6px}
.node-analysis-bpmn-controls.hidden{display:none}
.node-analysis-view-row{position:relative;display:flex;align-items:center}
.node-analysis-view-row > button{min-height:34px}
#nodeAnalysisLayoutWrap .widget-menu{top:38px;bottom:auto;left:0;right:auto;min-width:180px}
.node-analysis-title-row h2{margin:0;font-size:18px;line-height:1.2}
.node-analysis-subject-label{margin-top:4px;font-size:12px;color:var(--muted)}
.node-analysis-toolbar{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.node-analysis-toolbar button{min-height:34px}
.node-analysis-toolbar .compact-btn{min-height:28px;padding:4px 8px;font-size:11px}
.node-analysis-snapshot-manager{border:1px solid var(--border);border-radius:12px;padding:8px;background:color-mix(in srgb,var(--surface-2) 66%,transparent);display:grid;gap:8px;max-height:28vh;overflow:auto}
.node-analysis-snapshot-manager.hidden{display:none}
.node-analysis-snapshot-head{display:flex;justify-content:space-between;align-items:center;gap:8px}
.node-analysis-snapshot-row{display:grid;gap:6px;border:1px solid color-mix(in srgb,var(--border) 86%,var(--accent) 14%);border-radius:10px;padding:7px}
.node-analysis-status{font-size:11px;line-height:1.35;padding:7px 9px;border:1px solid var(--border);border-radius:10px;background:color-mix(in srgb,var(--surface-2) 74%,transparent);color:var(--muted)}
.node-analysis-status.ok{border-color:color-mix(in srgb,var(--secondary) 55%,var(--border));color:color-mix(in srgb,var(--secondary) 70%,var(--text))}
.node-analysis-status.warn{border-color:color-mix(in srgb,var(--button) 55%,var(--border));color:color-mix(in srgb,var(--button) 72%,var(--text))}
.node-analysis-status.error{border-color:color-mix(in srgb,var(--danger) 65%,var(--border));color:color-mix(in srgb,var(--danger) 78%,var(--text))}
.node-analysis-layout-hint{font-size:11px;color:var(--muted);line-height:1.35;min-height:28px}
.node-analysis-summary{font-size:12px}
.node-analysis-summary-chips{display:flex;flex-wrap:wrap;gap:6px}
.node-analysis-summary-chip{padding:6px 9px;border-radius:999px;border:1px solid var(--border);background:color-mix(in srgb,var(--surface) 72%,transparent);color:var(--text);font-size:12px}
.node-analysis-summary-chip.active{border-color:color-mix(in srgb,var(--accent) 75%,white 8%);background:color-mix(in srgb,var(--accent) 25%,transparent)}
.node-analysis-inspector{border:1px solid var(--border);border-radius:14px;padding:10px;background:color-mix(in srgb,var(--surface-2) 70%,transparent);font-size:12px;line-height:1.45;overflow:auto;min-height:220px;max-height:38vh}
.node-analysis-inspector .notice.warning{color:var(--danger);font-weight:700}
.node-analysis-library-head{display:grid;grid-template-columns:1fr;gap:8px}
.node-analysis-library-panels{display:grid;gap:10px;min-height:0}
.node-analysis-list{display:grid;gap:6px;max-height:220px;overflow:auto;border:1px solid var(--border);border-radius:12px;padding:8px;background:color-mix(in srgb,var(--surface) 68%,transparent)}
.node-analysis-list-item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:7px 9px;border-radius:10px;border:1px solid color-mix(in srgb,var(--border) 88%,var(--accent) 12%);background:color-mix(in srgb,var(--surface-2) 72%,transparent);font-size:12px;text-align:left;color:var(--text)}
.node-analysis-list-item span{font-size:11px;color:var(--muted)}
.node-analysis-list-item.active{border-color:color-mix(in srgb,var(--accent) 70%,white 10%);background:color-mix(in srgb,var(--accent) 20%,transparent)}
.node-analysis-canvas-wrap{position:relative;overflow:hidden;cursor:grab;background:radial-gradient(circle at 42% 35%,color-mix(in srgb,var(--accent) 14%,transparent),transparent 44%),linear-gradient(180deg,color-mix(in srgb,var(--workspace-bg) 94%,transparent),color-mix(in srgb,var(--workspace-bg) 82%,transparent))}
.node-analysis-canvas-wrap:active{cursor:grabbing}
.node-analysis-selection-box{position:absolute;border:1px dashed color-mix(in srgb,var(--accent) 80%,white 10%);background:color-mix(in srgb,var(--accent) 24%,transparent);pointer-events:none;z-index:20}
.node-analysis-edges{position:absolute;inset:0;width:100%;height:100%;pointer-events:auto;overflow:visible;transform-origin:0 0}
.node-analysis-nodes{position:absolute;inset:0;transform-origin:0 0}
.node-analysis-node-wrap{position:absolute;transform:translate(-50%,-50%) scale(var(--node-analysis-node-scale,1));transform-origin:center center;display:grid;grid-template-columns:minmax(150px,230px) auto;align-items:start;gap:6px}
.node-analysis-node{position:relative;display:grid;gap:2px;min-width:150px;max-width:230px;text-align:left;padding:10px 11px;border-radius:12px;border:1px solid color-mix(in srgb,var(--accent) 26%,var(--border));background:color-mix(in srgb,var(--surface) 92%,var(--workspace-bg) 8%);color:var(--text);box-shadow:var(--shadow);cursor:grab}
.node-analysis-node:active{cursor:grabbing}
.node-analysis-offset-btn{padding:5px 7px;border-radius:9px;border:1px solid var(--border);background:color-mix(in srgb,var(--surface-2) 70%,transparent);font-size:11px;color:var(--text)}
.node-analysis-offset-btn.active{border-color:var(--node-analysis-edge-down);background:color-mix(in srgb,var(--node-analysis-edge-down) 22%,transparent)}
.node-analysis-anchor{position:absolute;width:9px;height:9px;border-radius:999px;border:1px solid var(--node-analysis-anchor-border);background:var(--node-analysis-anchor-fill);opacity:0;pointer-events:none}
.node-analysis-anchor.active{opacity:1;pointer-events:auto;box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 30%,transparent)}
.node-analysis-anchor-left{left:-5px;top:50%;transform:translateY(-50%)}
.node-analysis-anchor-right{right:-5px;top:50%;transform:translateY(-50%)}
.node-analysis-anchor-top{top:-5px;left:50%;transform:translateX(-50%)}
.node-analysis-anchor-bottom{bottom:-5px;left:50%;transform:translateX(-50%)}
.node-analysis-node-title{font-size:12px;font-weight:700;line-height:1.25}
.node-analysis-node-sub{font-size:11px;color:var(--muted)}
.node-analysis-node-subject{border-color:var(--node-analysis-node-subject-border);background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 20%,var(--surface) 80%),color-mix(in srgb,var(--surface) 92%,var(--workspace-bg) 8%));min-width:200px}
.node-analysis-node-workspace{border-color:var(--node-analysis-node-workspace-border)}
.node-analysis-node-mission{border-color:var(--node-analysis-node-mission-border)}
.node-analysis-node-card{border-color:var(--node-analysis-node-card-border)}
.node-analysis-node-instance{border-color:var(--node-analysis-node-instance-border)}
.node-analysis-node-active{box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 36%,transparent),0 14px 32px rgba(0,0,0,.32)}
.node-analysis-node-locked{border-style:dashed;box-shadow:0 0 0 2px color-mix(in srgb,var(--button) 30%,transparent),0 14px 32px rgba(0,0,0,.32)}
.node-analysis-edge-group{cursor:pointer}
.node-analysis-edge{stroke:var(--node-analysis-edge-default);stroke-width:1.7;fill:none}
.node-analysis-edge-hit{stroke:transparent;stroke-width:16;fill:none;pointer-events:stroke}
.node-analysis-edge-handle{fill:color-mix(in srgb,var(--surface) 60%,var(--accent) 40%);stroke:color-mix(in srgb,var(--accent) 84%,white 10%);stroke-width:1.2;opacity:.2;cursor:grab}
.node-analysis-edge-label{fill:var(--node-analysis-edge-label-fill);font-size:20px;font-weight:700;text-anchor:middle;paint-order:stroke;stroke:var(--node-analysis-edge-label-stroke);stroke-width:4px}
.node-analysis-edge-down .node-analysis-edge{stroke:var(--node-analysis-edge-down)}
.node-analysis-edge-up .node-analysis-edge{stroke:var(--node-analysis-edge-up)}
.node-analysis-edge-muted{opacity:.2}
.node-analysis-edge-group.node-analysis-edge-active .node-analysis-edge{stroke:var(--node-analysis-edge-active);stroke-width:2.5}
.node-analysis-edge-group.node-analysis-edge-active .node-analysis-edge-handle,.node-analysis-edge-group:hover .node-analysis-edge-handle{opacity:.96}
.node-analysis-edge-group.node-analysis-edge-connected .node-analysis-edge{stroke:var(--node-analysis-edge-connected);stroke-width:2.2;opacity:.95}
.node-analysis-edge-group.node-analysis-edge-connected .node-analysis-edge-handle{opacity:.82}
.node-analysis-node-muted{opacity:.3}
.node-analysis-node-connected .node-analysis-node{box-shadow:0 0 0 2px color-mix(in srgb,var(--secondary) 30%,transparent),var(--shadow)}
.node-analysis-nav-dock{right:18px;bottom:18px;z-index:33;opacity:1}
.node-analysis-legend-dock{left:18px;right:auto;bottom:18px;z-index:33;display:grid;gap:6px;justify-items:start}
.node-analysis-legend-panel{min-width:280px;max-width:min(420px,42vw);padding:8px;border-radius:12px;border:1px solid color-mix(in srgb,var(--accent) 30%,var(--border));background:color-mix(in srgb,var(--nav-tool-bg) 86%,transparent);box-shadow:var(--shadow);font-size:12px;line-height:1.35}
.node-analysis-legend-row{display:flex;align-items:center;gap:8px;padding:3px 2px}
.node-analysis-legend-sample{display:inline-block;min-width:22px;height:12px}
.node-analysis-legend-node{height:10px;min-width:18px;border-radius:8px;border:1px solid color-mix(in srgb,var(--accent) 60%,var(--border));background:color-mix(in srgb,var(--surface) 82%,var(--accent) 18%)}
.node-analysis-legend-link-down{height:2px;border-radius:2px;background:var(--node-analysis-edge-down)}
.node-analysis-legend-link-up{height:2px;border-radius:2px;background:var(--node-analysis-edge-up)}
.node-analysis-legend-anchor{min-width:10px;height:10px;border-radius:999px;border:1px solid color-mix(in srgb,var(--accent) 66%,white 12%);background:color-mix(in srgb,var(--surface) 84%,var(--accent) 16%)}
.node-analysis-legend-handle{min-width:12px;height:12px;border-radius:999px;border:1px solid color-mix(in srgb,var(--accent) 84%,white 10%);background:color-mix(in srgb,var(--surface) 60%,var(--accent) 40%)}
.node-analysis-color-drawer{position:absolute;right:-400px;top:14px;bottom:14px;width:min(360px,42vw);border:1px solid color-mix(in srgb,var(--accent) 32%,var(--border));background:color-mix(in srgb,var(--node-analysis-panel-bg) 92%,transparent);border-radius:14px;box-shadow:var(--shadow);padding:10px;overflow:auto;transition:right .2s ease;z-index:36}
.node-analysis-color-drawer.open{right:14px}
.node-analysis-step-builder{position:absolute;left:16px;top:16px;z-index:35;width:min(360px,42vw);border:1px solid color-mix(in srgb,var(--accent) 32%,var(--border));background:color-mix(in srgb,var(--node-analysis-panel-bg) 94%,transparent);border-radius:12px;box-shadow:var(--shadow);padding:10px;display:grid;gap:8px}
.node-analysis-step-builder.hidden{display:none}
.node-analysis-step-builder-head{display:flex;justify-content:space-between;align-items:center;gap:8px}
.node-analysis-color-drawer-head{display:flex;justify-content:space-between;align-items:center;gap:8px}
.node-analysis-color-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:8px}
.node-analysis-color-grid label{display:grid;gap:4px;font-size:11px}
.node-analysis-color-grid input[type="color"]{width:100%;height:34px;padding:0;border-radius:8px;border:1px solid var(--border);background:transparent}

@media (max-width:920px){
  .node-analysis-shell{grid-template-columns:1fr}
  .node-analysis-sidebar{max-height:42vh;border-right:none;border-bottom:1px solid color-mix(in srgb,var(--accent) 35%,var(--border))}
  .node-analysis-toolbar{grid-template-columns:repeat(2,minmax(0,1fr))}
  .node-analysis-legend-dock{left:8px;bottom:8px}
  .node-analysis-legend-panel{max-width:min(90vw,420px)}
  .node-analysis-color-drawer{width:min(88vw,360px);top:8px;bottom:8px}
  .node-analysis-color-drawer.open{right:8px}
  .node-analysis-step-builder{left:8px;right:8px;top:8px;width:auto;max-width:none}
}

/* Chrome compatibility pass: prevent rail text clipping/overflow and provide
   graceful fallback when advanced paint/filter features are unavailable. */
.sidebar-nav,.main-shell,.page-content,.dashboard-container,.dashboard-grid{min-width:0}
.rail-page-copy,.rail-function-label,.rail-subcategory-label{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  overflow-wrap:anywhere;
}
.rail-tools-menu{max-width:min(92vw,420px)}

@supports not (color: color-mix(in srgb, black 50%, white)) {
  .sidebar{background:linear-gradient(180deg,var(--surface),var(--surface-2))}
  .topbar{background:rgba(17,24,39,.92)}
  .widget{background:linear-gradient(180deg,var(--surface),rgba(255,255,255,.03))}
  .rail-page-expander{background:rgba(255,255,255,.04)}
  .rail-tools-menu .rail-btn.is-saving{background:rgba(79,179,217,.14)}
  .rail-tools-menu .rail-btn.is-saved{background:rgba(76,175,80,.14)}
  .rail-tools-menu .rail-btn.is-error{background:rgba(211,60,60,.14)}
}

@supports not ((-webkit-backdrop-filter: blur(2px)) or (backdrop-filter: blur(2px))) {
  .workspace-nav-dock,
  .feedback-dialog,
  .govcon-prefilter-rail,
  .restore-chrome-btn,
  .focus-rail-tab{
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
    background:rgba(10,18,30,.96);
  }
  .launcher-app-list,
  .launcher-main{
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
    background:linear-gradient(180deg,rgba(255,255,255,.1),rgba(255,255,255,.05));
  }
}

/* Mobile stabilization overrides.
   Keep this as the last mobile block so older viewport rules cannot fight it. */
@media (max-width:760px){
  html,body{width:100%;max-width:100vw;overflow:hidden}
  body{overscroll-behavior:none;-webkit-text-size-adjust:100%}
  .rail-divider-toggle{display:inline-flex}
  body.mobile-shell-compact .sidebar,
  body.mobile-shell-compact .main-shell{
    transform:scale(.8);
    transform-origin:top left;
  }
  /* Keep compact mode reachable: do not compensate width/height after scaling,
     otherwise UI controls drift off-screen on narrow mobile viewports. */
  body.mobile-shell-compact .sidebar{height:100dvh}
  body.mobile-shell-compact .main-shell{max-width:100% !important}
  body.mobile-shell-compact .page-content{overflow:auto !important}
  body.mobile-shell-compact .workspace-nav-dock{
    right:2px;
    bottom:2px;
    transform:scale(.8);
    transform-origin:bottom right;
    max-width:calc(100vw - 64px);
  }
  body.mobile-shell-compact .focus-rail-tab{
    left:0;
    transform:translateY(-50%) scale(.9);
    transform-origin:left center;
  }
  body.mobile-shell-compact .focus-exit-tab{
    right:4px;
    top:4px;
    transform:scale(.9);
    transform-origin:top right;
    max-width:45vw;
  }
  .app-shell{grid-template-columns:52px minmax(0,1fr);height:100dvh;max-width:100vw}
  .sidebar{width:52px !important;min-width:52px !important;padding:8px 5px 10px;border-radius:0 14px 14px 0}
  .sidebar.rail-expanded{width:min(80vw,280px) !important}
  .main-shell,
  body.rail-pinned-expanded .main-shell,
  body.rail-pinned-docked .main-shell{margin-left:0 !important;width:100% !important;max-width:100% !important;height:100dvh;overflow:hidden}
  .topbar{padding:8px 10px !important;align-items:flex-start;gap:8px;min-height:56px !important}
  .topbar-left,.topbar-actions{min-width:0}
  .topbar-actions{display:flex;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;max-width:100%;justify-content:flex-start}
  .topbar-actions::-webkit-scrollbar{height:0}
  .topbar-actions button{flex:0 0 auto;max-width:none}
  .page-content{width:100% !important;max-width:100% !important;overflow:auto !important;-webkit-overflow-scrolling:touch}
  .dashboard-container,.dashboard-grid{min-width:0;max-width:100%}
  .dashboard-grid:not(.editing):not(.single-card-focus){display:flex;flex-direction:column;gap:10px;padding:10px !important;overflow-x:hidden;overflow-y:auto}
  .dashboard-grid:not(.editing):not(.single-card-focus) .widget{position:relative !important;left:auto !important;top:auto !important;width:100% !important;max-width:100% !important;min-width:0 !important;height:auto !important}
  .widget,.widget-body,.table-list,.permission-grid-wrap,.opportunity-snapshot-grid-shell{max-width:100%;min-width:0}
  .widget-body,.table-list,.permission-grid-wrap,.opportunity-snapshot-grid-shell{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .table-actions,.govcon-actions{display:grid !important;grid-template-columns:1fr !important;gap:8px}
  .table-actions button,.table-actions .button-link,.govcon-actions button{width:100%;min-width:0}
  .control-input,input[type="file"],select,textarea{max-width:100%;min-width:0}
  .quill-assistant-panel{
    left:8px;
    right:8px;
    bottom:8px;
    top:auto;
    width:auto;
    min-width:0;
    min-height:0;
    max-width:calc(100vw - 16px);
    max-height:min(58dvh,420px);
    resize:none;
    overflow:hidden;
  }
  .quill-assistant-header{position:sticky;top:0;z-index:2}
  .quill-assistant-body{max-height:calc(min(58dvh,420px) - 56px);overflow:auto}
  .quill-assistant-history{height:clamp(120px,24dvh,190px)}

  /* Home mobile clipping fix:
     avoid right-edge crop from nested overflow:hidden plus parallax transforms. */
  body.home-landing-mode .home-dashboard-grid{
    overflow-x:visible !important;
    padding-inline:12px !important;
  }
  body.home-landing-mode .home-landing-shell{
    overflow:visible !important;
    min-width:0;
  }
  body.home-landing-mode .home-hero-card,
  body.home-landing-mode .home-feature-strip,
  body.home-landing-mode .home-parallax-card,
  body.home-landing-mode .home-spotlight-panel,
  body.home-landing-mode .home-about-section,
  body.home-landing-mode .home-about-box,
  body.home-landing-mode .home-contact-box{
    overflow:visible !important;
    width:100% !important;
    max-width:100% !important;
    min-width:0;
    box-sizing:border-box;
  }
  body.home-landing-mode .home-parallax-copy,
  body.home-landing-mode .home-parallax-art,
  body.home-landing-mode .home-hero-copy,
  body.home-landing-mode .home-hero-main-art{
    transform:none !important;
  }
  body.home-landing-mode .home-parallax-copy p,
  body.home-landing-mode .home-hero-lead{
    overflow-wrap:anywhere;
    word-break:normal;
  }
}
