:root{
  --bg:#eef8fb;
  --surface:#ffffff;
  --surface-2:#eaf6fa;
  --surface-3:#d5ebf2;
  --surface-4:#f7fcfe;
  --text:#0c2a36;
  --muted:#4b6d7c;
  --subtle:#7aa0ad;
  --border:#b8d8e4;
  --accent:#004c8f;
  --accent-2:#0092bc;
  --accent-neon:#00ffff;
  --accent-deep:#214780;
  --homes:#009ca8;
  --mobile:#84c0f5;
  --pymes:#d86055;
  --danger:#b42318;
  --warning:#b54708;
  --success:#067647;
  --shadow:0 18px 46px rgba(12,42,54,.18);
  --shadow-soft:0 8px 24px rgba(0,76,143,.10);
  --radius:8px;
}
*{box-sizing:border-box}
html{color-scheme:light}
body{
  margin:0;
  min-height:100vh;
  background:
    linear-gradient(180deg, rgba(0,76,143,.08), rgba(238,248,251,0) 360px),
    var(--bg);
  color:var(--text);
  font-family:Lexend,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  overflow-x:hidden;
  -webkit-tap-highlight-color:rgba(0,146,188,.16);
}
button,input,select,textarea{font:inherit}
button,a,input,select,textarea{outline-offset:3px;touch-action:manipulation}
button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid rgba(37,99,235,.45)}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
[hidden]{display:none!important}
.icon-sprite{position:absolute;width:0;height:0;overflow:hidden}
.icon-sprite symbol *,.btn-glyph,.btn-glyph *{fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}
.auth-shell{
  min-height:100vh;
  min-height:100dvh;
  display:grid;
  place-content:center;
  place-items:center;
  padding:24px;
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(158deg, #0c2a36 0%, #004c8f 48%, #0092bc 100%);
}
.auth-shell::before{
  content:"";
  position:absolute;
  inset:auto -8vw -28vh -8vw;
  height:44vh;
  background:
    radial-gradient(ellipse at 24% 52%, rgba(255,255,255,.52), rgba(255,255,255,0) 58%),
    radial-gradient(ellipse at 76% 45%, rgba(132,192,245,.32), rgba(255,255,255,0) 62%);
  opacity:.86;
}
.brand-wave{
  position:absolute;
  border:4px solid rgba(0,255,255,.72);
  border-left-color:transparent;
  border-bottom-color:transparent;
  border-radius:50%;
  pointer-events:none;
}
.wave-one{width:760px;height:360px;left:-140px;top:12vh;transform:rotate(-12deg)}
.wave-two{width:560px;height:260px;right:-120px;bottom:16vh;transform:rotate(162deg);border-color:rgba(255,255,255,.46);border-left-color:transparent;border-bottom-color:transparent}
.login-panel{
  width:min(650px,100%);
  background:rgba(255,255,255,.96);
  border:1px solid rgba(255,255,255,.78);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:34px 36px;
  display:grid;
  gap:22px;
  position:relative;
  z-index:1;
}
.brand-lockup{display:flex;align-items:center;justify-content:space-between;gap:28px}
.etb-logo{display:block;width:104px;height:auto}
.etb-logo-small{width:70px}
.brand-claim{
  color:var(--accent);
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
}
.eyebrow{
  display:block;
  color:var(--accent-2);
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  margin-bottom:5px;
}
.login-copy h1{
  color:var(--accent-deep);
  font-size:30px;
  line-height:1.12;
  max-width:560px;
  text-wrap:balance;
  margin:0 0 10px;
}
.login-copy p{font-size:14px;max-width:58ch}
.login-copy strong{color:var(--accent)}
.app-shell{
  min-height:100vh;
  display:grid;
  grid-template-rows:auto auto 1fr;
  min-width:0;
  overflow-x:clip;
  background:
    linear-gradient(180deg, rgba(0,76,143,.08), rgba(238,248,251,0) 320px),
    var(--bg);
}
.auth-message{margin:0;color:var(--muted);font-size:13px;line-height:1.45}
.auth-message.error{color:var(--danger);font-weight:700}
.topbar{
  background:linear-gradient(110deg, var(--accent-deep), var(--accent), var(--accent-2));
  border-bottom:1px solid rgba(255,255,255,.18);
  padding:16px max(24px,env(safe-area-inset-right)) 16px max(24px,env(safe-area-inset-left));
  display:flex;
  gap:16px;
  align-items:center;
  justify-content:space-between;
  color:#fff;
  position:relative;
  overflow:visible;
  z-index:20;
}
.topbar::after{
  content:"";
  position:absolute;
  width:min(420px,38vw);
  height:180px;
  right:24px;
  top:-68px;
  border:3px solid rgba(0,255,255,.42);
  border-left-color:transparent;
  border-bottom-color:transparent;
  border-radius:50%;
  transform:rotate(8deg);
}
.topbar-brand{display:flex;align-items:center;gap:14px;position:relative;z-index:1;min-width:0;flex:1 1 auto}
.topbar-brand .brand{min-width:0}
.topbar .brand p,.topbar .brand h1,.topbar .eyebrow{color:#fff}
.topbar .brand h1{
  max-width:100%;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.topbar .brand p{
  opacity:.78;
  max-width:62ch;
  display:-webkit-box;
  -webkit-line-clamp:2;
  line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.topbar-actions{position:relative;z-index:1}
.topbar .last-refresh{color:rgba(255,255,255,.86)}
.topbar .btn{border-color:rgba(255,255,255,.32);background:rgba(255,255,255,.12);color:#fff}
.topbar .btn:hover{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.6)}
.topbar .btn-primary{background:#fff;border-color:#fff;color:var(--accent)}
.topbar .btn-primary:hover{background:#e9fbff;border-color:#e9fbff}
.topbar-refresh-action{
  position:relative;
  display:inline-flex;
  align-items:center;
  flex:0 0 auto;
}
.topbar-refresh-action[hidden]{display:none}
.action-tooltip{
  position:absolute;
  z-index:45;
  inset:calc(100% + 9px) 0 auto auto;
  width:min(260px,calc(100vw - 32px));
  padding:8px 10px;
  border:1px solid rgba(142,205,221,.9);
  border-radius:var(--radius);
  background:#0c2a36;
  color:#fff;
  box-shadow:var(--shadow-soft);
  font-size:12px;
  line-height:1.35;
  font-weight:800;
  white-space:normal;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:translateY(3px);
  transition:opacity .14s ease,transform .14s ease,visibility .14s ease;
}
.action-tooltip::before{
  content:"";
  position:absolute;
  right:18px;
  bottom:100%;
  border:6px solid transparent;
  border-bottom-color:#0c2a36;
}
.topbar-refresh-action:hover .action-tooltip,
.topbar-refresh-action:focus-within .action-tooltip,
.action-tooltip:hover{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:translateY(0);
}
.topbar .status-dot{background:var(--accent-neon);box-shadow:0 0 0 5px rgba(0,255,255,.18)}
.topbar .etb-logo{filter:drop-shadow(0 1px 2px rgba(12,42,54,.18))}
.brand h1{font-size:18px;line-height:1.2;margin:0;font-weight:800}
.brand p{margin:4px 0 0;color:var(--muted);font-size:12px;line-height:1.45}
.topbar-actions{display:flex;align-items:center;gap:12px;flex:0 0 auto;flex-wrap:nowrap;justify-content:flex-end;min-width:0;position:relative}
.topbar-meta{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}
.status-dot{width:10px;height:10px;border-radius:50%;background:var(--success);box-shadow:0 0 0 5px rgba(6,118,71,.12)}
.last-refresh{color:var(--muted);font-size:12px;min-width:135px}
.user-badge{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto auto;
  align-items:center;
  gap:10px 12px;
  width:min(476px,42vw);
  min-width:0;
  border:1px solid rgba(255,255,255,.24);
  border-radius:var(--radius);
  background:rgba(255,255,255,.13);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18),0 8px 22px rgba(12,42,54,.12);
  padding:7px;
  color:#fff;
  backdrop-filter:saturate(130%) blur(6px);
}
.user-badge:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.36)}
.user-picture,.user-initials{
  width:36px;
  height:36px;
  border-radius:50%;
  border:2px solid rgba(255,255,255,.82);
  box-shadow:0 0 0 3px rgba(0,255,255,.14);
  background:linear-gradient(135deg,#e7fbff,#84c0f5);
}
.user-picture{object-fit:cover}
.user-initials{
  display:grid;
  place-items:center;
  color:var(--accent-deep);
  font-size:13px;
  font-weight:900;
}
.user-identity{display:grid;gap:2px;min-width:0;line-height:1.15}
.user-name,.user-email{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-name{font-size:13px;font-weight:900;color:#fff}
.user-email{font-size:11px;font-weight:700;color:rgba(255,255,255,.78)}
.user-options{
  align-self:stretch;
  min-height:34px;
  width:38px;
  padding:0;
}
.user-options[aria-expanded="true"]{
  background:rgba(255,255,255,.28);
  border-color:rgba(255,255,255,.66);
}
.user-options.status-ok{color:#dcfce7}
.user-options.status-warning{color:#fef3c7}
.user-options.status-error{color:#fee2e2}
.user-logout{
  align-self:stretch;
  min-height:34px;
  padding-inline:12px;
}
.btn{
  border:1px solid var(--border);
  background:var(--surface);
  color:var(--text);
  border-radius:var(--radius);
  padding:8px 13px;
  min-height:36px;
  cursor:pointer;
  font-weight:800;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  white-space:nowrap;
  transition:background-color .16s ease,border-color .16s ease,color .16s ease,box-shadow .16s ease,transform .16s ease;
}
.btn-glyph{width:16px;height:16px;flex:0 0 auto}
.btn:hover{border-color:#64bfd5;background:#f6fcff;box-shadow:0 6px 18px rgba(0,76,143,.12)}
.btn:active{transform:translateY(1px)}
.btn:disabled{opacity:.6;cursor:not-allowed}
.btn-primary{
  background:linear-gradient(135deg,var(--accent),var(--accent-deep));
  border-color:rgba(255,255,255,.2);
  color:white;
  box-shadow:0 10px 22px rgba(0,76,143,.18);
}
.btn-primary:hover{background:linear-gradient(135deg,var(--accent-deep),#0b3d73);border-color:rgba(255,255,255,.34);box-shadow:0 12px 26px rgba(0,76,143,.24)}
.btn-ghost{border-color:transparent;background:transparent;color:var(--muted)}
.btn-ghost:hover{background:#eaf8fc;color:var(--accent);box-shadow:none}
.btn-icon{width:36px;padding:0}
.btn-wide{width:100%}
.tabs{
  background:var(--surface);
  border-bottom:1px solid var(--border);
  padding:0 24px;
  display:flex;
  gap:6px;
  overflow-x:auto;
  scrollbar-width:thin;
}
.diagnostics-panel{
  position:absolute;
  z-index:35;
  inset:calc(100% + 8px) 0 auto auto;
  width:min(760px,calc(100vw - 32px));
  display:grid;
  gap:10px;
  padding:12px;
  border:1px solid rgba(184,216,228,.96);
  border-radius:var(--radius);
  background:rgba(255,255,255,.98);
  box-shadow:0 18px 46px rgba(12,42,54,.18);
  color:var(--text);
}
.diagnostics-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  min-width:0;
}
.diagnostics-summary{
  color:var(--text);
  font-size:12px;
  line-height:1.25;
  font-weight:900;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.diagnostics-refresh{width:26px;min-height:26px;flex:0 0 auto}
.diagnostics-items{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  align-items:stretch;
  justify-content:flex-start;
  gap:6px;
  min-width:0;
}
.diagnostic-chip{
  display:inline-flex;
  align-items:flex-start;
  gap:6px;
  border:1px solid var(--border);
  border-radius:8px;
  background:#fff;
  color:var(--muted);
  padding:6px 8px;
  font-size:10px;
  line-height:1.2;
  font-weight:900;
  max-width:100%;
  min-width:0;
}
.diagnostic-chip::before{
  content:"";
  width:6px;
  height:6px;
  border-radius:50%;
  background:var(--subtle);
  flex:0 0 auto;
  margin-top:3px;
}
.diagnostic-label{white-space:nowrap}
.diagnostic-message{
  min-width:0;
  overflow:visible;
  text-overflow:clip;
  white-space:normal;
  overflow-wrap:anywhere;
  font-weight:800;
  color:var(--subtle);
}
.diagnostic-ok{border-color:#abefc6;color:#067647;background:#ecfdf3}
.diagnostic-ok::before{background:#12b76a}
.diagnostic-error{border-color:#fecdca;color:#b42318;background:#fffbfa}
.diagnostic-error::before{background:#f04438}
.diagnostic-warning{border-color:#fedf89;color:#b54708;background:#fffaeb}
.diagnostic-warning::before{background:#f79009}
.diagnostic-skipped{border-color:#d0d5dd;color:#475467;background:#f9fafb}
.diagnostic-skipped::before{background:#98a2b3}
.tab{
  border:0;
  background:transparent;
  color:var(--muted);
  padding:13px 12px;
  cursor:pointer;
  font-weight:700;
  border-bottom:3px solid transparent;
  min-height:46px;
  white-space:nowrap;
  transition:color .16s ease,background-color .16s ease,border-color .16s ease;
}
.tab:hover{background:#f3fbfd;color:var(--accent)}
.tab[aria-selected="true"]{color:var(--accent);border-bottom-color:var(--accent-neon);background:#f8fdff}
main{min-width:0}
.view{display:none;padding:18px max(24px,env(safe-area-inset-right)) 24px max(24px,env(safe-area-inset-left))}
.view.active{display:block}
.board-toolbar{display:grid;grid-template-columns:minmax(260px,1fr) auto minmax(260px,360px);gap:14px;align-items:end;margin-bottom:16px}
.filters{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.board-column-toggle{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:38px;
  padding:8px 12px;
  border:1px solid var(--border);
  border-radius:999px;
  background:var(--surface);
  color:var(--text);
  font-size:12px;
  font-weight:800;
  white-space:nowrap;
  cursor:pointer;
  box-shadow:0 1px 2px rgba(16,24,40,.04);
}
.board-column-toggle:hover{border-color:#8ed8e4;background:#f5fcff}
.board-column-toggle:focus-within{outline:3px solid rgba(37,99,235,.35);outline-offset:3px}
.board-column-toggle input{width:16px;height:16px;accent-color:var(--accent)}
.field{display:grid;gap:6px;min-width:0;position:relative}
.field label,.field-label{font-size:12px;font-weight:700;color:var(--muted)}
.field-label-row{display:flex;align-items:center;gap:6px;min-width:0;position:relative;justify-self:start}
.tooltip-trigger{
  width:18px;
  height:18px;
  border:1px solid var(--border);
  border-radius:50%;
  background:var(--surface-4);
  color:var(--accent);
  display:inline-grid;
  place-items:center;
  padding:0;
  cursor:help;
  font-size:11px;
  line-height:1;
  font-weight:900;
}
.tooltip-trigger:hover,.tooltip-trigger:focus-visible{background:#e7fbff;border-color:#64bfd5}
.field-tooltip{
  position:absolute;
  z-index:30;
  inset:auto auto calc(100% + 8px) 0;
  width:min(280px,calc(100vw - 48px));
  padding:8px 10px;
  border:1px solid #8ecddd;
  border-radius:var(--radius);
  background:#0c2a36;
  color:#fff;
  box-shadow:var(--shadow-soft);
  font-size:12px;
  line-height:1.35;
  font-weight:700;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:translateY(3px);
  transition:opacity .14s ease,transform .14s ease,visibility .14s ease;
}
.field-tooltip::after{
  content:"";
  position:absolute;
  left:12px;
  top:100%;
  border:6px solid transparent;
  border-top-color:#0c2a36;
}
.tooltip-trigger:hover + .field-tooltip,
.tooltip-trigger:focus + .field-tooltip,
.field-tooltip:hover{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:translateY(0);
}
.observability-field-limit .field-tooltip,
.observability-actions .field-tooltip{
  inset:auto 0 calc(100% + 8px) auto;
}
.observability-field-limit .field-tooltip::after,
.observability-actions .field-tooltip::after{
  left:auto;
  right:12px;
}
.input,.select,.textarea{
  border:1px solid var(--border);
  background:var(--surface);
  color:var(--text);
  border-radius:var(--radius);
  padding:9px 10px;
  min-height:38px;
  width:100%;
  min-width:0;
  transition:border-color .16s ease,box-shadow .16s ease,background-color .16s ease;
}
.input:hover,.select:hover,.textarea:hover{border-color:#8ecddd}
.input:focus-visible,.select:focus-visible,.textarea:focus-visible{background:#fff;box-shadow:0 0 0 4px rgba(0,146,188,.12)}
.input[aria-invalid="true"],.select[aria-invalid="true"],.textarea[aria-invalid="true"],
.input:user-invalid,.select:user-invalid,.textarea:user-invalid{
  border-color:var(--danger);
  box-shadow:0 0 0 4px rgba(180,35,24,.12);
}
.input[required]:user-valid,.select[required]:user-valid,.textarea[required]:user-valid{
  border-color:#73d5a1;
}
.form-error{
  display:none;
  color:var(--danger);
  font-size:12px;
  font-weight:800;
  line-height:1.35;
}
.input[aria-invalid="true"] ~ .form-error,
.select[aria-invalid="true"] ~ .form-error,
.textarea[aria-invalid="true"] ~ .form-error,
.input:user-invalid ~ .form-error,
.select:user-invalid ~ .form-error,
.textarea:user-invalid ~ .form-error{
  display:block;
}
.field-hint{color:var(--muted);font-size:12px;font-weight:700;line-height:1.35}
.textarea{min-height:88px;resize:vertical}
.chip{
  border:1px solid var(--border);
  border-radius:999px;
  background:var(--surface);
  color:var(--muted);
  padding:7px 10px;
  cursor:pointer;
  font-size:13px;
  font-weight:700;
  display:inline-flex;
  align-items:center;
  gap:7px;
  min-height:34px;
  transition:background-color .16s ease,border-color .16s ease,color .16s ease,box-shadow .16s ease;
}
.chip .type-icon{color:var(--type-color,var(--accent));flex:0 0 16px}
.chip span{min-width:0}
.chip strong{
  color:var(--type-color,var(--accent));
  font-size:12px;
  line-height:1;
  font-weight:900;
}
.chip:hover{background:#f5fcff;border-color:var(--type-color,#8ed8e4);color:var(--accent)}
.chip.active{background:#e7fbff;color:var(--accent);border-color:var(--type-color,#63dce8);box-shadow:inset 0 0 0 1px rgba(0,146,188,.14)}
.wi-type-actividades-ambientes{--type-color:#e30613}
.wi-type-api-resource{--type-color:#0078d4}
.wi-type-bug{--type-color:#d13438}
.wi-type-codigo-seguro{--type-color:#f2c811}
.wi-type-entrega-fuentes{--type-color:#3498db}
.wi-type-epic{--type-color:#ff6a00}
.wi-type-feature{--type-color:#744da9}
.wi-type-gestion-demanda{--type-color:#2f8f46}
.wi-type-gestion-documento{--type-color:#7f6ad1}
.wi-type-gestion-paso-produccion{--type-color:#9b59b6}
.wi-type-impedimentos{--type-color:#e30613}
.wi-type-portafolio{--type-color:#e6007e}
.wi-type-product-backlog-item{--type-color:#0099bc}
.wi-type-puesta-en-produccion{--type-color:#b8a900}
.wi-type-refinamiento{--type-color:#242424}
.wi-type-risk{--type-color:#e30613}
.wi-type-solicitud-ambientes{--type-color:#2f8f46}
.wi-type-task{--type-color:#c39b00}
.wi-type-test-case{--type-color:#006272}
.wi-type-transicion{--type-color:#1b66b1}
.wi-type-wiki{--type-color:#45b8d8}
.wi-type-custom{--type-color:#667085}
.type-icon{
  width:16px;
  height:16px;
  color:var(--type-color,var(--accent));
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
  flex:0 0 auto;
}
.board{
  display:flex;
  gap:14px;
  overflow-x:auto;
  padding-bottom:18px;
  min-height:calc(100vh - 210px);
  scroll-snap-type:x proximity;
  scrollbar-color:#7aa0ad #d8edf4;
  scrollbar-width:auto;
  overscroll-behavior-x:contain;
  touch-action:pan-y;
  cursor:grab;
}
.board::-webkit-scrollbar{height:16px}
.board::-webkit-scrollbar-track{
  background:#d8edf4;
  border-radius:999px;
}
.board::-webkit-scrollbar-thumb{
  min-width:72px;
  border:3px solid #d8edf4;
  border-radius:999px;
  background:#7aa0ad;
}
.board::-webkit-scrollbar-thumb:hover{background:#4b6d7c}
.board.is-panning{
  cursor:grabbing;
  scroll-snap-type:none;
  user-select:none;
}
.board.is-panning *{cursor:grabbing!important}
.board:has(.work-card.dragging){
  cursor:default;
  scroll-snap-type:none;
}
.column{
  flex:0 0 310px;
  background:linear-gradient(180deg, var(--surface-4), var(--surface-2));
  border:1px solid var(--border);
  border-radius:var(--radius);
  display:flex;
  flex-direction:column;
  max-height:calc(100vh - 220px);
  scroll-snap-align:start;
  box-shadow:var(--shadow-soft);
}
@supports (content-visibility:auto){
  .column{
    content-visibility:auto;
    contain-intrinsic-size:auto 310px auto 680px;
  }
}
.column.drag-over{
  border-color:var(--accent-2);
  box-shadow:inset 0 0 0 2px rgba(0,146,188,.28),0 12px 28px rgba(0,76,143,.14);
  background:linear-gradient(180deg,#f0fcff,#def4fa);
}
.column.drop-compatible{
  border-color:#22d3ee;
  box-shadow:inset 0 0 0 2px rgba(34,211,238,.32),0 10px 28px rgba(0,146,188,.14);
}
.column.drop-compatible .column-header{
  background:linear-gradient(90deg,rgba(0,255,255,.18),rgba(255,255,255,.2));
}
.column.drop-current{
  border-color:#8ecddd;
  box-shadow:inset 0 0 0 2px rgba(142,205,221,.22);
}
.column.drop-incompatible{
  opacity:.56;
  filter:saturate(.72);
}
.column.drop-incompatible .column-body{
  pointer-events:none;
}
.column-header{padding:12px;display:flex;align-items:center;justify-content:space-between;gap:8px;border-bottom:1px solid var(--border)}
.column-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:800;min-width:0}
.column-title span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.state-mark{width:10px;height:10px;border-radius:50%;background:var(--accent)}
.count-pill{font-size:12px;font-weight:800;color:var(--muted);background:var(--surface);border:1px solid var(--border);padding:2px 8px;border-radius:999px}
.column-body{padding:10px;overflow:auto;display:grid;gap:10px;align-content:start}
.work-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:0 1px 2px rgba(16,24,40,.05);
  padding:12px;
  cursor:grab;
  display:grid;
  gap:10px;
  min-width:0;
  transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease;
}
.work-card:hover{border-color:#64bfd5;box-shadow:0 8px 22px rgba(0,76,143,.11);transform:translateY(-1px)}
.work-card:active{cursor:grabbing}
.work-card.dragging{opacity:.45;cursor:grabbing}
.card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.type-badge,.meta-badge,.relation-badge,.comment-badge{border-radius:999px;padding:3px 8px;font-size:11px;font-weight:800;line-height:1.35}
.type-badge{
  display:inline-flex;
  align-items:center;
  gap:5px;
  max-width:100%;
  background:color-mix(in srgb,var(--type-color,var(--accent)) 12%,#fff);
  color:var(--type-color,var(--accent));
}
.type-badge .type-icon{width:14px;height:14px;stroke-width:2.25}
.type-custom{background:#f2f4f7;color:#667085}
.item-id{font-size:12px;color:var(--muted);font-weight:800;white-space:nowrap}
.card-title{font-size:14px;line-height:1.35;font-weight:700;margin:0;overflow-wrap:anywhere}
.card-meta{display:flex;gap:6px;flex-wrap:wrap}
.meta-badge{background:var(--surface-2);color:var(--muted)}
.relation-badge{background:#f0f9ff;color:#026aa2}
.comment-badge,.table-comments{
  display:inline-flex;
  align-items:center;
  gap:5px;
  background:#eefaff;
  color:var(--accent);
}
.comment-badge .btn-glyph,.table-comments .btn-glyph{width:13px;height:13px}
.card-actions{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}
.card-action-buttons{display:flex;align-items:center;justify-content:flex-end;gap:6px;flex:0 0 auto}
.state-move-select{
  width:auto;
  min-width:92px;
  max-width:128px;
  min-height:34px;
  padding:6px 30px 6px 9px;
  font-size:12px;
  font-weight:800;
  color:var(--accent);
  background:#f7fcff;
}
.assignee{color:var(--muted);font-size:12px;min-width:0;flex:1 1 150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dashboard-grid{display:grid;gap:16px;min-width:0}
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,180px),1fr));gap:12px}
.dashboard-summary-toolbar{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  min-width:0;
  margin-top:-4px;
}
.dashboard-summary-toggle{
  min-height:32px;
  padding:6px 10px;
  color:var(--accent);
  background:#f6fcff;
  border-color:#c7e2eb;
}
.dashboard-summary-toggle[aria-pressed="true"]{
  color:var(--muted);
  background:#fff;
  border-style:dashed;
}
.stat-card,.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:0 1px 2px rgba(16,24,40,.04);min-width:0}
.stat-card{position:relative;overflow:hidden}
.stat-card-button,.stat-card-filter{
  display:block;
  width:100%;
  color:inherit;
  text-align:left;
  cursor:pointer;
  transition:border-color .16s ease,box-shadow .16s ease,background-color .16s ease,transform .16s ease;
}
.stat-card-button{
  font:inherit;
}
.stat-card-button:hover,.stat-card-filter:hover{
  border-color:#64bfd5;
  background:#f8fdff;
  box-shadow:0 8px 22px rgba(0,76,143,.11);
}
.stat-card-button:active,.stat-card-filter:active{transform:translateY(1px)}
.stat-card-button:focus-visible,.stat-card-filter:focus-within{
  outline:3px solid rgba(37,99,235,.45);
  outline-offset:3px;
}
.stat-card.active{
  border-color:#63dce8;
  background:#f4fdff;
  box-shadow:inset 0 0 0 1px rgba(0,146,188,.16),0 8px 22px rgba(0,76,143,.1);
}
.stat-card::before{content:"";position:absolute;inset:0 auto 0 0;width:4px;background:linear-gradient(180deg,var(--accent-2),var(--accent-neon))}
.stat-check{
  position:absolute;
  top:10px;
  right:10px;
  width:18px;
  height:18px;
  border:1px solid var(--border);
  border-radius:5px;
  background:#fff;
}
.stat-card.active .stat-check{
  border-color:var(--accent-2);
  background:var(--accent-2);
}
.stat-card.active .stat-check::after{
  content:"";
  position:absolute;
  left:5px;
  top:2px;
  width:5px;
  height:9px;
  border:solid #fff;
  border-width:0 2px 2px 0;
  transform:rotate(45deg);
}
.stat-card strong{display:block;font-size:28px;line-height:1;font-weight:800}
.stat-card span{display:block;margin-top:7px;color:var(--muted);font-size:12px;font-weight:700;text-transform:uppercase}
.stat-card .stat-check{margin-top:0}
.stat-card .stat-card-icon{
  display:inline-grid;
  place-items:center;
  width:30px;
  height:30px;
  margin-top:0;
  margin-bottom:10px;
  border-radius:8px;
  background:color-mix(in srgb,var(--type-color,var(--accent)) 13%,#fff);
  color:var(--type-color,var(--accent));
}
.stat-card .stat-card-icon-neutral{--type-color:var(--accent)}
.stat-card .stat-card-icon .type-icon{width:18px;height:18px}
.stat-card .stat-label{
  margin-top:7px;
  color:var(--muted);
  text-transform:none;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.table-type,.drawer-type{
  display:inline-flex;
  align-items:center;
  gap:6px;
  min-width:0;
  color:var(--type-color,var(--accent));
  font-weight:800;
}
.table-type .type-icon,.drawer-type .type-icon{width:15px;height:15px}
.charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,320px),1fr));gap:16px}
.charts[hidden]{display:none}
.panel h2,.panel h3{margin:0 0 12px;font-size:15px}
.panel-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.panel-title-row h2{margin:0}
.bar-list{display:grid;gap:10px}
.bar-row{display:grid;gap:5px}
.bar-row header{display:flex;justify-content:space-between;gap:10px;color:var(--muted);font-size:12px;font-weight:700;min-width:0}
.bar-row header span:first-child{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bar-track{height:10px;background:var(--surface-2);border-radius:999px;overflow:hidden}
.bar-fill{height:100%;background:var(--accent);border-radius:999px}
.bar-project{background:var(--accent-2)}
.bar-state{background:var(--warning)}
.width-1{width:5%}.width-2{width:10%}.width-3{width:15%}.width-4{width:20%}.width-5{width:25%}
.width-6{width:30%}.width-7{width:35%}.width-8{width:40%}.width-9{width:45%}.width-10{width:50%}
.width-11{width:55%}.width-12{width:60%}.width-13{width:65%}.width-14{width:70%}.width-15{width:75%}
.width-16{width:80%}.width-17{width:85%}.width-18{width:90%}.width-19{width:95%}.width-20{width:100%}
.table-wrap{
  overflow:auto;
  max-width:100%;
  border-radius:var(--radius);
}
.dashboard-table-toolbar{
  position:sticky;
  top:0;
  z-index:8;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  min-width:0;
  margin:8px 0 10px;
  padding:8px 10px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:rgba(255,255,255,.96);
  box-shadow:0 8px 18px rgba(12,65,88,.08);
}
.dashboard-table-toolbar[hidden]{
  display:none;
}
.dashboard-table-context{
  color:var(--muted);
  font-size:12px;
  font-weight:800;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.dashboard-table-toolbar-actions{
  display:inline-flex;
  align-items:center;
  gap:6px;
  flex:0 0 auto;
}
#tableArea{
  padding-bottom:8px;
  scrollbar-color:#7aa0ad #d8edf4;
  scrollbar-width:auto;
  overscroll-behavior-x:contain;
}
#tableArea::-webkit-scrollbar{height:16px}
#tableArea::-webkit-scrollbar-track{
  background:#d8edf4;
  border-radius:999px;
}
#tableArea::-webkit-scrollbar-thumb{
  min-width:72px;
  border:3px solid #d8edf4;
  border-radius:999px;
  background:#7aa0ad;
}
#tableArea::-webkit-scrollbar-thumb:hover{background:#4b6d7c}
.dashboard-scroll-button{
  width:32px;
  min-height:32px;
  padding:0;
  border-color:#b9dced;
  background:#f6fcff;
  color:var(--accent);
  font-size:22px;
  line-height:1;
}
.dashboard-scroll-button:disabled{
  opacity:.38;
  cursor:not-allowed;
  box-shadow:none;
}
.dashboard-detail-table{
  min-width:1320px;
  border-collapse:separate;
  border-spacing:0;
  table-layout:fixed;
}
.dashboard-detail-table th,
.dashboard-detail-table td{
  max-width:none;
}
.dashboard-detail-table thead th{
  position:sticky;
  top:0;
  z-index:2;
  padding:0;
}
.dashboard-detail-table th:nth-child(1),
.dashboard-detail-table td:nth-child(1){
  position:sticky;
  left:0;
  z-index:3;
  background:var(--surface);
}
.dashboard-detail-table th:nth-child(2),
.dashboard-detail-table td:nth-child(2){
  position:sticky;
  left:94px;
  z-index:3;
  background:var(--surface);
  box-shadow:14px 0 18px -18px rgba(9,55,74,.64);
}
.dashboard-detail-table thead th:nth-child(1),
.dashboard-detail-table thead th:nth-child(2){
  z-index:7;
  background:var(--surface-2);
}
.dashboard-detail-table .dashboard-table-filter-row th:nth-child(1),
.dashboard-detail-table .dashboard-table-filter-row th:nth-child(2){
  z-index:6;
  background:#f6fcff;
}
.dashboard-sort-button{
  width:100%;
  min-height:39px;
  padding:10px;
  border:0;
  background:transparent;
  color:inherit;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  font:inherit;
  font-weight:900;
  text-align:left;
}
.dashboard-sort-button:hover{
  background:#dff1f8;
  color:var(--accent);
}
.dashboard-sort-button:focus-visible{
  outline:3px solid rgba(37,99,235,.45);
  outline-offset:-3px;
}
.dashboard-sort-button.active{
  color:var(--accent);
}
.dashboard-sort-indicator{
  flex:0 0 auto;
  width:0;
  height:0;
  border-left:5px solid transparent;
  border-right:5px solid transparent;
  opacity:.42;
}
.dashboard-sort-indicator.dashboard-sort-desc{
  border-top:7px solid currentColor;
  opacity:1;
}
.dashboard-sort-indicator.dashboard-sort-asc{
  border-bottom:7px solid currentColor;
  opacity:1;
}
.dashboard-sort-indicator.dashboard-sort-none{
  border-top:7px solid currentColor;
}
.dashboard-detail-table .dashboard-table-filter-row th{
  top:39px;
  padding:6px 8px 8px;
  background:#f6fcff;
  border-bottom-color:#9ed1e2;
}
.dashboard-table-filter{
  width:100%;
  min-height:30px;
  padding:5px 8px;
  border-radius:6px;
  font-size:12px;
  font-weight:700;
}
.dashboard-detail-table td{
  vertical-align:middle;
}
.dashboard-table-row{
  cursor:pointer;
}
.dashboard-table-row:hover td{
  background:#f4fbfe;
}
.dashboard-table-row:focus-visible{
  outline:none;
}
.dashboard-table-row:focus-visible td{
  box-shadow:inset 0 0 0 2px rgba(0,76,143,.24);
}
.dashboard-table-row.is-selected td{
  background:#e8f7ff;
  border-bottom-color:#8ac8dc;
  box-shadow:inset 0 1px 0 rgba(0,146,188,.24),inset 0 -1px 0 rgba(0,146,188,.24);
}
.dashboard-table-row.is-selected td:first-child{
  color:var(--accent);
  font-weight:900;
}
.dashboard-table-row.is-selected td:first-child::before{
  content:"";
  position:absolute;
  inset:8px auto 8px 0;
  width:4px;
  border-radius:999px;
  background:var(--accent-2);
}
.dashboard-id-column{width:94px}
.dashboard-title-column{width:360px}
.dashboard-type-column{width:240px}
.dashboard-state-column{width:170px}
.dashboard-project-column{width:230px}
.dashboard-comments-column{width:170px}
.dashboard-assignee-column{width:260px}
.dashboard-updated-column{width:150px}
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{padding:10px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}
th{background:var(--surface-2);color:var(--muted);font-size:12px;white-space:nowrap}
tr:hover td{background:#fafbfc}
td{max-width:340px;overflow-wrap:anywhere}
.row-number{width:44px;max-width:44px;text-align:right;color:var(--muted);font-variant-numeric:tabular-nums;white-space:nowrap}
.drawer-backdrop{position:fixed;inset:0;background:rgba(17,24,39,.44);display:none;z-index:20}
.drawer-backdrop.open{display:block}
.drawer{
  position:fixed;
  inset:0 0 0 auto;
  width:min(920px,100vw);
  background:var(--surface);
  box-shadow:var(--shadow);
  display:grid;
  grid-template-rows:auto 1fr;
  transform:translateX(100%);
  transition:transform .2s ease;
  z-index:21;
  overscroll-behavior:contain;
}
.drawer.open{transform:translateX(0)}
.drawer-header{border-bottom:1px solid var(--border);padding:18px max(20px,env(safe-area-inset-right)) 18px 20px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.drawer-title{display:grid;gap:8px}
.drawer-title h2{font-size:18px;margin:0;line-height:1.3;overflow-wrap:anywhere;text-wrap:pretty}
.drawer-subtitle{display:flex;gap:8px;flex-wrap:wrap;color:var(--muted);font-size:12px;font-weight:700;min-width:0}
.drawer-body{overflow:auto;padding:18px 20px;display:grid;gap:18px}
.detail-grid{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(280px,.85fr);gap:18px;align-items:start}
.section-title{font-size:13px;text-transform:uppercase;color:var(--muted);letter-spacing:.04em;margin:0 0 10px;font-weight:800}
.space-top{margin-top:12px}
.comment-form{margin-top:18px}
.discussion-panel{grid-column:1/-1}
.comments-list{display:grid;gap:12px}
.comment-item{
  display:grid;
  grid-template-columns:36px minmax(0,1fr);
  gap:10px;
  padding:12px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--surface);
  box-shadow:0 1px 2px rgba(16,24,40,.04);
}
.comment-avatar{
  width:36px;
  height:36px;
  border-radius:50%;
  object-fit:cover;
  background:#e7fbff;
  color:var(--accent);
  border:1px solid var(--border);
}
.comment-avatar-fallback{
  display:inline-grid;
  place-items:center;
  font-size:12px;
  font-weight:900;
}
.comment-body{display:grid;gap:6px;min-width:0}
.comment-header{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;min-width:0}
.comment-header strong{font-size:13px;line-height:1.3;overflow-wrap:anywhere}
.comment-header time{color:var(--muted);font-size:12px;font-weight:700}
.comment-content{display:grid;gap:8px;min-width:0}
.comment-content p{margin:0;color:var(--text);font-size:14px;line-height:1.5;overflow-wrap:anywhere}
.comment-content a{color:var(--accent);font-weight:700;text-decoration-thickness:1px;text-underline-offset:2px}
.comment-attachment{margin:2px 0 0;max-width:100%;min-width:0}
.comment-attachment a{display:inline-block;max-width:100%;border-radius:6px}
.comment-attachment img{
  display:block;
  width:auto;
  max-width:100%;
  max-height:420px;
  object-fit:contain;
  border:1px solid var(--border);
  border-radius:6px;
  background:var(--surface-2);
}
.form-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;margin-top:12px}
.user-results{display:grid;gap:6px;margin-top:8px}
.user-option{width:100%;text-align:left;border:1px solid var(--border);background:var(--surface);border-radius:var(--radius);padding:9px 10px;cursor:pointer}
.user-option:hover{border-color:var(--accent);background:#f8fbff}
.user-option[aria-selected="true"]{border-color:var(--accent);background:#eefaff;box-shadow:0 0 0 2px rgba(0,146,188,.16)}
.tree-panel{display:grid;gap:12px}
.tree-list,.tree-list ul{list-style:none;margin:0;padding-left:0}
.tree-list ul{padding-left:18px;border-left:2px solid var(--surface-3);margin-left:12px}
.tree-node{margin:8px 0}
.tree-card{border:1px solid var(--border);border-radius:var(--radius);padding:10px;display:grid;gap:7px;background:var(--surface)}
.tree-card.focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.12)}
.tree-card-top{display:flex;justify-content:space-between;gap:10px;align-items:start;min-width:0}
.tree-card-title{font-size:13px;font-weight:800;line-height:1.35}
.dependency-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.dependency-list{display:grid;gap:8px}
.dependency-item{border:1px solid var(--border);border-radius:var(--radius);padding:9px;background:var(--surface)}
.empty-state{border:1px dashed var(--border);color:var(--muted);background:rgba(255,255,255,.58);border-radius:var(--radius);padding:18px;text-align:center;font-weight:600}
.board>.empty-state,.board>.loading-inline{
  flex:1 1 100%;
  min-width:min(100%,520px);
  min-height:240px;
  display:grid;
  place-items:center;
  align-self:stretch;
}
#observabilityView.view{padding:10px max(20px,env(safe-area-inset-right)) 16px max(20px,env(safe-area-inset-left))}
#observabilityView .panel{padding:12px 16px}
#observabilityView .panel h2{margin-bottom:8px}
.observability-layout{display:grid;gap:10px;min-width:0}
.observability-form{
  display:grid;
  grid-template-columns:minmax(0,1fr) max-content;
  gap:10px 12px;
  align-items:start;
}
.observability-form>*{min-width:0}
.observability-criteria{
  min-width:0;
  margin:0;
  padding:0;
  border:0;
  display:grid;
  grid-template-columns:
    minmax(180px,.95fr)
    minmax(250px,1.35fr)
    minmax(210px,1.1fr)
    minmax(210px,1.1fr)
    minmax(112px,.58fr)
    minmax(220px,1.08fr)
    minmax(220px,1.08fr)
    minmax(96px,.48fr);
  gap:8px 10px;
  align-items:end;
}
.observability-criteria legend:not(.sr-only){
  grid-column:1 / -1;
  margin:0 0 -2px;
  padding:0;
  color:var(--muted);
  font-size:11px;
  font-weight:900;
  line-height:1.2;
  text-transform:uppercase;
}
.observability-batch-panel{
  grid-column:1 / -1;
  display:grid;
  gap:8px;
  padding:10px 12px;
  border:1px solid #b9dced;
  border-radius:var(--radius);
  background:linear-gradient(180deg,#f8fdff,#eefaff);
}
.observability-batch-panel[hidden]{display:none}
.observability-batch-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  min-width:0;
}
.observability-batch-field{min-width:0}
.observability-batch-side{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  min-width:0;
}
.observability-batch-side .field-hint{white-space:nowrap}
.observability-batch-side .btn{min-height:32px;padding:6px 9px;font-size:12px}
.observability-correlation-list{
  min-height:104px;
  resize:vertical;
  font-family:ui-monospace,SFMono-Regular,Consolas,monospace;
  font-size:13px;
  line-height:1.45;
}
.observability-field-http .input,
.observability-field-limit .input{font-variant-numeric:tabular-nums}
.observability-field-http .input{text-align:center}
.observability-field-limit .input{text-align:right}
.observability-actions{
  margin:18px 0 0;
  padding-left:12px;
  border-left:1px solid var(--border);
  align-self:end;
  justify-content:flex-end;
  flex-direction:column-reverse;
}
.observability-actions .btn{
  width:100%;
  min-width:132px;
}
.observability-actions .btn-ghost[aria-expanded="true"]{
  border-color:#64bfd5;
  background:#eefaff;
  color:var(--accent);
  box-shadow:inset 0 0 0 1px rgba(0,146,188,.12);
}
.observability-guide{
  margin-top:8px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:#f8fdff;
  padding:5px 8px;
  display:flex;
  align-items:center;
  gap:6px 8px;
  flex-wrap:wrap;
}
.observability-guide-title{
  color:var(--text);
  font-size:12px;
  line-height:1.2;
  font-weight:900;
  white-space:nowrap;
}
.observability-guide-list{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:6px;
}
.observability-guide-item{
  position:relative;
  display:inline-flex;
  align-items:center;
  min-width:0;
  max-width:100%;
  gap:4px;
  flex-wrap:wrap;
  padding:2px 4px;
}
.observability-guide-label{
  color:inherit;
  font-size:11px;
  font-weight:inherit;
  line-height:1.2;
  white-space:nowrap;
  margin-right:2px;
}
.observability-guide .tooltip-trigger{
  width:14px;
  height:14px;
  border-color:currentColor;
  background:rgba(255,255,255,.62);
  color:inherit;
  font-size:9px;
}
.observability-guide .field-tooltip{
  width:min(330px,calc(100vw - 48px));
  color:#fff;
  font-weight:700;
  white-space:normal;
}
.observability-guide-item:hover .field-tooltip,
.observability-guide-item:focus-within .field-tooltip{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:translateY(0);
}
.observability-guide .channel-chip,
.observability-guide .message-chip,
.observability-guide .http-chip{
  padding:3px 6px 3px 8px;
  min-width:0;
  width:max-content;
}
.observability-guide-item:last-child .field-tooltip{
  inset:auto 0 calc(100% + 8px) auto;
}
.observability-guide-item:last-child .field-tooltip::after{
  left:auto;
  right:12px;
}
.observability-results-panel{
  min-height:clamp(460px,calc(100dvh - 380px),760px);
  height:clamp(460px,calc(100dvh - 380px),760px);
  max-height:calc(100dvh - 24px);
  display:grid;
  grid-template-rows:auto auto minmax(0,1fr);
  overflow:hidden;
}
.results-title-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
  min-width:0;
}
.results-title-actions .last-refresh{
  min-width:0;
}
.results-fullscreen-button{
  flex:0 0 34px;
  width:34px;
  height:34px;
  min-height:34px;
  padding:0;
}
.results-fullscreen-button[aria-pressed="true"]{
  border-color:#64bfd5;
  background:#eefaff;
  color:var(--accent);
}
.observability-results-panel:fullscreen{
  width:100vw;
  height:100vh;
  min-height:100vh;
  max-height:none;
  padding:18px;
  border:0;
  border-radius:0;
  background:var(--surface);
  box-shadow:none;
  display:grid;
  grid-template-rows:auto auto minmax(0,1fr);
  overflow:hidden;
}
.observability-results-panel:fullscreen .table-wrap{
  min-height:0;
  height:100%;
}
.observability-results-panel:fullscreen .observability-results-toolbar{
  align-items:end;
}
.observability-results-toolbar{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  margin:6px 0 10px;
}
.observability-results-panel .table-wrap{
  min-height:0;
  height:100%;
  max-height:100%;
  overflow:auto;
  scrollbar-gutter:stable;
  overscroll-behavior:contain;
  touch-action:pan-x pan-y;
}
.observability-table-filter{
  flex:1 1 280px;
  max-width:460px;
}
.observability-filter-count{
  flex:0 1 auto;
  white-space:nowrap;
}
.observability-export-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.observability-export-actions .btn{min-height:34px;padding:7px 10px;font-size:12px}
.observability-download-state{
  min-height:120px;
  display:grid;
  place-items:center;
  align-content:center;
  gap:6px;
  border:1px dashed #9cc9df;
  border-radius:var(--radius);
  background:#f6fcff;
  color:#365f70;
  padding:18px;
  text-align:center;
  font-size:13px;
  line-height:1.45;
}
.observability-download-state strong{color:#102a43;font-size:15px}
.observability-download-state span{max-width:72ch}
.observability-export-progress{
  width:min(520px,100%);
  height:10px;
  accent-color:#0f7fb0;
}
.admin-layout{display:grid;gap:16px;min-width:0}
.admin-create-panel{overflow:hidden;display:grid;gap:10px}
.admin-create-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  min-width:0;
}
.admin-create-header h2{margin:0}
.admin-create-button{
  flex:0 0 auto;
  min-height:36px;
  padding:8px 14px;
  box-shadow:0 8px 18px rgba(0,76,143,.14);
}
.admin-form{
  display:grid;
  grid-template-columns:minmax(420px,.86fr) minmax(560px,1.14fr);
  gap:12px;
  align-items:start;
}
.admin-form>*{min-width:0}
.admin-form-group{
  min-width:0;
  margin:0;
  padding:10px 12px 12px;
  border:1px solid #c7e2eb;
  border-radius:var(--radius);
  background:linear-gradient(180deg,#f8fdff,#f2fbfd);
}
.admin-form-group legend{
  padding:0 6px;
  color:var(--muted);
  font-size:11px;
  font-weight:900;
  line-height:1.2;
  text-transform:uppercase;
}
.admin-identity-grid{
  display:grid;
  grid-template-columns:minmax(210px,1fr) minmax(210px,1fr) max-content;
  gap:12px;
  align-items:end;
}
.admin-active-check{
  min-height:38px;
  padding:8px 10px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:#fff;
}
.admin-access-grid{
  display:grid;
  grid-template-columns:minmax(220px,.75fr) minmax(320px,1.25fr);
  gap:12px;
  align-items:start;
}
.admin-users-panel{min-height:360px}
.admin-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}
.admin-toolbar .input{width:min(390px,42vw);min-width:260px}
.module-field{min-width:0}
.module-checks{display:flex;flex-wrap:wrap;gap:8px}
.module-check{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);border-radius:999px;background:#fff;padding:7px 10px;font-size:12px;font-weight:800;color:var(--text);white-space:nowrap;max-width:100%}
.module-check span{min-width:0;overflow:hidden;text-overflow:ellipsis}
.module-check input{accent-color:var(--accent)}
.module-check:has(input:disabled){opacity:.62;cursor:not-allowed}
.permission-check{border-style:dashed}
.compact-modules,.compact-permissions{max-width:none}
.compact-modules .module-check,.compact-permissions .module-check{padding:6px 9px}
.compact-input{min-width:0;max-width:260px}
.check-row{display:inline-flex;align-items:center;gap:8px;font-weight:800;color:var(--text)}
.check-row input{accent-color:var(--accent)}
.inline-check{white-space:nowrap}
.self-badge{display:inline-flex;margin-left:8px;border:1px solid #b9e6fe;border-radius:999px;background:#f0f9ff;color:#026aa2;padding:2px 7px;font-size:11px;font-weight:800}
.admin-users-table{
  min-width:1320px;
  table-layout:fixed;
}
.admin-users-table th,
.admin-users-table td{
  max-width:none;
  vertical-align:top;
}
.admin-users-table th:nth-child(1),
.admin-users-table td:nth-child(1){width:250px}
.admin-users-table th:nth-child(2),
.admin-users-table td:nth-child(2){width:230px}
.admin-users-table th:nth-child(3),
.admin-users-table td:nth-child(3){width:118px}
.admin-users-table th:nth-child(4),
.admin-users-table td:nth-child(4){width:300px}
.admin-users-table th:nth-child(5),
.admin-users-table td:nth-child(5){width:360px}
.admin-users-table th:nth-child(6),
.admin-users-table td:nth-child(6){width:150px}
.admin-users-table th:nth-child(7),
.admin-users-table td:nth-child(7){width:132px;text-align:right}
.admin-user-cell strong{
  display:block;
  max-width:100%;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.admin-save-button{min-height:32px;padding:6px 10px;font-size:12px}
.observability-table{
  width:1826px;
  min-width:100%;
  border-collapse:separate;
  border-spacing:0;
  table-layout:fixed;
}
.observability-table th,
.observability-table td{
  background:var(--surface);
  max-width:none;
  overflow-wrap:normal;
}
.observability-table th{
  position:sticky;
  top:0;
  z-index:4;
  background:#e7f5fb;
  border-bottom-color:#9ed1e2;
}
.observability-table td{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.observability-table td:nth-child(7){
  overflow:hidden;
  white-space:normal;
}
.observability-table tbody tr:hover td,
.observability-table tbody tr:focus-visible td{
  background:#f4fbfe;
}
.observability-row{
  cursor:pointer;
}
.observability-row:focus-visible{
  outline:none;
}
.observability-row:focus-visible td{
  box-shadow:inset 0 0 0 2px rgba(0,76,143,.28);
}
.observability-row.is-selected td{
  background:#e8f7ff;
  border-bottom-color:#8ac8dc;
  box-shadow:inset 0 1px 0 rgba(0,146,188,.24),inset 0 -1px 0 rgba(0,146,188,.24);
}
.observability-row.is-selected .row-number{
  color:var(--accent);
  font-weight:900;
}
.observability-row.is-selected .row-number::before{
  content:"";
  position:absolute;
  inset:8px auto 8px 0;
  width:4px;
  border-radius:999px;
  background:var(--accent-2);
}
.trace-sticky-start{
  position:sticky;
  left:0;
  z-index:3;
}
.observability-table th.trace-sticky-start{
  z-index:6;
}
.trace-sticky-end{
  position:sticky;
  right:0;
  z-index:3;
  background:var(--surface);
  box-shadow:-12px 0 18px -16px rgba(12,42,54,.5);
}
.observability-table th.trace-sticky-end{
  z-index:6;
}
.trace-detail-cell{
  min-width:116px;
  width:116px;
  text-align:center;
}
.trace-detail-button{
  min-width:78px;
  padding-inline:10px;
}
.observability-table th:nth-child(1),
.observability-table td:nth-child(1){width:44px}
.observability-table th:nth-child(2),
.observability-table td:nth-child(2){width:210px}
.observability-table th:nth-child(3),
.observability-table td:nth-child(3){width:86px}
.observability-table th:nth-child(4),
.observability-table td:nth-child(4){width:230px}
.observability-table th:nth-child(5),
.observability-table td:nth-child(5){width:380px}
.observability-table th:nth-child(6),
.observability-table td:nth-child(6){width:170px}
.observability-table th:nth-child(7),
.observability-table td:nth-child(7){width:220px}
.observability-table th:nth-child(8),
.observability-table td:nth-child(8){width:190px}
.observability-table th:nth-child(9),
.observability-table td:nth-child(9){width:180px}
.observability-table th:nth-child(10),
.observability-table td:nth-child(10){width:116px}
.trace-id{display:inline-block;max-width:100%;overflow:hidden;text-overflow:ellipsis;vertical-align:bottom;white-space:nowrap;font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:12px;color:#344054}
.trace-endpoint-cell{
  width:380px;
}
.trace-endpoint-cell code{
  display:inline-block;
  max-width:100%;
  color:#102a43;
  font-family:ui-monospace,SFMono-Regular,Consolas,monospace;
  font-size:12px;
  line-height:1.45;
  overflow:hidden;
  text-overflow:ellipsis;
  vertical-align:bottom;
  white-space:nowrap;
  text-wrap:nowrap;
}
.date-cell{display:grid;gap:5px;min-width:190px}
.date-cell time{font-variant-numeric:tabular-nums}
.date-health{
  width:max-content;
  border:1px solid var(--border);
  border-radius:999px;
  padding:2px 7px;
  font-size:11px;
  font-weight:800;
  color:var(--muted);
  background:#fff;
  white-space:nowrap;
}
.date-health-ok{border-color:#abefc6;color:#067647;background:#ecfdf3}
.date-health-warning{border-color:#fedf89;color:#b54708;background:#fffaeb}
.date-health-unknown{border-color:#d0d5dd;color:#475467;background:#f9fafb}
.channel-stack{display:flex;align-items:center;gap:6px;flex-wrap:wrap;min-width:0;max-width:100%}
.channel-chip,.message-chip,.http-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--border);
  border-radius:999px;
  padding:3px 8px;
  font-size:11px;
  line-height:1.15;
  font-weight:900;
  color:#475467;
  background:#f9fafb;
  white-space:nowrap;
}
.channel-chip{border-color:#b9e6fe;color:#026aa2;background:#f0f9ff}
.channel-soap{border-color:#d9d6fe;color:#5925dc;background:#f4f3ff}
.channel-service{border-color:#c7d7fe;color:#3538cd;background:#eef4ff}
.message-chip{border-color:#fedf89;color:#b54708;background:#fffaeb}
.message-in{border-color:#abefc6;color:#067647;background:#ecfdf3}
.message-out{border-color:#fecdca;color:#b42318;background:#fef3f2}
.http-chip{min-width:54px}
.http-ok{border-color:#abefc6;color:#067647;background:#ecfdf3}
.http-warn{border-color:#fedf89;color:#b54708;background:#fffaeb}
.http-error{border-color:#fecdca;color:#b42318;background:#fef3f2}
.trace-detail{display:grid;gap:14px;min-width:0}
.trace-section{
  border:1px solid var(--border);
  background:var(--surface);
  border-radius:var(--radius);
  overflow:hidden;
}
@supports (content-visibility:auto){
  .trace-section{
    content-visibility:auto;
    contain-intrinsic-size:auto none auto 260px;
  }
}
.trace-section-header{
  min-height:46px;
  padding:10px 12px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  border-bottom:1px solid var(--border);
  background:var(--surface-4);
}
.trace-section-header h3{margin:0;font-size:13px;line-height:1.3;color:var(--text)}
.trace-section-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.trace-copy-button{min-height:28px;padding:5px 8px;font-size:11px}
.trace-format{
  flex:0 0 auto;
  border:1px solid var(--border);
  border-radius:999px;
  padding:3px 8px;
  font-size:11px;
  font-weight:800;
  color:var(--muted);
  background:#fff;
}
.trace-format-valid{border-color:#abefc6;color:#067647;background:#ecfdf3}
.trace-format-invalid{border-color:#fedf89;color:#b54708;background:#fffaeb}
.trace-format-message{margin:0;padding:10px 12px;border-bottom:1px solid var(--border);color:var(--warning);font-size:12px;font-weight:700;background:#fffaeb}
.trace-format-note{color:#344054;background:#f9fafb}
.trace-meta{
  margin:0;
  padding:12px;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(190px,1fr));
  gap:10px 14px;
}
.trace-meta-row{min-width:0}
.trace-meta dt{margin:0 0 4px;color:var(--muted);font-size:11px;font-weight:800;text-transform:uppercase}
.trace-meta dd{margin:0;overflow-wrap:anywhere;font-size:13px;line-height:1.35}
.trace-url-details{
  border-top:1px solid var(--border);
  background:#f8fcfe;
}
.trace-url-details summary{
  min-height:42px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px 12px;
  color:var(--text);
  cursor:pointer;
  font-size:12px;
  font-weight:900;
  list-style-position:inside;
}
.trace-url-count{
  flex:0 0 auto;
  border:1px solid #b9e6fe;
  border-radius:999px;
  padding:3px 8px;
  color:#026aa2;
  background:#f0f9ff;
  font-size:11px;
  line-height:1.1;
  white-space:nowrap;
}
.trace-url-body{
  display:grid;
  gap:10px;
  padding:0 12px 12px;
  min-width:0;
}
.trace-url-endpoint{
  display:grid;
  grid-template-columns:max-content minmax(0,1fr) auto;
  align-items:center;
  gap:8px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:#fff;
  padding:8px;
  min-width:0;
}
.trace-url-endpoint span{
  color:var(--muted);
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
}
.trace-url-endpoint code,
.trace-url-param-name,
.trace-url-param-value{
  font-family:ui-monospace,SFMono-Regular,Consolas,monospace;
}
.trace-url-endpoint code{
  min-width:0;
  color:#102a43;
  font-size:12px;
  overflow-wrap:anywhere;
}
.trace-url-param-list{
  display:grid;
  gap:6px;
  max-height:min(44vh,420px);
  overflow:auto;
  scrollbar-gutter:stable;
  overscroll-behavior:contain;
  padding-right:2px;
}
.trace-url-param-row{
  display:grid;
  grid-template-columns:minmax(130px,220px) minmax(0,1fr);
  gap:10px;
  align-items:start;
  border:1px solid #d7e8ef;
  border-radius:var(--radius);
  background:#fff;
  padding:8px 10px;
  min-width:0;
}
.trace-url-param-name{
  color:var(--accent-deep);
  font-size:12px;
  font-weight:800;
  overflow-wrap:anywhere;
}
.trace-url-param-value{
  display:grid;
  gap:4px;
  min-width:0;
  color:#102a43;
  font-size:12px;
  line-height:1.45;
  overflow-wrap:anywhere;
}
.trace-url-param-value small{
  color:var(--muted);
  font-size:11px;
  line-height:1.35;
  overflow-wrap:anywhere;
}
.trace-code{
  margin:0;
  background:#0c2a36;
  color:#e7fbff;
  padding:14px;
  max-height:62vh;
  overflow:auto;
  white-space:pre;
  overflow-wrap:normal;
  font-family:"Cascadia Code","Consolas",monospace;
  font-size:12px;
  line-height:1.5;
  tab-size:2;
}
.trace-code-text,.trace-code-empty{
  white-space:pre-wrap;
  overflow-wrap:anywhere;
}
.trace-source-query{border-top:1px solid var(--border);background:var(--surface-4)}
.trace-source-query-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;font-size:12px}
.trace-source-query .trace-code{max-height:28vh;background:#10212b}
.toast-region{position:fixed;right:18px;bottom:18px;z-index:40;display:grid;gap:8px;max-width:min(420px,calc(100vw - 36px))}
.toast{background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--accent);box-shadow:var(--shadow);border-radius:var(--radius);padding:12px 14px;font-size:13px;font-weight:700}
.toast.error{border-left-color:var(--danger)}
.toast.success{border-left-color:var(--success)}
.toast.loading{border-left-color:var(--warning)}
.loading-inline{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-weight:700}
.spinner{width:16px;height:16px;border:2px solid var(--surface-3);border-top-color:var(--accent);border-radius:50%;animation:spin .75s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}
}
@media(max-width:1600px){
  .observability-form{grid-template-columns:minmax(0,1fr) max-content}
  .observability-criteria{grid-template-columns:repeat(12,minmax(0,1fr))}
  .observability-field-environment{grid-column:span 2}
  .observability-field-text{grid-column:span 4}
  .observability-field-correlation{grid-column:span 3}
  .observability-field-api{grid-column:span 3}
  .observability-field-http{grid-column:span 2}
  .observability-field-date{grid-column:span 3}
  .observability-field-limit{grid-column:span 2}
  .observability-table{
    width:1438px;
  }
  .observability-table th:nth-child(1),
  .observability-table td:nth-child(1){width:40px}
  .observability-table th:nth-child(2),
  .observability-table td:nth-child(2){width:162px}
  .observability-table th:nth-child(3),
  .observability-table td:nth-child(3){width:72px}
  .observability-table th:nth-child(4),
  .observability-table td:nth-child(4){width:156px}
  .observability-table th:nth-child(5),
  .observability-table td:nth-child(5),
  .trace-endpoint-cell{width:286px}
  .observability-table th:nth-child(6),
  .observability-table td:nth-child(6){width:132px}
  .observability-table th:nth-child(7),
  .observability-table td:nth-child(7){width:230px}
  .observability-table th:nth-child(8),
  .observability-table td:nth-child(8){width:144px}
  .observability-table th:nth-child(9),
  .observability-table td:nth-child(9){width:130px}
  .observability-table th:nth-child(10),
  .observability-table td:nth-child(10),
  .trace-detail-cell{width:88px;min-width:88px}
  .trace-detail-button{min-width:64px;padding-inline:8px}
}
@media(max-width:1180px){
  .topbar{
    display:grid;
    grid-template-columns:minmax(0,1fr);
    align-items:start;
  }
  .topbar-brand,
  .topbar-actions{
    width:100%;
  }
  .topbar-actions{
    display:grid;
    grid-template-columns:minmax(0,max-content) minmax(300px,476px);
    justify-content:end;
    align-items:center;
  }
  .topbar-meta{
    min-width:0;
  }
  .observability-form{grid-template-columns:1fr}
  .observability-actions{
    grid-column:1 / -1;
    margin-top:0;
    padding-left:0;
    border-left:0;
    flex-direction:row;
    justify-content:flex-end;
  }
  .observability-actions .btn{width:auto;min-width:132px}
  .observability-field-environment,
  .observability-field-http,
  .observability-field-limit{grid-column:span 2}
  .observability-field-text,
  .observability-field-correlation,
  .observability-field-api,
  .observability-field-date{grid-column:span 5}
  .observability-batch-panel{grid-column:1 / -1}
  .observability-table{
    width:1320px;
  }
  .observability-table td.trace-sticky-end{
    position:static;
    box-shadow:none;
  }
  .observability-table th.trace-sticky-end{
    right:auto;
    box-shadow:none;
  }
}
@media(max-width:900px){
  .auth-shell{place-content:center;place-items:center;padding:clamp(18px,6vh,48px) 18px}
  .login-panel{width:min(560px,100%);padding:24px 20px;gap:18px;margin:0}
  .brand-lockup{align-items:flex-start;gap:16px}
  .etb-logo{width:92px}
  .brand-claim{max-width:150px;text-align:right;line-height:1.25}
  .login-copy h1{font-size:24px;line-height:1.14}
  .login-copy p{font-size:13px;line-height:1.5}
  .topbar,.board-toolbar{display:grid;grid-template-columns:1fr}
  .observability-form{grid-template-columns:1fr}
  .observability-form>*{grid-column:1 / -1}
  .observability-criteria{grid-template-columns:repeat(2,minmax(0,1fr))}
  .observability-criteria > .field{grid-column:auto}
  .observability-criteria legend:not(.sr-only){grid-column:1 / -1}
  .admin-form{grid-template-columns:1fr}
  .admin-identity-grid,
  .admin-access-grid{grid-template-columns:1fr}
  .admin-active-check{justify-self:start}
  .admin-toolbar{justify-content:flex-start}
  .panel-title-row{display:grid}
  .dashboard-table-toolbar{
    display:grid;
    grid-template-columns:1fr auto;
    align-items:center;
  }
  .dashboard-table-context{
    white-space:normal;
    line-height:1.35;
  }
  .topbar{align-items:flex-start}
  .topbar-actions{display:grid;grid-template-columns:1fr;justify-content:stretch;width:100%}
  .topbar-meta{flex-wrap:wrap;width:100%}
  .topbar-actions .btn{flex:1 1 140px}
  .last-refresh{flex:1 1 auto}
  .observability-batch-header{display:grid;grid-template-columns:1fr;align-items:start}
  .observability-batch-side{justify-content:space-between}
  .user-badge{min-width:0;width:100%;max-width:none}
  .last-refresh{min-width:0}
  .diagnostics-panel{inset:calc(100% + 8px) 0 auto auto;width:min(640px,calc(100vw - 28px));padding:10px}
  .diagnostics-head{align-items:flex-start}
  .detail-grid,.dependency-grid{grid-template-columns:1fr}
  .view{padding:14px}
  .tabs{padding:0 14px}
  .column{flex-basis:286px}
}
@media(max-width:620px){
  .auth-shell{padding:14px}
  .brand-lockup{display:grid}
  .brand-claim{text-align:left;max-width:none}
  .topbar{padding:14px}
  .topbar-brand{align-items:flex-start}
  .topbar .brand p{display:none}
  .etb-logo-small{width:58px}
  .topbar-meta{display:grid;grid-template-columns:auto minmax(0,1fr)}
  .topbar-meta .btn-primary{grid-column:1 / -1;width:100%}
  .dashboard-table-toolbar{
    grid-template-columns:1fr;
    justify-items:stretch;
  }
  .dashboard-table-toolbar-actions{
    justify-content:flex-end;
  }
  .user-badge{grid-template-columns:auto minmax(0,1fr) auto;max-width:100%;width:100%}
  .user-options{grid-column:3;grid-row:1;width:40px}
  .user-logout{grid-column:1 / -1;width:100%}
  .diagnostics-panel{
    inset:calc(100% + 8px) 0 auto 0;
    width:100%;
    max-height:min(58vh,420px);
    display:grid;
    grid-template-columns:1fr;
    gap:6px;
    overflow:auto;
  }
  .diagnostics-head{
    display:grid;
    grid-template-columns:minmax(0,1fr) auto;
    align-items:center;
    gap:8px;
  }
  .diagnostics-summary{white-space:normal}
  .diagnostics-items{grid-template-columns:1fr;justify-content:flex-start}
  .diagnostic-chip{width:100%;max-width:none;justify-content:flex-start}
  .user-name{font-size:12px}
  .user-email{font-size:10px}
  .observability-form{grid-template-columns:1fr}
  .observability-criteria{grid-template-columns:1fr}
  .observability-actions{display:grid;grid-template-columns:1fr}
  .observability-actions .btn{width:100%}
  .observability-batch-side{display:grid;grid-template-columns:1fr;justify-items:start}
  .admin-create-header{display:grid;grid-template-columns:1fr}
  .admin-create-button{width:100%}
  .admin-toolbar{display:grid;grid-template-columns:1fr;width:100%}
  .admin-toolbar .input{width:100%;min-width:0;max-width:none}
  .panel,.stat-card{padding:14px}
  .drawer{width:100vw}
  .drawer-header,.drawer-body{padding-left:14px;padding-right:14px}
  .trace-url-endpoint,
  .trace-url-param-row{grid-template-columns:1fr}
  .trace-url-endpoint .trace-copy-button{justify-self:start}
  .board{min-height:calc(100vh - 250px)}
  .column{flex-basis:min(86vw,310px);max-height:calc(100vh - 260px)}
  th,td{padding:9px 8px}
}
