@font-face {
  font-family: "SF Pro Display";
  src:
    url("../font/SFPRODISPLAYREGULAR.aaeac71d99a3.OTF") format("opentype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "SF Pro Display";
  src:
    url("../font/SFPRODISPLAYMEDIUM.51fd7406327f.OTF") format("opentype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "SF Pro Display Brand";
  src:
    url("../font/SFPRODISPLAYSEMIBOLDITALIC.fce0a93d0980.OTF") format("opentype");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

:root {
  --header-height: 118px;
  --header-offset: var(--header-height);
  --viewport-height: 100vh;
  --sidebar-width: 290px;
  --font-body: "SF Pro Display", "Trebuchet MS", system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-title: "SF Pro Display", "Trebuchet MS", system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-subtitle: "SF Pro Display", "Trebuchet MS", system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-brand: "SF Pro Display Brand", "SF Pro Display", "Trebuchet MS", system-ui, -apple-system, "Segoe UI", sans-serif;
  --radius-xl: 16px;
  --radius-lg: 12px;
  --radius-md: 8px;
  --radius-sm: 6px;

  --duration-fast: 140ms;
  --duration: 220ms;
  --duration-slow: 380ms;
  --ease-out: cubic-bezier(0.2, 0.9, 0.2, 1);
  --ease-soft: cubic-bezier(0.2, 0.8, 0.2, 1);

  --text: #1f2937;
  --muted: rgba(31, 41, 55, 0.78);

  --silver-0: #eef2f6;
  --silver-1: #cdd8e3;
  --silver-2: #9fb3c6;
  --silver-3: #6f8aa4;
  --silver-4: #15314a;
  --accent: #1f4d7a;
  --accent-strong: #102a3f;
  --accent-soft: rgba(31, 77, 122, 0.22);
  --accent-2: #5d87a7;
  --accent-2-soft: rgba(93, 135, 167, 0.26);
  --navbar-bg: linear-gradient(135deg, #eef2f6 0%, #cdd8e3 48%, #7f9bb3 100%);
  --header-line: linear-gradient(90deg, transparent 0%, rgba(31, 77, 122, 0.9) 35%, rgba(16, 42, 63, 0.95) 65%, transparent 100%);

  --glass: rgba(248, 250, 252, 0.72);
  --glass-strong: rgba(248, 250, 252, 0.86);
  --glass-border: rgba(15, 23, 42, 0.12);
  --glass-border-strong: rgba(15, 23, 42, 0.2);

  --input-bg: rgba(248, 250, 252, 0.82);
  --input-border: rgba(31, 77, 122, 0.28);

  --shadow: 0 16px 34px rgba(2, 6, 23, 0.14);
  --shadow-strong: 0 28px 60px rgba(2, 6, 23, 0.2);

  --focus: rgba(31, 77, 122, 0.42);
  --nav-hover: rgba(31, 77, 122, 0.14);
  --nav-active: rgba(93, 135, 167, 0.22);

  --scrollbar-thumb: rgba(31, 77, 122, 0.35);
  --scrollbar-track: rgba(238, 242, 246, 0.7);

  --card-bg: rgba(248, 250, 252, 0.74);
  --card-overlay: rgba(205, 216, 227, 0.62);
  --card-border: rgba(15, 23, 42, 0.14);
  --notes-bg: rgba(248, 250, 252, 0.72);
  --notes-border: rgba(31, 77, 122, 0.22);

  --nav-dot: rgba(31, 77, 122, 0.38);

  --home-hero-panel-bg:
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.82) 0%, transparent 28%),
    linear-gradient(145deg, rgba(243, 248, 253, 0.98) 0%, rgba(223, 234, 244, 0.95) 56%, rgba(213, 227, 241, 0.92) 100%);
  --home-hero-panel-line: linear-gradient(90deg, rgba(31, 77, 122, 0.08), rgba(93, 135, 167, 0.48), rgba(31, 77, 122, 0.08));
  --home-hero-panel-title: #18344d;
  --home-hero-panel-muted: rgba(24, 52, 77, 0.82);
  --home-hero-panel-soft: rgba(24, 52, 77, 0.62);
  --home-hero-panel-separator: rgba(111, 138, 164, 0.68);
  --home-hero-panel-border: rgba(31, 77, 122, 0.18);
  --home-hero-action-bg: rgba(31, 77, 122, 0.11);
  --home-hero-action-bg-hover: rgba(31, 77, 122, 0.18);
  --home-hero-action-border: rgba(31, 77, 122, 0.2);
  --home-hero-action-text: #18344d;
  --home-hero-metric-bg: rgba(255, 255, 255, 0.82);
  --home-hero-metric-bg-hover: rgba(255, 255, 255, 0.92);
  --home-hero-metric-border: rgba(31, 77, 122, 0.16);
  --home-hero-metric-label: rgba(24, 52, 77, 0.68);
  --home-hero-metric-value: #16314a;
  --home-hero-metric-hint: rgba(24, 52, 77, 0.72);

  --home-meeting-bg: var(--home-hero-panel-bg);
  --home-meeting-border: var(--home-hero-panel-border);
  --home-meeting-title: var(--home-hero-panel-title);
  --home-meeting-muted: var(--home-hero-panel-muted);
  --home-meeting-soft: var(--home-hero-panel-soft);
  --home-meeting-icon: rgba(31, 77, 122, 0.72);
  --home-meeting-chip-bg: rgba(31, 77, 122, 0.14);
  --home-meeting-chip-text: #18344d;
  --home-meeting-media-bg: rgba(255, 255, 255, 0.72);
  --home-meeting-media-border: rgba(31, 77, 122, 0.16);
  --home-meeting-media-overlay:
    linear-gradient(180deg, rgba(248, 250, 252, 0.02) 0%, rgba(15, 23, 42, 0.08) 100%),
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.2) 0%, transparent 40%);
}

@supports (height: 100dvh) {
  :root {
    --viewport-height: 100dvh;
  }
}

body[data-theme="dark"] {
  --text: #e8edf3;
  --muted: rgba(232, 237, 243, 0.74);

  --silver-0: #0a1624;
  --silver-1: #11263c;
  --silver-2: #2a4962;
  --silver-3: #5a7d98;
  --silver-4: #cdd8e3;
  --accent: #86b3d6;
  --accent-strong: #d7e3f0;
  --accent-soft: rgba(134, 179, 214, 0.26);
  --accent-2: #5a8fb4;
  --accent-2-soft: rgba(90, 143, 180, 0.28);
  --navbar-bg: linear-gradient(135deg, #0a1624 0%, #11263c 52%, #2a4962 100%);
  --header-line: linear-gradient(90deg, transparent 0%, rgba(134, 179, 214, 0.9) 35%, rgba(215, 227, 240, 0.9) 65%, transparent 100%);

  --glass: rgba(17, 38, 60, 0.72);
  --glass-strong: rgba(10, 22, 36, 0.78);
  --glass-border: rgba(205, 216, 227, 0.16);
  --glass-border-strong: rgba(205, 216, 227, 0.22);

  --input-bg: rgba(17, 38, 60, 0.78);
  --input-border: rgba(134, 179, 214, 0.22);

  --shadow: 0 18px 44px rgba(0, 0, 0, 0.55);
  --shadow-strong: 0 28px 70px rgba(0, 0, 0, 0.62);

  --focus: rgba(134, 179, 214, 0.36);
  --nav-hover: rgba(134, 179, 214, 0.18);
  --nav-active: rgba(90, 143, 180, 0.22);

  --scrollbar-thumb: rgba(134, 179, 214, 0.28);
  --scrollbar-track: rgba(10, 22, 36, 0.8);

  --card-bg: rgba(17, 38, 60, 0.76);
  --card-overlay: rgba(42, 73, 98, 0.62);
  --card-border: rgba(205, 216, 227, 0.18);
  --notes-bg: rgba(17, 38, 60, 0.72);
  --notes-border: rgba(134, 179, 214, 0.2);

  --nav-dot: rgba(134, 179, 214, 0.34);

  --home-hero-panel-bg:
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.2) 0%, transparent 30%),
    linear-gradient(145deg, rgba(13, 31, 50, 0.98) 0%, rgba(18, 44, 72, 0.95) 58%, rgba(27, 58, 89, 0.92) 100%);
  --home-hero-panel-line: linear-gradient(90deg, rgba(255, 255, 255, 0.04), rgba(126, 185, 232, 0.36), rgba(255, 255, 255, 0.04));
  --home-hero-panel-title: #f8fafc;
  --home-hero-panel-muted: rgba(226, 232, 240, 0.82);
  --home-hero-panel-soft: rgba(226, 232, 240, 0.62);
  --home-hero-panel-separator: rgba(148, 163, 184, 0.66);
  --home-hero-panel-border: rgba(205, 216, 227, 0.16);
  --home-hero-action-bg: rgba(255, 255, 255, 0.09);
  --home-hero-action-bg-hover: rgba(126, 185, 232, 0.18);
  --home-hero-action-border: rgba(205, 216, 227, 0.16);
  --home-hero-action-text: #f8fafc;
  --home-hero-metric-bg: rgba(255, 255, 255, 0.08);
  --home-hero-metric-bg-hover: rgba(255, 255, 255, 0.11);
  --home-hero-metric-border: rgba(205, 216, 227, 0.14);
  --home-hero-metric-label: rgba(226, 232, 240, 0.7);
  --home-hero-metric-value: #ffffff;
  --home-hero-metric-hint: rgba(226, 232, 240, 0.76);

  --home-meeting-bg: var(--home-hero-panel-bg);
  --home-meeting-border: var(--home-hero-panel-border);
  --home-meeting-title: var(--home-hero-panel-title);
  --home-meeting-muted: var(--home-hero-panel-muted);
  --home-meeting-soft: var(--home-hero-panel-soft);
  --home-meeting-icon: rgba(191, 219, 254, 0.88);
  --home-meeting-chip-bg: rgba(255, 255, 255, 0.12);
  --home-meeting-chip-text: rgba(248, 250, 252, 0.94);
  --home-meeting-media-bg: rgba(255, 255, 255, 0.08);
  --home-meeting-media-border: rgba(205, 216, 227, 0.12);
  --home-meeting-media-overlay:
    linear-gradient(180deg, rgba(12, 18, 28, 0.06) 0%, rgba(12, 18, 28, 0.24) 100%),
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.14) 0%, transparent 40%);
}

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-family: var(--font-body);
}

body {
  min-height: 100vh;
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.55;
  color: var(--text);
  overflow-x: hidden;
  overflow-y: hidden;
  background:
    radial-gradient(1200px 620px at 10% -10%, rgba(93, 135, 167, 0.35), transparent 60%),
    radial-gradient(900px 560px at 100% 0%, rgba(159, 179, 198, 0.28), transparent 62%),
    linear-gradient(160deg, var(--silver-0) 0%, var(--silver-2) 100%);
  transition: background var(--duration-slow) var(--ease-soft), color var(--duration-slow) var(--ease-soft);
}

body[data-theme="dark"] {
  background:
    radial-gradient(1200px 620px at 10% -10%, rgba(90, 143, 180, 0.22), transparent 60%),
    radial-gradient(900px 560px at 100% 0%, rgba(134, 179, 214, 0.14), transparent 62%),
    linear-gradient(160deg, var(--silver-0) 0%, var(--silver-2) 100%);
}

h1,
h2,
h3,
h4,
h5,
h6,
.app-title,
.login-title,
.board__title,
.account-title,
.modal__title {
  font-family: var(--font-title);
  font-weight: 500;
}

.app-subtitle,
.login-subtitle,
.company__subtitle,
.account-subtitle,
.modal__subtitle,
.calendar-note,
.auth-hint {
  font-family: var(--font-subtitle);
}

.sidebar__section,
.sidebar__link,
.company__list-title,
.company__content h2,
.company-page__meta h2 {
  font-family: var(--font-title);
  font-weight: 500;
}

b,
strong {
  font-family: var(--font-body);
  font-weight: 600;
}

.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;
}

.skip-link {
  position: fixed;
  left: 14px;
  top: 14px;
  z-index: 120;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid var(--glass-border-strong);
  background: linear-gradient(160deg, var(--glass-strong) 0%, var(--glass) 100%);
  color: var(--text);
  text-decoration: none;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  box-shadow: var(--shadow);
  transform: translateY(-160%);
  opacity: 0;
  transition:
    transform var(--duration) var(--ease-out),
    opacity var(--duration) var(--ease-out);
}

.skip-link:focus-visible {
  transform: translateY(0);
  opacity: 1;
}

kbd {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 22px;
  padding: 0 7px;
  border-radius: 8px;
  border: 1px solid var(--glass-border);
  background: rgba(255, 255, 255, 0.08);
  color: var(--text);
  font: inherit;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  box-shadow: inset 0 -1px 0 rgba(255, 255, 255, 0.12);
}

/* Login */
html.is-login-root {
  height: 100%;
  overflow: hidden;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

html.is-login-root::-webkit-scrollbar {
  width: 0;
  height: 0;
}

body.is-login {
  min-height: 100%;
  overflow: hidden;
  background:
    radial-gradient(860px 520px at 16% 10%, rgba(132, 188, 232, 0.18), transparent 58%),
    radial-gradient(780px 440px at 84% 8%, rgba(82, 132, 173, 0.2), transparent 58%),
    radial-gradient(720px 420px at 50% 110%, rgba(16, 42, 63, 0.42), transparent 62%),
    linear-gradient(180deg, #06111b 0%, #0b1b2b 46%, #102739 100%);
}

.login-screen {
  height: 100vh;
  height: 100svh;
  min-height: 100vh;
  min-height: 100svh;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 40px 16px;
  position: relative;
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior: contain;
  overflow-anchor: none;
  scrollbar-width: none;
  -ms-overflow-style: none;
  isolation: isolate;
}

.login-screen::-webkit-scrollbar {
  width: 0;
  height: 0;
}

.login-screen::before {
  content: none;
}

.login-screen::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(540px 320px at 50% 0%, rgba(172, 224, 255, 0.12), transparent 66%),
    radial-gradient(380px 240px at 24% 18%, rgba(93, 135, 167, 0.16), transparent 66%),
    radial-gradient(420px 280px at 80% 12%, rgba(72, 125, 170, 0.14), transparent 66%);
  pointer-events: none;
  z-index: 0;
}

.login-sparkles {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}

.login-sparkles__canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  opacity: 0.96;
}

.login-sparkles__veil {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(560px 220px at 50% 12%, rgba(255, 255, 255, 0.08), transparent 68%),
    radial-gradient(780px 440px at 50% 0%, rgba(110, 181, 233, 0.14), transparent 68%),
    linear-gradient(180deg, rgba(6, 17, 27, 0) 0%, rgba(6, 17, 27, 0.08) 55%, rgba(6, 17, 27, 0.22) 100%);
}

.login-sparkles__orb {
  position: absolute;
  border-radius: 999px;
  filter: blur(80px);
  opacity: 0.56;
  mix-blend-mode: screen;
}

.login-sparkles__orb--left {
  width: 280px;
  height: 280px;
  left: -72px;
  top: 12%;
  background: rgba(135, 201, 255, 0.16);
}

.login-sparkles__orb--right {
  width: 360px;
  height: 360px;
  right: -120px;
  top: 2%;
  background: rgba(93, 135, 167, 0.18);
}

.login-panel {
  width: min(460px, 92vw);
  border-radius: var(--radius-xl);
  background: linear-gradient(165deg, rgba(248, 250, 252, 0.9) 0%, rgba(221, 231, 240, 0.78) 100%);
  border: 1px solid rgba(214, 228, 240, 0.24);
  box-shadow:
    0 32px 80px rgba(2, 6, 23, 0.34),
    inset 0 1px 0 rgba(255, 255, 255, 0.38);
  padding: 32px 28px;
  display: grid;
  gap: 24px;
  margin-block: auto;
  overflow-anchor: none;
  position: relative;
  z-index: 1;
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  overflow: visible;
  transition: box-shadow var(--duration-slow) var(--ease-out);
}

.login-panel--wide {
  width: min(560px, 92vw);
}

.login-panel.is-auth-switching {
  transition: box-shadow var(--duration-slow) var(--ease-out);
  box-shadow:
    0 36px 90px rgba(2, 6, 23, 0.38),
    0 0 54px rgba(103, 178, 238, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.44);
}

.login-panel::before {
  content: "";
  position: absolute;
  left: 14%;
  right: 14%;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(125, 199, 255, 0.92) 50%, transparent 100%);
  box-shadow:
    0 0 20px rgba(125, 199, 255, 0.75),
    0 0 44px rgba(125, 199, 255, 0.32);
  pointer-events: none;
}

.login-panel::after {
  content: "";
  position: absolute;
  inset: 36px 14% auto;
  height: 180px;
  background: radial-gradient(circle at 50% 0, rgba(145, 212, 255, 0.18), transparent 70%);
  pointer-events: none;
}

.login-brand {
  display: grid;
  justify-items: center;
  text-align: center;
  gap: 10px;
  position: relative;
  z-index: 1;
  padding-bottom: 8px;
}

.login-logo {
  width: 132px;
  height: 132px;
  object-fit: contain;
  filter: drop-shadow(0 12px 24px rgba(15, 23, 42, 0.2));
}

.login-kicker {
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--muted);
}

.login-title {
  font-size: 22px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #0e2235;
  text-shadow: 0 10px 30px rgba(125, 199, 255, 0.22);
  perspective: 640px;
}

.login-subtitle {
  font-size: 12px;
  color: var(--muted);
  letter-spacing: 0.02em;
  text-transform: none;
}

.login-brand__sparkline {
  position: relative;
  width: min(300px, 100%);
  height: 12px;
  margin-top: -5px;
  margin-bottom: -4px;
  overflow: hidden;
}

.login-brand__sparkline::before,
.login-brand__sparkline::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
}

.login-brand__sparkline::before {
  left: 50%;
  top: 2px;
  width: 72%;
  height: 8px;
  transform: translateX(-50%);
  background: radial-gradient(ellipse at 50% 50%, rgba(69, 169, 244, 0.2) 0%, rgba(69, 169, 244, 0.1) 46%, transparent 74%);
  filter: blur(4px);
  opacity: 0.54;
  z-index: 0;
}

.login-brand__sparkline::after {
  content: none;
}

.login-brand__sparkline-main,
.login-brand__sparkline-core {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  border-radius: 999px;
  pointer-events: none;
}

.login-brand__sparkline-main {
  top: 5px;
  width: 86%;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(43, 103, 151, 0.18) 9%, rgba(52, 156, 235, 0.56) 26%, rgba(76, 181, 247, 0.68) 48%, rgba(76, 181, 247, 0.68) 52%, rgba(52, 156, 235, 0.56) 74%, rgba(43, 103, 151, 0.18) 91%, transparent 100%);
  box-shadow:
    0 0 7px rgba(61, 166, 246, 0.34),
    0 0 16px rgba(61, 166, 246, 0.16);
  z-index: 2;
}

.login-brand__sparkline-core {
  top: 3px;
  width: 34%;
  min-width: 82px;
  height: 5px;
  background: linear-gradient(90deg, transparent 0%, rgba(40, 148, 229, 0.14) 8%, rgba(55, 163, 242, 0.34) 34%, rgba(89, 190, 255, 0.46) 50%, rgba(55, 163, 242, 0.34) 66%, rgba(40, 148, 229, 0.14) 92%, transparent 100%);
  filter: blur(3px);
  opacity: 0.52;
  z-index: 3;
}

@media (prefers-reduced-motion: reduce) {
  .login-brand__sparkline::before,
  .login-brand__sparkline::after,
  .login-brand__sparkline-main,
  .login-brand__sparkline-core {
    animation: none;
  }
}

.login-form {
  display: grid;
  gap: 14px;
  position: relative;
  z-index: 1;
}

.auth-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.auth-tab {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  border-radius: var(--radius-md);
  border: 1px solid var(--glass-border);
  background: rgba(255, 255, 255, 0.35);
  color: var(--text);
  text-decoration: none;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  overflow: hidden;
  transition:
    transform var(--duration) var(--ease-out),
    box-shadow var(--duration) var(--ease-out),
    border-color var(--duration) var(--ease-out),
    background var(--duration-slow) var(--ease-out);
}

.auth-tab::before {
  content: "";
  position: absolute;
  pointer-events: none;
  opacity: 0;
}

.auth-tab::before {
  inset: 0;
  background:
    linear-gradient(
      110deg,
      transparent 0%,
      transparent 35%,
      rgba(255, 255, 255, 0.46) 49%,
      rgba(126, 202, 255, 0.24) 55%,
      transparent 70%,
      transparent 100%
    );
  transform: translateX(-120%);
}

.auth-tab:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 22px rgba(2, 6, 23, 0.12);
  border-color: var(--glass-border-strong);
}

.auth-tab.is-active {
  background: linear-gradient(135deg, rgba(205, 216, 227, 0.72) 0%, rgba(93, 135, 167, 0.36) 100%);
  border-color: rgba(31, 77, 122, 0.35);
}

.auth-panels {
  display: grid;
  gap: 12px;
  position: relative;
  isolation: isolate;
  overflow-anchor: none;
}

.auth-panels::before {
  content: "";
  position: absolute;
  left: -18%;
  right: -18%;
  top: -12px;
  height: calc(100% + 24px);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(
      105deg,
      transparent 0%,
      transparent 38%,
      rgba(255, 255, 255, 0.78) 49%,
      rgba(126, 202, 255, 0.34) 54%,
      transparent 66%,
      transparent 100%
    );
  filter: blur(10px);
  mix-blend-mode: screen;
  opacity: 0;
  pointer-events: none;
  transform: translateX(-60%);
  z-index: 4;
}

.auth-panels.is-auth-switching {
  overflow: hidden;
}

.auth-panels.is-auth-switching::before {
  animation: auth-panel-switch-sheen 620ms var(--ease-soft) both;
}

.auth-form.is-auth-switch-layer {
  position: absolute;
  inset: 0 0 auto 0;
  width: 100%;
}

.auth-form.is-auth-switch-incoming {
  z-index: 2;
}

.auth-form.is-auth-switch-outgoing {
  z-index: 1;
}

.auth-form.is-hidden {
  display: none;
}

@keyframes auth-panel-switch-sheen {
  0% {
    opacity: 0;
    transform: translateX(-60%);
  }

  26% {
    opacity: 0.82;
  }

  100% {
    opacity: 0;
    transform: translateX(58%);
  }
}

@media (prefers-reduced-motion: reduce) {
  .auth-panels.is-auth-switching::before {
    animation: none;
  }
}

.auth-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.auth-optional {
  color: var(--muted);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.auth-hint {
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
}

.auth-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.auth-secondary {
  padding: 12px 12px;
  border-radius: var(--radius-md);
  border: 1px solid var(--glass-border-strong);
  background: rgba(255, 255, 255, 0.22);
  color: var(--text);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out), transform var(--duration) var(--ease-out);
  width: 100%;
}

.auth-secondary:hover {
  transform: translateY(-1px);
  background: rgba(255, 255, 255, 0.32);
  border-color: rgba(31, 77, 122, 0.28);
}

.auth-actions .login-submit {
  width: 100%;
}

.auth-flash {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 10px 12px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--glass-border);
  background: rgba(255, 255, 255, 0.34);
}

.auth-flash__gif {
  width: 92px;
  height: 92px;
  object-fit: contain;
  filter: drop-shadow(0 10px 22px rgba(2, 6, 23, 0.16));
  flex: 0 0 auto;
}

.auth-flash__stack {
  min-width: 0;
  flex: 1;
}

.input-group {
  position: relative;
  display: grid;
}

.input-group input {
  padding-right: 46px;
}

.icon-btn {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 32px;
  height: 32px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--glass-border);
  background: rgba(255, 255, 255, 0.2);
  cursor: pointer;
  transition: background var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out), transform var(--duration) var(--ease-out);
}

.icon-btn:hover {
  transform: translateY(-50%) scale(1.02);
  background: rgba(255, 255, 255, 0.3);
  border-color: var(--glass-border-strong);
}

.icon-btn::before {
  content: "";
  width: 16px;
  height: 16px;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  background: currentColor;
  color: var(--text);
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 5c-7 0-10 7-10 7s3 7 10 7 10-7 10-7-3-7-10-7Zm0 12a5 5 0 1 1 5-5 5 5 0 0 1-5 5Zm0-8a3 3 0 1 0 3 3 3 3 0 0 0-3-3Z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 5c-7 0-10 7-10 7s3 7 10 7 10-7 10-7-3-7-10-7Zm0 12a5 5 0 1 1 5-5 5 5 0 0 1-5 5Zm0-8a3 3 0 1 0 3 3 3 3 0 0 0-3-3Z'/%3E%3C/svg%3E") center/contain no-repeat;
  opacity: 0.9;
}

.icon-btn.is-on::before {
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='m3 4.27 2.28 2.28A11.74 11.74 0 0 0 2 12s3 7 10 7a9.63 9.63 0 0 0 4.2-.91l2.53 2.53 1.27-1.27L4.27 3ZM12 17c-4.42 0-6.88-3.87-7.71-5A11.2 11.2 0 0 1 6.69 8l1.57 1.57A4.94 4.94 0 0 0 8 11a4 4 0 0 0 4 4 4.94 4.94 0 0 0 1.43-.26L15.23 16A8.05 8.05 0 0 1 12 17Zm7.71-5a10.93 10.93 0 0 1-1.67 2.49l-2.48-2.48A4 4 0 0 0 12 8a4.21 4.21 0 0 0-.9.1L9.16 6.16A8.11 8.11 0 0 1 12 5c4.42 0 6.88 3.87 7.71 5Z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='m3 4.27 2.28 2.28A11.74 11.74 0 0 0 2 12s3 7 10 7a9.63 9.63 0 0 0 4.2-.91l2.53 2.53 1.27-1.27L4.27 3ZM12 17c-4.42 0-6.88-3.87-7.71-5A11.2 11.2 0 0 1 6.69 8l1.57 1.57A4.94 4.94 0 0 0 8 11a4 4 0 0 0 4 4 4.94 4.94 0 0 0 1.43-.26L15.23 16A8.05 8.05 0 0 1 12 17Zm7.71-5a10.93 10.93 0 0 1-1.67 2.49l-2.48-2.48A4 4 0 0 0 12 8a4.21 4.21 0 0 0-.9.1L9.16 6.16A8.11 8.11 0 0 1 12 5c4.42 0 6.88 3.87 7.71 5Z'/%3E%3C/svg%3E") center/contain no-repeat;
}

.errorlist {
  list-style: none;
  margin-top: 8px;
  padding: 10px 12px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(239, 68, 68, 0.35);
  background: rgba(239, 68, 68, 0.12);
  color: var(--text);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  display: grid;
  gap: 6px;
}

.login-error {
  padding: 10px 12px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(239, 68, 68, 0.4);
  background: rgba(239, 68, 68, 0.12);
  color: var(--text);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.login-field {
  display: grid;
  gap: 6px;
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  position: relative;
  isolation: isolate;
  z-index: 0;
  --login-field-fx-top: 22px;
  --login-field-fx-height: 42px;
}

.login-field:focus-within,
.login-field.is-combobox-open {
  z-index: 20;
}

.login-field > * {
  position: relative;
  z-index: 1;
}

.login-field__sheen,
.login-field__focus-ring {
  position: absolute;
  left: -2px;
  right: -2px;
  top: calc(var(--login-field-fx-top) - 2px);
  height: calc(var(--login-field-fx-height) + 4px);
  border-radius: calc(var(--radius-md) + 2px);
  pointer-events: none;
  opacity: 0;
  z-index: 0;
}

.login-field__sheen {
  background:
    linear-gradient(
      112deg,
      transparent 0%,
      transparent 38%,
      rgba(255, 255, 255, 0.88) 49%,
      rgba(143, 213, 255, 0.52) 54%,
      transparent 63%,
      transparent 100%
    );
  background-size: 240% 100%;
  background-position: 140% 50%;
  filter: blur(8px);
  mix-blend-mode: screen;
}

.login-field__focus-ring {
  border: 1px solid rgba(98, 167, 226, 0.54);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(132, 196, 245, 0.04));
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.08),
    0 16px 30px rgba(58, 129, 193, 0.14),
    0 0 0 0 rgba(93, 167, 229, 0.18);
  transform: scale(0.985);
}

.login-field > input,
.login-field > .input-group input {
  padding: 10px 12px;
  border-radius: var(--radius-md);
  border: 1px solid var(--input-border);
  background: var(--input-bg);
  color: var(--text);
  font-size: 13px;
  outline: none;
  transition: box-shadow var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out);
}

.login-field select {
  padding: 10px 34px 10px 12px;
  border-radius: var(--radius-md);
  border: 1px solid var(--input-border);
  background: var(--input-bg);
  color: var(--text);
  font-size: 13px;
  outline: none;
  appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--muted) 50%),
    linear-gradient(135deg, var(--muted) 50%, transparent 50%);
  background-position:
    calc(100% - 15px) calc(50% - 1px),
    calc(100% - 10px) calc(50% - 1px);
  background-size: 5px 6px, 5px 6px;
  background-repeat: no-repeat;
  transition: box-shadow var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out);
}

.login-field select:focus {
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--focus);
}

.login-field select:disabled {
  color: var(--muted);
  background: var(--input-bg);
  opacity: 0.9;
}

.login-field .filter-combobox {
  min-width: 0;
  width: 100%;
}

.login-field .filter-combobox__control {
  width: 100%;
  min-height: 42px;
  padding-left: 12px;
  padding-right: 6px;
  border-radius: var(--radius-md);
  border-color: var(--input-border);
  background: var(--input-bg);
  outline: none;
}

.login-field .filter-combobox.filter-combobox--field .filter-combobox__control {
  padding-left: 12px;
  padding-right: 4px;
}

.login-field .filter-combobox__input {
  width: 0;
  min-width: 0;
  height: 40px;
  min-height: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--text);
  font-size: 13px;
  line-height: 1.3;
  letter-spacing: normal;
  text-transform: none;
  outline: none;
  padding: 10px 8px 10px 0;
  font-family: inherit;
  box-shadow: none;
  flex: 1 1 0;
}

.login-field .filter-combobox.filter-combobox--field .filter-combobox__input {
  padding-right: 8px;
  cursor: pointer;
}

.login-field .filter-combobox__input:focus {
  border: 0;
  box-shadow: none;
}

.login-field .filter-combobox__toggle {
  width: 30px;
  height: 30px;
  color: var(--muted);
}

.login-field .filter-combobox.filter-combobox--field .filter-combobox__toggle {
  width: 30px;
  height: 30px;
  margin-left: 0;
  border-radius: 8px;
  color: var(--muted);
}

.login-field .filter-combobox__toggle:hover,
.login-field .filter-combobox__clear:hover {
  color: var(--text);
}

.login-field .filter-combobox__menu {
  z-index: 60;
  border-color: rgba(128, 160, 189, 0.42);
  background:
    linear-gradient(180deg, rgba(247, 250, 252, 0.985) 0%, rgba(232, 240, 247, 0.965) 100%);
  box-shadow:
    0 24px 42px rgba(15, 23, 42, 0.18),
    0 10px 22px rgba(62, 102, 138, 0.12);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
}

.login-field .filter-combobox.filter-combobox--field .filter-combobox__menu {
  top: calc(100% + 6px);
}

.login-field .filter-combobox.filter-combobox--drop-up .filter-combobox__menu {
  top: auto;
  bottom: calc(100% + 6px);
}

.login-field .filter-combobox__option {
  font-size: 13px;
  letter-spacing: normal;
  text-transform: none;
  background: rgba(255, 255, 255, 0.92);
  border-color: rgba(194, 207, 221, 0.48);
}

.login-field .filter-combobox__empty {
  font-size: 12px;
  letter-spacing: normal;
  text-transform: none;
}

.login-field .filter-combobox__option:hover,
.login-field .filter-combobox__option.is-active {
  background: rgba(223, 234, 244, 0.98);
  border-color: rgba(131, 161, 189, 0.42);
}

.login-field .filter-combobox__option.is-selected {
  background: linear-gradient(135deg, rgba(220, 234, 246, 0.98) 0%, rgba(204, 223, 239, 0.96) 100%);
  border-color: rgba(113, 148, 181, 0.5);
}

.login-field .filter-combobox__control:focus-within,
.login-field .filter-combobox.is-open .filter-combobox__control,
.login-field .filter-combobox.filter-combobox--field .filter-combobox__control:focus-within,
.login-field .filter-combobox.filter-combobox--field.is-open .filter-combobox__control {
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--focus);
}

.login-field > input:focus,
.login-field > .input-group input:focus {
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--focus);
}

.login-submit {
  padding: 10px 14px;
  border-radius: var(--radius-md);
  border: 1px solid var(--accent-strong);
  background: linear-gradient(135deg, var(--silver-1) 0%, var(--accent-2) 100%);
  color: var(--text);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  cursor: pointer;
  transition: transform var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out), filter var(--duration) var(--ease-out);
}

.login-submit:hover {
  transform: translate3d(0, -2px, 0);
  box-shadow: 0 16px 28px rgba(2, 6, 23, 0.18);
}

.login-links {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.auth-tabs,
.auth-flash,
.auth-actions,
.login-links,
.login-form > .login-submit {
  backface-visibility: hidden;
  transform: translateZ(0);
}

.login-link {
  color: var(--text);
  text-decoration: none;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.85;
}

.login-link:hover {
  color: var(--accent-strong);
  text-decoration: underline;
  text-underline-offset: 4px;
}

.login-loading {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  background: rgba(15, 23, 42, 0.35);
  backdrop-filter: blur(8px) saturate(120%);
  -webkit-backdrop-filter: blur(8px) saturate(120%);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--duration-slow) var(--ease-soft);
  z-index: 10;
}

.login-loading__panel {
  padding: 30px 34px;
  border-radius: var(--radius-lg);
  background: linear-gradient(160deg, rgba(248, 250, 252, 0.9) 0%, rgba(205, 216, 227, 0.8) 100%);
  border: 1px solid var(--glass-border);
  box-shadow: var(--shadow-strong);
  display: grid;
  gap: 12px;
  text-align: center;
  color: var(--text);
  min-width: 260px;
  position: relative;
  overflow: hidden;
}

.login-loading__panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(220px 140px at 30% 20%, rgba(31, 77, 122, 0.18), transparent 70%);
  pointer-events: none;
}

.login-loading__panel img {
  width: 240px;
  height: 240px;
  object-fit: contain;
  margin: 0 auto;
}

body.is-loading .login-loading {
  opacity: 1;
  pointer-events: auto;
}

html.has-post-login-fx body[data-eyeq-page="home"] #app-shell {
  opacity: 0;
}

[data-page-transition-target] {
  min-width: 0;
}

body.is-page-transitioning [data-page-transition-target] {
  pointer-events: none;
}

body.is-theme-transitioning #app-shell {
  will-change: transform, filter;
}

body.is-post-login-entering #app-shell {
  will-change: opacity, transform, filter;
}

body.is-density-transitioning .content,
body.is-density-transitioning .board__panel,
body.is-density-transitioning .board__row,
body.is-density-transitioning .company {
  will-change: transform, opacity, filter;
}

.page-theme-frost {
  position: fixed;
  inset: 0;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  z-index: 9999;
  overflow: hidden;
  will-change: opacity, visibility;
}

.page-theme-frost.is-active {
  visibility: visible;
}

.page-theme-frost__veil,
.page-theme-frost__sheen,
.page-theme-frost__glint {
  position: absolute;
  inset: 0;
  will-change: opacity, filter, transform;
}

.page-theme-frost__veil {
  background:
    radial-gradient(
      1200px 780px at 50% 18%,
      var(--theme-frost-mist, rgba(230, 239, 247, 0.58)) 0%,
      transparent 76%
    ),
    linear-gradient(155deg, var(--theme-frost-veil, rgba(248, 250, 252, 0.48)) 0%, transparent 78%);
  backdrop-filter: blur(16px) saturate(0.96);
}

.page-theme-frost__sheen {
  background:
    linear-gradient(
      110deg,
      transparent 0%,
      transparent 36%,
      var(--theme-frost-sheen, rgba(255, 255, 255, 0.28)) 50%,
      transparent 64%,
      transparent 100%
    );
}

.page-theme-frost__glint {
  background:
    radial-gradient(
      760px 420px at 50% 50%,
      var(--theme-frost-glint, rgba(126, 185, 232, 0.24)) 0%,
      transparent 74%
    );
  mix-blend-mode: screen;
}

@media (max-width: 700px) {
  .login-screen {
    align-items: flex-start;
    padding: 24px 14px 40px;
  }

  .login-panel,
  .login-panel--wide {
    width: min(100%, 100%);
    margin-block: 0;
    padding: 24px 18px;
  }

  .login-brand__sparkline {
    width: 100%;
  }

  .login-sparkles__orb--left {
    width: 220px;
    height: 220px;
    left: -90px;
  }

  .login-sparkles__orb--right {
    width: 260px;
    height: 260px;
    right: -120px;
  }
}

/* Account */
.account-header {
  display: grid;
  gap: 4px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--glass-border);
}

.account-title {
  font-size: 16px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.account-title--small {
  font-size: 13px;
  letter-spacing: 0.12em;
}

.account-header--compact {
  margin-top: 14px;
  border-bottom: none;
  padding-bottom: 0;
}

.account-subtitle {
  font-size: 12px;
  color: var(--muted);
  letter-spacing: 0.02em;
  text-transform: none;
}

.account-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  padding: 10px 0 4px;
}

.account-meta__item {
  border-radius: var(--radius-lg);
  border: 1px solid var(--glass-border);
  background: rgba(255, 255, 255, 0.32);
  padding: 8px 10px;
  display: grid;
  gap: 4px;
}

.account-meta__label {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
}

.account-meta__value {
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text);
  word-break: break-word;
}

.rubrica-toolbar {
  --rubrica-toolbar-control-height: 44px;
  --rubrica-toolbar-control-radius: 14px;
  --rubrica-toolbar-control-padding: 18px;
  --rubrica-filter-field-height: 34px;
  --rubrica-filter-field-radius: 11px;
  --rubrica-filter-button-height: 34px;
  --rubrica-filter-button-radius: 11px;
  --rubrica-filter-button-padding: 12px;
  --rubrica-tab-height: 34px;
  --rubrica-tab-radius: 12px;
  --rubrica-tab-padding: 14px;
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}

[data-rubrica-root][data-rubrica-loading="true"] {
  pointer-events: none;
}

[data-rubrica-root].is-switching {
  animation: employee-pane-enter 240ms var(--ease-out);
}

.rubrica-tabs {
  position: relative;
  display: flex;
  align-items: flex-end;
  gap: 6px;
  flex: 1 1 0;
  min-width: 0;
  margin-top: 0;
  padding-top: 0;
  padding-bottom: 0;
  overflow-x: auto;
  overflow-y: hidden;
  border-bottom: 1px solid var(--glass-border);
  isolation: isolate;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.rubrica-tabs::-webkit-scrollbar {
  display: none;
}

.rubrica-tab {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 2;
  min-height: 46px;
  padding: 0 16px;
  border: 0;
  border-radius: 14px 14px 0 0;
  background: transparent;
  color: var(--muted);
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  text-transform: none;
  letter-spacing: 0;
  white-space: nowrap;
  cursor: pointer;
  transition:
    transform var(--duration) var(--ease-out),
    color var(--duration) var(--ease-out);
}

.rubrica-tab:hover {
  transform: translateY(-1px);
  color: var(--accent-strong);
}

.rubrica-tab:focus-visible {
  outline: none;
  transform: translateY(-1px);
  color: var(--accent-strong);
}

.rubrica-tab[data-cursor-target="true"],
.rubrica-tab:hover,
.rubrica-tab:focus-visible {
  color: var(--accent-strong);
}

.rubrica-tab.is-active {
  color: var(--accent-strong);
}

.rubrica-tabs__cursor {
  position: absolute;
  left: 0;
  bottom: -1px;
  z-index: 1;
  width: 0;
  height: 46px;
  border-radius: 14px 14px 0 0;
  border: 1px solid rgba(31, 77, 122, 0.18);
  border-bottom-color: transparent;
  background:
    radial-gradient(circle at 50% 0%, rgba(255, 255, 255, 0.48) 0%, transparent 64%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.94) 0%, rgba(233, 240, 248, 0.82) 100%);
  box-shadow:
    0 12px 24px rgba(31, 77, 122, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.44);
  opacity: 0;
  transform: translateX(0);
  transition:
    transform 280ms cubic-bezier(0.22, 1, 0.36, 1),
    width 280ms cubic-bezier(0.22, 1, 0.36, 1),
    height 280ms cubic-bezier(0.22, 1, 0.36, 1),
    opacity 180ms ease-out;
  pointer-events: none;
}

.rubrica-tabs__cursor::after {
  content: "";
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 0;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--accent-2), var(--accent));
}

.rubrica-filter-form {
  flex: 0 1 560px;
  width: min(100%, 560px);
  max-width: 100%;
  margin-top: 0;
}

.rubrica-filter-shell {
  display: grid;
  grid-template-columns: minmax(320px, 1fr) repeat(2, minmax(92px, auto));
  gap: 8px;
  align-items: end;
}

.rubrica-filter-field {
  gap: 4px;
  min-width: 0;
}

.rubrica-filter-field select,
.rubrica-filter-field .filter-combobox__control,
.rubrica-filter-shell .btn {
  min-height: var(--rubrica-toolbar-control-height);
  border-radius: var(--rubrica-toolbar-control-radius);
}

.rubrica-filter-field select,
.rubrica-filter-field .filter-combobox,
.rubrica-filter-field .filter-combobox__control {
  width: 100%;
  min-width: 0;
}

.rubrica-filter-field select {
  min-height: var(--rubrica-filter-field-height);
  border-radius: var(--rubrica-filter-field-radius);
  padding-left: 14px;
  padding-right: 34px;
}

.rubrica-filter-field .filter-combobox__control {
  min-height: var(--rubrica-filter-field-height);
  border-radius: var(--rubrica-filter-field-radius);
  padding-left: 14px;
  padding-right: 8px;
}

.rubrica-filter-field .filter-combobox__input {
  height: calc(var(--rubrica-filter-field-height) - 6px);
  padding-top: 6px;
  padding-bottom: 6px;
}

.rubrica-filter-field .filter-combobox__clear,
.rubrica-filter-field .filter-combobox__toggle {
  width: 28px;
  height: 28px;
}

.rubrica-filter-shell .btn {
  width: 100%;
  min-width: 92px;
  min-height: var(--rubrica-filter-button-height);
  padding: 0 var(--rubrica-filter-button-padding);
  border-radius: var(--rubrica-filter-button-radius);
  font-size: 10px;
  letter-spacing: 0.08em;
}

.rubrica-layout {
  grid-template-columns: 1fr;
  margin-top: 14px;
}

.board__panel[data-rubrica-root] {
  overflow: visible;
}

.board__panel[data-rubrica-root] .filter-combobox.is-open {
  z-index: 120;
}

.rubrica-pane {
  display: grid;
  gap: 18px;
}

.rubrica-pane.is-switching {
  animation: employee-pane-enter 240ms var(--ease-out);
}

.rubrica-pane[hidden] {
  display: none !important;
}

.rubrica-table-wrap {
  overflow: auto;
  border-radius: 16px;
  border: 1px solid var(--glass-border);
  background: linear-gradient(160deg, color-mix(in srgb, var(--glass-strong) 92%, white) 0%, color-mix(in srgb, var(--glass) 96%, transparent) 100%);
}

.rubrica-company-cell {
  display: grid;
  gap: 6px;
  min-width: 0;
  max-width: 100%;
}

.rubrica-company-cell__viewport {
  position: relative;
  width: min(100%, 32rem);
  max-width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  padding-block: 2px;
  scrollbar-width: none;
  -ms-overflow-style: none;
  -webkit-mask-image: linear-gradient(90deg, transparent 0, black 14px, black calc(100% - 14px), transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0, black 14px, black calc(100% - 14px), transparent 100%);
}

.rubrica-company-cell__viewport::-webkit-scrollbar {
  display: none;
}

.rubrica-company-cell__track {
  display: inline-flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 6px;
  min-width: 0;
  width: max-content;
  padding-right: 6px;
}

.rubrica-company-cell__meta {
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.rubrica-company-pill {
  flex: 0 0 auto;
  min-width: 0;
  max-width: 11.75rem;
  justify-content: center;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: 1.2;
}

.rubrica-company-pill--muted {
  opacity: 0.72;
}

.rubrica-form-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.rubrica-form-grid--user {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.rubrica-form-grid .filter-combobox--field .filter-combobox__menu,
.pc-asset-status-edit .filter-combobox--field .filter-combobox__menu {
  padding: 2px;
  border-radius: 10px;
}

.rubrica-form-grid .filter-combobox--field .filter-combobox__list,
.pc-asset-status-edit .filter-combobox--field .filter-combobox__list {
  gap: 1px;
  max-height: min(168px, var(--filter-combobox-available-height, 24vh));
}

.rubrica-form-grid .filter-combobox--field .filter-combobox__option,
.pc-asset-status-edit .filter-combobox--field .filter-combobox__option {
  padding: 5px 10px;
  border-radius: 7px;
  font-size: 11px;
  line-height: 1.15;
}

.account-field--pc-assignee {
  position: relative;
}

[data-pc-assignee-field] {
  position: relative;
}

.rubrica-form-grid {
  --rubrica-form-control-height: 32px;
}

.account-field--pc-assignee.is-open {
  z-index: 121;
}

[data-pc-assignee-field].is-open {
  z-index: 121;
}

[data-rubrica-root] .rubrica-form-grid .account-field > input:not([type="hidden"]),
[data-rubrica-root] .rubrica-form-grid .account-field > select,
[data-rubrica-root] .rubrica-form-grid .account-field--pc-assignee .pc-assignee-field-shell > input[data-pc-assignee-input],
[data-rubrica-root] .rubrica-form-grid .account-field > .filter-combobox .filter-combobox__control {
  min-height: var(--rubrica-form-control-height);
  height: var(--rubrica-form-control-height);
}

[data-rubrica-root] .rubrica-form-grid .account-field--pc-assignee .pc-assignee-field-shell > input[data-pc-assignee-input] {
  display: block;
  width: 100%;
  box-sizing: border-box;
  padding: 0 10px;
  font-size: 12px;
  line-height: 1.2;
}

[data-rubrica-root] [data-pc-assignee-field] > input[data-pc-assignee-input] {
  display: block;
  width: 100%;
  box-sizing: border-box;
  padding: 0 10px;
  font-size: 12px;
  line-height: 1.2;
}

.account-field--pc-assignee .pc-assignee-field-shell {
  display: block;
  position: relative;
  width: 100%;
}

.pc-assignee-inline-shell {
  display: block;
  position: relative;
  width: 100%;
}

.js .account-field--pc-assignee .pc-assignee-selector.is-ready {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  gap: 0;
  z-index: 24;
}

.js [data-pc-assignee-field] .pc-assignee-selector.is-ready {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  gap: 0;
  z-index: 24;
}

.account-field--pc-assignee .work-groups-member-selector__dropdown {
  margin-top: 0;
  border-radius: 14px;
}

.account-field--pc-assignee .work-groups-member-selector__list {
  max-height: 210px;
}

.account-field--pc-assignee .work-groups-member-selector__option {
  padding: 7px 8px;
}

.account-field--pc-assignee .work-groups-member-selector__option-name {
  font-size: 11px;
}

.account-field--pc-assignee .work-groups-member-selector__option-email,
.account-field--pc-assignee .work-groups-member-selector__status,
.account-field--pc-assignee .work-groups-member-selector__list-empty {
  font-size: 11px;
}

.rubrica-table-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 12px;
  margin-bottom: 8px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--glass-border);
}

.rubrica-table-head__meta {
  display: grid;
  gap: 6px;
  min-width: 0;
}

.rubrica-table-head__title {
  margin: 0;
  font-size: 13px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text);
}

.rubrica-table-head__subtitle {
  margin: 0;
  max-width: 780px;
  font-size: 11px;
  line-height: 1.4;
  letter-spacing: 0;
  text-transform: none;
  color: var(--muted);
}

.rubrica-sort-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.rubrica-sort-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid var(--glass-border-strong);
  background: linear-gradient(160deg, rgba(255, 255, 255, 0.72) 0%, rgba(232, 239, 246, 0.82) 100%);
  color: var(--muted);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  white-space: nowrap;
  transition:
    transform var(--duration) var(--ease-out),
    border-color var(--duration) var(--ease-out),
    box-shadow var(--duration) var(--ease-out),
    color var(--duration) var(--ease-out),
    background var(--duration) var(--ease-out);
}

.rubrica-sort-tab:hover,
.rubrica-sort-tab:focus-visible {
  color: var(--text);
  border-color: color-mix(in srgb, var(--accent) 40%, var(--glass-border-strong));
  transform: translateY(-1px);
}

.rubrica-sort-tab:focus-visible {
  outline: none;
  box-shadow:
    0 0 0 3px color-mix(in srgb, var(--accent-soft) 40%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.rubrica-sort-tab.is-active {
  color: #f8fafc;
  border-color: transparent;
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);
  box-shadow:
    0 10px 22px rgba(31, 77, 122, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

.rubrica-table-head__actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

.rubrica-table-toggle {
  width: 38px;
  min-width: 38px;
  height: 38px;
  padding: 0;
  display: inline-grid;
  place-items: center;
  border-radius: 11px;
}

.rubrica-bulk-form {
  display: grid;
}

.rubrica-table-input,
.rubrica-table-select {
  width: 100%;
  min-width: 0;
  padding: 6px 8px;
  border-radius: 10px;
  border: 1px solid var(--glass-border-strong);
  background: linear-gradient(160deg, var(--glass-strong) 0%, var(--glass) 100%);
  color: var(--text);
  font: inherit;
  font-size: 12px;
}

.rubrica-table-select {
  appearance: none;
}

.rubrica-row-actions {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0;
}

.rubrica-row-actions__form {
  display: inline-flex;
  margin: 0;
}

.rubrica-row-action {
  width: 38px;
  min-width: 38px;
  height: 38px;
  min-height: 38px;
  padding: 0;
  border-radius: 11px;
  font-size: 13px;
  display: inline-grid;
  place-items: center;
}

.rubrica-table-toggle .fa-pencil {
  width: 14px;
  height: 14px;
  flex: 0 0 14px;
}

.rubrica-row-action .fa-solid.fa-trash,
.rubrica-row-action .fa-regular.fa-trash {
  width: 14px;
  height: 14px;
  flex: 0 0 14px;
}

.rubrica-row-action.is-active {
  border-color: var(--accent);
  color: var(--accent-strong);
  box-shadow: inset 0 0 0 1px var(--accent-soft);
}

.rubrica-row-action--danger:hover,
.rubrica-row-action--danger:focus-visible {
  border-color: #b91c1c;
  color: #b91c1c;
}

.rubrica-table-actions {
  width: 80px;
  text-align: center;
}

.rubrica-bulk-form td .filter-combobox {
  display: block;
  width: 100%;
  max-width: 100%;
}

.rubrica-bulk-form td .filter-combobox__control {
  min-height: 30px;
  height: 30px;
  padding-left: 9px;
  padding-right: 2px;
  border-radius: 10px;
  border-color: rgba(93, 135, 167, 0.18);
  background: rgba(255, 255, 255, 0.38);
  box-sizing: border-box;
  outline: none;
  box-shadow: none;
}

.rubrica-bulk-form td .filter-combobox__input {
  width: 100%;
  min-width: 0;
  height: 28px;
  min-height: 0;
  padding: 5px 4px 5px 0;
  border: 0 !important;
  border-radius: 0;
  background: transparent !important;
  color: var(--text);
  font-size: 12px;
  line-height: 1.15;
  font-family: inherit;
  outline: none;
  box-shadow: none !important;
  flex: 1 1 auto;
  cursor: pointer;
  caret-color: transparent;
  user-select: none;
  pointer-events: none;
  -webkit-user-select: none;
  appearance: none;
  -webkit-appearance: none;
}

.rubrica-bulk-form td .filter-combobox__input::selection {
  background: transparent;
  color: inherit;
}

.rubrica-bulk-form td .filter-combobox__input::-moz-selection {
  background: transparent;
  color: inherit;
}

.rubrica-bulk-form td .filter-combobox.filter-combobox--field .filter-combobox__control:focus,
.rubrica-bulk-form td .filter-combobox.filter-combobox--field .filter-combobox__control:focus-visible,
.rubrica-bulk-form td .filter-combobox.filter-combobox--field .filter-combobox__control:focus-within,
.rubrica-bulk-form td .filter-combobox.filter-combobox--field.is-open .filter-combobox__control {
  border-color: rgba(93, 135, 167, 0.24);
  background: rgba(255, 255, 255, 0.48);
  outline: none;
  box-shadow: none;
}

.rubrica-bulk-form td .filter-combobox__clear,
.rubrica-bulk-form td .filter-combobox__toggle {
  width: 28px;
  height: 28px;
  flex: 0 0 28px;
}

.rubrica-bulk-form td .filter-combobox--field .filter-combobox__toggle {
  margin-left: 0;
}

.pc-asset-status-edit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  max-width: 100%;
  min-width: 0;
  margin-inline: auto;
  gap: 0;
}

.pc-asset-status-heading,
.pc-asset-status-cell {
  width: 15%;
  min-width: 0;
  vertical-align: middle !important;
  overflow: visible;
}

[data-rubrica-root] .pc-asset-table .pc-asset-status-heading,
[data-rubrica-root] .pc-asset-table .pc-asset-status-cell {
  text-align: center;
}

.pc-asset-status-picker {
  width: 100%;
  max-width: 156px;
  margin-inline: auto;
  flex: 0 1 156px;
}

.pc-asset-status-picker__native-select {
  width: 100%;
  min-width: 0;
  min-height: 32px;
  height: 32px;
  padding: 0 34px 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, 0.24);
  background: rgba(255, 255, 255, 0.62);
  color: var(--text);
  font: inherit;
  font-size: 12px;
  font-weight: 600;
  appearance: none;
}

.pc-asset-status-picker__trigger {
  display: none;
}

.js .pc-asset-status-picker.is-ready .pc-asset-status-picker__native-select {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  opacity: 0;
  pointer-events: none;
  clip: rect(0 0 0 0);
  overflow: hidden;
}

.js .pc-asset-status-picker.is-ready .pc-asset-status-picker__trigger {
  display: flex;
}

.pc-asset-status-picker__trigger {
  width: 100%;
  min-width: 0;
  min-height: 32px;
  height: 32px;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, 0.24);
  background: rgba(255, 255, 255, 0.62);
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 14px;
  font-size: 12px;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  transition:
    border-color var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out),
    transform var(--duration-fast) var(--ease-out);
}

.pc-asset-status-picker__trigger:hover {
  transform: translateY(-1px);
}

.pc-asset-status-picker.is-open .pc-asset-status-picker__trigger {
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--focus) 38%, transparent);
}

.pc-asset-status-picker__dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: currentColor;
  opacity: 0.85;
  flex: 0 0 auto;
}

.pc-asset-status-picker__label {
  flex: 1 1 auto;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  text-align: left;
  line-height: 1.2;
}

.pc-asset-status-picker__chevron {
  width: 8px;
  height: 8px;
  flex: 0 0 auto;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg) translateY(-1px);
  transform-origin: center;
  transition: transform var(--duration-fast) var(--ease-out);
}

.pc-asset-status-picker.is-open .pc-asset-status-picker__chevron {
  transform: rotate(-135deg) translateY(-1px);
}

.pc-asset-status-picker[data-status-tone="success"] .pc-asset-status-picker__trigger {
  color: #4d7a12;
  border-color: rgba(77, 122, 18, 0.22);
  background: rgba(236, 248, 215, 0.96);
}

.pc-asset-status-picker[data-status-tone="warning"] .pc-asset-status-picker__trigger {
  color: #966500;
  border-color: rgba(150, 101, 0, 0.22);
  background: rgba(255, 241, 205, 0.96);
}

.pc-asset-status-picker[data-status-tone="danger"] .pc-asset-status-picker__trigger {
  color: #a53939;
  border-color: rgba(165, 57, 57, 0.22);
  background: rgba(255, 223, 223, 0.96);
}

.pc-asset-status-picker[data-status-tone="muted"] .pc-asset-status-picker__trigger {
  color: #556273;
  border-color: rgba(85, 98, 115, 0.2);
  background: rgba(226, 232, 240, 0.92);
}

.pc-asset-status-cell .employee-status-pill {
  width: 100%;
  max-width: 156px;
  justify-content: center;
  margin-inline: auto;
}

.pc-asset-status-picker__menu {
  position: fixed;
  z-index: 260;
  display: grid;
  gap: 6px;
  padding: 6px;
  border-radius: 16px;
  border: 1px solid var(--glass-border);
  background:
    radial-gradient(circle at top right, rgba(125, 199, 255, 0.18), transparent 42%),
    linear-gradient(165deg, color-mix(in srgb, var(--glass-strong) 96%, white) 0%, color-mix(in srgb, var(--glass) 96%, transparent) 100%);
  box-shadow: 0 18px 38px rgba(15, 23, 42, 0.16);
  backdrop-filter: blur(18px) saturate(145%);
  -webkit-backdrop-filter: blur(18px) saturate(145%);
}

.pc-asset-status-picker__menu[hidden] {
  display: none !important;
}

.pc-asset-status-picker__option {
  width: 100%;
  min-width: 0;
  border: 1px solid transparent;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.2);
  color: var(--text);
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  font-size: 12px;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  text-align: left;
  transition:
    background var(--duration-fast) var(--ease-out),
    transform var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out);
}

.pc-asset-status-picker__option:hover,
.pc-asset-status-picker__option:focus-visible {
  transform: translateY(-1px);
  outline: none;
}

.pc-asset-status-picker__option-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: currentColor;
  opacity: 0.85;
  flex: 0 0 auto;
}

.pc-asset-status-picker__option-label {
  min-width: 0;
  line-height: 1.2;
}

.pc-asset-status-picker__option-check {
  width: 16px;
  height: 16px;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, 0.32);
  display: grid;
  place-items: center;
  flex: 0 0 auto;
}

.pc-asset-status-picker__option-check::after {
  content: "";
  width: 4px;
  height: 8px;
  border-right: 2px solid transparent;
  border-bottom: 2px solid transparent;
  transform: rotate(45deg) translate(-1px, -1px);
}

.pc-asset-status-picker__option.is-selected .pc-asset-status-picker__option-check {
  background: currentColor;
  border-color: currentColor;
}

.pc-asset-status-picker__option.is-selected .pc-asset-status-picker__option-check::after {
  border-color: #fff;
}

.pc-asset-status-picker__option--success {
  color: #4d7a12;
  background: rgba(236, 248, 215, 0.82);
}

.pc-asset-status-picker__option--success:hover,
.pc-asset-status-picker__option--success:focus-visible,
.pc-asset-status-picker__option--success.is-selected {
  background: rgba(224, 242, 188, 0.96);
}

.pc-asset-status-picker__option--warning {
  color: #966500;
  background: rgba(255, 241, 205, 0.84);
}

.pc-asset-status-picker__option--warning:hover,
.pc-asset-status-picker__option--warning:focus-visible,
.pc-asset-status-picker__option--warning.is-selected {
  background: rgba(255, 233, 184, 0.96);
}

.pc-asset-status-picker__option--danger {
  color: #a53939;
  background: rgba(255, 223, 223, 0.84);
}

.pc-asset-status-picker__option--danger:hover,
.pc-asset-status-picker__option--danger:focus-visible,
.pc-asset-status-picker__option--danger.is-selected {
  background: rgba(255, 208, 208, 0.96);
}

.pc-asset-status-edit .btn {
  width: fit-content;
  min-height: 34px;
  padding-inline: 12px;
}

.js .pc-asset-status-picker.is-ready + .pc-asset-status-edit__submit {
  display: none;
}

.pc-asset-status-edit__errors,
.pc-asset-status-edit__errors .errorlist {
  margin: 0;
  padding: 0;
  list-style: none;
  color: #a53939;
  font-size: 11px;
  line-height: 1.35;
}

.pc-asset-table-wrap {
  overflow: hidden;
}

.pc-asset-table {
  min-width: 0;
}

.pc-asset-bulk-form .filter-combobox {
  display: block;
  width: 100%;
  max-width: 100%;
}

[data-rubrica-root] .pc-asset-bulk-form td.pc-asset-cell-text {
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
}

[data-rubrica-root] .pc-asset-bulk-form td .filter-combobox__control {
  min-height: 30px;
  height: 30px;
  padding-left: 9px;
  padding-right: 2px;
  border-radius: 10px;
  border-color: rgba(93, 135, 167, 0.18);
  background: rgba(255, 255, 255, 0.38);
  box-sizing: border-box;
  outline: none;
  box-shadow: none;
}

[data-rubrica-root] .pc-asset-bulk-form td .filter-combobox__input {
  width: 100%;
  min-width: 0;
  height: 28px;
  min-height: 0;
  padding: 5px 4px 5px 0;
  border: 0 !important;
  border-radius: 0;
  background: transparent !important;
  color: var(--text);
  font-size: 12px;
  line-height: 1.15;
  font-family: inherit;
  outline: none;
  box-shadow: none !important;
  flex: 1 1 auto;
  cursor: pointer;
  caret-color: transparent;
  user-select: none;
  pointer-events: none;
  -webkit-user-select: none;
  appearance: none;
  -webkit-appearance: none;
}

[data-rubrica-root] .pc-asset-bulk-form td .filter-combobox__input::selection {
  background: transparent;
  color: inherit;
}

[data-rubrica-root] .pc-asset-bulk-form td .filter-combobox__input::-moz-selection {
  background: transparent;
  color: inherit;
}

[data-rubrica-root] .pc-asset-bulk-form td .filter-combobox.filter-combobox--field .filter-combobox__control:focus,
[data-rubrica-root] .pc-asset-bulk-form td .filter-combobox.filter-combobox--field .filter-combobox__control:focus-visible,
[data-rubrica-root] .pc-asset-bulk-form td .filter-combobox.filter-combobox--field .filter-combobox__control:focus-within,
[data-rubrica-root] .pc-asset-bulk-form td .filter-combobox.filter-combobox--field.is-open .filter-combobox__control {
  border-color: rgba(93, 135, 167, 0.24);
  background: rgba(255, 255, 255, 0.48);
  outline: none;
  box-shadow: none;
}

[data-rubrica-root] .pc-asset-bulk-form td .filter-combobox__clear,
[data-rubrica-root] .pc-asset-bulk-form td .filter-combobox__toggle {
  width: 28px;
  height: 28px;
  flex: 0 0 28px;
}

[data-rubrica-root] .pc-asset-bulk-form td .filter-combobox--field .filter-combobox__toggle {
  margin-left: 0;
}

[data-rubrica-root] .pc-asset-bulk-form td .filter-combobox--floating-menu .filter-combobox__menu {
  position: fixed;
  right: auto;
  z-index: 320;
}

body > .filter-combobox__menu {
  position: fixed;
  right: auto;
  z-index: 320;
}

body > .filter-combobox__menu[aria-hidden="false"] {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0) scale(1);
  transition:
    opacity 180ms ease-out,
    transform 220ms cubic-bezier(0.22, 1, 0.36, 1),
    visibility 0ms linear 0ms;
}

body > .filter-combobox__menu--drop-up {
  transform: translateY(6px) scale(0.985);
  transform-origin: bottom center;
}

body > .filter-combobox__menu--drop-up[aria-hidden="false"] {
  transform: translateY(0) scale(1);
}

body > .filter-combobox__menu,
[data-rubrica-root] .pc-asset-bulk-form td .filter-combobox__menu {
  padding: 3px;
  border-radius: 11px;
}

body > .filter-combobox__menu .filter-combobox__list,
[data-rubrica-root] .pc-asset-bulk-form td .filter-combobox__list {
  gap: 2px;
  max-height: min(180px, var(--filter-combobox-available-height, 26vh));
}

body > .filter-combobox__menu .filter-combobox__option,
[data-rubrica-root] .pc-asset-bulk-form td .filter-combobox__option {
  padding: 7px 9px;
  border-radius: 8px;
  font-size: 12px;
  line-height: 1.1;
}

[data-rubrica-root] .pc-asset-table th,
[data-rubrica-root] .pc-asset-table td {
  padding: 5px 6px;
}

[data-rubrica-root] .pc-asset-table thead th {
  font-size: 9px;
  letter-spacing: 0.08em;
}

[data-rubrica-root] .pc-asset-table tbody td {
  font-size: 11px;
}

[data-rubrica-root] .pc-asset-table .pc-asset-col {
  min-width: 0;
  vertical-align: middle;
}

[data-rubrica-root] .pc-asset-table .pc-asset-col--company {
  width: 18%;
}

[data-rubrica-root] .pc-asset-table .pc-asset-col--area {
  width: 13%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

[data-rubrica-root] .pc-asset-table .pc-asset-col--person {
  width: 16%;
}

[data-rubrica-root] .pc-asset-table .pc-asset-col--asset,
[data-rubrica-root] .pc-asset-table .pc-asset-col--model,
[data-rubrica-root] .pc-asset-table .pc-asset-col--type,
[data-rubrica-root] .pc-asset-table .pc-asset-col--technician {
  width: 15%;
}

[data-rubrica-root] .pc-asset-table .pc-asset-col--serial,
[data-rubrica-root] .pc-asset-table .pc-asset-col--code,
[data-rubrica-root] .pc-asset-table .pc-asset-col--date {
  width: 11%;
}

[data-rubrica-root] .pc-asset-table .pc-asset-col--status {
  width: 14%;
}

[data-rubrica-root] .pc-asset-table .pc-asset-col--issue {
  width: 20%;
}

[data-rubrica-root] .pc-asset-table th.pc-asset-col--serial,
[data-rubrica-root] .pc-asset-table td.pc-asset-col--serial,
[data-rubrica-root] .pc-asset-table th.pc-asset-col--code,
[data-rubrica-root] .pc-asset-table td.pc-asset-col--code,
[data-rubrica-root] .pc-asset-table th.pc-asset-col--date,
[data-rubrica-root] .pc-asset-table td.pc-asset-col--date,
[data-rubrica-root] .pc-asset-table th.pc-asset-col--status,
[data-rubrica-root] .pc-asset-table td.pc-asset-col--status {
  text-align: center;
}

[data-rubrica-root] .pc-asset-table td.pc-asset-col--serial,
[data-rubrica-root] .pc-asset-table td.pc-asset-col--code,
[data-rubrica-root] .pc-asset-table td.pc-asset-col--date {
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

[data-rubrica-root] .pc-asset-table th:last-child,
[data-rubrica-root] .pc-asset-table td:last-child {
  width: 108px;
  min-width: 108px;
  overflow: visible;
}

[data-rubrica-root] .pc-asset-table .rubrica-table-actions {
  width: 108px;
  min-width: 108px;
  overflow: visible;
}

[data-rubrica-root] .pc-asset-table .rubrica-row-actions {
  gap: 6px;
  width: 100%;
  justify-content: center;
  flex-wrap: nowrap;
}

[data-rubrica-root] .pc-asset-table .rubrica-row-actions__form {
  flex: 0 0 auto;
}

[data-rubrica-root] .pc-asset-table .rubrica-row-action {
  width: 36px;
  min-width: 36px;
  height: 36px;
  min-height: 36px;
  border-radius: 10px;
  font-size: 14px;
  overflow: visible;
}

[data-rubrica-root] .pc-asset-table .rubrica-row-action .fa-pencil,
[data-rubrica-root] .pc-asset-table .rubrica-row-action .fa-trash {
  width: 16px;
  height: 16px;
  flex: 0 0 16px;
  font-size: 16px;
}

[data-rubrica-root] .pc-asset-table .rubrica-company-cell {
  gap: 0;
}

[data-rubrica-root] .pc-asset-table .rubrica-company-cell__viewport {
  width: 100%;
  overflow: hidden;
  padding-block: 0;
  -webkit-mask-image: none;
  mask-image: none;
}

[data-rubrica-root] .pc-asset-table .rubrica-company-cell__track {
  width: 100%;
  padding-right: 0;
}

[data-rubrica-root] .pc-asset-table .rubrica-company-pill {
  max-width: 100%;
  min-height: 28px;
}

.pc-asset-cell-text {
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.35;
}

.pc-asset-col--notes.pc-asset-cell-text,
.pc-asset-col--issue.pc-asset-cell-text {
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
  overflow-wrap: anywhere;
}

.pc-asset-cell-text--muted {
  color: var(--muted);
}

.pc-asset-inline-errors {
  margin-top: 4px;
  font-size: 10px;
  line-height: 1.3;
  color: #b91c1c;
}

.rubrica-table-wrap .company__table--employees {
  width: 100%;
  min-width: 0;
  table-layout: fixed;
  border-collapse: separate;
  border-spacing: 0;
}

.rubrica-table-wrap .company__table--employees th,
.rubrica-table-wrap .company__table--employees td {
  min-width: 0;
  vertical-align: top;
}

[data-rubrica-root] .rubrica-table-wrap .company__table--employees tbody td {
  vertical-align: middle;
}

.rubrica-table-wrap .company__table--employees th:first-child,
.rubrica-table-wrap .company__table--employees td:first-child {
  width: 24%;
}

.rubrica-table-wrap .company__table--employees thead th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: color-mix(in srgb, var(--glass-strong) 94%, white);
  box-shadow: inset 0 -1px 0 var(--glass-border);
  white-space: nowrap;
}

.rubrica-table-wrap .company__table--employees tbody tr {
  transition: background-color var(--duration) var(--ease-out);
}

.rubrica-table-wrap .company__table--employees tbody tr:hover {
  background: color-mix(in srgb, var(--accent-soft) 18%, transparent);
}

.rubrica-table-wrap .company__table--employees td:first-child {
  vertical-align: top;
}

.rubrica-table-wrap .company__table--employees td:not(:first-child) {
  overflow-wrap: anywhere;
}

.rubrica-table-wrap .company__table--employees td:nth-child(4),
.rubrica-table-wrap .company__table--employees td:nth-child(5) {
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.rubrica-table-wrap .company__table--employees td:last-child,
.rubrica-table-wrap .company__table--employees th:last-child {
  text-align: center;
}

@media (max-width: 960px) {
  .rubrica-table-head {
    flex-direction: column;
    align-items: stretch;
  }

  .rubrica-table-head__actions {
    align-self: flex-end;
  }

  .rubrica-company-pill {
    max-width: 100%;
  }

  .rubrica-company-cell__viewport {
    width: 100%;
  }

  .rubrica-table-wrap .company__table--employees {
    min-width: 720px;
  }

  .rubrica-table-wrap .company__table--employees th:first-child,
  .rubrica-table-wrap .company__table--employees td:first-child {
    width: 28%;
  }

  .pc-asset-table-wrap {
    overflow-x: hidden;
  }

  .pc-asset-table {
    min-width: 0 !important;
  }
}


.rubrica-form-errors,
.rubrica-form-errors .errorlist,
.account-field .errorlist {
  margin: 0;
  padding: 0;
  list-style: none;
}

.rubrica-form-errors,
.account-field .errorlist {
  font-size: 11px;
  letter-spacing: 0;
  text-transform: none;
  color: #b91c1c;
}

.rubrica-placeholder {
  display: grid;
  gap: 10px;
  margin-top: 18px;
  padding: 24px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--glass-border);
  background:
    radial-gradient(circle at top right, rgba(59, 130, 246, 0.12) 0%, transparent 40%),
    linear-gradient(160deg, var(--glass-strong) 0%, var(--glass) 100%);
}

.rubrica-placeholder__eyebrow {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
}

.rubrica-placeholder__title {
  margin: 0;
  font-size: 18px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text);
}

.rubrica-placeholder__text {
  margin: 0;
  font-size: 13px;
  line-height: 1.6;
  color: var(--muted);
}

body[data-theme="dark"] .rubrica-tabs {
  border-bottom-color: rgba(134, 179, 214, 0.18);
}

body[data-theme="dark"] .rubrica-tabs__cursor {
  border-color: rgba(134, 179, 214, 0.24);
  background:
    radial-gradient(circle at 50% 0%, rgba(147, 197, 253, 0.16) 0%, transparent 64%),
    linear-gradient(180deg, rgba(20, 41, 64, 0.96) 0%, rgba(9, 24, 40, 0.94) 100%);
  box-shadow:
    0 14px 26px rgba(2, 6, 23, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

body[data-theme="dark"] .rubrica-tab:hover,
body[data-theme="dark"] .rubrica-tab:focus-visible,
body[data-theme="dark"] .rubrica-tab.is-active,
body[data-theme="dark"] .rubrica-tab[data-cursor-target="true"] {
  color: #e5eef8;
}

@media (prefers-reduced-motion: reduce) {
  [data-rubrica-root][data-rubrica-loading="true"],
  [data-rubrica-root].is-switching,
  .rubrica-pane.is-switching {
    animation: none;
  }
}

.account-form {
  display: grid;
  gap: 10px;
  padding-top: 8px;
}

.account-form--filters {
  gap: 8px;
  padding-top: 6px;
}

.account-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.account-form--filters .account-grid {
  gap: 8px;
}

.account-form--filters .account-field {
  gap: 3px;
}

.account-form--filters .account-field select {
  min-height: 34px;
  padding-top: 6px;
  padding-bottom: 6px;
}

.account-form--filters .account-actions {
  gap: 8px;
}

.account-grid--single {
  grid-template-columns: 1fr;
}

.account-field--full {
  grid-column: 1 / -1;
}

.calendar-multi-select,
.work-groups__form select[multiple] {
  min-height: 128px;
}

.board__panel--work-groups {
  display: grid;
  gap: 18px;
  padding-bottom: 28px;
  overflow: visible;
}

.work-groups__layout {
  display: grid;
  grid-template-columns: minmax(360px, 460px) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
  padding-bottom: 16px;
}

.work-groups__editor {
  position: static;
  align-self: start;
  margin-top: -22px;
  margin-bottom: 18px;
  overflow: hidden;
  min-height: 0;
  min-width: 0;
}

.work-groups__editor .company__content {
  padding: 0;
}

.work-groups__editor.company {
  overflow: hidden;
  min-height: 0;
}

.work-groups__list {
  min-width: 0;
  display: grid;
  gap: 14px;
}

.work-groups__list-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  padding: 4px 4px 0;
}

.work-groups__list-title {
  margin: 0;
  font-size: 13px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.work-groups__list-subtitle {
  margin: 4px 0 0;
  font-size: 12px;
  color: var(--muted);
}

.work-groups__list-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 38px;
  min-height: 38px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, 0.22);
  background: rgba(255, 255, 255, 0.38);
  color: var(--text);
  font-size: 12px;
  font-weight: 700;
}

.work-groups__list .company-page__grid {
  grid-template-columns: repeat(auto-fit, minmax(300px, 420px));
  justify-content: start;
  margin-top: 0;
  align-items: start;
}

.work-groups__form {
  gap: 8px;
}

.work-groups__form .account-grid {
  gap: 8px;
}

.work-groups__member-field {
  position: relative;
  min-width: 0;
}

.js .work-groups__native-select.is-enhanced {
  display: none;
}

.work-groups-member-selector {
  display: none;
}

.js .work-groups-member-selector.is-ready {
  position: relative;
  display: grid;
  gap: 10px;
}

.work-groups-member-selector__toolbar {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 16px;
  flex-wrap: wrap;
  padding: 10px 4px 4px;
  border-radius: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.work-groups-member-selector__selected {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 16px;
  min-width: 0;
}

.work-groups-member-selector__empty {
  display: none;
  min-height: 0;
  width: auto;
  padding: 0;
  font-size: 12px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--muted);
}

.work-groups-member-selector__selected-item,
.work-groups-member-selector__add {
  border: 0;
  background: transparent;
  padding: 0;
  display: grid;
  justify-items: center;
  align-items: start;
  gap: 8px;
  color: var(--text);
  cursor: pointer;
  appearance: none;
  transition: transform var(--duration-fast) var(--ease-out);
}

.work-groups-member-selector__selected-item {
  animation: work-groups-member-selector-pop 180ms var(--ease-out);
}

.work-groups-member-selector__selected-item-media {
  position: relative;
  display: grid;
  place-items: center;
  width: 56px;
  height: 56px;
  overflow: visible;
}

.work-groups-member-selector__selected-item-media::after {
  content: "\00D7";
  position: absolute;
  top: -6px;
  right: -4px;
  z-index: 3;
  color: rgba(15, 23, 42, 0.94);
  font-size: 13px;
  font-weight: 700;
  line-height: 1;
  text-shadow: 0 1px 1px rgba(255, 255, 255, 0.92);
  pointer-events: none;
}

.work-groups-member-selector__selected-item:hover,
.work-groups-member-selector__add:hover {
  transform: translateY(-1px);
}

.work-groups-member-selector__selected-item:focus-visible,
.work-groups-member-selector__add:focus-visible,
.work-groups-member-selector__option:focus-visible,
.work-groups-member-selector__search input:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--focus);
}

.work-groups-member-selector__avatar,
.work-groups-member-selector__add-circle,
.work-groups-member-selector__option-avatar {
  position: relative;
  border-radius: 50%;
  flex: 0 0 auto;
  aspect-ratio: 1 / 1;
  box-sizing: border-box;
  overflow: hidden;
  justify-self: center;
  align-self: center;
  transform: translateZ(0);
}

.work-groups-member-selector__avatar {
  min-width: 56px;
  width: 56px;
  max-width: 56px;
  min-height: 56px;
  height: 56px;
  max-height: 56px;
  display: grid;
  place-items: center;
  border: 2px solid rgba(255, 255, 255, 0.38);
  background: var(--avatar-bg, linear-gradient(135deg, rgba(173, 216, 255, 0.96) 0%, rgba(138, 188, 236, 0.96) 100%));
  color: var(--avatar-fg, #103352);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.04em;
  box-shadow: 0 14px 26px rgba(15, 23, 42, 0.14);
}

.work-groups-member-selector__avatar::before {
  display: none;
}

.work-groups-member-selector__avatar::before {
  content: "×";
  position: absolute;
  top: -3px;
  right: -3px;
  z-index: 2;
  width: 18px;
  height: 18px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  border: 1.5px solid rgba(255, 255, 255, 0.92);
  background: linear-gradient(145deg, #dc2626 0%, #b91c1c 100%);
  box-shadow: 0 8px 16px rgba(185, 28, 28, 0.28);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
  pointer-events: none;
}

.work-groups-member-selector__avatar::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: inherit;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.18), transparent 60%);
  pointer-events: none;
}

.work-groups-member-selector__avatar::before {
  content: none !important;
  display: none !important;
}

.work-groups-member-selector__avatar.has-image::after {
  display: none;
}

.work-groups-member-selector__selected-item-name,
.work-groups-member-selector__add-label {
  max-width: 62px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: none;
}

.work-groups-member-selector__add {
  color: var(--text);
}

.work-groups-member-selector__add-circle {
  min-width: 56px;
  width: 56px;
  max-width: 56px;
  min-height: 56px;
  height: 56px;
  max-height: 56px;
  display: grid;
  place-items: center;
  border: 2px dashed rgba(31, 41, 55, 0.34);
  background: transparent;
  transition:
    border-color var(--duration-fast) var(--ease-out),
    background var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out),
    transform var(--duration-fast) var(--ease-out);
}

.work-groups-member-selector__add:hover .work-groups-member-selector__add-circle,
.work-groups-member-selector__add[aria-expanded="true"] .work-groups-member-selector__add-circle {
  border-color: var(--accent);
  background: rgba(31, 77, 122, 0.08);
}

.work-groups-member-selector__add[aria-expanded="true"] .work-groups-member-selector__add-circle {
  box-shadow: 0 0 0 3px var(--focus);
}

.work-groups-member-selector__add[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

.work-groups-member-selector__add-symbol {
  font-size: 28px;
  line-height: 1;
  color: var(--accent);
}

.work-groups-member-selector__dropdown {
  position: static;
  width: 100%;
  margin-top: 4px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--glass-border-strong);
  background: var(--glass-strong);
  box-shadow: var(--shadow-strong);
  overflow: hidden;
  z-index: 20;
  transform-origin: top center;
}

.work-groups-member-selector__search {
  display: block;
  padding: 12px;
  border-bottom: 1px solid var(--glass-border);
}

.work-groups-member-selector__search input {
  width: 100%;
  min-height: 38px;
  padding: 8px 12px;
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  background: rgba(148, 163, 184, 0.12);
  color: var(--text);
  font: inherit;
  font-size: 13px;
  letter-spacing: 0;
  text-transform: none;
}

.work-groups-member-selector__search input::placeholder {
  color: var(--muted);
}

.work-groups-member-selector__list {
  max-height: 248px;
  overflow-y: auto;
  padding: 6px;
  display: grid;
  gap: 2px;
}

@media (min-width: 1100px) and (min-height: 940px) {
  .work-groups__editor {
    position: sticky;
    top: 22px;
    margin-bottom: 0;
  }
}

.work-groups-member-selector__option {
  border: 0;
  background: transparent;
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr) 18px;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 8px;
  border-radius: 10px;
  color: var(--text);
  cursor: pointer;
  text-align: left;
  transition: background var(--duration-fast) var(--ease-out), transform var(--duration-fast) var(--ease-out);
}

.work-groups-member-selector__option:hover {
  background: rgba(31, 77, 122, 0.08);
}

.work-groups-member-selector__option.is-selected {
  background: rgba(31, 77, 122, 0.1);
}

.work-groups-member-selector__option.is-disabled {
  opacity: 0.46;
  cursor: not-allowed;
  background: rgba(148, 163, 184, 0.06);
}

.work-groups-member-selector__option-avatar {
  min-width: 40px;
  width: 40px;
  max-width: 40px;
  min-height: 40px;
  height: 40px;
  max-height: 40px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: var(--avatar-bg, linear-gradient(135deg, rgba(173, 216, 255, 0.96) 0%, rgba(138, 188, 236, 0.96) 100%));
  color: var(--avatar-fg, #103352);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
}

.work-groups-member-selector__avatar-image,
.work-groups-member-selector__option-avatar-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  position: relative;
  z-index: 1;
}

.work-groups-member-selector__avatar-initial,
.work-groups-member-selector__option-avatar-initial {
  display: block;
  color: inherit;
  font: inherit;
  line-height: 1;
  letter-spacing: inherit;
  position: relative;
  z-index: 1;
}

.work-groups-member-selector__option-copy {
  min-width: 0;
  display: grid;
  gap: 1px;
  text-transform: none;
  letter-spacing: 0;
}

.work-groups-member-selector__option-name,
.work-groups-member-selector__option-email {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.work-groups-member-selector__option-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
}

.work-groups-member-selector__option-email {
  font-size: 11px;
  color: var(--muted);
}

.work-groups-member-selector__option-check {
  min-width: 18px;
  width: 18px;
  max-width: 18px;
  min-height: 18px;
  height: 18px;
  max-height: 18px;
  position: relative;
  border-radius: 50%;
  border: 1px solid var(--input-border);
  display: grid;
  place-items: center;
  box-sizing: border-box;
  overflow: hidden;
  justify-self: center;
  align-self: center;
  aspect-ratio: 1 / 1;
  flex: 0 0 auto;
  font-size: 0;
  color: transparent;
  transition:
    background var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out),
    color var(--duration-fast) var(--ease-out);
}

.work-groups-member-selector__option-check::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 5px;
  height: 9px;
  border-right: 2px solid transparent;
  border-bottom: 2px solid transparent;
  transform: translate(-50%, -58%) rotate(45deg);
  transform-origin: center;
}

.work-groups-member-selector__option.is-selected .work-groups-member-selector__option-check {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.work-groups-member-selector__option.is-selected .work-groups-member-selector__option-check::after {
  border-color: #fff;
}

.work-groups-member-selector__list-empty,
.work-groups-member-selector__status {
  padding-top: 2px;
  font-size: 12px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--muted);
}

@keyframes work-groups-member-selector-pop {
  from {
    opacity: 0;
    transform: translateY(6px) scale(0.94);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.work-groups-member-selector__list-empty {
  padding: 18px 12px;
  text-align: center;
}

.work-groups-member-selector__status {
  padding-inline: 2px;
}

.work-groups__editor-head,
.work-groups__card-head,
.work-groups__card-actions {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.company--tile.work-groups__card {
  min-height: 0;
  height: auto;
  max-width: 420px;
  padding: 12px 14px;
}

.work-groups__card .company__content {
  display: grid;
  gap: 10px;
  padding: 14px 16px;
}

.work-groups__card.is-editing {
  border-color: rgba(59, 130, 246, 0.34);
  box-shadow: 0 12px 24px rgba(15, 23, 42, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.32), rgba(255, 255, 255, 0.22));
}

.work-groups__card-title-block {
  min-width: 0;
  display: grid;
  gap: 4px;
}

.work-groups__card-title {
  margin: 0;
  font-size: 15px;
  line-height: 1.2;
  letter-spacing: 0;
  text-transform: none;
}

.work-groups__card-count {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}

.work-groups__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.work-groups__card .employee-inline-tags {
  margin-top: 12px;
}

.work-groups__card-actions {
  align-self: start;
  align-items: center;
  justify-content: flex-end;
  margin-top: 0;
  gap: 12px;
  flex-wrap: nowrap;
}

.work-groups__card-actions form {
  margin: 0;
  display: flex;
}

.work-groups__card-members {
  margin: 0;
  max-width: 46ch;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.work-groups__card-action {
  border: 0;
  padding: 0;
  background: transparent;
  color: var(--accent);
  font: inherit;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition:
    color var(--duration-fast) var(--ease-out),
    opacity var(--duration-fast) var(--ease-out);
}

.work-groups__card-action:hover,
.work-groups__card-action:focus-visible {
  color: var(--accent-strong);
  opacity: 1;
  text-decoration: underline;
  text-underline-offset: 0.18em;
}

.work-groups__card-action:focus-visible {
  outline: none;
}

.work-groups__card-action--danger {
  color: #dc2626;
}

.work-groups__card-action--danger:hover,
.work-groups__card-action--danger:focus-visible {
  color: #b91c1c;
}

.work-groups__empty {
  min-height: clamp(190px, 24vw, 280px);
  padding: 28px;
  display: grid;
  align-content: center;
  gap: 8px;
  border-radius: var(--radius-lg);
  border: 1px dashed var(--glass-border);
  background: rgba(255, 255, 255, 0.18);
}

.work-groups__empty-title {
  font-size: 14px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.work-groups__empty-text {
  margin-top: 0;
  font-size: 12px;
  color: var(--muted);
}

@media (max-width: 1280px) {
  .work-groups__layout {
    grid-template-columns: minmax(320px, 420px) minmax(0, 1fr);
  }

  .work-groups__list .company-page__grid {
    grid-template-columns: repeat(auto-fit, minmax(280px, 360px));
  }
}

body[data-density="compact"] .company--tile.work-groups__card {
  min-height: 0;
}

@media (max-width: 1120px) {
  .work-groups__layout {
    grid-template-columns: 1fr;
  }

  .work-groups__editor,
  .work-groups__list {
    width: 100%;
  }

  .work-groups__editor {
    margin-top: 0;
  }

  .work-groups__list .company-page__grid {
    grid-template-columns: 1fr;
  }
}

.profile-avatar-panel {
  position: relative;
  display: grid;
  gap: 14px;
  padding: 14px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--glass-border);
  background: linear-gradient(160deg, rgba(255, 255, 255, 0.22) 0%, rgba(255, 255, 255, 0.08) 100%);
}

.profile-avatar-panel__preview {
  display: flex;
  align-items: center;
  gap: 14px;
}

.profile-avatar-panel__trigger {
  position: relative;
  border: 0;
  padding: 0;
  background: transparent;
  cursor: pointer;
  flex: 0 0 auto;
  border-radius: 999px;
}

.profile-avatar-panel__media {
  width: 64px;
  height: 64px;
  border-radius: 999px;
  overflow: hidden;
  flex: 0 0 auto;
  display: grid;
  place-items: center;
  background: var(--avatar-bg, rgba(15, 23, 42, 0.08));
  border: 1px solid var(--glass-border);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.28);
  color: var(--avatar-fg, var(--text));
}

.profile-avatar-panel__trigger:focus-visible .profile-avatar-panel__media,
.profile-avatar-panel__trigger:hover .profile-avatar-panel__media {
  border-color: var(--accent);
  box-shadow:
    0 0 0 4px color-mix(in srgb, var(--accent) 16%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.profile-avatar-panel__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.profile-avatar-panel__initial {
  font-size: 21px;
  line-height: 1;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: inherit;
}

.profile-avatar-panel__copy {
  display: grid;
  gap: 4px;
}

.profile-avatar-panel__title {
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
}

.profile-avatar-panel__subtitle {
  font-size: 12px;
  color: var(--muted);
}

.profile-avatar-panel__menu {
  position: absolute;
  top: 76px;
  left: 14px;
  z-index: 24;
  display: grid;
  gap: 12px;
  width: min(360px, calc(100vw - 80px));
  padding: 14px;
  border-radius: 18px;
  border: 1px solid var(--glass-border);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(246, 248, 252, 0.92) 100%);
  box-shadow: 0 24px 52px rgba(15, 23, 42, 0.16);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
}

.profile-avatar-panel__menu[hidden] {
  display: none;
}

.profile-avatar-panel__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.profile-avatar-panel__action {
  border: 1px solid var(--glass-border-strong);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.68);
  color: color-mix(in srgb, var(--accent) 44%, #475569);
  padding: 9px 14px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  transition:
    transform var(--duration) var(--ease-out),
    border-color var(--duration) var(--ease-out),
    background var(--duration) var(--ease-out),
    color var(--duration) var(--ease-out);
}

.profile-avatar-panel__action:hover,
.profile-avatar-panel__action.is-active {
  transform: translateY(-1px);
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 14%, rgba(255, 255, 255, 0.9));
  color: var(--accent-strong);
}

.profile-avatar-panel__color-picker {
  display: grid;
  gap: 12px;
  padding: 12px;
  border-radius: 20px;
  border: 1px solid rgba(148, 163, 184, 0.18);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.78) 0%, rgba(244, 247, 251, 0.9) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.42);
}

.profile-avatar-panel__color-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.profile-avatar-panel__color-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}

.profile-avatar-panel__color-value {
  font-size: 11px;
  font-weight: 700;
  color: var(--text);
}

.profile-avatar-panel__status {
  font-size: 12px;
  color: var(--muted);
  line-height: 1.5;
}

.profile-avatar-panel__color-picker .developer-color-picker__area,
.profile-avatar-panel__color-picker .developer-color-picker__slider,
.profile-avatar-panel__color-picker .developer-color-picker__hex {
  border-radius: 18px;
}

.profile-avatar-panel__color-picker .developer-color-picker__slider,
.profile-avatar-panel__color-picker .developer-color-picker__hex {
  padding: 10px 12px 12px;
  border: 1px solid rgba(148, 163, 184, 0.18);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.36);
}

.profile-avatar-panel__color-picker .developer-color-picker__slider {
  gap: 8px;
  margin-block: 0;
}

.profile-avatar-panel__inputs {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
  white-space: nowrap;
}

.profile-avatar-panel__inputs input[type="file"] {
  position: absolute;
  inset: 0;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.profile-avatar-panel__errors {
  display: grid;
  gap: 6px;
}

.profile-avatar-panel__errors .errorlist {
  margin: 0;
}

.fa-solid.fa-apple-whole {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M15.7 8.1c-.7 0-1.3.2-1.9.5-.6.3-1.1.5-1.8.5s-1.2-.2-1.8-.5c-.6-.3-1.2-.5-1.9-.5-2.4 0-4.3 2.1-4.3 5.1 0 2.3 1 4.7 2.3 6.1.7.8 1.5 1.3 2.4 1.3.6 0 1.1-.2 1.6-.4.5-.2 1-.4 1.7-.4s1.2.2 1.7.4c.5.2 1 .4 1.6.4.9 0 1.6-.5 2.4-1.3 1.3-1.4 2.3-3.9 2.3-6.1 0-3-1.9-5.1-4.3-5.1Zm-3.6-4.7c1.7 0 3.1.9 3.7 2.3-1.8.4-3.1 1.5-3.8 3.1-1.5-.6-2.7-1.9-3-3.6.8-1.1 1.8-1.8 3.1-1.8Z'/%3E%3Cpath fill='black' d='M15 2.7c.8-.5 1.9-.7 3-.4-.1 1.7-1.1 3-2.8 3.4.1-1.3-.1-2.2-.2-3Z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M15.7 8.1c-.7 0-1.3.2-1.9.5-.6.3-1.1.5-1.8.5s-1.2-.2-1.8-.5c-.6-.3-1.2-.5-1.9-.5-2.4 0-4.3 2.1-4.3 5.1 0 2.3 1 4.7 2.3 6.1.7.8 1.5 1.3 2.4 1.3.6 0 1.1-.2 1.6-.4.5-.2 1-.4 1.7-.4s1.2.2 1.7.4c.5.2 1 .4 1.6.4.9 0 1.6-.5 2.4-1.3 1.3-1.4 2.3-3.9 2.3-6.1 0-3-1.9-5.1-4.3-5.1Zm-3.6-4.7c1.7 0 3.1.9 3.7 2.3-1.8.4-3.1 1.5-3.8 3.1-1.5-.6-2.7-1.9-3-3.6.8-1.1 1.8-1.8 3.1-1.8Z'/%3E%3Cpath fill='black' d='M15 2.7c.8-.5 1.9-.7 3-.4-.1 1.7-1.1 3-2.8 3.4.1-1.3-.1-2.2-.2-3Z'/%3E%3C/svg%3E");
}

.fa-solid.fa-bowling-ball {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Ccircle fill='black' cx='12' cy='12' r='9'/%3E%3Ccircle fill='white' cx='9' cy='8' r='1.35'/%3E%3Ccircle fill='white' cx='13' cy='7.2' r='1.25'/%3E%3Ccircle fill='white' cx='11.5' cy='11' r='1.15'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Ccircle fill='black' cx='12' cy='12' r='9'/%3E%3Ccircle fill='white' cx='9' cy='8' r='1.35'/%3E%3Ccircle fill='white' cx='13' cy='7.2' r='1.25'/%3E%3Ccircle fill='white' cx='11.5' cy='11' r='1.15'/%3E%3C/svg%3E");
}

.fa-solid.fa-bolt {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M13.3 2 5.8 13h5L9.9 22l8.3-11.5h-5.4L13.3 2Z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M13.3 2 5.8 13h5L9.9 22l8.3-11.5h-5.4L13.3 2Z'/%3E%3C/svg%3E");
}

.fa-solid.fa-droplet {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 2.8c2.2 3.2 6.2 7.1 6.2 11.1A6.2 6.2 0 1 1 5.8 14c0-4 4-7.9 6.2-11.1Z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 2.8c2.2 3.2 6.2 7.1 6.2 11.1A6.2 6.2 0 1 1 5.8 14c0-4 4-7.9 6.2-11.1Z'/%3E%3C/svg%3E");
}

.fa-solid.fa-fire {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M13.6 2.5c.6 2.5-.5 4.5-2 5.8-1 1-1.8 1.8-1.8 3 0 1.3 1 2.2 2.3 2.2 2.2 0 3.4-2 3.2-4.4 2.3 1.8 3.9 4.3 3.9 7 0 3.7-3 6.4-7.1 6.4-4 0-7.1-2.7-7.1-6.6 0-3.2 2.1-5.6 4.3-7.8 1.8-1.8 3.6-3.5 4.3-5.6Z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M13.6 2.5c.6 2.5-.5 4.5-2 5.8-1 1-1.8 1.8-1.8 3 0 1.3 1 2.2 2.3 2.2 2.2 0 3.4-2 3.2-4.4 2.3 1.8 3.9 4.3 3.9 7 0 3.7-3 6.4-7.1 6.4-4 0-7.1-2.7-7.1-6.6 0-3.2 2.1-5.6 4.3-7.8 1.8-1.8 3.6-3.5 4.3-5.6Z'/%3E%3C/svg%3E");
}

.fa-solid.fa-cat {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='m7 4 2.6 2.7c.8-.3 1.6-.5 2.4-.5s1.7.2 2.4.5L17 4l1.5 4.6c1.1 1.1 1.8 2.6 1.8 4.3 0 3.8-3.7 6.9-8.3 6.9S3.7 16.7 3.7 12.9c0-1.7.7-3.2 1.8-4.3L7 4Zm2.7 8.1a1 1 0 1 0 0 2 1 1 0 0 0 0-2Zm4.6 0a1 1 0 1 0 0 2 1 1 0 0 0 0-2Zm-5.7 3.5c1 .9 2.2 1.3 3.4 1.3s2.5-.4 3.4-1.3l-1.2-.9c-.6.5-1.4.8-2.2.8s-1.6-.3-2.2-.8l-1.2.9Z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='m7 4 2.6 2.7c.8-.3 1.6-.5 2.4-.5s1.7.2 2.4.5L17 4l1.5 4.6c1.1 1.1 1.8 2.6 1.8 4.3 0 3.8-3.7 6.9-8.3 6.9S3.7 16.7 3.7 12.9c0-1.7.7-3.2 1.8-4.3L7 4Zm2.7 8.1a1 1 0 1 0 0 2 1 1 0 0 0 0-2Zm4.6 0a1 1 0 1 0 0 2 1 1 0 0 0 0-2Zm-5.7 3.5c1 .9 2.2 1.3 3.4 1.3s2.5-.4 3.4-1.3l-1.2-.9c-.6.5-1.4.8-2.2.8s-1.6-.3-2.2-.8l-1.2.9Z'/%3E%3C/svg%3E");
}

.fa-solid.fa-pizza-slice {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 3c3.3 0 6.1.6 8.5 1.7L13 21.5a2.1 2.1 0 0 1-3.8 0L3.5 7.1C5.9 4.4 8.8 3 12 3Z'/%3E%3Ccircle fill='white' cx='10' cy='10' r='1.2'/%3E%3Ccircle fill='white' cx='14.3' cy='8.6' r='1.1'/%3E%3Ccircle fill='white' cx='12.1' cy='13.6' r='1.1'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 3c3.3 0 6.1.6 8.5 1.7L13 21.5a2.1 2.1 0 0 1-3.8 0L3.5 7.1C5.9 4.4 8.8 3 12 3Z'/%3E%3Ccircle fill='white' cx='10' cy='10' r='1.2'/%3E%3Ccircle fill='white' cx='14.3' cy='8.6' r='1.1'/%3E%3Ccircle fill='white' cx='12.1' cy='13.6' r='1.1'/%3E%3C/svg%3E");
}

.fa-solid.fa-bicycle {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Ccircle fill='none' stroke='black' stroke-width='2' cx='6' cy='16.5' r='3.3'/%3E%3Ccircle fill='none' stroke='black' stroke-width='2' cx='18' cy='16.5' r='3.3'/%3E%3Cpath fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M8.9 16.5 12 10.2l2.4 6.3M12 10.2h4l2 6.3M12 10.2 9.8 7.8H7.5'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Ccircle fill='none' stroke='black' stroke-width='2' cx='6' cy='16.5' r='3.3'/%3E%3Ccircle fill='none' stroke='black' stroke-width='2' cx='18' cy='16.5' r='3.3'/%3E%3Cpath fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M8.9 16.5 12 10.2l2.4 6.3M12 10.2h4l2 6.3M12 10.2 9.8 7.8H7.5'/%3E%3C/svg%3E");
}

.fa-solid.fa-basketball {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Ccircle fill='none' stroke='black' stroke-width='2' cx='12' cy='12' r='8.5'/%3E%3Cpath fill='none' stroke='black' stroke-width='2' d='M12 3.5c2.2 2.2 3.4 5.2 3.4 8.5S14.2 18.3 12 20.5M12 3.5C9.8 5.7 8.6 8.7 8.6 12s1.2 6.3 3.4 8.5M3.7 12h16.6'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Ccircle fill='none' stroke='black' stroke-width='2' cx='12' cy='12' r='8.5'/%3E%3Cpath fill='none' stroke='black' stroke-width='2' d='M12 3.5c2.2 2.2 3.4 5.2 3.4 8.5S14.2 18.3 12 20.5M12 3.5C9.8 5.7 8.6 8.7 8.6 12s1.2 6.3 3.4 8.5M3.7 12h16.6'/%3E%3C/svg%3E");
}

.fa-solid.fa-chess-knight {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M15.7 4c-2.2 0-4 1.8-4 4 0 .6.1 1.1.3 1.6-1.8.9-3 2.7-3 4.9v1.5h7.8c1.7 0 3.2 1.4 3.2 3.2v.8H6v-1.8h8.3c-.3-.5-.8-.8-1.4-.8H7v-3c0-3.1 1.7-5.7 4.6-7.1-.2-.4-.3-.8-.3-1.3 0-2.2 1.8-4 4-4 .7 0 1.4.2 2 .5l-.9 1.7c-.3-.1-.6-.2-.9-.2Z'/%3E%3Ccircle fill='white' cx='15.4' cy='7.2' r='1.1'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M15.7 4c-2.2 0-4 1.8-4 4 0 .6.1 1.1.3 1.6-1.8.9-3 2.7-3 4.9v1.5h7.8c1.7 0 3.2 1.4 3.2 3.2v.8H6v-1.8h8.3c-.3-.5-.8-.8-1.4-.8H7v-3c0-3.1 1.7-5.7 4.6-7.1-.2-.4-.3-.8-.3-1.3 0-2.2 1.8-4 4-4 .7 0 1.4.2 2 .5l-.9 1.7c-.3-.1-.6-.2-.9-.2Z'/%3E%3Ccircle fill='white' cx='15.4' cy='7.2' r='1.1'/%3E%3C/svg%3E");
}

.fa-solid.fa-fan {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Ccircle fill='black' cx='12' cy='12' r='2.1'/%3E%3Cpath fill='black' d='M12 4c2.8 0 5 2.3 5 5 0 .7-.1 1.3-.4 1.9l-4.6-.8c-.7-1.2-1-2.4-1-3.7 0-.8.3-1.7 1-2.4ZM4 12c0-2.8 2.3-5 5-5 .7 0 1.3.1 1.9.4l-.8 4.6c-1.2.7-2.4 1-3.7 1-.8 0-1.7-.3-2.4-1ZM12 20c-2.8 0-5-2.3-5-5 0-.7.1-1.3.4-1.9l4.6.8c.7 1.2 1 2.4 1 3.7 0 .8-.3 1.7-1 2.4ZM20 12c0 2.8-2.3 5-5 5-.7 0-1.3-.1-1.9-.4l.8-4.6c1.2-.7 2.4-1 3.7-1 .8 0 1.7.3 2.4 1Z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Ccircle fill='black' cx='12' cy='12' r='2.1'/%3E%3Cpath fill='black' d='M12 4c2.8 0 5 2.3 5 5 0 .7-.1 1.3-.4 1.9l-4.6-.8c-.7-1.2-1-2.4-1-3.7 0-.8.3-1.7 1-2.4ZM4 12c0-2.8 2.3-5 5-5 .7 0 1.3.1 1.9.4l-.8 4.6c-1.2.7-2.4 1-3.7 1-.8 0-1.7-.3-2.4-1ZM12 20c-2.8 0-5-2.3-5-5 0-.7.1-1.3.4-1.9l4.6.8c.7 1.2 1 2.4 1 3.7 0 .8-.3 1.7-1 2.4ZM20 12c0 2.8-2.3 5-5 5-.7 0-1.3-.1-1.9-.4l.8-4.6c1.2-.7 2.4-1 3.7-1 .8 0 1.7.3 2.4 1Z'/%3E%3C/svg%3E");
}

.fa-regular.fa-face-grin {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Ccircle fill='none' stroke='black' stroke-width='2' cx='12' cy='12' r='8.5'/%3E%3Ccircle fill='black' cx='9' cy='10' r='1.2'/%3E%3Ccircle fill='black' cx='15' cy='10' r='1.2'/%3E%3Cpath fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M8 14c1 2 2.4 3 4 3s3-.9 4-3'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Ccircle fill='none' stroke='black' stroke-width='2' cx='12' cy='12' r='8.5'/%3E%3Ccircle fill='black' cx='9' cy='10' r='1.2'/%3E%3Ccircle fill='black' cx='15' cy='10' r='1.2'/%3E%3Cpath fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M8 14c1 2 2.4 3 4 3s3-.9 4-3'/%3E%3C/svg%3E");
}

.fa-regular.fa-comment-dots {
  width: 18px;
  height: 18px;
  display: inline-block;
  background: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='black' stroke-width='2.15' stroke-linecap='round' stroke-linejoin='round' d='M7.2 17.2H4V6.7A2.7 2.7 0 0 1 6.7 4h10.6A2.7 2.7 0 0 1 20 6.7v6.6a2.7 2.7 0 0 1-2.7 2.7H10l-2.8 2.8v-1.6Z'/%3E%3Ccircle fill='black' cx='9' cy='10.1' r='1.2'/%3E%3Ccircle fill='black' cx='12' cy='10.1' r='1.2'/%3E%3Ccircle fill='black' cx='15' cy='10.1' r='1.2'/%3E%3C/svg%3E") center/contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='black' stroke-width='2.15' stroke-linecap='round' stroke-linejoin='round' d='M7.2 17.2H4V6.7A2.7 2.7 0 0 1 6.7 4h10.6A2.7 2.7 0 0 1 20 6.7v6.6a2.7 2.7 0 0 1-2.7 2.7H10l-2.8 2.8v-1.6Z'/%3E%3Ccircle fill='black' cx='9' cy='10.1' r='1.2'/%3E%3Ccircle fill='black' cx='12' cy='10.1' r='1.2'/%3E%3Ccircle fill='black' cx='15' cy='10.1' r='1.2'/%3E%3C/svg%3E") center/contain no-repeat;
}

.fa-regular.fa-paper-plane {
  width: 16px;
  height: 16px;
  display: inline-block;
  background: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='black' stroke-width='1.9' stroke-linecap='round' stroke-linejoin='round' d='M21 3 10.6 13.4'/%3E%3Cpath fill='none' stroke='black' stroke-width='1.9' stroke-linecap='round' stroke-linejoin='round' d='m21 3-6.3 18-4.1-7-7-4.1L21 3Z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='black' stroke-width='1.9' stroke-linecap='round' stroke-linejoin='round' d='M21 3 10.6 13.4'/%3E%3Cpath fill='none' stroke='black' stroke-width='1.9' stroke-linecap='round' stroke-linejoin='round' d='m21 3-6.3 18-4.1-7-7-4.1L21 3Z'/%3E%3C/svg%3E") center/contain no-repeat;
}

.fa-solid.fa-moon {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M14.5 3.2A8.7 8.7 0 1 0 20.8 16c-1 .4-2 .6-3.1.6A8.9 8.9 0 0 1 8.8 7.7c0-1 .2-2 .6-3.1 1.6-1 3.3-1.4 5.1-1.4Z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M14.5 3.2A8.7 8.7 0 1 0 20.8 16c-1 .4-2 .6-3.1.6A8.9 8.9 0 0 1 8.8 7.7c0-1 .2-2 .6-3.1 1.6-1 3.3-1.4 5.1-1.4Z'/%3E%3C/svg%3E");
}

.fa-solid.fa-paw {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cellipse fill='black' cx='8' cy='8.2' rx='2' ry='2.8'/%3E%3Cellipse fill='black' cx='16' cy='8.2' rx='2' ry='2.8'/%3E%3Cellipse fill='black' cx='6.4' cy='13.1' rx='1.9' ry='2.5'/%3E%3Cellipse fill='black' cx='17.6' cy='13.1' rx='1.9' ry='2.5'/%3E%3Cpath fill='black' d='M12 12.5c-2.8 0-5 2.1-5 4.7 0 1.8 1.3 2.8 3 2.8 1 0 1.6-.3 2-.6.4.3 1 .6 2 .6 1.7 0 3-.9 3-2.8 0-2.6-2.2-4.7-5-4.7Z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cellipse fill='black' cx='8' cy='8.2' rx='2' ry='2.8'/%3E%3Cellipse fill='black' cx='16' cy='8.2' rx='2' ry='2.8'/%3E%3Cellipse fill='black' cx='6.4' cy='13.1' rx='1.9' ry='2.5'/%3E%3Cellipse fill='black' cx='17.6' cy='13.1' rx='1.9' ry='2.5'/%3E%3Cpath fill='black' d='M12 12.5c-2.8 0-5 2.1-5 4.7 0 1.8 1.3 2.8 3 2.8 1 0 1.6-.3 2-.6.4.3 1 .6 2 .6 1.7 0 3-.9 3-2.8 0-2.6-2.2-4.7-5-4.7Z'/%3E%3C/svg%3E");
}

.account-field {
  display: grid;
  gap: 5px;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}

.account-field input {
  min-height: 38px;
  padding: 8px 10px;
  border-radius: var(--radius-md);
  border: 1px solid var(--input-border);
  background: var(--input-bg);
  color: var(--text);
  font-size: 13px;
  line-height: 1.3;
  outline: none;
  transition: box-shadow var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out);
}

.account-field input:focus {
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--focus);
}

.account-field textarea {
  padding: 8px 10px;
  border-radius: var(--radius-md);
  border: 1px solid var(--input-border);
  background: var(--input-bg);
  color: var(--text);
  font-size: 13px;
  outline: none;
  transition: box-shadow var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out);
  resize: vertical;
  min-height: 74px;
  line-height: 1.45;
  font-family: inherit;
  letter-spacing: 0;
  text-transform: none;
}

.account-field textarea:focus {
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--focus);
}

.account-field select {
  min-height: 38px;
  padding: 8px 32px 8px 10px;
  border-radius: var(--radius-md);
  border: 1px solid var(--input-border);
  background: var(--input-bg);
  color: var(--text);
  font-size: 13px;
  line-height: 1.3;
  outline: none;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  transition: box-shadow var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out);
  background-image:
    linear-gradient(45deg, transparent 50%, var(--muted) 50%),
    linear-gradient(135deg, var(--muted) 50%, transparent 50%);
  background-position:
    calc(100% - 15px) calc(50% - 1px),
    calc(100% - 10px) calc(50% - 1px);
  background-size: 5px 6px, 5px 6px;
  background-repeat: no-repeat;
}

.account-field select[multiple] {
  min-height: 96px;
  padding: 6px 8px;
  appearance: auto;
  -webkit-appearance: listbox;
  -moz-appearance: listbox;
  background-image: none;
}

.account-field small {
  font-size: 10px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--muted);
}

.account-multi-check {
  max-height: 132px;
  overflow: auto;
  border-radius: var(--radius-md);
  border: 1px solid var(--input-border);
  background: var(--input-bg);
  padding: 5px;
  display: grid;
  gap: 3px;
}

.account-multi-check__item {
  display: flex;
  align-items: center;
  gap: 7px;
  border-radius: 999px;
  padding: 5px 7px;
  cursor: pointer;
  color: var(--text);
  text-transform: none;
  letter-spacing: 0;
  font-size: 12px;
}

.account-multi-check__item:hover {
  background: rgba(148, 163, 184, 0.18);
}

.account-multi-check__item input[type="checkbox"] {
  width: 15px;
  height: 15px;
  flex: 0 0 auto;
}

.account-multi-check__item span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.account-field select:focus {
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--focus);
}

.account-field select.select--minimal {
  padding-right: 26px;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--muted) 50%),
    linear-gradient(135deg, var(--muted) 50%, transparent 50%);
  background-position:
    calc(100% - 14px) calc(50% - 1px),
    calc(100% - 9px) calc(50% - 1px);
  background-size: 5px 6px, 5px 6px;
  background-repeat: no-repeat;
}

.filter-combobox {
  position: relative;
  min-width: 0;
}

.filter-combobox.is-open {
  z-index: 42;
}

.filter-combobox__native-select {
  display: none;
}

.filter-combobox__control {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 34px;
  padding-left: 9px;
  padding-right: 5px;
  border-radius: var(--radius-md);
  border: 1px solid var(--input-border);
  background: var(--input-bg);
  overflow: hidden;
  transition:
    border-color var(--duration) var(--ease-out),
    box-shadow var(--duration) var(--ease-out),
    background var(--duration) var(--ease-out);
}

.filter-combobox--field .filter-combobox__control {
  padding-left: 10px;
  padding-right: 4px;
  cursor: pointer;
}

.filter-combobox.filter-combobox--field .filter-combobox__control:focus-within,
.filter-combobox.filter-combobox--field.is-open .filter-combobox__control {
  border-color: rgba(31, 77, 122, 0.24);
  box-shadow: none;
}

.filter-combobox__control:focus-within,
.filter-combobox.is-open .filter-combobox__control {
  border-color: var(--focus);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--focus) 60%, transparent);
}

.filter-combobox__icon,
.filter-combobox__clear,
.filter-combobox__toggle,
.filter-combobox__option-check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.filter-combobox__icon {
  display: none;
}

.filter-combobox__icon svg,
.filter-combobox__clear svg,
.filter-combobox__toggle svg,
.filter-combobox__option-check svg {
  width: 16px;
  height: 16px;
}

.account-field .filter-combobox__input {
  width: 100%;
  min-width: 0;
  height: 32px;
  min-height: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--text);
  font-size: 12px;
  line-height: 1.2;
  outline: none;
  padding: 6px 4px 6px 0;
  font-family: inherit;
  box-shadow: none;
  flex: 1 1 auto;
}

.filter-combobox--field .filter-combobox__input {
  padding-right: 8px;
  cursor: pointer;
  caret-color: transparent;
  user-select: none;
  pointer-events: none;
}

.filter-combobox--field .filter-combobox__input::selection {
  background: transparent;
  color: inherit;
}

.account-field .filter-combobox__input:focus {
  border: 0;
  box-shadow: none;
}

.filter-combobox__input::placeholder {
  color: var(--muted);
  opacity: 0.78;
}

.filter-combobox__clear,
.filter-combobox__toggle {
  width: 26px;
  height: 26px;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  transition:
    color var(--duration-fast) var(--ease-out),
    transform var(--duration-fast) var(--ease-out);
}

.filter-combobox--field .filter-combobox__toggle {
  width: 30px;
  height: 30px;
  margin-left: 1px;
  border-radius: 10px;
  color: var(--text);
}

.filter-combobox__clear:hover,
.filter-combobox__toggle:hover {
  color: var(--text);
}

.filter-combobox__clear:active,
.filter-combobox__toggle:active {
  transform: scale(0.96);
}

.filter-combobox__clear[hidden] {
  display: none;
}

.filter-combobox__toggle svg {
  transition: transform var(--duration-fast) var(--ease-out);
}

.filter-combobox.is-open .filter-combobox__toggle svg {
  transform: rotate(180deg);
}

.filter-combobox__menu {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 8px);
  z-index: 48;
  padding: 6px;
  border-radius: 14px;
  border: 1px solid var(--glass-border);
  background:
    radial-gradient(circle at top right, rgba(125, 199, 255, 0.18), transparent 42%),
    linear-gradient(165deg, color-mix(in srgb, var(--glass-strong) 96%, white) 0%, color-mix(in srgb, var(--glass) 96%, transparent) 100%);
  box-shadow: 0 18px 38px rgba(15, 23, 42, 0.16);
  backdrop-filter: blur(18px) saturate(145%);
  -webkit-backdrop-filter: blur(18px) saturate(145%);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-6px) scale(0.985);
  transform-origin: top center;
  transition:
    opacity 180ms ease-out,
    transform 220ms cubic-bezier(0.22, 1, 0.36, 1),
    visibility 0ms linear 220ms;
}

.filter-combobox--field .filter-combobox__menu {
  left: 1px;
  right: 1px;
  top: calc(100% + 4px);
  padding: 3px;
  border-radius: 11px;
}

.filter-combobox--drop-up .filter-combobox__menu {
  top: auto;
  bottom: calc(100% + 10px);
  transform: translateY(6px) scale(0.985);
  transform-origin: bottom center;
}

.filter-combobox.is-open .filter-combobox__menu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0) scale(1);
  transition:
    opacity 180ms ease-out,
    transform 220ms cubic-bezier(0.22, 1, 0.36, 1),
    visibility 0ms linear 0ms;
}

.filter-combobox__list {
  display: grid;
  gap: 3px;
  max-height: min(280px, 38vh);
  overflow: auto;
  padding: 2px 2px 2px 0;
  scroll-padding-top: 2px;
  scroll-padding-bottom: 2px;
}

.filter-combobox--field .filter-combobox__list {
  gap: 2px;
  max-height: min(180px, var(--filter-combobox-available-height, 26vh));
}

.filter-combobox__option {
  width: 100%;
  border: 1px solid transparent;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.16);
  color: var(--text);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  text-align: left;
  padding: 8px 10px;
  font-size: 12px;
  line-height: 1.2;
  font-family: inherit;
  transition:
    transform var(--duration-fast) var(--ease-out),
    background var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out),
    color var(--duration-fast) var(--ease-out);
}

.filter-combobox--field .filter-combobox__option {
  padding: 7px 11px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.08);
}

.filter-combobox__option:hover,
.filter-combobox__option.is-active {
  transform: translateY(-1px);
  background: rgba(93, 135, 167, 0.16);
  border-color: rgba(31, 77, 122, 0.16);
}

.filter-combobox--field .filter-combobox__option:hover,
.filter-combobox--field .filter-combobox__option.is-active {
  transform: none;
  background: rgba(93, 135, 167, 0.14);
}

.filter-combobox__option.is-selected {
  background: rgba(31, 77, 122, 0.14);
  border-color: rgba(31, 77, 122, 0.22);
}

.filter-combobox--field .filter-combobox__option.is-selected {
  background: linear-gradient(135deg, rgba(214, 230, 244, 0.9) 0%, rgba(198, 219, 238, 0.84) 100%);
  border-color: rgba(125, 162, 194, 0.48);
}

.filter-combobox__option.is-disabled {
  opacity: 0.46;
  cursor: not-allowed;
}

.filter-combobox__option-label {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.filter-combobox__option-check {
  flex: 0 0 auto;
  color: var(--accent-strong);
  opacity: 0;
  transform: scale(0.9);
  transition:
    opacity var(--duration-fast) var(--ease-out),
    transform var(--duration-fast) var(--ease-out);
}

.filter-combobox__option.is-selected .filter-combobox__option-check {
  opacity: 1;
  transform: scale(1);
}

.filter-combobox__empty {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 10px 12px;
  color: var(--muted);
  font-size: 11px;
  line-height: 1.2;
  text-transform: none;
  letter-spacing: 0;
}

.filter-combobox__empty[hidden] {
  display: none;
}

body[data-theme="dark"] .filter-combobox__control {
  background: rgba(17, 38, 60, 0.84);
}

body[data-theme="dark"] .filter-combobox__icon {
  color: rgba(205, 216, 227, 0.62);
}

body[data-theme="dark"] .filter-combobox__clear:hover,
body[data-theme="dark"] .filter-combobox__toggle:hover {
  color: var(--accent-strong);
}

body[data-theme="dark"] .filter-combobox__menu {
  border-color: rgba(205, 216, 227, 0.16);
  background:
    radial-gradient(circle at top right, rgba(134, 179, 214, 0.18), transparent 42%),
    linear-gradient(165deg, rgba(16, 30, 52, 0.94) 0%, rgba(10, 22, 38, 0.92) 100%);
  box-shadow: 0 24px 46px rgba(0, 0, 0, 0.46);
}

body[data-theme="dark"] .filter-combobox__option {
  background: rgba(255, 255, 255, 0.04);
}

body[data-theme="dark"] .filter-combobox--field .filter-combobox__option {
  background: rgba(255, 255, 255, 0.03);
}

body[data-theme="dark"] .filter-combobox__option:hover,
body[data-theme="dark"] .filter-combobox__option.is-active {
  background: rgba(134, 179, 214, 0.14);
  border-color: rgba(134, 179, 214, 0.18);
}

body[data-theme="dark"] .filter-combobox__option.is-selected {
  background: rgba(134, 179, 214, 0.16);
  border-color: rgba(134, 179, 214, 0.22);
}

body[data-theme="dark"] .filter-combobox--field .filter-combobox__option.is-selected {
  background: linear-gradient(135deg, rgba(53, 83, 111, 0.9) 0%, rgba(42, 68, 93, 0.84) 100%);
  border-color: rgba(134, 179, 214, 0.28);
}

.account-static {
  min-height: 38px;
  padding: 8px 10px;
  border-radius: var(--radius-md);
  border: 1px solid var(--input-border);
  background: var(--input-bg);
  color: var(--text);
  font-size: 13px;
  display: flex;
  align-items: center;
  line-height: 1.3;
  text-transform: none;
  letter-spacing: 0;
  font-family: inherit;
}

.account-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: var(--radius-md);
  border: 1px solid var(--input-border);
  background: var(--input-bg);
  justify-self: start;
}

.account-toggle input[type="checkbox"] {
  width: 16px;
  height: 16px;
  margin: 0;
  padding: 0;
  border-radius: 4px;
  border: 1px solid var(--input-border);
  background: var(--input-bg);
  accent-color: var(--accent);
  appearance: none;
  -webkit-appearance: none;
  position: relative;
  display: inline-grid;
  place-items: center;
  box-shadow: none;
  background-image: none;
}

.account-toggle input[type="checkbox"]::after {
  content: "";
  width: 8px;
  height: 4px;
  border-left: 2px solid var(--accent-strong);
  border-bottom: 2px solid var(--accent-strong);
  transform: rotate(-45deg) scale(0);
  transition: transform var(--duration) var(--ease-out);
}

.account-toggle input[type="checkbox"]:checked {
  background: rgba(31, 77, 122, 0.2);
  border-color: var(--accent);
}

.account-toggle input[type="checkbox"]:checked::after {
  transform: rotate(-45deg) scale(1);
}

.account-toggle__label {
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
}

.account-perms-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.account-toggle.account-toggle--option {
  cursor: pointer;
  user-select: none;
}

@media (max-width: 820px) {
  .rubrica-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .rubrica-form-grid {
    grid-template-columns: 1fr;
  }

  .rubrica-tabs {
    width: 100%;
  }

  .rubrica-filter-form {
    flex: 1 1 auto;
  }

  .rubrica-filter-shell {
    grid-template-columns: 1fr;
  }

  .rubrica-filter-shell .btn {
    min-width: 0;
  }

  .account-perms-grid {
    grid-template-columns: 1fr;
  }

  .employee-detail-grid {
    grid-template-columns: 1fr;
  }

  .employee-detail-section--full {
    grid-column: auto;
  }

  .employee-detail-list,
  .employee-detail-list--user {
    grid-template-columns: 1fr;
  }

  .employee-check-grid {
    grid-template-columns: 1fr;
  }

  .employee-notification-grid {
    grid-template-columns: 1fr;
  }
}

.account-actions {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  flex-wrap: wrap;
}

.account-actions--spaced {
  margin-top: 12px;
}

.employee-actions {
  gap: 14px;
}

.employee-detail-form {
  display: contents;
}

.employee-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  align-items: stretch;
}

.employee-detail-layout {
  display: contents;
}

.employee-detail-section {
  display: grid;
  gap: 10px;
  height: 100%;
  padding: 12px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--glass-border);
  background:
    radial-gradient(circle at top right, rgba(148, 163, 184, 0.12) 0%, transparent 38%),
    linear-gradient(160deg, var(--glass-strong) 0%, var(--glass) 100%);
}

.employee-detail-section--full {
  grid-column: 1 / -1;
}

.employee-detail-section--user {
  order: 1;
}

.employee-detail-section--company {
  order: 2;
}

.employee-detail-section--add-company {
  order: 3;
}

.employee-detail-section--notifications {
  order: 4;
}

.employee-detail-section--pages {
  order: 5;
}

.employee-detail-section__head {
  display: grid;
  gap: 4px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--glass-border);
}

.employee-detail-section__title {
  margin: 0;
  font-size: 13px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text);
}

.employee-detail-section__subtitle {
  margin: 0;
  font-size: 11px;
  line-height: 1.35;
  color: var(--muted);
  text-transform: none;
  letter-spacing: 0;
}

.employee-detail-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.employee-detail-list--user {
  gap: 8px;
}

.employee-detail-list--company {
  gap: 8px;
}

.employee-detail-item {
  padding: 7px 10px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(148, 163, 184, 0.22);
  background: rgba(255, 255, 255, 0.18);
  align-content: start;
  gap: 4px;
}

.employee-detail-item span:first-child {
  font-size: 10px;
  letter-spacing: 0.12em;
}

.employee-detail-item--full {
  grid-column: 1 / -1;
}

.employee-detail-item .account-static,
.employee-detail-item input,
.employee-detail-item select,
.employee-detail-item textarea {
  width: 100%;
  min-height: 34px;
  padding-top: 6px;
  padding-bottom: 6px;
  font-size: 12.5px;
}

.employee-detail-item .account-static {
  padding-inline: 10px;
}

.employee-detail-item textarea {
  min-height: 72px;
}

.employee-detail-item.account-field--toggle .account-toggle {
  justify-self: stretch;
  justify-content: flex-start;
  min-height: 34px;
}

.employee-detail-item select[multiple] {
  min-height: 96px;
}

.employee-detail-item--status {
  align-content: center;
}

.employee-membership-switch {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding-top: 2px;
  align-items: center;
}

.employee-membership-switch .btn {
  min-height: 28px;
  padding: 4px 10px;
  border-radius: 10px;
  font-size: 10px;
  line-height: 1.1;
  letter-spacing: 0.08em;
  white-space: nowrap;
}

.employee-actions--footer {
  order: 6;
  grid-column: 1 / -1;
  margin-top: 0;
}

.employee-detail-item--checks {
  gap: 6px;
}

.employee-check-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
}

.employee-check {
  display: flex;
  align-items: center;
  gap: 7px;
  min-height: 34px;
  padding: 6px 10px;
  border-radius: 10px;
  border: 1px solid rgba(148, 163, 184, 0.28);
  background: rgba(255, 255, 255, 0.34);
  color: var(--text);
  font-size: 11px;
  letter-spacing: 0;
  text-transform: none;
  cursor: pointer;
}

.employee-check:hover {
  border-color: rgba(59, 130, 246, 0.38);
  background: rgba(255, 255, 255, 0.48);
}

.employee-check input[type="checkbox"] {
  width: 16px;
  height: 16px;
  margin: 0;
  flex: 0 0 auto;
  accent-color: var(--accent);
}

.employee-check span {
  font-size: 11px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--text);
}

.employee-detail-perms {
  gap: 8px 12px;
}

.employee-detail-perms .account-toggle--option {
  width: 100%;
  justify-content: flex-start;
  min-height: 34px;
  padding: 6px 10px;
  border-radius: 10px;
}

.employee-detail-perms .account-toggle__label {
  font-size: 11px;
  letter-spacing: 0.1em;
}

.employee-detail-perms .account-toggle input[type="checkbox"] {
  width: 16px;
  height: 16px;
  border: 0;
  border-radius: 0;
  padding: 0;
  appearance: auto;
  -webkit-appearance: checkbox;
  background: transparent;
  display: block;
  place-items: normal;
}

.employee-detail-perms .account-toggle input[type="checkbox"]::after {
  content: none;
}

.employee-detail-perms .account-toggle input[type="checkbox"]:checked {
  background: transparent;
  border: 0;
}

.employee-page-perm-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
}

.employee-page-perm-card {
  display: grid;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(148, 163, 184, 0.28);
  background: rgba(255, 255, 255, 0.34);
}

.employee-page-perm-card__title {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(15, 23, 42, 0.74);
}

.employee-page-perm-card__toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: var(--text);
}

.employee-page-perm-card__toggle input[type="checkbox"] {
  width: 16px;
  height: 16px;
  margin: 0;
  accent-color: var(--accent);
}

.employee-card--notification-panel {
  gap: 0;
}

.employee-card__head--notification {
  padding-bottom: 12px;
}

.employee-notification-sections {
  display: grid;
}

.employee-notification-section {
  display: grid;
  gap: 10px;
  padding: 14px 0;
  border-top: 1px solid rgba(148, 163, 184, 0.18);
}

.employee-notification-section:first-child {
  padding-top: 16px;
  border-top: 0;
}

.employee-notification-section.is-unavailable {
  opacity: 0.7;
}

.employee-notification-section__head {
  display: grid;
  gap: 6px;
}

.employee-notification-section__copy {
  display: grid;
  gap: 4px;
}

.employee-notification-section__title {
  margin: 0;
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
}

.employee-notification-section__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 12px;
  font-size: 11px;
  line-height: 1.45;
  color: var(--muted);
}

.employee-notification-table-shell {
  overflow-x: auto;
  border: 1px solid rgba(148, 163, 184, 0.18);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.22);
}

.employee-notification-table {
  width: 100%;
  min-width: 720px;
  border-collapse: collapse;
}

.employee-notification-table thead th {
  padding: 10px 14px;
  border-bottom: 1px solid rgba(148, 163, 184, 0.18);
  background: rgba(255, 255, 255, 0.28);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  text-align: left;
}

.employee-notification-table thead th:last-child,
.employee-notification-table thead th:nth-last-child(2) {
  text-align: center;
}

.employee-notification-row + .employee-notification-row .employee-notification-cell {
  border-top: 1px solid rgba(148, 163, 184, 0.14);
}

.employee-notification-row.is-disabled {
  opacity: 0.62;
}

.employee-notification-cell {
  padding: 12px 14px;
  vertical-align: middle;
}

.employee-notification-cell--title {
  width: 28%;
}

.employee-notification-cell--description {
  width: 42%;
}

.employee-notification-cell--channel {
  width: 15%;
  text-align: center;
}

.employee-notification-card__heading {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.employee-notification-card__title {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.01em;
  text-transform: none;
  color: var(--text);
}

.employee-notification-card__text {
  font-size: 11px;
  line-height: 1.45;
  color: var(--muted);
  text-transform: none;
  letter-spacing: 0;
}

.employee-notification-card__toggle.is-disabled {
  opacity: 0.52;
}

.employee-notification-cell--channel .employee-page-list__toggle,
.employee-notification-cell--channel .employee-inline-tag {
  justify-content: center;
  min-width: 78px;
}

.employee-notification-cell__empty {
  font-size: 12px;
  color: rgba(100, 116, 139, 0.78);
}

@media (max-width: 860px) {
  .employee-notification-table-shell {
    margin-inline: -2px;
  }
}

.board__panel.board__panel--employee-workspace {
  padding: 0;
  gap: 0;
  overflow: visible;
}

.employee-workspace__topbar,
.employee-hero,
.employee-tabs,
.employee-workspace__form,
.employee-pane--secondary {
  padding-inline: 24px;
}

.employee-workspace__topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding-top: 22px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--glass-border);
}

.employee-breadcrumb {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  color: var(--muted);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.employee-breadcrumb__link {
  color: var(--muted);
  text-decoration: none;
  transition: color var(--duration) var(--ease-out);
}

.employee-breadcrumb__link:hover,
.employee-breadcrumb__link:focus-visible {
  color: var(--accent-strong);
  outline: none;
}

.employee-breadcrumb__divider {
  color: rgba(148, 163, 184, 0.72);
}

.employee-breadcrumb__current {
  color: var(--text);
  font-weight: 700;
}

.employee-workspace__actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.employee-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding-top: 22px;
  padding-bottom: 22px;
  background:
    radial-gradient(circle at top right, rgba(104, 176, 232, 0.16) 0%, transparent 34%),
    linear-gradient(150deg, rgba(255, 255, 255, 0.24) 0%, rgba(255, 255, 255, 0.08) 100%);
  border-bottom: 1px solid var(--glass-border);
}

.employee-hero__identity {
  display: flex;
  align-items: center;
  gap: 16px;
  min-width: 0;
}

.employee-avatar {
  width: 72px;
  height: 72px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  font-size: 24px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--avatar-fg, #103352);
  background: var(--avatar-bg, linear-gradient(135deg, rgba(173, 216, 255, 0.96) 0%, rgba(138, 188, 236, 0.96) 100%));
  box-shadow: 0 18px 40px rgba(74, 124, 168, 0.18);
  overflow: hidden;
}

.employee-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.employee-hero__copy {
  min-width: 0;
  display: grid;
  gap: 7px;
}

.employee-hero__title {
  margin: 0;
  font-size: clamp(28px, 3vw, 36px);
  line-height: 1.04;
}

.employee-hero__subtitle,
.employee-hero__meta {
  margin: 0;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  color: var(--muted);
}

.employee-hero__subtitle {
  font-size: 14px;
}

.employee-hero__meta {
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.employee-hero__status {
  min-width: 220px;
  display: grid;
  gap: 10px;
  justify-items: end;
  text-align: right;
}

.employee-status-cluster {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.employee-status-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 32px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, 0.24);
  background: rgba(255, 255, 255, 0.62);
  color: var(--text);
  font-size: 12px;
  font-weight: 600;
}

.employee-status-pill::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: currentColor;
  opacity: 0.85;
}

.employee-status-pill--success {
  color: #4d7a12;
  background: rgba(236, 248, 215, 0.96);
}

.employee-status-pill--warning {
  color: #966500;
  background: rgba(255, 241, 205, 0.96);
}

.employee-status-pill--danger {
  color: #a53939;
  background: rgba(255, 223, 223, 0.96);
}

.employee-status-pill--muted {
  color: #556273;
  background: rgba(226, 232, 240, 0.92);
}

.employee-hero__email {
  color: var(--text);
  font-size: 14px;
  text-decoration: none;
}

.employee-hero__email--muted {
  color: var(--muted);
}

.employee-membership-overview {
  display: grid;
  gap: 8px;
}

.employee-membership-overview__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  padding: 16px 24px 0;
}

.employee-membership-overview__title {
  margin: 0;
  font-family: var(--font-title);
  font-size: 14px;
  color: var(--text);
}

.employee-membership-strip {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  overflow-y: hidden;
  padding: 4px 24px 6px;
  scrollbar-width: thin;
  scrollbar-color: rgba(74, 124, 168, 0.55) rgba(148, 163, 184, 0.14);
  scrollbar-gutter: stable;
  scroll-padding-inline: 24px;
  overscroll-behavior-inline: contain;
  -webkit-overflow-scrolling: touch;
}

.employee-membership-strip::-webkit-scrollbar {
  height: 10px;
}

.employee-membership-strip::-webkit-scrollbar-track {
  background: rgba(148, 163, 184, 0.14);
  border-radius: 999px;
}

.employee-membership-strip::-webkit-scrollbar-thumb {
  background: rgba(74, 124, 168, 0.55);
  border-radius: 999px;
}

.employee-membership-strip::-webkit-scrollbar-thumb:hover {
  background: rgba(74, 124, 168, 0.72);
}

.employee-membership-chip {
  flex: 0 0 auto;
  min-width: 180px;
  display: grid;
  gap: 4px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(148, 163, 184, 0.24);
  background: rgba(255, 255, 255, 0.3);
  text-decoration: none;
  color: var(--text);
  transition: transform var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out), background var(--duration) var(--ease-out);
}

.employee-membership-chip:hover,
.employee-membership-chip:focus-visible {
  transform: translateY(-1px);
  border-color: var(--accent);
  outline: none;
}

.employee-membership-chip.is-active {
  border-color: color-mix(in srgb, var(--accent) 55%, transparent);
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.46) 0%, rgba(179, 214, 244, 0.26) 100%);
}

.employee-membership-chip__name {
  font-size: 13px;
  font-weight: 700;
}

.employee-membership-chip__meta {
  font-size: 11px;
  color: var(--muted);
}

/* Employee directory */
.board__panel--employee-directory {
  padding: 0;
  display: grid;
  gap: 0;
  overflow: hidden;
  border-radius: calc(var(--radius-xl) + 4px);
}

.employee-directory__hero {
  display: grid;
  grid-template-columns: minmax(320px, 0.78fr) minmax(0, 1.22fr);
  gap: 18px;
  align-items: start;
  padding: 24px;
  background:
    radial-gradient(circle at top right, rgba(34, 197, 94, 0.12) 0%, transparent 34%),
    radial-gradient(circle at 0% 0%, rgba(14, 165, 233, 0.18) 0%, transparent 42%),
    linear-gradient(150deg, rgba(255, 255, 255, 0.28) 0%, rgba(255, 255, 255, 0.08) 100%);
  border-bottom: 1px solid var(--glass-border);
  border-top-left-radius: inherit;
  border-top-right-radius: inherit;
}

.employee-directory__hero-copy {
  min-width: 0;
  align-self: start;
  align-content: start;
  gap: 6px;
  padding-bottom: 0;
  border-bottom: none;
}

.employee-directory__stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(140px, 1fr));
  gap: 10px;
  align-self: start;
  justify-self: stretch;
  width: 100%;
}

.employee-directory__stat-card {
  display: grid;
  gap: 4px;
  min-height: 86px;
  padding: 12px 14px;
  border-radius: 18px;
  border: 1px solid rgba(148, 163, 184, 0.2);
  background: rgba(255, 255, 255, 0.56);
  box-shadow: 0 12px 26px rgba(15, 23, 42, 0.07);
  align-content: start;
}

.employee-directory__stat-label {
  font-size: 9px;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  color: var(--muted);
}

.employee-directory__stat-value {
  font-family: var(--font-title);
  font-size: clamp(20px, 1.75vw, 24px);
  line-height: 1;
  color: var(--text);
}

.employee-directory__stat-note {
  max-width: 19ch;
  font-size: 9.5px;
  line-height: 1.25;
  color: var(--muted);
}

.employee-directory__filters {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: end;
  padding: 12px 20px;
  border-bottom: 1px solid var(--glass-border);
}

.employee-directory__filters-main {
  display: grid;
  grid-template-columns: minmax(240px, 340px) auto;
  gap: 10px;
  align-items: end;
}

.employee-directory__filter-field {
  margin: 0;
  gap: 3px;
}

.employee-directory__filters-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.employee-directory__filters-summary {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-self: end;
}

.employee-directory__shell {
  --employee-directory-columns:
    minmax(0, 2.05fr)
    minmax(160px, 0.92fr)
    minmax(120px, 0.72fr)
    minmax(132px, 0.78fr)
    minmax(132px, 0.78fr)
    minmax(220px, 1.16fr)
    minmax(112px, 0.52fr);
  min-width: 0;
  padding: 10px 12px 14px;
}

.employee-directory__header,
.employee-directory__row {
  display: grid;
  grid-template-columns: var(--employee-directory-columns);
  gap: 14px;
  align-items: center;
  padding-inline: 24px;
}

.employee-directory__header {
  position: sticky;
  top: 10px;
  z-index: 2;
  min-height: 48px;
  margin-bottom: 8px;
  padding-block: 0;
  background: rgba(247, 250, 252, 0.82);
  backdrop-filter: blur(14px);
  border: 1px solid rgba(148, 163, 184, 0.18);
  border-radius: 18px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}

.employee-directory__header-actions {
  justify-self: end;
  text-align: right;
}

.employee-directory__header-joined,
.employee-directory__header-last-access,
.employee-directory__cell--joined,
.employee-directory__cell--last-access {
  margin-left: 0;
}

.employee-directory__list {
  display: grid;
  gap: 8px;
}

.employee-directory__row {
  min-height: 76px;
  padding-top: 10px;
  padding-bottom: 10px;
  border: 1px solid color-mix(in srgb, var(--glass-border) 82%, transparent);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.18);
  transition:
    background-color var(--duration) var(--ease-out),
    transform var(--duration) var(--ease-out),
    border-color var(--duration) var(--ease-out),
    box-shadow var(--duration) var(--ease-out);
}

.employee-directory__row:hover {
  background: color-mix(in srgb, var(--accent-soft) 14%, rgba(255, 255, 255, 0.34));
  border-color: color-mix(in srgb, var(--accent) 20%, rgba(148, 163, 184, 0.16));
  box-shadow: 0 12px 22px rgba(15, 23, 42, 0.06);
}

.employee-directory__cell {
  min-width: 0;
}

.employee-directory__person {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.employee-directory__avatar-shell {
  position: relative;
  flex: 0 0 auto;
}

.employee-directory__avatar {
  width: 38px;
  height: 38px;
  overflow: hidden;
  border-radius: 999px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(148, 163, 184, 0.22);
  background: var(--avatar-bg, linear-gradient(135deg, rgba(173, 216, 255, 0.96) 0%, rgba(138, 188, 236, 0.96) 100%));
  box-shadow: 0 10px 20px rgba(74, 124, 168, 0.14);
  color: var(--avatar-fg, #103352);
}

.employee-directory__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.employee-directory__avatar-initials {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: inherit;
}

.employee-directory__presence {
  position: absolute;
  right: -2px;
  bottom: -2px;
  width: 11px;
  height: 11px;
  border-radius: 999px;
  border: 2px solid rgba(248, 250, 252, 0.96);
  background: #94a3b8;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.16);
}

.employee-directory__presence--success {
  background: #16a34a;
}

.employee-directory__presence--warning {
  background: #d97706;
}

.employee-directory__presence--danger {
  background: #dc2626;
}

.employee-directory__presence--muted {
  background: #64748b;
}

.employee-directory__person-copy {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.employee-directory__person-name {
  display: inline-flex;
  width: fit-content;
  max-width: 100%;
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
  text-decoration: none;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.employee-directory__person-name:hover,
.employee-directory__person-name:focus-visible {
  color: var(--accent-strong);
}

.employee-directory__person-meta {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  font-size: 11px;
  color: var(--muted);
}

.employee-directory__person-meta span {
  white-space: nowrap;
}

.employee-directory__role-main,
.employee-directory__joined-value {
  font-size: 12px;
  font-weight: 700;
  color: var(--text);
}

.employee-directory__joined-line {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}

.employee-directory__joined-line--empty {
  gap: 0;
}

.employee-directory__role-meta,
.employee-directory__joined-meta,
.employee-directory__company-meta {
  margin-top: 2px;
  font-size: 11px;
  color: var(--muted);
}

.employee-directory__joined-line .employee-directory__joined-meta {
  margin-top: 0;
}

.employee-directory__status {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.board__panel--employee-directory .employee-status-pill {
  min-height: 28px;
  padding: 0 12px;
  gap: 6px;
  font-size: 11px;
}

.board__panel--employee-directory .employee-status-pill::before {
  width: 7px;
  height: 7px;
}

.employee-directory__company-stack {
  min-width: 0;
}

.employee-directory__company-preview {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
}

.board__panel--employee-directory .employee-inline-tag {
  min-height: 24px;
  padding: 0 10px;
  border-radius: 999px;
  font-size: 10px;
}

.employee-directory__company-preview .employee-inline-tag {
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.employee-directory__actions {
  display: flex;
  justify-content: flex-end;
}

.board__panel--employee-directory .employee-directory__actions .btn {
  min-height: 32px;
  padding: 6px 12px;
  border-radius: 14px;
  font-size: 10px;
  letter-spacing: 0.14em;
}

.employee-directory__empty {
  display: grid;
  justify-items: center;
  gap: 12px;
  padding: 44px 24px;
  text-align: center;
}

.employee-directory__empty-title {
  font-family: var(--font-title);
  font-size: 18px;
  color: var(--text);
}

.employee-directory__empty-text {
  max-width: 56ch;
  margin: 0;
  color: var(--muted);
}

body[data-theme="dark"] .employee-directory__hero {
  background:
    radial-gradient(circle at top right, rgba(34, 197, 94, 0.18) 0%, transparent 34%),
    radial-gradient(circle at 0% 0%, rgba(14, 165, 233, 0.2) 0%, transparent 42%),
    linear-gradient(160deg, rgba(16, 30, 52, 0.86) 0%, rgba(10, 22, 38, 0.92) 100%);
}

body[data-theme="dark"] .employee-directory__stat-card,
body[data-theme="dark"] .employee-directory__header,
body[data-theme="dark"] .employee-directory__avatar {
  border-color: rgba(134, 179, 214, 0.22);
}

body[data-theme="dark"] .employee-directory__stat-card {
  background: rgba(15, 23, 42, 0.45);
}

body[data-theme="dark"] .employee-directory__header {
  background: rgba(10, 18, 32, 0.82);
}

body[data-theme="dark"] .employee-directory__row:hover {
  background: rgba(30, 41, 59, 0.36);
}

body[data-theme="dark"] .employee-directory__row {
  background: rgba(15, 23, 42, 0.22);
}

body[data-theme="dark"] .employee-directory__avatar {
  background: var(--avatar-bg, linear-gradient(145deg, rgba(24, 50, 79, 0.98) 0%, rgba(15, 30, 50, 0.98) 100%));
}

body[data-theme="dark"] .employee-directory__presence {
  border-color: rgba(7, 20, 34, 0.94);
}

body[data-theme="dark"] .board__panel--employee-directory .employee-inline-tag {
  background: rgba(15, 23, 42, 0.5);
}

@media (min-width: 1201px) {
  .employee-directory__header {
    text-align: center;
  }

  .employee-directory__header > :first-child {
    text-align: left;
  }

  .employee-directory__cell--role,
  .employee-directory__cell--status,
  .employee-directory__cell--joined,
  .employee-directory__cell--last-access,
  .employee-directory__cell--companies {
    display: grid;
    justify-items: center;
    text-align: center;
  }

  .employee-directory__header-joined,
  .employee-directory__header-last-access,
  .employee-directory__cell--joined,
  .employee-directory__cell--last-access {
    justify-self: center;
  }

  .employee-directory__status,
  .employee-directory__company-preview {
    justify-content: center;
  }

  .employee-directory__company-stack {
    display: grid;
    gap: 4px;
    justify-items: center;
  }
}

@media (max-width: 1200px) {
  .employee-directory__hero {
    grid-template-columns: 1fr;
  }

  .employee-directory__stats {
    justify-self: stretch;
    width: 100%;
  }

  .employee-directory__filters {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .employee-directory__filters-summary {
    justify-self: start;
  }

  .employee-directory__header {
    display: none;
  }

  .employee-directory__row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px 18px;
    align-items: start;
    padding-top: 14px;
    padding-bottom: 14px;
  }

  .employee-directory__cell {
    display: grid;
    gap: 6px;
  }

  .employee-directory__cell--joined,
  .employee-directory__cell--last-access {
    margin-left: 0;
  }

  .employee-directory__cell::before {
    content: attr(data-label);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--muted);
  }

  .employee-directory__cell--person,
  .employee-directory__cell--actions {
    grid-column: 1 / -1;
  }

  .employee-directory__cell--person::before,
  .employee-directory__cell--actions::before {
    display: none;
  }

  .employee-directory__actions {
    justify-content: flex-start;
  }
}

@media (max-width: 860px) {
  .employee-directory__hero,
  .employee-directory__filters,
  .employee-directory__row {
    padding-inline: 16px;
  }

  .employee-directory__header {
    margin-inline: 0;
  }

  .employee-directory__shell {
    padding-inline: 10px;
  }

  .employee-directory__stats {
    grid-template-columns: 1fr 1fr;
  }

  .employee-directory__filters-main {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 680px) {
  .employee-directory__stats,
  .employee-directory__row {
    grid-template-columns: 1fr;
  }
}

.employee-tabs {
  position: relative;
  display: flex;
  align-items: flex-end;
  gap: 6px;
  padding-top: 18px;
  padding-bottom: 0;
  overflow-x: auto;
  overflow-y: hidden;
  border-bottom: 1px solid var(--glass-border);
  isolation: isolate;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.employee-tabs::-webkit-scrollbar {
  display: none;
}

.employee-tabs__cursor {
  position: absolute;
  left: 0;
  bottom: -1px;
  z-index: 1;
  width: 0;
  height: 46px;
  border-radius: 14px 14px 0 0;
  border: 1px solid rgba(31, 77, 122, 0.18);
  border-bottom-color: transparent;
  background:
    radial-gradient(circle at 50% 0%, rgba(255, 255, 255, 0.48) 0%, transparent 64%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.94) 0%, rgba(233, 240, 248, 0.82) 100%);
  box-shadow:
    0 12px 24px rgba(31, 77, 122, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.44);
  opacity: 0;
  transform: translateX(0);
  transition:
    transform 280ms cubic-bezier(0.22, 1, 0.36, 1),
    width 280ms cubic-bezier(0.22, 1, 0.36, 1),
    height 280ms cubic-bezier(0.22, 1, 0.36, 1),
    opacity 160ms ease-out;
  pointer-events: none;
}

.employee-tabs__cursor::after {
  content: "";
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 0;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--accent-2), var(--accent));
}

.employee-tab {
  flex: 0 0 auto;
  position: relative;
  z-index: 2;
  min-height: 46px;
  padding: 0 16px;
  border: 0;
  border-radius: 14px 14px 0 0;
  background: transparent;
  color: var(--muted);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition:
    color var(--duration) var(--ease-out),
    transform var(--duration) var(--ease-out);
}

.employee-tab::after {
  content: none;
}

.employee-tab:hover,
.employee-tab:focus-visible {
  color: var(--accent-strong);
  transform: translateY(-1px);
  outline: none;
}

.employee-tab.is-active,
.employee-tab[data-cursor-target="true"] {
  color: var(--accent-strong);
}

.employee-workspace__form,
.employee-pane--secondary {
  padding-top: 20px;
}

.employee-workspace__form {
  padding-bottom: 18px;
}

.employee-pane--secondary {
  padding-bottom: 18px;
}

.employee-pane {
  display: grid;
  gap: 18px;
}

.employee-pane.is-switching {
  animation: employee-pane-enter 240ms var(--ease-out);
}

.employee-pane[hidden] {
  display: none !important;
}

@keyframes employee-pane-enter {
  from {
    opacity: 0;
    transform: translateY(12px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.employee-pane__grid,
.employee-pane__stack {
  display: grid;
  gap: 18px;
}

.employee-pane__grid--summary {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.employee-card {
  display: grid;
  gap: 16px;
  padding: 20px;
  border-radius: 22px;
  border: 1px solid rgba(148, 163, 184, 0.2);
  background:
    radial-gradient(circle at top right, rgba(148, 163, 184, 0.12) 0%, transparent 34%),
    linear-gradient(155deg, rgba(255, 255, 255, 0.42) 0%, rgba(255, 255, 255, 0.2) 100%);
  box-shadow: 0 18px 38px rgba(15, 23, 42, 0.08);
}

.employee-card--full {
  grid-column: 1 / -1;
}

.employee-card__head {
  display: grid;
  gap: 6px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(148, 163, 184, 0.2);
}

.employee-card__head--split {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 14px;
}

.employee-card__title {
  margin: 0;
  font-size: 15px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.employee-card__subtitle,
.employee-card__hint {
  margin: 0;
  color: var(--muted);
  line-height: 1.45;
}

.employee-card__subtitle {
  font-size: 12px;
}

.employee-card__hint {
  font-size: 11px;
}

.employee-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  align-items: start;
}

.employee-form-field {
  min-width: 0;
  align-content: start;
}

.employee-form-note {
  margin: -4px 0 0;
  font-size: 10px;
  line-height: 1.35;
  color: var(--muted);
  letter-spacing: 0;
  text-transform: none;
}

.employee-form-note--full {
  grid-column: 1 / -1;
}

.employee-form-field--full,
.employee-form-field--checks {
  grid-column: 1 / -1;
}

.employee-membership-list {
  display: grid;
  gap: 12px;
}

.employee-membership-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid rgba(148, 163, 184, 0.2);
  background: rgba(255, 255, 255, 0.26);
}

.employee-membership-row.is-selected {
  border-color: color-mix(in srgb, var(--accent) 52%, transparent);
  background: linear-gradient(150deg, rgba(255, 255, 255, 0.4) 0%, rgba(184, 222, 248, 0.22) 100%);
}

.employee-membership-row__copy {
  display: grid;
  gap: 6px;
}

.employee-membership-row__title {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.employee-membership-row__meta {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
}

.employee-membership-row__actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.employee-membership-add {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 54px;
  padding: 0 16px;
  border-radius: 16px;
  border: 1px dashed rgba(148, 163, 184, 0.38);
  background: rgba(255, 255, 255, 0.08);
  color: var(--text);
  cursor: pointer;
  text-align: left;
  transition: border-color var(--duration) var(--ease-out), background var(--duration) var(--ease-out), transform var(--duration) var(--ease-out);
}

.employee-membership-add:hover,
.employee-membership-add:focus-visible {
  border-color: var(--accent);
  background: rgba(255, 255, 255, 0.18);
  transform: translateY(-1px);
  outline: none;
}

.employee-membership-add--disabled {
  cursor: default;
  opacity: 0.72;
}

.employee-membership-add--disabled:hover,
.employee-membership-add--disabled:focus-visible {
  transform: none;
  border-color: rgba(148, 163, 184, 0.38);
  background: rgba(255, 255, 255, 0.08);
}

.employee-membership-add__icon {
  width: 22px;
  height: 22px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  background: rgba(15, 23, 42, 0.72);
  color: #fff;
  font-size: 14px;
  font-weight: 700;
}

.employee-membership-add__label {
  font-size: 14px;
  font-weight: 600;
}

.employee-inline-tags,
.employee-summary-strip {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.employee-inline-tag {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, 0.24);
  background: rgba(255, 255, 255, 0.38);
  color: var(--text);
  font-size: 11px;
  font-weight: 600;
}

.employee-inline-tag--active {
  color: var(--accent-strong);
  border-color: color-mix(in srgb, var(--accent) 42%, transparent);
  background: rgba(202, 231, 255, 0.56);
}

.employee-page-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.employee-page-list__item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(148, 163, 184, 0.2);
  background: rgba(255, 255, 255, 0.24);
  transition: border-color var(--duration) var(--ease-out), background var(--duration) var(--ease-out);
}

.employee-page-list__item.is-disabled {
  opacity: 0.72;
}

.employee-page-list__main {
  min-width: 0;
  display: grid;
}

.employee-page-list__title-row {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.employee-page-list__title {
  margin: 0;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 13px;
}

.employee-page-list__state {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 9px;
  border-radius: 999px;
  background: rgba(202, 231, 255, 0.56);
  color: var(--accent-strong);
  font-size: 10px;
  font-weight: 600;
  white-space: nowrap;
}

.employee-page-list__item.is-disabled .employee-page-list__state {
  background: rgba(226, 232, 240, 0.82);
  color: #556273;
}

.employee-page-list__toggles {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: nowrap;
  justify-content: flex-end;
}

.employee-page-list__toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 30px;
  padding: 0 9px;
  border-radius: 10px;
  border: 1px solid rgba(148, 163, 184, 0.2);
  background: rgba(255, 255, 255, 0.42);
  font-size: 11px;
}

.employee-page-list__toggle input[type="checkbox"] {
  width: 16px;
  height: 16px;
  margin: 0;
  accent-color: var(--accent);
}

.employee-page-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 12px;
}

.employee-page-card {
  display: grid;
  gap: 12px;
  padding: 16px;
  border-radius: 18px;
  border: 1px solid rgba(148, 163, 184, 0.2);
  background: rgba(255, 255, 255, 0.24);
  transition: border-color var(--duration) var(--ease-out), background var(--duration) var(--ease-out);
}

.employee-page-card.is-disabled {
  opacity: 0.72;
}

.employee-page-card__head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
}

.employee-page-card__title {
  margin: 0;
  font-size: 13px;
}

.employee-page-card__text {
  margin: 6px 0 0;
  color: var(--muted);
  font-size: 11px;
  line-height: 1.45;
}

.employee-page-card__state {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 11px;
  border-radius: 999px;
  background: rgba(202, 231, 255, 0.56);
  color: var(--accent-strong);
  font-size: 11px;
  font-weight: 600;
  white-space: nowrap;
}

.employee-page-card.is-disabled .employee-page-card__state {
  background: rgba(226, 232, 240, 0.82);
  color: #556273;
}

.employee-page-card__toggles {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.employee-page-card__toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 38px;
  padding: 0 12px;
  border-radius: 12px;
  border: 1px solid rgba(148, 163, 184, 0.2);
  background: rgba(255, 255, 255, 0.42);
  font-size: 12px;
}

.employee-page-card__toggle input[type="checkbox"] {
  width: 16px;
  height: 16px;
  margin: 0;
  accent-color: var(--accent);
}

.board__panel--employee-workspace .employee-card--notification-panel {
  gap: 0;
}

.board__panel--employee-workspace .employee-card__head--notification {
  padding-bottom: 10px;
}

.board__panel--employee-workspace .employee-notification-section {
  gap: 8px;
  padding: 12px 0;
  border-top-color: rgba(31, 77, 122, 0.14);
}

.board__panel--employee-workspace .employee-notification-section__title {
  font-size: 12px;
  color: #1f2937;
}

.board__panel--employee-workspace .employee-notification-section__meta {
  font-size: 10px;
  color: #556273;
}

.board__panel--employee-workspace .employee-notification-table-shell {
  border-color: rgba(31, 77, 122, 0.16);
  border-radius: 14px;
  background:
    linear-gradient(165deg, rgba(255, 255, 255, 0.74) 0%, rgba(243, 247, 252, 0.9) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.46);
}

.board__panel--employee-workspace .employee-notification-table thead th {
  padding: 9px 12px;
  border-bottom-color: rgba(31, 77, 122, 0.14);
  background: rgba(233, 241, 248, 0.82);
  color: #5b6778;
}

.board__panel--employee-workspace .employee-notification-cell {
  padding: 10px 12px;
}

.board__panel--employee-workspace .employee-notification-row + .employee-notification-row .employee-notification-cell {
  border-top-color: rgba(31, 77, 122, 0.12);
}

.board__panel--employee-workspace .employee-notification-row.is-disabled {
  opacity: 0.58;
}

.board__panel--employee-workspace .employee-notification-cell__empty {
  color: #7a8797;
}

.employee-placeholder {
  min-height: 220px;
  display: grid;
  place-content: center;
  gap: 10px;
  padding: 22px;
  border-radius: 18px;
  border: 1px dashed rgba(148, 163, 184, 0.34);
  background: rgba(255, 255, 255, 0.2);
  text-align: center;
}

.employee-placeholder--compact {
  min-height: auto;
}

.employee-placeholder__title {
  font-size: 14px;
  font-weight: 700;
}

.employee-placeholder__text {
  margin: 0;
  color: var(--muted);
  line-height: 1.5;
}

.employee-inline-form__actions {
  display: flex;
  justify-content: flex-end;
}

.employee-membership-modal__panel {
  width: min(860px, calc(100% - 32px));
}

.employee-modal-form {
  margin-top: 16px;
  display: grid;
  gap: 16px;
}

.employee-membership-modal .employee-form-grid {
  gap: 10px 12px;
}

.employee-membership-modal .employee-form-field {
  gap: 4px;
}

.employee-membership-modal .account-field input,
.employee-membership-modal .account-field select,
.employee-membership-modal .account-static {
  min-height: 34px;
  height: 34px;
  box-sizing: border-box;
  padding-top: 0;
  padding-bottom: 0;
  font-size: 12px;
  line-height: 1.2;
}

.employee-membership-modal .account-field input,
.employee-membership-modal .account-static {
  padding-left: 10px;
  padding-right: 10px;
}

.employee-membership-modal .account-field select {
  padding-left: 10px;
  padding-right: 28px;
}

.employee-membership-modal .employee-modal-form__actions {
  margin-top: 2px;
}

.employee-modal-form__actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

.employee-errors {
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(220, 38, 38, 0.18);
  background: rgba(254, 226, 226, 0.65);
}

.account-danger--employee {
  margin-top: 2px;
}

.board__panel--employee-workspace .employee-workspace__topbar,
.board__panel--employee-workspace .employee-hero,
.board__panel--employee-workspace .employee-tabs,
.board__panel--employee-workspace .employee-workspace__form,
.board__panel--employee-workspace .employee-pane--secondary {
  padding-inline: 18px;
}

.board__panel--employee-workspace .employee-workspace__topbar {
  gap: 12px;
  padding-top: 14px;
  padding-bottom: 12px;
}

.board__panel--employee-workspace .employee-breadcrumb {
  gap: 8px;
  font-size: 12px;
}

.board__panel--employee-workspace .employee-workspace__actions {
  gap: 8px;
}

.board__panel--employee-workspace .employee-hero {
  gap: 14px;
  padding-top: 14px;
  padding-bottom: 14px;
}

.board__panel--employee-workspace .employee-hero__identity {
  gap: 12px;
}

.board__panel--employee-workspace .employee-avatar {
  width: 58px;
  height: 58px;
  border-radius: 999px;
  font-size: 20px;
  box-shadow: 0 14px 28px rgba(74, 124, 168, 0.16);
}

.board__panel--employee-workspace .employee-hero__copy {
  gap: 4px;
}

.board__panel--employee-workspace .employee-hero__title {
  font-size: clamp(22px, 2.6vw, 30px);
}

.board__panel--employee-workspace .employee-hero__subtitle,
.board__panel--employee-workspace .employee-hero__meta {
  gap: 8px;
}

.board__panel--employee-workspace .employee-hero__subtitle {
  font-size: 13px;
}

.board__panel--employee-workspace .employee-hero__meta {
  font-size: 11px;
}

.board__panel--employee-workspace .employee-hero__status {
  min-width: 200px;
  gap: 8px;
}

.board__panel--employee-workspace .employee-status-cluster {
  gap: 6px;
}

.board__panel--employee-workspace .employee-status-pill {
  min-height: 28px;
  padding: 0 11px;
  gap: 6px;
  font-size: 12px;
}

.board__panel--employee-workspace .employee-status-pill::before {
  width: 7px;
  height: 7px;
}

.board__panel--employee-workspace .employee-hero__email {
  font-size: 13px;
}

.board__panel--employee-workspace .employee-membership-overview__head {
  gap: 10px;
  padding: 10px 18px 0;
}

.board__panel--employee-workspace .employee-membership-overview__title {
  font-size: 13px;
}

.board__panel--employee-workspace .employee-membership-strip {
  gap: 8px;
  padding: 4px 18px 6px;
}

.board__panel--employee-workspace .employee-membership-chip {
  min-width: 160px;
  gap: 3px;
  padding: 9px 11px;
  border-radius: 13px;
}

.board__panel--employee-workspace .employee-membership-chip__name {
  font-size: 13px;
}

.board__panel--employee-workspace .employee-membership-chip__meta {
  font-size: 11px;
}

.board__panel--employee-workspace .employee-tabs {
  gap: 3px;
  padding-top: 10px;
}

.board__panel--employee-workspace .employee-tabs__cursor {
  border-radius: 11px 11px 0 0;
}

.board__panel--employee-workspace .employee-tab {
  min-height: 38px;
  padding: 0 13px;
  border-radius: 11px 11px 0 0;
  font-size: 13px;
}

.board__panel--employee-workspace .employee-workspace__form,
.board__panel--employee-workspace .employee-pane--secondary {
  padding-top: 12px;
}

.board__panel--employee-workspace .employee-pane,
.board__panel--employee-workspace .employee-pane__grid,
.board__panel--employee-workspace .employee-pane__stack {
  gap: 12px;
}

.board__panel--employee-workspace .employee-pane__grid--summary {
  align-items: start;
}

.board__panel--employee-workspace .employee-pane__grid--summary > .employee-card {
  height: auto;
}

.board__panel--employee-workspace .employee-card {
  gap: 12px;
  padding: 14px;
  border-radius: 18px;
  border-color: rgba(31, 77, 122, 0.22);
  background:
    radial-gradient(circle at top right, rgba(125, 174, 214, 0.12) 0%, transparent 34%),
    linear-gradient(165deg, rgba(255, 255, 255, 0.82) 0%, rgba(245, 249, 253, 0.92) 100%);
  box-shadow: 0 16px 32px rgba(15, 23, 42, 0.1);
  align-content: start;
}

.board__panel--employee-workspace .employee-card__head {
  gap: 4px;
  padding-bottom: 8px;
  border-bottom-color: rgba(31, 77, 122, 0.18);
}

.board__panel--employee-workspace .employee-card__head--split {
  gap: 10px;
}

.board__panel--employee-workspace .employee-card__title {
  font-size: 14px;
}

.board__panel--employee-workspace .employee-card__subtitle {
  font-size: 12px;
}

.board__panel--employee-workspace .employee-card__hint {
  font-size: 11px;
}

.board__panel--employee-workspace .employee-form-grid {
  gap: 8px;
}

.board__panel--employee-workspace .account-field {
  gap: 4px;
  font-size: 11px;
  letter-spacing: 0.12em;
}

.board__panel--employee-workspace .account-field .filter-combobox {
  width: 100%;
}

.board__panel--employee-workspace .account-field input,
.board__panel--employee-workspace .account-field select,
.board__panel--employee-workspace .account-field textarea,
.board__panel--employee-workspace .account-static,
.board__panel--employee-workspace .account-field .filter-combobox__control {
  min-height: 32px;
  box-sizing: border-box;
  font-size: 13px;
  line-height: 1.25;
  background: rgba(255, 255, 255, 0.92);
  border-color: rgba(31, 77, 122, 0.24);
  color: #1f2937;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.36);
}

.board__panel--employee-workspace .account-field input,
.board__panel--employee-workspace .account-field select,
.board__panel--employee-workspace .account-static,
.board__panel--employee-workspace .account-field .filter-combobox__control {
  height: 32px;
  padding-top: 0;
  padding-bottom: 0;
}

.board__panel--employee-workspace .account-field select {
  padding-right: 30px;
}

.board__panel--employee-workspace .account-field .filter-combobox__control {
  padding-left: 10px;
  padding-right: 4px;
}

.board__panel--employee-workspace .account-field .filter-combobox__input {
  height: 30px;
  padding-top: 0;
  padding-bottom: 0;
  font-size: 13px;
  line-height: 1.25;
}

.board__panel--employee-workspace .account-field .filter-combobox__toggle,
.board__panel--employee-workspace .account-field .filter-combobox--field .filter-combobox__toggle {
  width: 28px;
  height: 28px;
  border-radius: 8px;
}

.board__panel--employee-workspace .account-field input:focus,
.board__panel--employee-workspace .account-field select:focus,
.board__panel--employee-workspace .account-field textarea:focus,
.board__panel--employee-workspace .account-field .filter-combobox__control:focus-within,
.board__panel--employee-workspace .account-field .filter-combobox.is-open .filter-combobox__control {
  border-color: rgba(59, 130, 246, 0.52);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.42),
    0 0 0 3px rgba(147, 197, 253, 0.26);
}

.board__panel--employee-workspace .account-field textarea {
  min-height: 64px;
}

.board__panel--employee-workspace .account-field small {
  font-size: 11px;
}

.board__panel--employee-workspace .employee-check-grid {
  gap: 5px;
}

.board__panel--employee-workspace .employee-check {
  min-height: 28px;
  padding: 3px 7px;
  gap: 6px;
  font-size: 11.5px;
  border-color: rgba(31, 77, 122, 0.18);
  background: rgba(255, 255, 255, 0.78);
}

.board__panel--employee-workspace .employee-check span {
  font-size: 11.5px;
}

.board__panel--employee-workspace .employee-membership-list {
  gap: 8px;
}

.board__panel--employee-workspace .employee-membership-row {
  gap: 10px;
  padding: 9px 11px;
  border-radius: 14px;
  border-color: rgba(31, 77, 122, 0.2);
  background:
    linear-gradient(165deg, rgba(255, 255, 255, 0.78) 0%, rgba(241, 246, 252, 0.9) 100%);
}

.board__panel--employee-workspace .employee-membership-row__copy {
  gap: 4px;
}

.board__panel--employee-workspace .employee-membership-row__title {
  gap: 8px;
}

.board__panel--employee-workspace .employee-membership-row__meta {
  font-size: 12px;
}

.board__panel--employee-workspace .employee-membership-row__actions {
  gap: 6px;
}

.board__panel--employee-workspace .employee-membership-add {
  gap: 8px;
  min-height: 38px;
  padding: 0 11px;
  border-radius: 14px;
  border-color: rgba(31, 77, 122, 0.2);
  background: rgba(255, 255, 255, 0.58);
}

.board__panel--employee-workspace .employee-membership-add__icon {
  width: 18px;
  height: 18px;
  font-size: 12px;
}

.board__panel--employee-workspace .employee-membership-add__label {
  font-size: 12px;
}

.board__panel--employee-workspace .employee-inline-tags,
.board__panel--employee-workspace .employee-summary-strip {
  gap: 6px;
}

.board__panel--employee-workspace .employee-inline-tag {
  min-height: 24px;
  padding: 0 10px;
  font-size: 11px;
}

.board__panel--employee-workspace .employee-page-list {
  gap: 8px;
}

.board__panel--employee-workspace .employee-page-list__item {
  gap: 10px;
  padding: 8px 10px;
  border-radius: 12px;
  border-color: rgba(31, 77, 122, 0.22);
  background:
    linear-gradient(165deg, rgba(255, 255, 255, 0.82) 0%, rgba(241, 246, 252, 0.92) 100%);
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.05);
}

.board__panel--employee-workspace .employee-page-list__main {
  display: grid;
}

.board__panel--employee-workspace .employee-page-list__title-row {
  gap: 6px;
}

.board__panel--employee-workspace .employee-page-list__title {
  font-size: 12px;
}

.board__panel--employee-workspace .employee-page-list__state {
  min-height: 22px;
  padding: 0 8px;
  font-size: 10px;
  border: 1px solid rgba(96, 165, 250, 0.24);
  background: rgba(219, 234, 254, 0.9);
  color: #1e3a5f;
}

.board__panel--employee-workspace .employee-page-list__toggles {
  gap: 6px;
}

.board__panel--employee-workspace .employee-page-list__toggle {
  min-height: 26px;
  padding: 0 7px;
  gap: 5px;
  font-size: 11px;
  border-color: rgba(31, 77, 122, 0.22);
  background: rgba(255, 255, 255, 0.9);
  color: #1f2937;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.4);
}

.board__panel--employee-workspace .employee-page-grid {
  gap: 8px;
}

.board__panel--employee-workspace .employee-page-card {
  gap: 9px;
  padding: 10px;
  border-radius: 14px;
  border-color: rgba(31, 77, 122, 0.22);
  background:
    linear-gradient(165deg, rgba(255, 255, 255, 0.82) 0%, rgba(241, 246, 252, 0.92) 100%);
  box-shadow: 0 12px 24px rgba(15, 23, 42, 0.06);
}

.board__panel--employee-workspace .employee-page-card__head {
  gap: 9px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(31, 77, 122, 0.14);
}

.board__panel--employee-workspace .employee-page-card__title {
  font-size: 12px;
}

.board__panel--employee-workspace .employee-page-card__text {
  margin-top: 4px;
  font-size: 10px;
  color: #556273;
}

.board__panel--employee-workspace .employee-page-card__state {
  min-height: 24px;
  padding: 0 9px;
  font-size: 10px;
  border: 1px solid rgba(96, 165, 250, 0.24);
  background: rgba(219, 234, 254, 0.9);
  color: #1e3a5f;
}

.board__panel--employee-workspace .employee-page-card__toggles {
  gap: 8px;
}

.board__panel--employee-workspace .employee-page-card__toggle {
  min-height: 28px;
  padding: 0 8px;
  gap: 6px;
  font-size: 11px;
  border-color: rgba(31, 77, 122, 0.22);
  background: rgba(255, 255, 255, 0.9);
  color: #1f2937;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.4);
}

.board__panel--employee-workspace .employee-notification-card__title {
  font-size: 12px;
  font-weight: 600;
  color: #1f2937;
}

.board__panel--employee-workspace .employee-notification-card__text {
  font-size: 10.5px;
  color: #556273;
}

.board__panel--employee-workspace .employee-page-list__item:hover,
.board__panel--employee-workspace .employee-page-list__item:focus-within,
.board__panel--employee-workspace .employee-page-card:hover,
.board__panel--employee-workspace .employee-page-card:focus-within {
  border-color: rgba(59, 130, 246, 0.34);
  box-shadow: 0 14px 28px rgba(59, 130, 246, 0.1);
}

.board__panel--employee-workspace .employee-page-list__toggle:focus-within,
.board__panel--employee-workspace .employee-page-card__toggle:focus-within {
  border-color: rgba(59, 130, 246, 0.42);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.46),
    0 0 0 3px rgba(147, 197, 253, 0.22);
}

.board__panel--employee-workspace .employee-placeholder {
  min-height: 160px;
  gap: 8px;
  padding: 18px;
  border-radius: 14px;
}

.board__panel--employee-workspace .employee-placeholder__title {
  font-size: 13px;
}

.board__panel--employee-workspace .employee-membership-modal__panel {
  width: min(760px, calc(100% - 28px));
}

.board__panel--employee-workspace .employee-modal-form {
  margin-top: 12px;
  gap: 12px;
}

.board__panel--employee-workspace .employee-form-note {
  margin-top: -2px;
  font-size: 10px;
}

.board__panel--employee-workspace .employee-membership-modal .account-field input,
.board__panel--employee-workspace .employee-membership-modal .account-field select,
.board__panel--employee-workspace .employee-membership-modal .account-static {
  min-height: 30px;
  height: 30px;
  padding-top: 0;
  padding-bottom: 0;
  font-size: 12px;
}

.board__panel--employee-workspace .employee-membership-modal .account-field input,
.board__panel--employee-workspace .employee-membership-modal .account-static {
  padding-left: 10px;
  padding-right: 10px;
}

.board__panel--employee-workspace .employee-membership-modal .account-field select {
  padding-left: 10px;
  padding-right: 26px;
}

.board__panel--employee-workspace .employee-modal-form__actions {
  gap: 8px;
}

.board__panel--employee-workspace .employee-errors {
  padding: 10px 12px;
  border-radius: 12px;
}

.board__panel--employee-workspace .btn,
.employee-membership-modal .btn {
  min-height: 30px;
  padding: 5px 10px;
  font-size: 10px;
  letter-spacing: 0.1em;
}

@media (max-width: 960px) {
  .employee-workspace__topbar,
  .employee-hero {
    flex-direction: column;
    align-items: stretch;
  }

  .employee-hero__status {
    min-width: 0;
    justify-items: start;
    text-align: left;
  }

  .employee-status-cluster {
    justify-content: flex-start;
  }

  .employee-pane__grid--summary,
  .employee-form-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .employee-workspace__topbar,
  .employee-hero,
  .employee-membership-overview__head,
  .employee-membership-strip,
  .employee-tabs,
  .employee-workspace__form,
  .employee-pane--secondary {
    padding-inline: 16px;
  }

  .employee-avatar {
    width: 60px;
    height: 60px;
    border-radius: 999px;
    font-size: 20px;
  }

  .employee-card {
    padding: 16px;
    border-radius: 18px;
  }

  .employee-page-list,
  .employee-page-grid {
    grid-template-columns: 1fr;
  }

  .employee-page-list__item {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .employee-page-list__title-row,
  .employee-page-list__toggles {
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  .employee-membership-row {
    flex-direction: column;
    align-items: stretch;
  }

  .employee-membership-row__actions {
    justify-content: flex-start;
  }
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-hero {
  border-bottom-color: rgba(134, 179, 214, 0.18);
  background:
    radial-gradient(circle at top right, rgba(56, 189, 248, 0.18) 0%, transparent 36%),
    linear-gradient(150deg, rgba(16, 32, 52, 0.9) 0%, rgba(8, 20, 34, 0.98) 100%);
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-card {
  background:
    radial-gradient(circle at top right, rgba(59, 130, 246, 0.1) 0%, transparent 34%),
    linear-gradient(165deg, rgba(13, 28, 46, 0.96) 0%, rgba(8, 20, 34, 0.98) 100%);
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-page-list__item,
body[data-theme="dark"] .board__panel--employee-workspace .employee-page-card,
body[data-theme="dark"] .board__panel--employee-workspace .employee-membership-row {
  background:
    linear-gradient(165deg, rgba(17, 34, 55, 0.94) 0%, rgba(10, 24, 40, 0.98) 100%);
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-placeholder {
  border-color: rgba(134, 179, 214, 0.2);
  background:
    linear-gradient(165deg, rgba(10, 24, 40, 0.88) 0%, rgba(7, 18, 31, 0.96) 100%);
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-tabs__cursor {
  border-color: rgba(134, 179, 214, 0.24);
  background:
    radial-gradient(circle at 50% 0%, rgba(147, 197, 253, 0.16) 0%, transparent 64%),
    linear-gradient(180deg, rgba(20, 41, 64, 0.96) 0%, rgba(9, 24, 40, 0.94) 100%);
  box-shadow:
    0 14px 26px rgba(2, 6, 23, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-tab:hover,
body[data-theme="dark"] .board__panel--employee-workspace .employee-tab:focus-visible {
  background: transparent;
  color: #e5eef8;
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-tab.is-active,
body[data-theme="dark"] .board__panel--employee-workspace .employee-tab[data-cursor-target="true"] {
  color: #f8fbff;
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-membership-chip {
  border-color: rgba(134, 179, 214, 0.22);
  background:
    linear-gradient(165deg, rgba(18, 34, 55, 0.9) 0%, rgba(10, 24, 40, 0.96) 100%);
  color: #e5eef8;
  box-shadow: 0 10px 22px rgba(2, 6, 23, 0.18);
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-membership-chip:hover,
body[data-theme="dark"] .board__panel--employee-workspace .employee-membership-chip:focus-visible {
  border-color: rgba(96, 165, 250, 0.46);
  background:
    linear-gradient(165deg, rgba(22, 42, 67, 0.94) 0%, rgba(12, 28, 46, 0.98) 100%);
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-membership-chip.is-active {
  border-color: rgba(96, 165, 250, 0.42);
  background:
    linear-gradient(145deg, rgba(29, 78, 216, 0.22) 0%, rgba(13, 27, 45, 0.96) 100%);
  box-shadow: 0 14px 28px rgba(2, 6, 23, 0.24);
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-page-list__toggle,
body[data-theme="dark"] .board__panel--employee-workspace .employee-inline-tag,
body[data-theme="dark"] .board__panel--employee-workspace .employee-page-card__toggle,
body[data-theme="dark"] .board__panel--employee-workspace .employee-status-pill {
  background: rgba(15, 23, 42, 0.52);
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-inline-tag {
  border-color: rgba(134, 179, 214, 0.22);
  color: #dbeafe;
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-inline-tag--active {
  border-color: rgba(96, 165, 250, 0.3);
  background: rgba(30, 64, 175, 0.24);
  color: #dbeafe;
}

body[data-theme="dark"] .employee-membership-strip {
  scrollbar-color: rgba(147, 197, 253, 0.56) rgba(15, 23, 42, 0.34);
}

body[data-theme="dark"] .employee-membership-strip::-webkit-scrollbar-track {
  background: rgba(15, 23, 42, 0.34);
}

body[data-theme="dark"] .employee-membership-strip::-webkit-scrollbar-thumb {
  background: rgba(147, 197, 253, 0.56);
}

body[data-theme="dark"] .employee-membership-strip::-webkit-scrollbar-thumb:hover {
  background: rgba(147, 197, 253, 0.72);
}

body[data-theme="dark"] .board__panel--employee-workspace .account-field input,
body[data-theme="dark"] .board__panel--employee-workspace .account-field select,
body[data-theme="dark"] .board__panel--employee-workspace .account-field textarea,
body[data-theme="dark"] .board__panel--employee-workspace .account-static,
body[data-theme="dark"] .board__panel--employee-workspace .account-field .filter-combobox__control,
body[data-theme="dark"] .board__panel--employee-workspace .employee-check,
body[data-theme="dark"] .board__panel--employee-workspace .employee-membership-add {
  background: rgba(9, 24, 40, 0.82);
  border-color: rgba(134, 179, 214, 0.3);
  color: #e5eef8;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-card__head {
  border-bottom-color: rgba(134, 179, 214, 0.22);
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-breadcrumb,
body[data-theme="dark"] .board__panel--employee-workspace .employee-hero__subtitle,
body[data-theme="dark"] .board__panel--employee-workspace .employee-hero__meta,
body[data-theme="dark"] .board__panel--employee-workspace .employee-card__subtitle,
body[data-theme="dark"] .board__panel--employee-workspace .employee-card__hint,
body[data-theme="dark"] .board__panel--employee-workspace .employee-membership-chip__meta,
body[data-theme="dark"] .board__panel--employee-workspace .employee-placeholder__text {
  color: #9fb1c8;
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-card__title,
body[data-theme="dark"] .board__panel--employee-workspace .employee-membership-overview__title,
body[data-theme="dark"] .board__panel--employee-workspace .employee-page-list__title,
body[data-theme="dark"] .board__panel--employee-workspace .employee-page-card__title,
body[data-theme="dark"] .board__panel--employee-workspace .employee-placeholder__title,
body[data-theme="dark"] .board__panel--employee-workspace .employee-notification-section__title,
body[data-theme="dark"] .board__panel--employee-workspace .employee-notification-card__title {
  color: #e5eef8;
}

body[data-theme="dark"] .board__panel--employee-workspace .account-field input:focus,
body[data-theme="dark"] .board__panel--employee-workspace .account-field select:focus,
body[data-theme="dark"] .board__panel--employee-workspace .account-field textarea:focus,
body[data-theme="dark"] .board__panel--employee-workspace .account-field .filter-combobox__control:focus-within,
body[data-theme="dark"] .board__panel--employee-workspace .account-field .filter-combobox.is-open .filter-combobox__control {
  border-color: rgba(96, 165, 250, 0.52);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 0 0 3px rgba(59, 130, 246, 0.18);
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-page-list__item,
body[data-theme="dark"] .board__panel--employee-workspace .employee-page-card {
  border-color: rgba(134, 179, 214, 0.2);
  box-shadow: 0 14px 28px rgba(2, 6, 23, 0.24);
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-page-list__state,
body[data-theme="dark"] .board__panel--employee-workspace .employee-page-card__state {
  border-color: rgba(96, 165, 250, 0.28);
  background: rgba(30, 64, 175, 0.22);
  color: #dbeafe;
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-page-list__item.is-disabled .employee-page-list__state,
body[data-theme="dark"] .board__panel--employee-workspace .employee-page-card.is-disabled .employee-page-card__state {
  border-color: rgba(148, 163, 184, 0.22);
  background: rgba(71, 85, 105, 0.3);
  color: #cbd5e1;
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-page-list__toggle,
body[data-theme="dark"] .board__panel--employee-workspace .employee-page-card__toggle {
  border-color: rgba(134, 179, 214, 0.2);
  color: #e5eef8;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-page-card__head {
  border-bottom-color: rgba(134, 179, 214, 0.18);
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-notification-section {
  border-top-color: rgba(134, 179, 214, 0.16);
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-notification-table-shell {
  border-color: rgba(134, 179, 214, 0.18);
  background:
    linear-gradient(165deg, rgba(11, 24, 39, 0.78) 0%, rgba(8, 19, 32, 0.92) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-notification-table thead th {
  border-bottom-color: rgba(134, 179, 214, 0.16);
  background: rgba(18, 36, 57, 0.88);
  color: #9fb1c8;
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-notification-row + .employee-notification-row .employee-notification-cell {
  border-top-color: rgba(134, 179, 214, 0.14);
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-notification-section__meta,
body[data-theme="dark"] .board__panel--employee-workspace .employee-page-card__text,
body[data-theme="dark"] .board__panel--employee-workspace .employee-notification-card__text {
  color: #b8c6d8;
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-notification-cell__empty {
  color: #8ea2b9;
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-page-list__item:hover,
body[data-theme="dark"] .board__panel--employee-workspace .employee-page-list__item:focus-within,
body[data-theme="dark"] .board__panel--employee-workspace .employee-page-card:hover,
body[data-theme="dark"] .board__panel--employee-workspace .employee-page-card:focus-within {
  border-color: rgba(96, 165, 250, 0.34);
  box-shadow: 0 18px 34px rgba(2, 6, 23, 0.32);
}

body[data-theme="dark"] .board__panel--employee-workspace .employee-page-list__toggle:focus-within,
body[data-theme="dark"] .board__panel--employee-workspace .employee-page-card__toggle:focus-within {
  border-color: rgba(96, 165, 250, 0.38);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 0 0 3px rgba(59, 130, 246, 0.16);
}

@media (prefers-reduced-motion: reduce) {
  .employee-tabs__cursor,
  .employee-tab,
  .employee-pane.is-switching {
    transition: none;
    animation: none;
  }
}

.btn {
  min-height: 34px;
  padding: 8px 12px;
  border-radius: var(--radius-md);
  border: 1px solid var(--glass-border-strong);
  background: linear-gradient(135deg, var(--silver-1) 0%, var(--accent-2) 100%);
  color: var(--text);
  font-size: 10px;
  letter-spacing: 0.1em;
  line-height: 1.2;
  text-transform: uppercase;
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out), filter var(--duration) var(--ease-out);
}

.btn:hover {
  transform: translate3d(0, -1px, 0);
  box-shadow: 0 12px 22px rgba(0, 0, 0, 0.16);
}

.btn--secondary {
  background: rgba(255, 255, 255, 0.22);
  border-color: var(--glass-border);
}

.btn--secondary:hover {
  box-shadow: 0 12px 22px rgba(2, 6, 23, 0.12);
}

.btn--danger {
  background: rgba(239, 68, 68, 0.14);
  border-color: rgba(239, 68, 68, 0.35);
}

.btn--danger:hover {
  box-shadow: 0 12px 22px rgba(239, 68, 68, 0.12);
}

.account-danger {
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid var(--glass-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.notifications-list {
  margin-top: 10px;
  display: grid;
  gap: 10px;
}

.notifications-item {
  border-radius: var(--radius-lg);
  border: 1px solid var(--glass-border);
  background: rgba(255, 255, 255, 0.32);
  padding: 12px 14px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
}

.notifications-item__body {
  display: grid;
  gap: 6px;
}

.notifications-item__title {
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.notifications-item__meta {
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.notifications-item__text {
  font-size: 12px;
  color: var(--text);
  margin: 0;
}

.notifications-item__delete {
  width: 38px;
  height: 38px;
  border-radius: 12px;
  border: 1px solid var(--glass-border);
  background: rgba(255, 255, 255, 0.12);
  color: var(--muted);
  cursor: pointer;
  padding: 0;
  display: grid;
  place-items: center;
  transition: background var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out), color var(--duration) var(--ease-out), transform var(--duration) var(--ease-out);
}

.notifications-item__delete i {
  font-size: 20px;
  line-height: 1;
  display: block;
}

.notifications-item__delete:hover {
  background: var(--nav-hover);
  border-color: var(--glass-border-strong);
  color: var(--text);
  transform: translateY(-1px);
}

.notifications-item__delete:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 2px;
}

.notifications-item--stack {
  grid-template-columns: minmax(0, 1fr);
}

.notifications-item__actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 6px;
}

.notifications-item__actions form {
  margin: 0;
}

.board__panel--notifications {
  display: grid;
  gap: 18px;
}

.notifications-page__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--glass-border);
}

.notifications-page__copy {
  display: grid;
  gap: 6px;
}

.notifications-page__hint {
  margin: 0;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
}

.notifications-page__summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(92px, 1fr));
  gap: 10px;
}

.notifications-page__metric {
  min-width: 0;
  border-radius: 18px;
  border: 1px solid var(--glass-border);
  background: color-mix(in srgb, var(--glass-strong) 88%, white);
  padding: 14px 16px;
  display: grid;
  gap: 3px;
  text-align: right;
}

.notifications-page__metric-value {
  font-size: 28px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.04em;
}

.notifications-page__metric-label {
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}

.notifications-feed {
  display: grid;
  gap: 12px;
}

.notification-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 16px 18px;
  border-radius: 22px;
  border: 1px solid var(--glass-border);
  background:
    linear-gradient(160deg, color-mix(in srgb, var(--glass-strong) 94%, white) 0%, color-mix(in srgb, var(--glass) 96%, transparent) 100%);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
  transition:
    border-color var(--duration) var(--ease-out),
    transform var(--duration) var(--ease-out),
    box-shadow var(--duration) var(--ease-out),
    background var(--duration) var(--ease-out);
}

.notification-card:hover {
  transform: translateY(-1px);
  border-color: var(--glass-border-strong);
  box-shadow: 0 16px 30px rgba(15, 23, 42, 0.1);
}

.notification-card.is-unread {
  border-color: color-mix(in srgb, var(--accent) 24%, var(--glass-border-strong));
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--accent-soft) 34%, transparent), transparent 38%),
    linear-gradient(160deg, color-mix(in srgb, var(--glass-strong) 96%, white) 0%, color-mix(in srgb, var(--glass) 98%, transparent) 100%);
}

.notification-card__main {
  min-width: 0;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: flex-start;
  gap: 12px;
  flex: 1 1 auto;
}

.notification-card__status {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  margin-top: 6px;
  background: transparent;
  border: 1px solid transparent;
  box-shadow: none;
  transition:
    background var(--duration) var(--ease-out),
    border-color var(--duration) var(--ease-out),
    box-shadow var(--duration) var(--ease-out);
}

.notification-card.is-unread .notification-card__status {
  background: #ef4444;
  border-color: rgba(255, 255, 255, 0.85);
  box-shadow: 0 0 0 5px rgba(239, 68, 68, 0.12);
}

.notification-card__copy {
  min-width: 0;
  display: grid;
  gap: 4px;
}

.notification-card__eyebrow {
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}

.notification-card__title {
  margin: 0;
  font-size: 16px;
  line-height: 1.2;
  letter-spacing: -0.02em;
}

.notification-card__meta {
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
}

.notification-card__text {
  margin: 3px 0 0;
  font-size: 13px;
  color: color-mix(in srgb, var(--text) 84%, var(--muted));
}

.notification-card__actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 0 0 auto;
}

.notification-card__delete {
  width: 40px;
  height: 40px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, #ef4444 24%, var(--glass-border));
  background: rgba(239, 68, 68, 0.08);
  color: #dc2626;
  cursor: pointer;
  padding: 0;
  display: grid;
  place-items: center;
  transition:
    background var(--duration) var(--ease-out),
    border-color var(--duration) var(--ease-out),
    color var(--duration) var(--ease-out),
    transform var(--duration) var(--ease-out);
}

.notification-card__delete:hover {
  background: rgba(239, 68, 68, 0.14);
  border-color: rgba(239, 68, 68, 0.34);
  transform: translateY(-1px);
}

.notification-card__delete:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 2px;
}

.notifications-empty {
  border-radius: 24px;
  border: 1px dashed var(--glass-border-strong);
  background: rgba(255, 255, 255, 0.22);
  padding: 28px 22px;
  display: grid;
  gap: 6px;
  text-align: center;
}

.notifications-empty.is-hidden {
  display: none;
}

.notifications-empty__title {
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.notifications-empty__text {
  margin: 0;
  font-size: 13px;
  color: var(--muted);
}

.notification-context-menu {
  position: fixed;
  z-index: 120;
  min-width: 180px;
  padding: 6px;
  display: grid;
  gap: 4px;
  border-radius: 18px;
  border: 1px solid var(--glass-border-strong);
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--accent-soft) 24%, transparent), transparent 38%),
    linear-gradient(160deg, color-mix(in srgb, var(--glass-strong) 96%, white) 0%, color-mix(in srgb, var(--glass) 98%, transparent) 100%);
  box-shadow: var(--shadow-strong);
  backdrop-filter: blur(18px) saturate(132%);
}

.notification-context-menu[hidden] {
  display: none;
}

.notification-context-menu__item {
  width: 100%;
  display: block;
  text-align: left;
  text-decoration: none;
  border: 1px solid transparent;
  border-radius: 12px;
  background: transparent;
  color: var(--text);
  padding: 10px 12px;
  cursor: pointer;
  font: inherit;
  transition:
    background var(--duration) var(--ease-out),
    border-color var(--duration) var(--ease-out),
    transform var(--duration) var(--ease-out);
}

.notification-context-menu__item:hover {
  background: var(--nav-hover);
  border-color: var(--glass-border);
  transform: translateY(-1px);
}

.notification-context-menu__item.is-danger {
  color: #dc2626;
}

.notification-context-menu__item.is-danger:hover {
  background: rgba(239, 68, 68, 0.1);
  border-color: rgba(239, 68, 68, 0.24);
}

@media (max-width: 860px) {
  .notifications-page__header {
    flex-direction: column;
  }

  .notifications-page__summary {
    width: 100%;
  }

  .notification-card {
    flex-direction: column;
    align-items: stretch;
  }

  .notification-card__actions {
    justify-content: flex-end;
  }
}

@media (max-width: 640px) {
  .notifications-page__summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .notification-card {
    padding: 14px;
    border-radius: 18px;
  }

  .notification-card__main {
    gap: 10px;
  }

  .notification-card__actions {
    width: 100%;
  }

  .notification-card__actions .btn {
    flex: 1 1 auto;
    justify-content: center;
  }
}

.developer-mention-field {
  position: relative;
}

.developer-mention-field.is-open {
  z-index: 90;
}

.developer-mention-menu {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 40;
  display: grid;
  gap: 0;
  min-width: 176px;
  max-width: min(228px, calc(100% - 12px));
  max-height: 196px;
  padding: 0;
  overflow-x: hidden;
  overflow-y: auto;
  border-radius: 14px;
  border: 1px solid var(--glass-border-strong);
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--accent-2) 14%, transparent), transparent 42%),
    linear-gradient(160deg, color-mix(in srgb, var(--glass-strong) 96%, white) 0%, color-mix(in srgb, var(--glass) 98%, transparent) 100%);
  box-shadow: var(--shadow-strong);
  backdrop-filter: blur(16px) saturate(132%);
  overscroll-behavior: contain;
  scrollbar-gutter: stable;
}

.developer-mention-menu[hidden] {
  display: none;
}

.developer-mention-menu__list {
  display: grid;
  gap: 0;
  overflow: visible;
  padding: 4px;
}

.developer-mention-menu__item {
  border: 1px solid transparent;
  border-radius: 10px;
  background: transparent;
  color: var(--text);
  padding: 7px 8px;
  text-align: left;
  cursor: pointer;
  display: block;
  transition:
    border-color var(--duration) var(--ease-out),
    background var(--duration) var(--ease-out),
    transform var(--duration) var(--ease-out);
}

.developer-mention-menu__item:hover,
.developer-mention-menu__item.is-active {
  border-color: color-mix(in srgb, var(--accent) 34%, var(--glass-border-strong));
  background: color-mix(in srgb, var(--accent-soft) 46%, var(--glass-strong));
  transform: translateY(-1px);
}

.developer-mention-menu__identity {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 8px;
}

.developer-mention-menu__copy {
  min-width: 0;
  display: grid;
  gap: 1px;
}

.developer-mention-menu__avatar {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  border: 1px solid var(--glass-border);
  background: var(--avatar-bg, color-mix(in srgb, var(--glass-strong) 92%, white));
  color: var(--avatar-fg, var(--accent-strong));
  display: inline-grid;
  place-items: center;
  overflow: hidden;
  flex: 0 0 auto;
}

.developer-mention-menu__avatar-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.developer-mention-menu__avatar-initial {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: inherit;
}

.developer-mention-menu__name {
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.developer-mention-menu__meta {
  font-size: 10px;
  color: var(--muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.developer-mention-token {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 0 6px;
  background: rgba(59, 130, 246, 0.14);
  color: #1d4ed8;
  font-weight: 600;
}

.developer-rich-text__link {
  color: color-mix(in srgb, var(--accent) 78%, #1d4ed8);
  font-weight: 600;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
  word-break: break-all;
}

.developer-rich-text__link:hover,
.developer-rich-text__link:focus-visible {
  color: color-mix(in srgb, var(--accent) 92%, #1d4ed8);
}

.account-danger__title {
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text);
}

.account-danger__subtitle {
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

/* Intestazione */
.app-header {
  position: sticky;
  top: 0;
  z-index: 50;
  height: var(--header-height);
  display: flex;
  align-items: center;
  padding: 10px 18px;
  overflow: visible;
}

.app-header::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--navbar-bg);
  border-bottom: 1px solid var(--glass-border-strong);
  backdrop-filter: blur(16px) saturate(140%);
  -webkit-backdrop-filter: blur(16px) saturate(140%);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.12);
  z-index: 0;
}


.app-header::after {
  content: "";
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 0;
  height: 2px;
  background: var(--header-line);
  opacity: 0.85;
  z-index: 1;
  pointer-events: none;
}

.app-header__inner {
  position: relative;
  width: 100%;
  display: grid;
  grid-template-columns: minmax(240px, 340px) minmax(280px, 1fr) auto;
  gap: 14px;
  align-items: center;
  z-index: 2;
  overflow: visible;
}

.app-header__brand {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.app-header__menu-toggle {
  display: none;
  width: 44px;
  height: 44px;
  border: 1px solid var(--glass-border);
  border-radius: 14px;
  background: linear-gradient(160deg, var(--glass-strong) 0%, var(--glass) 100%);
  color: var(--text);
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.1);
  cursor: pointer;
  place-items: center;
  gap: 4px;
  padding: 0;
  transition:
    transform var(--duration) var(--ease-out),
    border-color var(--duration) var(--ease-out),
    box-shadow var(--duration) var(--ease-out);
}

.app-header__menu-toggle:hover {
  transform: translateY(-1px);
  border-color: var(--accent);
  box-shadow: 0 18px 34px rgba(15, 23, 42, 0.16);
}

.app-header__menu-toggle:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--focus);
}

.app-header__menu-toggle span {
  width: 18px;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
  transition:
    transform var(--duration) var(--ease-out),
    opacity var(--duration) var(--ease-out);
}

body.is-sidebar-open .app-header__menu-toggle span:nth-child(1) {
  transform: translateY(6px) rotate(45deg);
}

body.is-sidebar-open .app-header__menu-toggle span:nth-child(2) {
  opacity: 0;
}

body.is-sidebar-open .app-header__menu-toggle span:nth-child(3) {
  transform: translateY(-6px) rotate(-45deg);
}

/* Flash messages */
.flash-stack {
  display: grid;
  gap: 10px;
  margin-bottom: 14px;
}

.flash {
  padding: 10px 12px;
  border-radius: var(--radius-md);
  border: 1px solid var(--glass-border);
  background: var(--glass);
  color: var(--text);
  box-shadow: 0 10px 22px rgba(2, 6, 23, 0.1);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.flash--error {
  border-color: rgba(239, 68, 68, 0.45);
  background: rgba(239, 68, 68, 0.12);
}

.flash--success {
  border-color: rgba(34, 197, 94, 0.4);
  background: rgba(34, 197, 94, 0.12);
}

.flash--warning {
  border-color: rgba(234, 179, 8, 0.4);
  background: rgba(234, 179, 8, 0.12);
}

.app-header__brand-main {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.app-header__brand-controls {
  display: flex;
  align-items: center;
  gap: 10px;
}

.app-logo {
  width: 54px;
  height: 54px;
  object-fit: contain;
  filter: drop-shadow(0 12px 24px rgba(15, 23, 42, 0.18));
}

.app-header__text {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.app-brand {
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--muted);
  line-height: 1.1;
}

.app-title {
  font-size: 22px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  line-height: 1.15;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.app-brand,
.app-title,
.sidebar__title {
  font-family: var(--font-brand);
  font-weight: 600;
}

.app-subtitle {
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: none;
  color: var(--muted);
  line-height: 1.1;
}

.app-header__search {
  position: relative;
  min-width: 0;
  max-width: 520px;
  width: 100%;
  justify-self: center;
}

.search {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 999px;
  background: var(--input-bg);
  border: 1px solid var(--input-border);
  box-shadow: 0 16px 36px rgba(15, 23, 42, 0.12);
  backdrop-filter: blur(16px) saturate(140%);
  -webkit-backdrop-filter: blur(16px) saturate(140%);
  transition: box-shadow var(--duration) var(--ease-out), transform var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out);
}

.search:focus-within {
  border-color: rgba(31, 77, 122, 0.42);
  box-shadow: 0 18px 44px rgba(2, 6, 23, 0.16);
  transform: translateY(-1px);
}

.search__icon {
  color: var(--muted);
  flex: 0 0 auto;
}

.search__input {
  width: 100%;
  border: 0;
  outline: none;
  background: transparent;
  color: var(--text);
  font-size: 13px;
}

.search__input::placeholder {
  color: var(--muted);
}

.search__shortcut {
  flex: 0 0 auto;
  border: 1px solid var(--glass-border);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: var(--muted);
  min-width: 60px;
  height: 26px;
  padding: 0 8px;
  font-size: 9px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  transition:
    background var(--duration) var(--ease-out),
    color var(--duration) var(--ease-out),
    border-color var(--duration) var(--ease-out);
}

.search__shortcut:hover,
.search__shortcut:focus-visible {
  background: var(--nav-hover);
  color: var(--text);
  border-color: var(--accent);
  outline: none;
}

.search-results {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  border-radius: calc(var(--radius-xl) + 2px);
  background: linear-gradient(160deg, var(--glass-strong) 0%, var(--glass) 100%);
  border: 1px solid var(--glass-border);
  box-shadow: var(--shadow-strong);
  padding: 10px;
  display: grid;
  gap: 10px;
  z-index: 36;
  backdrop-filter: blur(22px) saturate(150%);
  -webkit-backdrop-filter: blur(22px) saturate(150%);
}

.search-results[hidden],
.search-results[aria-hidden="true"] {
  display: none;
}

.search-results__meta {
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
  line-height: 1.5;
}

.search-results__groups {
  display: grid;
  gap: 10px;
  max-height: min(56vh, 420px);
  overflow: auto;
  padding-right: 4px;
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) transparent;
}

.search-results__group {
  display: grid;
  gap: 6px;
}

.search-results__group[hidden] {
  display: none;
}

.search-results__heading {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
  padding: 0 2px;
}

.search-results__list {
  display: grid;
  gap: 6px;
}

.search-results__item {
  width: 100%;
  border: 1px solid transparent;
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.06);
  color: var(--text);
  text-decoration: none;
  display: grid;
  gap: 4px;
  padding: 9px 10px;
  text-align: left;
  cursor: pointer;
  transition:
    transform var(--duration) var(--ease-out),
    border-color var(--duration) var(--ease-out),
    background var(--duration) var(--ease-out),
    box-shadow var(--duration) var(--ease-out);
}

.search-results__item:hover,
.search-results__item.is-active,
.search-results__item:focus-visible {
  transform: translateY(-1px);
  border-color: var(--accent);
  background: color-mix(in srgb, var(--nav-hover) 90%, transparent);
  box-shadow: 0 16px 28px rgba(15, 23, 42, 0.12);
  outline: none;
}

.search-results__item-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.search-results__item-label {
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text);
}

.search-results__item-badge {
  flex: 0 0 auto;
  padding: 3px 7px;
  border-radius: 999px;
  border: 1px solid var(--glass-border);
  background: rgba(255, 255, 255, 0.08);
  color: var(--muted);
  font-size: 8px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.search-results__item-meta {
  font-size: 10px;
  line-height: 1.4;
  color: var(--muted);
}

.app-header__actions {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding-right: 8px;
  gap: 10px;
  z-index: 3;
  overflow: visible;
}

.toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 0;
  user-select: none;
  transition: transform var(--duration) var(--ease-out);
}

.toggle:hover {
  transform: translateY(-1px);
}

.toggle.is-disabled {
  opacity: 0.58;
}

.toggle.is-disabled:hover {
  transform: none;
}

.toggle__label {
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text);
  cursor: pointer;
  white-space: nowrap;
  font-weight: 600;
}

.toggle--header {
  padding: 0;
  gap: 8px;
}

.toggle--header .toggle__label {
  font-size: 11px;
  letter-spacing: 0.1em;
  font-weight: 400;
}

.toggle--header .toggle__input {
  width: 44px;
  height: 24px;
}

.toggle--header .toggle__input::after {
  width: 18px;
  height: 18px;
}

.toggle--header .toggle__input:checked::after {
  transform: translate3d(20px, -50%, 0);
}

.user-menu {
  position: relative;
}

.user-menu[open],
.notif-menu[open] {
  z-index: 30;
}

.user-menu__summary,
.user-menu__login {
  display: inline-grid;
  grid-template-columns: 26px 1fr 26px;
  align-items: center;
  gap: 10px;
  padding: 8px 14px;
  border-radius: 999px;
  background: var(--glass);
  border: 1px solid var(--glass-border);
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.1);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  cursor: pointer;
  user-select: none;
  text-decoration: none;
  color: var(--text);
  min-width: 210px;
}

.notif-menu {
  position: relative;
}

.notif-menu__summary {
  list-style: none;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: var(--glass);
  border: 1px solid var(--glass-border);
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.1);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  cursor: pointer;
  position: relative;
}

.notif-menu__summary::-webkit-details-marker {
  display: none;
}

.notif-menu__icon {
  width: 20px;
  height: 20px;
  display: grid;
  place-items: center;
  color: var(--text);
}

.fa-solid.fa-bell {
  width: 18px;
  height: 18px;
  display: inline-block;
  background: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 22a2.5 2.5 0 0 0 2.45-2h-4.9A2.5 2.5 0 0 0 12 22Zm7-6V11a7 7 0 0 0-14 0v5l-2 2v1h18v-1l-2-2Z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 22a2.5 2.5 0 0 0 2.45-2h-4.9A2.5 2.5 0 0 0 12 22Zm7-6V11a7 7 0 0 0-14 0v5l-2 2v1h18v-1l-2-2Z'/%3E%3C/svg%3E") center/contain no-repeat;
}

.notif-menu__badge {
  position: absolute;
  top: 3px;
  right: 3px;
  min-width: 18px;
  height: 18px;
  padding: 0 4px;
  border-radius: 999px;
  background: #ef4444;
  color: #ffffff;
  font-size: 10px;
  font-weight: 700;
  line-height: 1;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255, 255, 255, 0.6);
  box-shadow: 0 4px 10px rgba(239, 68, 68, 0.3);
}

.notif-menu__badge:empty {
  display: none;
}

.notif-menu__dropdown {
  min-width: 280px;
}

.notif-menu__item {
  display: grid;
  gap: 4px;
  padding: 10px 12px;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  text-decoration: none;
  color: var(--text);
  background: transparent;
  width: 100%;
  box-sizing: border-box;
}

.notif-menu__clear {
  border: 0;
  background: transparent;
  color: var(--muted);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 4px 6px;
  cursor: pointer;
  justify-self: end;
}

.notif-menu__clear:hover {
  color: var(--text);
}

.notif-menu__clear:disabled,
.notif-menu__clear.is-disabled {
  opacity: 0.5;
  cursor: default;
}

.notif-menu__item:hover {
  background: var(--nav-hover);
  border-color: var(--glass-border);
}

.notif-menu__item.is-unread {
  background: color-mix(in srgb, var(--accent-soft) 14%, transparent);
  border-color: color-mix(in srgb, var(--accent) 18%, var(--glass-border));
}

.notif-menu__title {
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.notif-menu__meta {
  font-size: 10px;
  color: var(--muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.notif-menu__dropdown .user-menu__item.notif-menu__all {
  justify-content: flex-end;
  border-color: transparent;
  background: transparent;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
  padding: 4px 6px;
  width: auto;
}

.notif-menu__dropdown .user-menu__item.notif-menu__all:hover {
  background: transparent;
  border-color: transparent;
  color: var(--text);
}

body[data-theme="dark"] .user-menu__summary,
body[data-theme="dark"] .user-menu__login {
  background: var(--glass-strong);
}

.user-menu__summary {
  list-style: none;
}

.user-menu__summary::-webkit-details-marker {
  display: none;
}

.user-menu__avatar {
  width: 26px;
  height: 26px;
  min-width: 26px;
  aspect-ratio: 1 / 1;
  border-radius: 999px;
  overflow: hidden;
  display: grid;
  place-items: center;
  background: var(--avatar-bg, rgba(15, 23, 42, 0.08));
  border: 1px solid var(--glass-border);
  color: var(--avatar-fg, var(--text));
}

.user-menu__avatar-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.user-menu__avatar-initial {
  font-size: 11px;
  line-height: 1;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: inherit;
}

body[data-theme="dark"] .user-menu__avatar {
  background: var(--avatar-bg, rgba(205, 216, 227, 0.08));
}

body[data-theme="dark"] .profile-avatar-panel {
  border-color: rgba(92, 105, 123, 0.42);
  background: linear-gradient(180deg, rgba(13, 17, 23, 0.94) 0%, rgba(16, 21, 28, 0.9) 100%);
}

body[data-theme="dark"] .profile-avatar-panel__media {
  background: var(--avatar-bg, rgba(13, 17, 23, 0.82));
  border-color: rgba(92, 105, 123, 0.48);
}

body[data-theme="dark"] .profile-avatar-panel__menu {
  border-color: rgba(92, 105, 123, 0.48);
  background: linear-gradient(180deg, rgba(13, 17, 23, 0.98) 0%, rgba(16, 21, 28, 0.96) 100%);
  box-shadow: 0 24px 52px rgba(0, 0, 0, 0.36);
}

body[data-theme="dark"] .profile-avatar-panel__color-picker {
  border-color: rgba(92, 105, 123, 0.42);
  background: linear-gradient(180deg, rgba(19, 25, 33, 0.86) 0%, rgba(14, 20, 28, 0.94) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

body[data-theme="dark"] .profile-avatar-panel__color-picker .developer-color-picker__slider,
body[data-theme="dark"] .profile-avatar-panel__color-picker .developer-color-picker__hex {
  border-color: rgba(92, 105, 123, 0.42);
  background: rgba(9, 24, 40, 0.78);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

body[data-theme="dark"] .profile-avatar-panel__action {
  border-color: rgba(92, 105, 123, 0.48);
  background: rgba(22, 27, 34, 0.92);
  color: color-mix(in srgb, var(--accent-2) 56%, #cbd5e1);
}

body[data-theme="dark"] .profile-avatar-panel__action:hover,
body[data-theme="dark"] .profile-avatar-panel__action.is-active {
  background: color-mix(in srgb, var(--accent) 18%, rgba(22, 27, 34, 0.96));
}

body[data-theme="dark"] .profile-avatar-panel__color-value {
  color: #f0f6fc;
}

body[data-theme="dark"] .profile-avatar-panel__initial,
body[data-theme="dark"] .user-menu__avatar-initial,
body[data-theme="dark"] .developer-task__avatar-initial,
body[data-theme="dark"] .developer-comment__avatar-initial {
  color: inherit;
}

@media (max-width: 720px) {
  .profile-avatar-panel__preview {
    align-items: flex-start;
  }

  .profile-avatar-panel__color-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .profile-avatar-panel__menu {
    top: 86px;
    left: 0;
    width: min(320px, calc(100vw - 56px));
  }
}

.fa-solid.fa-user {
  width: 15px;
  height: 15px;
  display: inline-block;
  background: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 12a4 4 0 1 0-4-4 4 4 0 0 0 4 4Zm0 2c-4.4 0-8 2.2-8 5v1h16v-1c0-2.8-3.6-5-8-5Z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 12a4 4 0 1 0-4-4 4 4 0 0 0 4 4Zm0 2c-4.4 0-8 2.2-8 5v1h16v-1c0-2.8-3.6-5-8-5Z'/%3E%3C/svg%3E") center/contain no-repeat;
}

.fa-solid.fa-pencil,
.fa-regular.fa-pencil {
  width: 15px;
  height: 15px;
  display: inline-block;
  background: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='black' stroke-width='1.9' stroke-linecap='round' stroke-linejoin='round' d='M4 20l3.8-.8L19 8c.7-.7.7-1.8 0-2.5l-.5-.5c-.7-.7-1.8-.7-2.5 0L4.8 16.2 4 20Z'/%3E%3Cpath fill='none' stroke='black' stroke-width='1.9' stroke-linecap='round' stroke-linejoin='round' d='m13.5 6.5 4 4'/%3E%3C/svg%3E") center/contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='black' stroke-width='1.9' stroke-linecap='round' stroke-linejoin='round' d='M4 20l3.8-.8L19 8c.7-.7.7-1.8 0-2.5l-.5-.5c-.7-.7-1.8-.7-2.5 0L4.8 16.2 4 20Z'/%3E%3Cpath fill='none' stroke='black' stroke-width='1.9' stroke-linecap='round' stroke-linejoin='round' d='m13.5 6.5 4 4'/%3E%3C/svg%3E") center/contain no-repeat;
}

.fa-solid.fa-trash,
.fa-regular.fa-trash {
  width: 15px;
  height: 15px;
  display: inline-block;
  background: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 448 512'%3E%3Cpath d='M135.2 17.7L128 32H32C14.3 32 0 46.3 0 64S14.3 96 32 96H416c17.7 0 32-14.3 32-32S433.7 32 416 32H320l-7.2-14.3C307.4 6.8 296.4 0 284.8 0H163.2c-11.6 0-22.6 6.8-28 17.7zM416 128H32l21.2 339.4C55.4 492.3 76.1 512 101 512H347c24.9 0 45.6-19.7 47.8-44.6L416 128z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 448 512'%3E%3Cpath d='M135.2 17.7L128 32H32C14.3 32 0 46.3 0 64S14.3 96 32 96H416c17.7 0 32-14.3 32-32S433.7 32 416 32H320l-7.2-14.3C307.4 6.8 296.4 0 284.8 0H163.2c-11.6 0-22.6 6.8-28 17.7zM416 128H32l21.2 339.4C55.4 492.3 76.1 512 101 512H347c24.9 0 45.6-19.7 47.8-44.6L416 128z'/%3E%3C/svg%3E") center/contain no-repeat;
}

.user-menu__name {
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  grid-column: 2;
  text-align: center;
  width: 100%;
}

.user-menu__dropdown {
  position: absolute;
  right: 0;
  top: calc(100% + 10px);
  min-width: 260px;
  border-radius: var(--radius-lg);
  background: linear-gradient(160deg, var(--glass-strong) 0%, var(--glass) 100%);
  border: 1px solid var(--glass-border);
  box-shadow: var(--shadow);
  padding: 8px;
  display: grid;
  gap: 6px;
  z-index: 20;
  transform-origin: top right;
  will-change: transform, opacity;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translate3d(0, -10px, 0) scale(0.985);
  backface-visibility: hidden;
  contain: paint;
  transition:
    opacity 180ms ease,
    transform 220ms cubic-bezier(0.22, 1, 0.36, 1),
    visibility 0s linear 220ms;
}

.user-menu.is-dropdown-open > .user-menu__dropdown,
.notif-menu.is-dropdown-open > .user-menu__dropdown {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translate3d(0, 0, 0) scale(1);
  transition-delay: 0s, 0s, 0s;
}

.user-menu__dropdown--fluid {
  min-width: min(292px, calc(100vw - 28px));
  padding: 0 0 4px;
  border: 0;
  background: transparent;
  box-shadow: none;
  overflow: visible;
  contain: layout paint;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  isolation: isolate;
}

.user-menu__stack {
  position: relative;
  width: min(292px, calc(100vw - 28px));
  min-width: 0;
  height: var(--fluid-stack-height, 0px);
  background: transparent;
  z-index: 1;
}

.user-menu__entry {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  opacity: 0;
  pointer-events: none;
  will-change: transform, opacity, filter;
  transform: translate3d(0, var(--fluid-entry-collapsed-y, 10px), 0) scale(var(--fluid-entry-scale, 0.985));
  filter: blur(10px) saturate(0.92);
  transition:
    transform 340ms cubic-bezier(0.22, 1, 0.36, 1),
    opacity 240ms ease,
    filter 240ms ease;
  transition-delay: calc(var(--item-index, 0) * 24ms);
  z-index: var(--fluid-entry-z, 1);
}

.user-menu.is-dropdown-open .user-menu__dropdown--fluid .user-menu__entry {
  opacity: 1;
  pointer-events: auto;
  transform: translate3d(0, var(--fluid-entry-offset, 0px), 0) scale(1);
  filter: none;
}

.user-menu__dropdown--fluid .user-menu__item {
  display: flex;
  align-items: center;
  gap: 0;
  min-height: 44px;
  padding: 8px 14px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--accent) 18%, rgba(15, 23, 42, 0.26));
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(246, 249, 252, 0.99) 100%);
  box-shadow:
    0 1px 3px rgba(15, 23, 42, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.82);
  color: color-mix(in srgb, var(--text) 96%, #0f172a);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  transition:
    transform var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out),
    background var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out);
}

.user-menu__dropdown--fluid .user-menu__item:hover {
  transform: translateX(3px);
  border-color: color-mix(in srgb, var(--accent) 34%, rgba(15, 23, 42, 0.28));
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 1) 0%, color-mix(in srgb, var(--accent-soft) 24%, rgba(244, 248, 252, 0.99)) 100%);
  box-shadow:
    0 2px 8px rgba(15, 23, 42, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.88);
}

.user-menu__dropdown--fluid .user-menu__item-label {
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
  font-weight: 400;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.user-menu__dropdown--fluid .user-menu__item--disabled {
  opacity: 0.8;
  border-color: color-mix(in srgb, var(--glass-border-strong) 94%, rgba(148, 163, 184, 0.24));
  background:
    linear-gradient(180deg, rgba(250, 251, 252, 0.98) 0%, rgba(242, 245, 248, 0.98) 100%);
  box-shadow:
    0 1px 2px rgba(15, 23, 42, 0.05),
    inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.user-menu__dropdown--fluid .user-menu__item--disabled:hover {
  transform: none;
  border-color: color-mix(in srgb, var(--glass-border-strong) 94%, rgba(148, 163, 184, 0.24));
  background:
    linear-gradient(180deg, rgba(250, 251, 252, 0.98) 0%, rgba(242, 245, 248, 0.98) 100%);
  box-shadow:
    0 1px 2px rgba(15, 23, 42, 0.05),
    inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.user-menu__entry--logout .user-menu__item,
.user-menu__dropdown--fluid .user-menu__item--logout {
  border-color: rgba(239, 68, 68, 0.46);
  background:
    linear-gradient(180deg, rgba(255, 250, 250, 0.99) 0%, rgba(254, 226, 226, 0.92) 100%);
  box-shadow:
    0 1px 3px rgba(239, 68, 68, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.82);
  color: #7f1d1d;
}

.user-menu__entry--logout .user-menu__item:hover,
.user-menu__dropdown--fluid .user-menu__item--logout:hover {
  border-color: rgba(239, 68, 68, 0.56);
  background:
    linear-gradient(180deg, rgba(255, 252, 252, 1) 0%, rgba(254, 202, 202, 0.96) 100%);
  box-shadow:
    0 2px 8px rgba(239, 68, 68, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.88);
}

.user-menu__dropdown form {
  margin: 0;
  width: 100%;
}

.user-menu__entry--logout form {
  display: block;
  width: 100%;
  padding-right: 1px;
  box-sizing: border-box;
}

.user-menu__dropdown--fluid button.user-menu__item {
  appearance: none;
  -webkit-appearance: none;
  font: inherit;
  line-height: inherit;
  overflow: visible;
}

.user-menu__item {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 10px 12px;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  background: transparent;
  color: var(--text);
  text-decoration: none;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  width: 100%;
  box-sizing: border-box;
  text-align: left;
}

.user-menu__item:hover {
  background: var(--nav-hover);
  border-color: var(--glass-border);
}

.user-menu__item--disabled {
  opacity: 0.52;
  cursor: not-allowed;
  pointer-events: none;
}

.user-menu__item--disabled:hover {
  background: transparent;
  border-color: transparent;
}

.user-menu__item--logout {
  border-color: rgba(239, 68, 68, 0.35);
  background: rgba(239, 68, 68, 0.12);
}

.user-menu__item--logout:hover {
  background: rgba(239, 68, 68, 0.18);
  border-color: rgba(239, 68, 68, 0.45);
}

@media (prefers-reduced-motion: reduce) {
  .user-menu__dropdown {
    transition: none;
    transform: translate3d(0, 0, 0) scale(1);
  }

  .user-menu__entry {
    transition: none;
    filter: none;
  }
}

body[data-theme="dark"] .user-menu__dropdown--fluid .user-menu__item {
  border-color: rgba(134, 179, 214, 0.3);
  background:
    linear-gradient(180deg, rgba(22, 31, 43, 0.99) 0%, rgba(16, 23, 34, 0.99) 100%);
  box-shadow:
    0 1px 3px rgba(0, 0, 0, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
  color: #e5edf5;
}

body[data-theme="dark"] .user-menu__dropdown--fluid .user-menu__item:hover {
  border-color: rgba(134, 179, 214, 0.42);
  background:
    linear-gradient(180deg, rgba(27, 39, 54, 1) 0%, rgba(18, 28, 42, 1) 100%);
  box-shadow:
    0 2px 8px rgba(0, 0, 0, 0.24),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

body[data-theme="dark"] .user-menu__dropdown--fluid .user-menu__item--disabled {
  border-color: rgba(92, 105, 123, 0.32);
  background:
    linear-gradient(180deg, rgba(19, 26, 36, 0.98) 0%, rgba(14, 20, 28, 0.98) 100%);
  box-shadow:
    0 1px 2px rgba(0, 0, 0, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

body[data-theme="dark"] .user-menu__entry--logout .user-menu__item,
body[data-theme="dark"] .user-menu__dropdown--fluid .user-menu__item--logout {
  border-color: rgba(248, 113, 113, 0.48);
  background:
    linear-gradient(180deg, rgba(58, 22, 27, 0.98) 0%, rgba(38, 16, 20, 0.98) 100%);
  box-shadow:
    0 1px 3px rgba(127, 29, 29, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.03);
  color: #fecaca;
}

.toggle__input {
  appearance: none;
  width: 44px;
  height: 24px;
  border-radius: 999px;
  background: rgba(96, 125, 139, 0.35);
  border: 2px solid transparent;
  position: relative;
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  cursor: pointer;
  transition: background var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out);
}

body[data-theme="dark"] .toggle__input {
  background: rgba(207, 216, 220, 0.2);
}

.toggle__input::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 1px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  transform: translate3d(0, -50%, 0);
  background: #eceff1;
  box-shadow: 0 10px 20px rgba(15, 23, 42, 0.18);
  transition: transform var(--duration) var(--ease-out), background var(--duration) var(--ease-out);
}

body[data-theme="dark"] .toggle__input::after {
  background: #90a4ae;
}

.toggle__input:checked {
  background: linear-gradient(135deg, var(--silver-2) 0%, var(--accent-strong) 100%);
  border-color: var(--accent);
}

.toggle__input:checked::after {
  transform: translate3d(20px, -50%, 0);
}

.toggle__input:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--focus);
}

.toggle__input:disabled {
  cursor: not-allowed;
}

.toggle.is-disabled .toggle__label {
  cursor: not-allowed;
  color: var(--muted);
}

/* Layout pagina */
.page {
  display: grid;
  grid-template-columns: var(--sidebar-width) 1fr;
  gap: 18px;
  padding: 18px;
  min-height: 0;
  height: calc(var(--viewport-height) - var(--header-offset));
  overflow: hidden;
  position: relative;
  z-index: 1;
}

.page-overlay {
  display: none;
  position: fixed;
  inset: var(--header-offset) 0 0 0;
  border: 0;
  padding: 0;
  margin: 0;
  background: rgba(15, 23, 42, 0.34);
  opacity: 0;
  pointer-events: none;
  transition:
    opacity var(--duration) var(--ease-out),
    backdrop-filter var(--duration) var(--ease-out),
    -webkit-backdrop-filter var(--duration) var(--ease-out);
  backdrop-filter: blur(0px);
  -webkit-backdrop-filter: blur(0px);
  z-index: 54;
}

/* Barra laterale */
.sidebar {
  height: 100%;
  min-height: 0;
  border-radius: var(--radius-xl);
  background: linear-gradient(160deg, var(--glass-strong) 0%, var(--glass) 100%);
  border: 1px solid var(--glass-border);
  box-shadow: var(--shadow);
  padding: 18px 16px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: relative;
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  transition: box-shadow var(--duration-slow) var(--ease-soft), border-color var(--duration-slow) var(--ease-soft), transform var(--duration-slow) var(--ease-soft);
  overflow: hidden;
}

.sidebar__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex: 0 0 auto;
}

.sidebar__close {
  display: none;
  width: 40px;
  height: 40px;
  border-radius: 12px;
  border: 1px solid var(--glass-border);
  background: rgba(255, 255, 255, 0.08);
  color: var(--text);
  cursor: pointer;
  place-items: center;
  font-size: 22px;
  line-height: 1;
  transition:
    transform var(--duration) var(--ease-out),
    border-color var(--duration) var(--ease-out),
    background var(--duration) var(--ease-out);
}

.sidebar__close:hover,
.sidebar__close:focus-visible {
  transform: translateY(-1px);
  border-color: var(--accent);
  background: var(--nav-hover);
  outline: none;
}

.post-login-flash {
  position: fixed;
  inset: 0;
  opacity: 0;
  pointer-events: none;
  z-index: 90;
  overflow: hidden;
  mix-blend-mode: screen;
  visibility: hidden;
}

.post-login-flash.is-active {
  visibility: visible;
}

.post-login-flash__veil,
.post-login-flash__wash,
.post-login-flash__beam {
  position: absolute;
  inset: 0;
}

.post-login-flash__veil {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(233, 245, 255, 0.84) 16%, rgba(169, 210, 242, 0.34) 52%, rgba(82, 126, 164, 0.08) 100%),
    radial-gradient(1200px 680px at 50% -6%, rgba(255, 255, 255, 0.82) 0%, rgba(220, 239, 255, 0.34) 46%, transparent 76%);
}

.post-login-flash__wash {
  inset: -10%;
  background:
    linear-gradient(125deg, rgba(255, 255, 255, 0) 10%, rgba(255, 255, 255, 0.94) 32%, rgba(211, 236, 255, 0.62) 48%, rgba(110, 173, 221, 0.16) 68%, transparent 84%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.2) 0%, rgba(196, 227, 252, 0.3) 22%, rgba(132, 184, 223, 0.1) 58%, transparent 100%);
  filter: blur(18px);
}

.post-login-flash__beam {
  left: -26vw;
  top: -32vh;
  width: 42vw;
  height: 190vh;
  inset: auto;
  background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.98) 36%, rgba(218, 239, 255, 0.72) 54%, rgba(118, 183, 232, 0.18) 72%, transparent 100%);
  filter: blur(18px);
  transform: rotate(16deg);
}

.post-login-flash__beam--primary {
  box-shadow:
    0 0 54px rgba(196, 230, 255, 0.42),
    0 0 120px rgba(160, 210, 247, 0.22);
}

.post-login-flash__beam--secondary {
  width: 26vw;
  left: -18vw;
  top: -36vh;
  height: 200vh;
  background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.84) 40%, rgba(208, 232, 255, 0.44) 58%, transparent 100%);
  filter: blur(26px);
  transform: rotate(12deg);
  box-shadow:
    0 0 42px rgba(220, 240, 255, 0.24),
    0 0 94px rgba(151, 199, 237, 0.18);
}

.sidebar__floating-actions {
  position: absolute;
  right: 14px;
  bottom: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
  z-index: 1;
}

.sidebar__edit {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  border: 1px solid var(--glass-border);
  background: linear-gradient(160deg, var(--glass-strong) 0%, var(--glass) 100%);
  color: var(--text);
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.12);
  display: grid;
  place-items: center;
  cursor: pointer;
  text-decoration: none;
  transition: transform var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out);
}

.sidebar__edit:hover {
  transform: translateY(-1px);
  box-shadow: 0 18px 34px rgba(15, 23, 42, 0.16);
  border-color: var(--accent);
}

.sidebar__edit:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 2px;
}

.sidebar__edit.is-favorites-burst {
  animation: favorites-opener-burst 520ms cubic-bezier(0.22, 1, 0.36, 1);
  border-color: var(--accent);
}

@keyframes favorites-opener-burst {
  0% {
    transform: scale(1);
    box-shadow: 0 14px 28px rgba(15, 23, 42, 0.12);
  }

  28% {
    transform: scale(0.92);
  }

  62% {
    transform: translateY(-2px) scale(1.08);
    box-shadow:
      0 0 0 10px color-mix(in srgb, var(--accent) 18%, transparent),
      0 20px 36px rgba(15, 23, 42, 0.18);
  }

  100% {
    transform: scale(1);
    box-shadow: 0 14px 28px rgba(15, 23, 42, 0.12);
  }
}

.sidebar__edit--secondary.is-active {
  border-color: var(--accent);
  background: linear-gradient(160deg, color-mix(in srgb, var(--accent-soft) 60%, var(--glass-strong)) 0%, color-mix(in srgb, var(--accent-2-soft) 72%, var(--glass)) 100%);
  color: var(--accent-strong);
  box-shadow: 0 16px 30px rgba(15, 23, 42, 0.16);
}

body.is-modal-open {
  overflow: hidden;
}

.modal {
  position: fixed;
  inset: 0;
  z-index: 60;
  display: grid;
  place-items: center;
}

.modal[hidden],
.modal[aria-hidden="true"] {
  display: none;
}

.modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.32);
  backdrop-filter: blur(10px) saturate(140%);
  -webkit-backdrop-filter: blur(10px) saturate(140%);
}

.modal__panel {
  position: relative;
  width: min(720px, calc(100% - 32px));
  border-radius: var(--radius-xl);
  background: linear-gradient(160deg, var(--glass-strong) 0%, var(--glass) 100%);
  border: 1px solid var(--glass-border);
  box-shadow: 0 22px 60px rgba(15, 23, 42, 0.18);
  padding: 14px;
}

.modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.modal__title {
  font-size: 13px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.modal__subtitle {
  margin-top: 4px;
  font-size: 11px;
  line-height: 1.45;
  color: var(--muted);
}

.modal__close {
  width: 30px;
  height: 30px;
  border-radius: 10px;
  border: 1px solid var(--glass-border);
  background: rgba(255, 255, 255, 0.1);
  color: var(--text);
  cursor: pointer;
  font-size: 16px;
  line-height: 1;
}

.favorites-modal {
  opacity: 1;
  visibility: hidden;
  pointer-events: none;
  transition: visibility 0ms linear 260ms;
}

.favorites-modal.is-open {
  visibility: visible;
  pointer-events: auto;
  transition-delay: 0ms;
}

.favorites-modal.is-closing {
  pointer-events: none;
}

.favorites-modal .modal__backdrop {
  opacity: 0;
  backdrop-filter: blur(0px) saturate(100%);
  -webkit-backdrop-filter: blur(0px) saturate(100%);
  transition:
    opacity 220ms cubic-bezier(0.22, 1, 0.36, 1),
    backdrop-filter 260ms cubic-bezier(0.22, 1, 0.36, 1),
    -webkit-backdrop-filter 260ms cubic-bezier(0.22, 1, 0.36, 1);
}

.favorites-modal .modal__panel {
  opacity: 0;
  transform: translate3d(-18px, 24px, 0) scale(0.94);
  transform-origin: left bottom;
  filter: blur(3px);
  box-shadow: 0 30px 70px rgba(15, 23, 42, 0.08);
  transition:
    transform 280ms cubic-bezier(0.22, 1, 0.36, 1),
    opacity 220ms cubic-bezier(0.22, 1, 0.36, 1),
    filter 220ms cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 280ms cubic-bezier(0.22, 1, 0.36, 1);
}

.favorites-modal__panel {
  width: min(860px, calc(100vw - 72px));
  max-height: calc(100vh - 24px);
  margin: 12px;
  padding: 16px;
  overflow: hidden;
}

.favorites-modal.is-open .modal__backdrop {
  opacity: 1;
  backdrop-filter: blur(10px) saturate(140%);
  -webkit-backdrop-filter: blur(10px) saturate(140%);
}

.favorites-modal.is-open .modal__panel {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
  filter: blur(0);
  box-shadow: 0 26px 68px rgba(15, 23, 42, 0.2);
}

.favorites-modal.is-closing .modal__backdrop {
  transition-duration: 180ms;
}

.favorites-modal.is-closing .modal__panel {
  transition-duration: 200ms;
}

.favorites-modal.is-gsap-opening .modal__backdrop,
.favorites-modal.is-gsap-opening .modal__panel,
.favorites-modal.is-gsap-closing .modal__backdrop,
.favorites-modal.is-gsap-closing .modal__panel {
  transition: none !important;
}

.agevolazione-modal,
.agevolazione-discard-modal,
.agevolazione-richtext-modal {
  opacity: 1;
  visibility: hidden;
  pointer-events: none;
  transition: visibility 0ms linear 280ms;
}

.agevolazione-modal.is-closing,
.agevolazione-discard-modal.is-closing,
.agevolazione-richtext-modal.is-closing {
  pointer-events: none;
}

.agevolazione-modal .modal__backdrop,
.agevolazione-discard-modal .modal__backdrop,
.agevolazione-richtext-modal .modal__backdrop {
  opacity: 0;
  backdrop-filter: blur(0px) saturate(100%);
  -webkit-backdrop-filter: blur(0px) saturate(100%);
  transition:
    opacity 240ms cubic-bezier(0.22, 1, 0.36, 1),
    backdrop-filter 240ms cubic-bezier(0.22, 1, 0.36, 1),
    -webkit-backdrop-filter 240ms cubic-bezier(0.22, 1, 0.36, 1);
}

.agevolazione-modal .modal__panel,
.agevolazione-discard-modal .modal__panel,
.agevolazione-richtext-modal .modal__panel {
  opacity: 0;
  transform: translate3d(0, 20px, 0) scale(0.97);
  filter: blur(1px);
  transition:
    transform 260ms cubic-bezier(0.22, 1, 0.36, 1),
    opacity 220ms cubic-bezier(0.22, 1, 0.36, 1),
    filter 220ms cubic-bezier(0.22, 1, 0.36, 1);
}

.agevolazione-modal.is-open,
.agevolazione-discard-modal.is-open,
.agevolazione-richtext-modal.is-open {
  visibility: visible;
  pointer-events: auto;
  transition-delay: 0ms;
}

.agevolazione-modal.is-open .modal__backdrop,
.agevolazione-discard-modal.is-open .modal__backdrop,
.agevolazione-richtext-modal.is-open .modal__backdrop {
  opacity: 1;
  backdrop-filter: blur(10px) saturate(140%);
  -webkit-backdrop-filter: blur(10px) saturate(140%);
}

.agevolazione-modal.is-open .modal__panel,
.agevolazione-discard-modal.is-open .modal__panel,
.agevolazione-richtext-modal.is-open .modal__panel {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
  filter: blur(0);
}

.agevolazione-modal.is-closing .modal__backdrop,
.agevolazione-discard-modal.is-closing .modal__backdrop,
.agevolazione-richtext-modal.is-closing .modal__backdrop {
  transition-duration: 190ms;
}

.agevolazione-modal.is-closing .modal__panel,
.agevolazione-discard-modal.is-closing .modal__panel,
.agevolazione-richtext-modal.is-closing .modal__panel {
  transition-duration: 180ms;
}

.favorites-editor {
  margin-top: 10px;
  display: grid;
  gap: 10px;
  min-height: 0;
}

.favorites-editor__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 6px;
  max-height: min(calc(100vh - 200px), 820px);
  overflow: auto;
  padding-right: 4px;
}

.favorites-editor__section-block {
  display: grid;
  gap: 6px;
  padding-bottom: 2px;
}

.favorites-editor__section-block + .favorites-editor__section-block {
  margin-top: 2px;
  padding-top: 10px;
  border-top: 1px solid var(--glass-border);
}

.favorites-editor__section {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 0 2px;
}

.favorites-editor__section-label {
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text);
}

.favorites-editor__section-meta {
  font-size: 9px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.favorites-editor__section-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 6px;
}

.favorites-editor__section-empty {
  list-style: none;
  padding: 8px 10px;
  border-radius: 12px;
  border: 1px dashed rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.02);
  color: var(--muted);
  font-size: 9px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-align: center;
}

.favorites-editor__item {
  position: relative;
  display: grid;
  grid-template-columns: 22px 18px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  min-height: 40px;
  padding: 8px 10px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--glass-border);
  background: rgba(255, 255, 255, 0.06);
  cursor: grab;
  transition:
    transform 160ms cubic-bezier(0.22, 1, 0.36, 1),
    background 160ms cubic-bezier(0.22, 1, 0.36, 1),
    border-color 160ms cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 160ms cubic-bezier(0.22, 1, 0.36, 1);
}

.favorites-editor__item.is-child {
  margin-left: 20px;
  background: rgba(255, 255, 255, 0.04);
}

.favorites-editor__item.is-dragging {
  opacity: 0.6;
}

.favorites-editor__item.is-drop-before,
.favorites-editor__item.is-drop-after,
.favorites-editor__item.is-drop-child {
  border-color: var(--accent);
}

.favorites-editor__item.is-drop-before {
  box-shadow: inset 0 2px 0 rgba(255, 255, 255, 0.22);
}

.favorites-editor__item.is-drop-after {
  box-shadow: inset 0 -2px 0 rgba(255, 255, 255, 0.22);
}

.favorites-editor__item.is-drop-child {
  border-color: color-mix(in srgb, var(--accent) 82%, white 18%);
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--accent) 18%, transparent) 0,
    color-mix(in srgb, var(--accent) 8%, rgba(255, 255, 255, 0.08)) 100%
  );
  box-shadow:
    inset 14px 0 0 color-mix(in srgb, var(--accent) 22%, transparent),
    0 10px 24px rgba(15, 23, 42, 0.08);
}

.favorites-editor__item.is-drop-detach {
  border-color: color-mix(in srgb, var(--accent) 72%, white 28%);
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--accent) 16%, transparent) 0,
    rgba(255, 255, 255, 0.04) 100%
  );
  outline: 1px solid color-mix(in srgb, var(--accent) 20%, transparent);
  outline-offset: -1px;
}

.favorites-editor__item[data-drop-hint]::after {
  content: attr(data-drop-hint);
  position: absolute;
  top: 6px;
  right: 8px;
  padding: 3px 7px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 20%, rgba(255, 255, 255, 0.12));
  border: 1px solid color-mix(in srgb, var(--accent) 42%, rgba(255, 255, 255, 0.18));
  color: var(--text);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  pointer-events: none;
}

.favorites-editor__handle {
  font-size: 11px;
  color: var(--muted);
  user-select: none;
}

.favorites-editor__copy {
  display: grid;
  gap: 0;
  min-width: 0;
}

.favorites-editor__label {
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.favorites-editor__meta {
  font-size: 11px;
  color: var(--muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.favorites-editor__actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}

.favorites-editor__root-drop {
  list-style: none;
  padding: 10px 12px;
  border-radius: var(--radius-lg);
  border: 1px dashed rgba(255, 255, 255, 0.18);
  color: var(--muted);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: center;
}

.favorites-editor__root-drop.is-drop-root {
  border-color: var(--accent);
  color: var(--text);
  background: rgba(255, 255, 255, 0.08);
}

.sidebar__brand {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 8px;
  min-width: 0;
}

.sidebar__logo {
  width: 42px;
  height: 42px;
  object-fit: contain;
  filter: drop-shadow(0 10px 18px rgba(15, 23, 42, 0.18));
}

.sidebar__title {
  font-size: 12px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--muted);
}

.sidebar__section {
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
  padding-top: 10px;
  border-top: 1px solid transparent;
  position: relative;
}

.sidebar__section::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  width: auto;
  height: 1px;
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--accent-2) 72%, transparent) 0%,
    color-mix(in srgb, var(--accent) 88%, transparent) 52%,
    color-mix(in srgb, var(--accent-2) 72%, transparent) 100%
  );
  opacity: 0.72;
}

.sidebar__nav {
  flex: 1 1 auto;
  min-height: 0;
  display: grid;
  align-content: start;
  gap: 14px;
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  padding-right: 6px;
  padding-bottom: 62px;
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) transparent;
}

.sidebar__nav::-webkit-scrollbar {
  width: 10px;
}

.sidebar__nav::-webkit-scrollbar-thumb {
  background: var(--scrollbar-thumb);
  border-radius: 999px;
}

.sidebar__nav::-webkit-scrollbar-track {
  background: transparent;
}

.sidebar__section-block {
  display: grid;
  gap: 6px;
}

.sidebar__section-links {
  display: grid;
  gap: 6px;
}

.sidebar__group {
  display: grid;
  gap: 6px;
}

.sidebar__group-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 4px;
  align-items: center;
}

.sidebar__link {
  position: relative;
  text-decoration: none;
  color: var(--text);
  font-size: 13px;
  padding: 10px 12px 10px 36px;
  border-radius: var(--radius-md);
  background: transparent;
  transition: transform var(--duration) var(--ease-out), background var(--duration) var(--ease-out);
}

.sidebar__link::before {
  content: "";
  position: absolute;
  left: 14px;
  top: 50%;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  transform: translateY(-50%);
  background: var(--nav-dot);
  border: 1px solid var(--glass-border);
}

.sidebar__link:hover {
  background: var(--nav-hover);
  transform: translateY(-1px);
}

.sidebar__link.is-active-branch {
  background: rgba(255, 255, 255, 0.06);
}

.sidebar__link.is-active {
  background: var(--nav-active);
}

.sidebar__link.is-active::before {
  background: linear-gradient(135deg, var(--silver-1) 0%, var(--accent-2) 100%);
  border-color: var(--accent);
}

.sidebar__submenu-toggle {
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  justify-self: end;
  width: 16px;
  height: 16px;
  padding: 0;
  margin-right: 8px;
  box-shadow: none;
  cursor: pointer;
  transition: color var(--duration) var(--ease-out), opacity var(--duration) var(--ease-out);
}

.sidebar__submenu-toggle:hover {
  color: var(--text);
  opacity: 1;
}

.sidebar__submenu-toggle:focus-visible {
  outline: none;
  color: var(--text);
}

.sidebar__submenu-toggle-icon {
  display: block;
  width: 6px;
  height: 6px;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: rotate(-45deg);
  transform-origin: 50% 50%;
}

.sidebar__group.is-branch-active .sidebar__submenu-toggle,
.sidebar__submenu-toggle.is-open {
  color: var(--text);
  background: transparent;
}

.sidebar__submenu {
  overflow: hidden;
}

.sidebar__submenu-inner {
  display: grid;
  gap: 6px;
  padding-left: 18px;
}

.sidebar__link--child {
  padding-left: 52px;
  font-size: 12px;
}

.sidebar__link--child::before {
  left: 28px;
  width: 6px;
  height: 6px;
}

/* Contenuto principale */
.content {
  height: 100%;
  overflow: auto;
  padding-right: 8px;
  padding-bottom: 18px;
  min-width: 0;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}

.content:focus-visible {
  outline: none;
}

.content::-webkit-scrollbar {
  width: 14px;
}

.content::-webkit-scrollbar-thumb {
  background: var(--scrollbar-thumb);
  border: 3px solid var(--scrollbar-track);
  border-radius: 999px;
}

.content::-webkit-scrollbar-track {
  background: var(--scrollbar-track);
  border-radius: 999px;
}

/* Pannello aziende */
.board {
  min-width: 0;
}

.board__panel {
  position: relative;
  border-radius: var(--radius-xl);
  background: linear-gradient(160deg, var(--glass-strong) 0%, var(--glass) 100%);
  border: 1px solid var(--glass-border);
  box-shadow: var(--shadow);
  padding: 16px;
  min-width: 0;
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  transition: box-shadow var(--duration-slow) var(--ease-soft), border-color var(--duration-slow) var(--ease-soft), transform var(--duration-slow) var(--ease-soft);
  overflow: hidden;
}

.board__panel--company-themed {
  isolation: isolate;
  --company-theme-rgb: 31, 77, 122;
  --company-theme-alt-rgb: 93, 135, 167;
  --company-theme-border-rgb: var(--company-theme-rgb);
  background: var(--company-panel-bg, linear-gradient(160deg, var(--glass-strong) 0%, var(--glass) 100%));
  border-color: var(--company-panel-border, var(--glass-border));
  box-shadow: var(--company-panel-shadow, var(--shadow));
  --company-panel-bg:
    radial-gradient(860px 360px at 12% 4%, rgba(var(--company-theme-rgb), 0.14), transparent 62%),
    radial-gradient(680px 320px at 88% 10%, rgba(var(--company-theme-alt-rgb), 0.12), transparent 58%),
    linear-gradient(160deg, rgba(249, 252, 255, 0.96) 0%, rgba(238, 244, 250, 0.92) 52%, rgba(230, 238, 246, 0.88) 100%);
  --company-panel-border: rgba(var(--company-theme-border-rgb), 0.16);
  --company-panel-shadow:
    0 24px 54px rgba(var(--company-theme-rgb), 0.1),
    inset 0 1px 0 rgba(255, 255, 255, 0.38);
  --company-panel-glow-left: rgba(var(--company-theme-rgb), 0.14);
  --company-panel-glow-right: rgba(var(--company-theme-alt-rgb), 0.12);
  --company-panel-sheen: rgba(255, 255, 255, 0.22);
  --company-panel-overlay-opacity: 1;
}

.board__panel--company-themed::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background:
    radial-gradient(720px 320px at 8% 4%, var(--company-panel-glow-left, transparent), transparent 68%),
    radial-gradient(680px 300px at 92% 8%, var(--company-panel-glow-right, transparent), transparent 66%),
    linear-gradient(90deg, transparent 0%, var(--company-panel-sheen, transparent) 48%, transparent 100%);
  opacity: var(--company-panel-overlay-opacity, 0);
  pointer-events: none;
  z-index: 0;
}

.board__panel--company-themed > * {
  position: relative;
  z-index: 1;
}

.board__panel--company-themed[data-company-theme="amish"] {
  --company-theme-rgb: 128, 32, 32;
  --company-theme-alt-rgb: 224, 224, 192;
}

.board__panel--company-themed[data-company-theme="andel"] {
  --company-theme-rgb: 32, 128, 160;
  --company-theme-alt-rgb: 32, 128, 192;
}

.board__panel--company-themed[data-company-theme="bucintoro"] {
  --company-theme-rgb: 96, 32, 32;
  --company-theme-alt-rgb: 64, 64, 64;
}

.board__panel--company-themed[data-company-theme="eco-pv"] {
  --company-theme-rgb: 19, 135, 224;
  --company-theme-alt-rgb: 255, 109, 24;
}

.board__panel--company-themed[data-company-theme="free-energy"] {
  --company-theme-rgb: 32, 96, 160;
  --company-theme-alt-rgb: 64, 128, 224;
}

.board__panel--company-themed[data-company-theme="im-innovation"] {
  --company-theme-rgb: 128, 128, 128;
  --company-theme-alt-rgb: 160, 192, 192;
}

.board__panel--company-themed[data-company-theme="krunos"] {
  --company-theme-rgb: 32, 64, 128;
  --company-theme-alt-rgb: 64, 160, 224;
}

.board__panel--company-themed[data-company-theme="zilio-environment"] {
  --company-theme-rgb: 64, 160, 64;
  --company-theme-alt-rgb: 64, 192, 96;
}

.board__panel--company-themed[data-company-theme="zilio-group"] {
  --company-theme-rgb: 160, 160, 160;
  --company-theme-alt-rgb: 160, 192, 192;
}

.board__panel--company-themed[data-company-theme="zilio-65"] {
  --company-theme-rgb: 255, 224, 0;
  --company-theme-alt-rgb: 255, 128, 0;
  --company-theme-border-rgb: 224, 160, 0;
}

.board__panel--company-themed[data-company-theme="zilio-real-estate"] {
  --company-theme-rgb: 96, 96, 96;
  --company-theme-alt-rgb: 160, 160, 160;
}

.board__panel--company-themed[data-company-theme="zilio-service"] {
  --company-theme-rgb: 64, 64, 64;
  --company-theme-alt-rgb: 192, 192, 192;
}

.board__panel--company-themed[data-company-theme="zilius"] {
  --company-theme-rgb: 128, 160, 32;
  --company-theme-alt-rgb: 96, 96, 96;
}

body[data-theme="dark"] .board__panel--company-themed {
  --company-panel-bg:
    radial-gradient(900px 380px at 12% 0%, rgba(var(--company-theme-rgb), 0.18), transparent 60%),
    radial-gradient(700px 340px at 90% 10%, rgba(var(--company-theme-alt-rgb), 0.14), transparent 56%),
    linear-gradient(160deg, rgba(7, 19, 31, 0.96) 0%, rgba(10, 28, 43, 0.94) 48%, rgba(17, 39, 58, 0.92) 100%);
  --company-panel-border: rgba(var(--company-theme-border-rgb), 0.18);
  --company-panel-shadow:
    0 28px 64px rgba(0, 0, 0, 0.42),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
  --company-panel-glow-left: rgba(var(--company-theme-rgb), 0.18);
  --company-panel-glow-right: rgba(var(--company-theme-alt-rgb), 0.14);
  --company-panel-sheen: rgba(255, 255, 255, 0.08);
}

.board__panel--employee-detail {
  display: grid;
  gap: 16px;
  align-content: start;
}

.board__panel--profile {
  overflow: visible;
}

.board__row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  align-items: stretch;
}

.home-hero {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: stretch;
  justify-content: flex-start;
  margin-bottom: 16px;
}

.home-hero--single {
  max-width: 520px;
}

.home-meetings-rail {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(500px, 500px));
  grid-auto-rows: 176px;
  gap: 10px;
  justify-content: start;
  align-items: stretch;
  align-content: stretch;
  width: min(100%, 1010px);
  flex: 0 1 1010px;
  height: 100%;
}

.home-overview {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  align-content: start;
  gap: 10px;
  align-items: start;
  min-height: 176px;
  width: min(100%, 500px);
  flex: 0 1 500px;
  padding: 12px 14px 14px;
  border-radius: calc(var(--radius-lg) + 1px);
  border: 1px solid var(--home-hero-panel-border);
  background: var(--home-hero-panel-bg);
  box-shadow:
    0 14px 28px rgba(15, 23, 42, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
  overflow: hidden;
}

.home-overview::after {
  content: "";
  position: absolute;
  inset: auto 22px 0 22px;
  height: 1px;
  background: var(--home-hero-panel-line);
}

.home-overview__copy {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.home-overview__top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px 14px;
  align-items: start;
}

.home-overview__eyebrow {
  margin: 0;
  font-size: 9px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--home-hero-panel-soft);
}

.home-overview__title {
  margin: 0;
  font-size: clamp(16px, 1.6vw, 21px);
  line-height: 1.08;
  letter-spacing: -0.03em;
  color: var(--home-hero-panel-title);
}

.home-overview__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 5px 9px;
  align-items: center;
  color: var(--home-hero-panel-muted);
  font-size: 10px;
  letter-spacing: 0.02em;
}

.home-overview__meta > span {
  position: relative;
}

.home-overview__meta > span + span::before {
  content: "·";
  margin-right: 14px;
  color: rgba(148, 163, 184, 0.66);
}

.home-overview__events {
  display: inline-flex;
  align-items: center;
}

.home-overview__meta > span + span::before {
  content: "\00B7";
  margin-right: 10px;
  color: var(--home-hero-panel-separator);
}

.home-overview__events-indicator {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  margin-right: 7px;
  background: linear-gradient(135deg, #fde68a 0%, #f97316 100%);
  box-shadow:
    0 0 0 0 rgba(249, 115, 22, 0.4),
    0 0 16px rgba(249, 115, 22, 0.34);
  animation: home-overview-pulse 1.8s ease-out infinite;
}

.home-overview__action {
  align-self: start;
  justify-self: end;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 0 11px;
  border-radius: 9px;
  border: 1px solid var(--home-hero-action-border);
  background: var(--home-hero-action-bg);
  color: var(--home-hero-action-text);
  text-decoration: none;
  font-size: 9px;
  letter-spacing: 0.06em;
  white-space: nowrap;
  text-transform: uppercase;
  transition:
    transform var(--duration) var(--ease-out),
    border-color var(--duration) var(--ease-out),
    background var(--duration) var(--ease-out);
}

.home-overview__action:hover,
.home-overview__action:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(126, 185, 232, 0.36);
  background: var(--home-hero-action-bg-hover);
}

.home-overview__action:focus-visible {
  outline: none;
}

.home-overview__metrics {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
  gap: 8px;
  width: 100%;
}

.home-overview__metric {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  min-height: 72px;
  padding: 10px 11px;
  position: relative;
  overflow: hidden;
  border-radius: 12px;
  border: 1px solid var(--home-hero-metric-border);
  background: var(--home-hero-metric-bg);
  text-decoration: none;
  color: inherit;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
  transition:
    transform var(--duration) var(--ease-out),
    border-color var(--duration) var(--ease-out),
    background var(--duration) var(--ease-out);
}

.home-overview__metric::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 3px;
  border-radius: 12px 0 0 12px;
  background: var(--home-metric-tone, rgba(93, 135, 167, 0.56));
}

.home-overview__metric:hover,
.home-overview__metric:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(148, 197, 255, 0.32);
  background: var(--home-hero-metric-bg-hover);
}

.home-overview__metric:focus-visible {
  outline: none;
}

.home-overview__metric--accent {
  --home-metric-tone: rgba(59, 130, 246, 0.9);
  border-color: rgba(59, 130, 246, 0.2);
  background:
    linear-gradient(160deg, rgba(59, 130, 246, 0.12) 0%, var(--home-hero-metric-bg) 70%);
}

.home-overview__metric--neutral {
  --home-metric-tone: rgba(93, 135, 167, 0.84);
  border-color: rgba(93, 135, 167, 0.2);
  background:
    linear-gradient(160deg, rgba(93, 135, 167, 0.1) 0%, var(--home-hero-metric-bg) 70%);
}

.home-overview__metric--success {
  --home-metric-tone: rgba(101, 163, 13, 0.9);
  border-color: rgba(101, 163, 13, 0.2);
  background:
    linear-gradient(160deg, rgba(132, 204, 22, 0.12) 0%, var(--home-hero-metric-bg) 70%);
}

.home-overview__metric--warning {
  --home-metric-tone: rgba(249, 115, 22, 0.92);
  border-color: rgba(249, 115, 22, 0.22);
  background:
    linear-gradient(160deg, rgba(249, 115, 22, 0.14) 0%, var(--home-hero-metric-bg) 70%);
}

.home-overview__metric-label {
  font-size: 9px;
  line-height: 1.15;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--home-hero-metric-label);
  font-family: var(--font-title);
}

.home-overview__metric-value {
  font-size: 17px;
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--home-hero-metric-value);
  font-family: var(--font-title);
}

.home-overview__metric-hint {
  font-size: 10px;
  line-height: 1.2;
  color: var(--home-hero-metric-hint);
}

.home-overview__metric--accent .home-overview__metric-hint {
  color: #84cc16;
}

.home-overview__metric--success .home-overview__metric-hint {
  color: #84cc16;
}

.home-overview__metric--warning .home-overview__metric-hint {
  color: #f97316;
}

.board__row--meetings {
  grid-template-columns: repeat(auto-fit, minmax(300px, 340px));
  justify-content: start;
  align-items: start;
  gap: 18px;
}

.company.company--meeting-card {
  display: grid;
  grid-template-columns: minmax(0, 0.86fr) minmax(220px, 1.14fr);
  grid-template-rows: 1fr;
  width: 100%;
  max-width: none;
  min-height: 176px;
  height: 100%;
  gap: 4px 8px;
  padding: 12px 14px 14px;
  font-family: var(--font-body);
  background: var(--home-meeting-bg);
  border-color: var(--home-meeting-border);
  box-shadow:
    0 14px 28px rgba(15, 23, 42, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  align-self: start;
  align-content: start;
}

.company.company--meeting-card::before {
  display: none;
}

.company.company--meeting-card::after {
  inset: auto 22px 0 22px;
  height: 1px;
  background: var(--home-hero-panel-line);
  opacity: 1;
}

.company.company--meeting-card-empty {
  grid-column: auto;
  grid-template-columns: 1fr;
  grid-template-rows: 1fr;
}

.home-event-card__card-link {
  color: inherit;
  text-decoration: none;
}

.home-event-card__card-link:focus-visible {
  outline: none;
  border-color: var(--accent);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--accent) 56%, transparent),
    0 14px 28px rgba(15, 23, 42, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.home-event-card__card-link:focus-visible::after {
  opacity: 1;
}

.home-event-card__content {
  display: grid;
  align-content: start;
  align-self: start;
  justify-items: start;
  gap: 2px;
  min-width: 0;
}

.home-event-card__header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 2px 8px;
  align-items: start;
  align-self: start;
}

.home-event-card__copy {
  display: grid;
  gap: 0;
  min-width: 0;
}

.home-event-card__eyebrow {
  margin: 0;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--home-meeting-soft);
  font-family: var(--font-title);
}

.home-event-card__description {
  margin: 0;
  font-size: 10px;
  line-height: 1.05;
  color: var(--home-meeting-muted);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  overflow: hidden;
}

.home-event-card__date {
  text-align: right;
  min-width: 54px;
  font-family: var(--font-title);
}

.home-event-card__weekday {
  display: block;
  margin-bottom: 1px;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--home-meeting-soft);
}

.home-event-card__day {
  display: inline-flex;
  align-items: baseline;
  gap: 3px;
  font-size: 17px;
  line-height: 1;
  letter-spacing: -0.05em;
  color: var(--home-meeting-title);
}

.home-event-card__day span {
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--home-meeting-muted);
}

.home-event-card__media {
  position: relative;
  min-height: 138px;
  height: 138px;
  width: 100%;
  aspect-ratio: 2.25 / 1;
  align-self: center;
  border-radius: 10px;
  background: var(--home-meeting-media-bg);
  overflow: hidden;
  border: 1px solid var(--home-meeting-media-border);
}

.home-event-card__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--home-meeting-media-overlay);
  pointer-events: none;
}

.home-event-card__media img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center 40%;
}

.home-event-card__media--empty {
  background: linear-gradient(160deg, rgba(30, 41, 59, 0.92) 0%, rgba(51, 65, 85, 0.88) 100%);
}

.home-event-card__media--empty img {
  opacity: 0.3;
  filter: saturate(0.6) brightness(0.9);
}

.home-event-card__media-chip {
  position: absolute;
  left: 8px;
  top: 8px;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 18px;
  padding: 0 7px;
  border-radius: 999px;
  background: var(--home-meeting-chip-bg);
  color: var(--home-meeting-chip-text);
  font-size: 9px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-family: var(--font-title);
}

.home-event-card__media-chip.is-today {
  background: rgba(245, 158, 11, 0.22);
  color: #fef3c7;
}

.home-event-card__body {
  display: grid;
  align-content: start;
  justify-items: start;
  justify-self: start;
  min-width: 0;
  gap: 1px;
  align-self: start;
}

.home-event-card__body--empty {
  justify-items: start;
  align-content: center;
  gap: 8px;
  min-height: 0;
}

.home-event-card__empty-visual {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 14px;
  background:
    linear-gradient(160deg, rgba(93, 135, 167, 0.16) 0%, rgba(31, 77, 122, 0.08) 100%);
  color: var(--home-meeting-icon);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.26);
}

.home-event-card__empty-visual svg {
  width: 22px;
  height: 22px;
  display: block;
}

.home-event-card__title {
  margin: 0;
  font-size: 14px;
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--home-meeting-title);
  font-family: var(--font-title);
}

.home-event-card__details {
  display: flex;
  flex-wrap: wrap;
  gap: 1px 7px;
  align-items: flex-start;
  justify-content: flex-start;
}

.home-event-card__detail {
  display: grid;
  grid-template-columns: 14px minmax(0, 1fr);
  gap: 3px;
  align-items: center;
  font-size: 10px;
  line-height: 1.05;
  color: var(--home-meeting-muted);
}

.home-event-card__icon {
  width: 14px;
  height: 14px;
  color: var(--home-meeting-icon);
}

.home-event-card__icon svg {
  width: 14px;
  height: 14px;
  display: block;
}

.home-event-card__note {
  margin: 0;
  font-size: 10px;
  line-height: 1.1;
  color: var(--home-meeting-soft);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  overflow: hidden;
  display: none;
}

.company.company--meeting-card-empty .home-event-card__description,
.company.company--meeting-card-empty .home-event-card__note {
  display: block;
  -webkit-line-clamp: unset;
}

.company.company--meeting-card-empty .home-event-card__note {
  max-width: 46ch;
  font-size: 10px;
  line-height: 1.45;
}

.company.company--meeting-card-empty .home-event-card__footer {
  margin-top: 0;
}

.home-event-card__footer {
  margin-top: 0;
  padding-top: 0;
  align-self: start;
  justify-self: start;
}

.home-meetings-rail > .company.company--meeting-card:only-child {
  grid-column: auto;
}

.home-event-card__action {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  width: auto;
  min-height: 16px;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--home-meeting-title);
  text-decoration: none;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0;
  text-transform: none;
  font-family: var(--font-title);
  transition:
    transform var(--duration) var(--ease-out),
    color var(--duration) var(--ease-out);
}

.home-event-card__action:hover,
.home-event-card__action:focus-visible {
  color: rgba(191, 219, 254, 0.98);
  transform: translateY(-1px);
}

.home-event-card__action:focus-visible {
  outline: none;
}

.home-event-card__action--muted {
  color: var(--home-meeting-soft);
  cursor: default;
}

.board__row--home {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

body[data-density="compact"] .board__row {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

body[data-density="compact"] .board__row--home {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

body[data-density="compact"] .home-overview {
  min-height: 158px;
  padding: 10px 12px 12px;
}

body[data-density="compact"] .home-overview__metrics {
  gap: 7px;
}

body[data-density="compact"] .home-overview__metric {
  min-height: 66px;
  padding: 9px 10px;
}

body[data-density="compact"] .home-overview__metric-value {
  font-size: 15px;
}

body[data-density="compact"] .company.company--meeting-card {
  min-height: 158px;
  grid-template-columns: minmax(0, 0.88fr) minmax(206px, 1.12fr);
  padding: 10px 12px 12px;
  gap: 4px 7px;
}

body[data-density="compact"] .home-event-card__content {
  gap: 2px;
}

body[data-density="compact"] .home-event-card__empty-visual {
  width: 40px;
  height: 40px;
}

body[data-density="compact"] .home-event-card__media {
  min-height: 122px;
  height: 122px;
}

body[data-density="compact"] .home-meetings-rail {
  grid-auto-rows: 158px;
}

@keyframes home-overview-pulse {
  0% {
    box-shadow:
      0 0 0 0 rgba(249, 115, 22, 0.38),
      0 0 16px rgba(249, 115, 22, 0.28);
  }
  70% {
    box-shadow:
      0 0 0 10px rgba(249, 115, 22, 0),
      0 0 18px rgba(249, 115, 22, 0.16);
  }
  100% {
    box-shadow:
      0 0 0 0 rgba(249, 115, 22, 0),
      0 0 16px rgba(249, 115, 22, 0.28);
  }
}

@media (prefers-reduced-motion: reduce) {
  .home-overview__events-indicator {
    animation: none;
  }
}

@media (max-width: 1200px) {
  .home-hero {
    gap: 10px;
  }

  .home-overview {
    width: min(100%, 480px);
    flex-basis: 480px;
    min-height: 170px;
  }

  .home-meetings-rail {
    grid-template-columns: repeat(auto-fit, minmax(460px, 1fr));
    grid-auto-rows: 170px;
    width: min(100%, 940px);
    flex-basis: 940px;
  }

  .company.company--meeting-card {
    grid-template-columns: minmax(0, 0.88fr) minmax(198px, 1.12fr);
    min-height: 170px;
  }
}

@media (max-width: 860px) {
  .home-hero {
    flex-direction: column;
  }

  .home-overview {
    grid-template-columns: 1fr;
    align-items: start;
    min-height: 0;
    width: 100%;
    flex-basis: auto;
  }

  .home-overview__top {
    grid-template-columns: 1fr;
  }

  .home-overview__action {
    justify-self: start;
    align-self: start;
  }

  .home-meetings-rail {
    grid-template-columns: 1fr;
    grid-auto-rows: auto;
    width: 100%;
    flex-basis: auto;
    height: auto;
  }

  .company.company--meeting-card {
    max-width: none;
    grid-template-columns: minmax(0, 0.9fr) minmax(180px, 1.1fr);
    min-height: 0;
    height: auto;
  }

  .home-event-card__date {
    text-align: left;
  }

  .home-event-card__media {
    min-height: 112px;
    height: 112px;
  }

  .home-event-card__note {
    display: -webkit-box;
  }
}

@media (max-width: 720px) {
  .board__row--home,
  body[data-density="compact"] .board__row--home {
    grid-template-columns: 1fr;
  }

  .company--list,
  .company--list-unified {
    min-height: 0;
  }

  .company__list-body {
    overflow: visible;
    padding-right: 0;
  }
}

@media (max-width: 640px) {
  .company.company--meeting-card {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .home-event-card__header {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .home-event-card__date {
    display: inline-flex;
    align-items: baseline;
    gap: 8px;
    min-width: 0;
    text-align: left;
  }

  .home-event-card__weekday {
    margin-bottom: 0;
  }

  .home-event-card__media {
    min-height: 150px;
    height: 150px;
  }
}

/* Schede azienda */
.company {
  position: relative;
  border-radius: var(--radius-lg);
  background: linear-gradient(160deg, var(--card-bg) 0%, var(--card-overlay) 100%);
  border: 1px solid var(--card-border);
  box-shadow: var(--shadow);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 18px 16px 14px;
  min-height: 620px;
  transform: translateZ(0);
  transition: transform var(--duration) var(--ease-soft), border-color var(--duration-fast) var(--ease-out);
  will-change: transform;
  backface-visibility: hidden;
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
}

body[data-density="compact"] .board__row .company {
  min-height: 420px;
}

.company::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 5px;
  background: linear-gradient(180deg, var(--accent-strong) 0%, var(--accent-2) 100%);
}

.company::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--accent-soft) 16%, transparent) 0%, transparent 56%),
    radial-gradient(circle at top right, color-mix(in srgb, var(--accent-2-soft) 18%, transparent) 0%, transparent 42%);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--duration) var(--ease-soft);
}

.company:hover {
  border-color: var(--accent);
}

.company.is-search-target {
  border-color: var(--accent);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--accent) 56%, transparent),
    var(--shadow-strong);
}

.company:hover::after {
  opacity: 1;
}

html.js .company {
  opacity: 0;
  transform: translate3d(0, 10px, 0);
  transition:
    opacity var(--duration-slow) var(--ease-soft),
    transform var(--duration-slow) var(--ease-soft),
    border-color var(--duration-fast) var(--ease-out);
  transition-delay: calc(var(--stagger, 0) * 20ms);
}

html.js .company.company--scrolltrigger {
  opacity: 1;
  transform: none;
  transition: border-color var(--duration-fast) var(--ease-out);
}

html.js body[data-page-transitions="soft"]:not(.is-page-enter-ready) [data-page-enter-item],
html.is-page-enter-preparing body[data-page-transitions="soft"] [data-page-enter-item] {
  opacity: 0;
  transform: translate3d(0, 36px, 0) scale(0.988);
  filter: blur(6px);
  will-change: opacity, transform, filter;
}

body.is-page-entering html.js .company,
body.is-post-login-entering html.js .company {
  transition-delay: 0ms;
}

body.is-page-entering html.js .company.is-visible,
body.is-post-login-entering html.js .company.is-visible {
  transition: border-color var(--duration-fast) var(--ease-out);
}

html.js .company.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

html.js .company.is-visible:hover {
  transform: translate3d(0, -3px, 0);
}

html:not(.js) .company:hover {
  transform: translate3d(0, -3px, 0);
}

.company__badge {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 48px;
  height: 48px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  color: #eceff1;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.12em;
  text-decoration: none;
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);
  box-shadow: 0 16px 30px rgba(0, 0, 0, 0.18);
  border: none;
  transition: transform var(--duration) var(--ease-out), filter var(--duration) var(--ease-out);
}

.company__badge:hover {
  transform: translateY(-1px) scale(1.03);
  filter: brightness(1.06);
}

.company__logo {
  height: 96px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px 6px 12px;
  border-bottom: 1px solid var(--glass-border);
  margin-top: 26px;
}

body[data-density="compact"] .board__row .company__logo {
  margin-top: 16px;
}

.company__logo img {
  max-height: 70px;
  max-width: 220px;
  object-fit: contain;
  display: block;
}

.company--plain-project .company__logo {
  margin-top: 0;
}

body[data-density="compact"] .board__row .company--plain-project .company__logo {
  margin-top: 0;
}

.company__logo-placeholder {
  width: 64px;
  height: 64px;
  border-radius: 20px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.04)),
    radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.18), transparent 58%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.company__content h2 {
  font-size: 15px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.company__subtitle {
  margin-top: 6px;
  font-size: 13px;
  color: var(--muted);
  line-height: 1.35;
}

.company__editable {
  margin-top: 10px;
  padding: 10px 12px;
  border-radius: var(--radius-md);
  border: 1px dashed var(--glass-border-strong);
  background: var(--notes-bg);
  font-size: 13px;
  line-height: 1.45;
  color: var(--text);
  min-height: 40px;
  outline: none;
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
}

.company__editable[contenteditable="true"]:empty::before {
  content: attr(data-placeholder);
  color: var(--muted);
}

.company__editable:focus {
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--focus);
}

.company__editable--large {
  min-height: 180px;
}

.company__editable--tile {
  min-height: 120px;
}

.company__notes {
  flex: 1;
  resize: none;
  padding: 14px;
  border-radius: var(--radius-md);
  border: 1px solid var(--notes-border);
  background: var(--notes-bg);
  font-size: 13px;
  line-height: 1.5;
  color: var(--text);
  width: 100%;
  outline: none;
  overflow: auto;
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
}

.company__notes:focus {
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--focus);
}

.company__notes--category {
  flex: 0 0 auto;
  min-height: 120px;
}

.company__notes--subcat {
  flex: 0 0 auto;
  min-height: 110px;
}

.company__notes--global {
  flex: 0 0 auto;
  min-height: 260px;
}

.company__phrases-board {
  display: grid;
  gap: 10px;
}

.company-page__tools {
  margin-top: 18px;
  width: 100%;
}

.company-tools {
  width: 100%;
}

.company-tools__grid {
  width: min(1200px, 100%);
  margin: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  align-items: stretch;
}

/* Layout unificato per categoria e frasi */
.company-tools__panel.company-tools__panel--combined {
  padding: 16px;
}

.company-tools__split {
  display: grid;
  grid-template-columns: minmax(280px, 1fr) auto minmax(280px, 1fr);
  gap: 16px;
  align-items: start;
}

.company-tools__section {
  display: grid;
  gap: 10px;
  align-content: start;
}

.company-tools__divider {
  width: 1px;
  background: var(--glass-border-strong);
  border-radius: 999px;
  align-self: stretch;
  opacity: 0.7;
}

.company-tools__section--add .company__phrases--pool {
  display: none;
}

.company-tools__hint {
  font-size: 11px;
  color: var(--muted);
  letter-spacing: 0.04em;
  min-height: 14px;
}

.company__phrase-add.is-select {
  border-color: rgba(34, 197, 94, 0.45);
  background: linear-gradient(135deg, rgba(34, 197, 94, 0.85) 0%, rgba(16, 185, 129, 0.85) 100%);
  color: #0b1f12;
}

.company__phrase-add.is-select:hover {
  box-shadow: 0 12px 22px rgba(16, 185, 129, 0.22);
}

.company-tools__panel {
  border-radius: var(--radius-lg);
  background: linear-gradient(160deg, var(--card-bg) 0%, var(--card-overlay) 100%);
  border: 1px solid var(--card-border);
  box-shadow: var(--shadow);
  padding: 14px;
  display: grid;
  gap: 10px;
  align-content: start;
  height: 100%;
}

.company-tools__title {
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.company-tools__row {
  display: flex;
  gap: 8px;
  align-items: center;
}

.company-tools__select {
  flex: 1;
  min-width: 0;
  padding: 8px 10px;
  border-radius: 8px;
  border: 1px solid var(--input-border);
  background: var(--input-bg);
  color: var(--text);
  font-size: 13px;
  outline: none;
  transition: box-shadow var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out);
}

.company-tools__select:focus {
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--focus);
}

.company-tools__input {
  flex: 1;
  min-width: 0;
}

.company-page__notes .company__phrases-board {
  width: min(420px, 100%);
  justify-self: start;
}

.company__phrases-composer {
  display: flex;
  align-items: center;
  gap: 8px;
}

.company__phrase-input {
  flex: 1;
  min-width: 0;
  padding: 8px 10px;
  border-radius: 8px;
  border: 1px solid var(--input-border);
  background: var(--input-bg);
  color: var(--text);
  font-size: 13px;
  outline: none;
  transition: box-shadow var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out);
}

.company__phrase-input:focus {
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--focus);
}

.company__phrase-add {
  padding: 6px 10px;
  border-radius: 8px;
  border: 1px solid var(--glass-border-strong);
  background: linear-gradient(135deg, var(--silver-1) 0%, var(--accent-2) 100%);
  color: var(--text);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  transition: transform var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out), filter var(--duration) var(--ease-out);
}

.company__phrase-add:hover {
  transform: translate3d(0, -1px, 0);
  box-shadow: 0 12px 22px rgba(0, 0, 0, 0.16);
}

.company__phrases {
  border-radius: 8px;
  border: 1px solid var(--glass-border);
  background: rgba(255, 255, 255, 0.5);
  padding: 8px;
  display: grid;
  gap: 10px;
}

.company__phrases[data-phrase-list] .company__phrases-list:empty::before {
  content: "";
  display: block;
  height: 14px;
  background:
    linear-gradient(90deg, rgba(15, 23, 42, 0.12), transparent),
    radial-gradient(circle at 8px 7px, rgba(15, 23, 42, 0.14) 2px, transparent 3px);
  opacity: 0.55;
}

.company__phrases.company__phrases--pool[data-phrase-list] .company__phrases-list:empty::before {
  content: none;
  display: none;
}

.company__phrases-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
}

.company__phrases-title {
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text);
}

.company__phrases-hint {
  font-size: 10px;
  color: var(--muted);
  opacity: 0.6;
}

.company__phrases-list {
  list-style: none;
  display: grid;
  gap: 6px;
  padding: 0;
  margin: 0;
  min-height: 24px;
}

.company__phrases-list.is-dragover {
  outline: 2px dashed var(--accent);
  outline-offset: 4px;
  border-radius: var(--radius-sm);
}

.company__phrase-item {
  padding: 5px 8px;
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.65) 0%, rgba(205, 216, 227, 0.7) 100%);
  border: 1px solid var(--glass-border);
  color: var(--text);
  font-size: 11px;
  line-height: 1.3;
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: grab;
  transition: transform var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out);
}

.company__phrase-text {
  flex: 1;
  min-width: 0;
}

.company__phrase-delete {
  border: 0;
  background: transparent;
  color: var(--muted);
  width: 20px;
  height: 20px;
  border-radius: 6px;
  display: inline-grid;
  place-items: center;
  cursor: pointer;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: background var(--duration) var(--ease-out), color var(--duration) var(--ease-out);
}

.company__phrase-delete .fa-solid.fa-trash,
.company__phrase-delete .fa-regular.fa-trash {
  width: 12px;
  height: 12px;
}

.company__phrase-delete:hover {
  background: var(--nav-hover);
  color: var(--text);
}

body[data-theme="dark"] .company__phrase-item {
  background: linear-gradient(135deg, rgba(17, 38, 60, 0.72) 0%, rgba(42, 73, 98, 0.6) 100%);
}

body[data-theme="dark"] .company__phrases {
  background: rgba(17, 38, 60, 0.55);
}

.company__phrase-item:active {
  cursor: grabbing;
  transform: scale(0.99);
}

.company__phrases--mini {
  padding: 6px;
  background: rgba(255, 255, 255, 0.55);
}

body[data-theme="dark"] .company__phrases--mini {
  background: rgba(17, 38, 60, 0.6);
}

.company__fields {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.company__fields--developer {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.company__fields--developer .company__field {
  min-height: 48px;
  padding: 11px 8px;
  border-radius: 12px;
}

.company__fields--developer .company__field-label {
  display: block;
  width: 100%;
  text-align: center;
  font-size: 10px;
  letter-spacing: 0.1em;
  line-height: 1.2;
}

.company__field {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
  padding: 14px 10px;
  border-radius: var(--radius-md);
  border: 1px solid var(--accent-strong);
  background: linear-gradient(135deg, var(--silver-1) 0%, var(--accent-2) 100%);
  text-decoration: none;
  box-shadow: 0 12px 22px rgba(0, 0, 0, 0.1);
  transition: transform var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out), filter var(--duration) var(--ease-out);
}

.company__field-label {
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text);
}

.company__field-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

.board--contributi .board__row {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.board__head--contributi {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
}

.board__title {
  font-size: 14px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.board__head--developer {
  display: grid;
  gap: 6px;
  margin-bottom: 18px;
}

.board__head--developer .board__title,
.board__head--developer .board__subtitle {
  width: fit-content;
}

.board__subtitle {
  margin-top: 6px;
  font-size: 12px;
  color: var(--muted);
}

.board__add-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}

.board__head-actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.contributi-overview-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 12px;
}

.board--contributi-overview .board__panel {
  overflow: visible;
}

.contributi-overview-sticky {
  position: sticky;
  top: 0;
  z-index: 12;
  margin: -18px -18px 12px;
  padding: 18px 18px 12px;
  border-radius: var(--radius-xl) var(--radius-xl) 0 0;
  background:
    linear-gradient(160deg, var(--glass-strong) 0%, var(--glass) 100%);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  border-bottom: 1px solid var(--glass-border);
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.08);
}

.contributi-overview-legend__item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: var(--muted);
}

.contributi-overview-groups {
  display: grid;
  gap: 14px;
}

.contributi-overview-group {
  position: relative;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  background: linear-gradient(160deg, var(--glass-strong) 0%, var(--glass) 100%);
  overflow: hidden;
}

.contributi-overview-group::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 5px;
  background: linear-gradient(180deg, var(--accent-strong) 0%, var(--accent-2) 100%);
  z-index: 1;
}

.contributi-overview-group__summary {
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 18px 14px 42px;
  position: relative;
}

.contributi-overview-group__summary::-webkit-details-marker {
  display: none;
}

.contributi-overview-group__summary::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 6px solid currentColor;
  opacity: 0.72;
  position: absolute;
  left: 18px;
  top: 20px;
  transition: transform var(--duration) var(--ease-out), opacity var(--duration) var(--ease-out);
}

.contributi-overview-group[open] .contributi-overview-group__summary::after {
  transform: rotate(180deg);
}

.contributi-overview-group__title {
  font-size: 13px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text);
}

.contributi-overview-group__count {
  margin-left: auto;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.contributi-status-dot {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: rgba(148, 163, 184, 0.35);
  box-shadow: 0 0 0 1px rgba(148, 163, 184, 0.2);
  display: inline-block;
}

.contributi-status-dot--active {
  background: #16a34a;
  box-shadow: 0 0 0 1px rgba(22, 163, 74, 0.25);
}

.contributi-status-dot--in-prescription {
  background: #c2410c;
  box-shadow: 0 0 0 1px rgba(194, 65, 12, 0.25);
}

.contributi-status-dot--concluded {
  background: #2563eb;
  box-shadow: 0 0 0 1px rgba(37, 99, 235, 0.25);
}

.contributi-status-dot--in-progress {
  background: #f59e0b;
  box-shadow: 0 0 0 1px rgba(245, 158, 11, 0.28);
}

.contributi-status-dot--expired,
.contributi-status-dot--discarded,
.contributi-status-dot--not-accepted {
  background: #dc2626;
  box-shadow: 0 0 0 1px rgba(220, 38, 38, 0.25);
}

.contributi-overview-table-wrap {
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  overflow: auto;
  background: linear-gradient(160deg, var(--glass-strong) 0%, var(--glass) 100%);
}

.contributi-overview-group .contributi-overview-table-wrap {
  border: none;
  border-top: 1px solid var(--glass-border);
  border-radius: 0;
}

.contributi-overview-table {
  width: 100%;
  min-width: 760px;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 11px;
}

.contributi-overview-table th,
.contributi-overview-table td {
  border-bottom: 1px solid var(--glass-border);
  border-right: 1px solid rgba(148, 163, 184, 0.2);
  padding: 8px;
  text-align: center;
  vertical-align: middle;
  background: rgba(255, 255, 255, 0.2);
  font-weight: 400;
}

.contributi-overview-table thead th {
  position: sticky;
  top: 0;
  z-index: 3;
  background: rgba(226, 232, 240, 0.92);
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text);
  min-width: 120px;
}

.contributi-overview-table__index-col,
.contributi-overview-table__index {
  width: 26px;
  min-width: 26px;
  max-width: 26px;
  padding-inline: 2px !important;
  font-size: 10px;
}

.contributi-overview-table__company-col,
.contributi-overview-table__company {
  position: sticky;
  left: 0;
  z-index: 2;
  text-align: left !important;
  min-width: 220px;
  max-width: 220px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.contributi-overview-table__company-col {
  z-index: 4;
}

.contributi-overview-table__company {
  font-size: 11px;
  color: var(--text);
  background: rgba(226, 232, 240, 0.9);
}

.contributi-overview-company-link {
  display: inline-flex;
  max-width: 100%;
  align-items: center;
  min-width: 0;
  color: inherit;
  text-decoration: none;
  border-radius: 8px;
  font-weight: 400;
  transition: color var(--duration) var(--ease-out), transform var(--duration) var(--ease-out);
}

.contributi-overview-company-link:hover {
  color: var(--accent);
  transform: translateX(1px);
}

.contributi-overview-company-link:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 2px;
}

.contributi-overview-cell {
  min-height: 28px;
  min-width: 36px;
  padding: 4px 6px;
  display: inline-grid;
  place-items: center;
  border-radius: 9px;
  border: 1px solid rgba(148, 163, 184, 0.35);
  background: rgba(255, 255, 255, 0.5);
  transition: transform var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out);
}

.contributi-overview-cell__dots {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 4px;
  max-width: 60px;
  line-height: 0;
}

.contributi-overview-cell:hover {
  transform: translateY(-1px);
  border-color: var(--accent);
  box-shadow: 0 10px 20px rgba(15, 23, 42, 0.12);
}

.contributi-overview-cell:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 2px;
}

.contributi-overview-empty {
  color: var(--muted);
  font-size: 14px;
}

body[data-theme="dark"] .contributi-overview-table th,
body[data-theme="dark"] .contributi-overview-table td {
  background: rgba(15, 23, 42, 0.32);
}

body[data-theme="dark"] .contributi-overview-table thead th,
body[data-theme="dark"] .contributi-overview-table__company-col,
body[data-theme="dark"] .contributi-overview-table__company {
  background: rgba(15, 23, 42, 0.86);
}

body[data-theme="dark"] .contributi-overview-sticky {
  box-shadow: 0 14px 26px rgba(2, 8, 23, 0.32);
}

.contributi-filters {
  margin-bottom: 0;
  border-radius: var(--radius-lg);
  border: 1px solid transparent;
  background:
    radial-gradient(circle at 92% 0%, rgba(34, 211, 238, 0.16) 0%, transparent 40%),
    linear-gradient(165deg, var(--glass-strong) 0%, var(--glass) 100%);
  box-shadow: none;
  padding: 0 12px;
  max-height: 0;
  opacity: 0;
  transform: translateY(-8px);
  overflow: hidden;
  visibility: hidden;
  pointer-events: none;
  transition:
    max-height 300ms cubic-bezier(0.22, 1, 0.36, 1),
    opacity 220ms cubic-bezier(0.22, 1, 0.36, 1),
    transform 300ms cubic-bezier(0.22, 1, 0.36, 1),
    padding 300ms cubic-bezier(0.22, 1, 0.36, 1),
    margin 300ms cubic-bezier(0.22, 1, 0.36, 1),
    border-color 280ms cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 300ms cubic-bezier(0.22, 1, 0.36, 1),
    visibility 0ms linear 300ms;
}

.contributi-filters.is-open {
  margin-bottom: 12px;
  padding: 10px 12px;
  max-height: var(--contributi-filters-height, 560px);
  opacity: 1;
  transform: translateY(0);
  overflow: visible;
  border-color: var(--glass-border);
  box-shadow: 0 14px 30px rgba(15, 23, 42, 0.12);
  visibility: visible;
  pointer-events: auto;
  transition:
    max-height 300ms cubic-bezier(0.22, 1, 0.36, 1),
    opacity 220ms cubic-bezier(0.22, 1, 0.36, 1),
    transform 300ms cubic-bezier(0.22, 1, 0.36, 1),
    padding 300ms cubic-bezier(0.22, 1, 0.36, 1),
    margin 300ms cubic-bezier(0.22, 1, 0.36, 1),
    border-color 280ms cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 300ms cubic-bezier(0.22, 1, 0.36, 1),
    visibility 0ms linear 0ms;
}

body[data-theme="dark"] .contributi-filters {
  background:
    radial-gradient(circle at 92% 0%, rgba(34, 211, 238, 0.14) 0%, transparent 40%),
    linear-gradient(165deg, rgba(16, 30, 52, 0.82) 0%, rgba(10, 22, 38, 0.9) 100%);
}

.contributi-filters__form {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr)) auto;
  gap: 8px;
  align-items: end;
}

.contributi-filters__field {
  margin: 0;
  gap: 3px;
}

.contributi-filters__field > span {
  line-height: 1.05;
}

.contributi-filters__field select,
.contributi-filters__field .filter-combobox__control {
  min-height: 34px;
}

.contributi-filters__field select {
  padding-top: 6px;
  padding-bottom: 6px;
}

.contributi-filters__field .filter-combobox__control {
  padding-left: 10px;
  padding-right: 4px;
}

.contributi-filters__field .filter-combobox__input {
  height: 32px;
  padding-top: 6px;
  padding-bottom: 6px;
}

.contributi-filters__field .filter-combobox__toggle {
  width: 30px;
  height: 30px;
}

.contributi-filters__field .filter-combobox__menu {
  padding: 3px;
  border-radius: 11px;
}

.contributi-filters__field .filter-combobox__list {
  gap: 2px;
}

.contributi-filters__field .filter-combobox__option {
  padding: 7px 11px;
  border-radius: 8px;
  font-size: 12px;
  line-height: 1.15;
}

.contributi-filters__actions {
  margin-top: 0;
  gap: 8px;
  justify-content: flex-end;
  align-self: end;
}

.board--contributi .board__panel {
  display: flex;
  flex-direction: column;
}

.board--contributi .board__head--contributi {
  order: 1;
}

.board--contributi .contributi-filters {
  order: 2;
}

.board--contributi .contributi-dashboard {
  order: 3;
}

.board--contributi .board__panel > .board__subtitle {
  order: 4;
}

.board--contributi .board__row--contributi {
  order: 5;
}

.icon-svg {
  width: 16px;
  height: 16px;
  display: inline-block;
  flex: 0 0 auto;
  color: currentColor;
}

.icon-svg--plus {
  width: 15px;
  height: 15px;
}

.icon-svg--tool {
  width: 15px;
  height: 15px;
}

.contributi-dashboard {
  display: grid;
  grid-template-columns: minmax(360px, 1fr) minmax(540px, 1.35fr);
  gap: 10px;
  margin-bottom: 12px;
  align-items: stretch;
}

.contributi-chart-card {
  min-height: 248px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--glass-border);
  background:
    radial-gradient(circle at 8% 0%, rgba(34, 211, 238, 0.24) 0%, transparent 45%),
    linear-gradient(160deg, var(--glass-strong) 0%, var(--glass) 100%);
  box-shadow: 0 18px 36px rgba(15, 23, 42, 0.16);
  padding: 10px 12px 12px;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 8px;
}

body[data-theme="dark"] .contributi-chart-card {
  background:
    radial-gradient(circle at 8% 0%, rgba(34, 211, 238, 0.22) 0%, transparent 45%),
    linear-gradient(160deg, rgba(16, 30, 52, 0.84) 0%, rgba(10, 22, 38, 0.9) 100%);
}

.contributi-chart-card__head {
  display: grid;
  gap: 4px;
}

.contributi-chart-card__head h3 {
  margin: 0;
  font-size: 15px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.contributi-chart-card__head p {
  margin: 0;
  color: var(--muted);
  font-size: 11px;
  letter-spacing: 0.04em;
  line-height: 1.35;
}

.contributi-chart-card--financial {
  min-width: 0;
}

.contributi-chart-card--deadlines {
  min-width: 0;
}

.contributi-chart {
  height: 100%;
  min-height: 0;
  width: 100%;
}

.contributi-metric {
  height: 100%;
  min-height: 188px;
  border-radius: var(--radius-md);
  border: 1px solid var(--glass-border);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.22) 0%, rgba(148, 163, 184, 0.08) 100%);
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 6px;
  text-align: center;
  padding: 8px;
}

.contributi-metric--financial {
  align-content: start;
  justify-items: stretch;
  text-align: left;
  gap: 6px;
}

.contributi-metric__financial-list {
  width: 100%;
  display: grid;
  gap: 4px;
}

.contributi-metric__financial-list p {
  margin: 0;
  border-radius: var(--radius-sm);
  border: 1px solid var(--glass-border);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.3) 0%, rgba(148, 163, 184, 0.12) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.22);
  padding: 7px 10px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  letter-spacing: 0.03em;
  color: var(--muted);
  line-height: 1.15;
}

.contributi-metric__financial-list span {
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.contributi-metric__financial-list strong {
  color: var(--text);
  font-size: clamp(17px, 1.25vw, 22px);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.01em;
  line-height: 1.05;
}

.contributi-metric--financial .contributi-metric__hint {
  text-align: left;
  padding: 0 2px;
}

.contributi-metric__value {
  font-size: clamp(26px, 2.2vw, 36px);
  font-weight: 700;
  color: var(--text);
  letter-spacing: 0.02em;
}

.contributi-metric__hint {
  margin: 0;
  font-size: 10px;
  color: var(--muted);
  letter-spacing: 0.03em;
  line-height: 1.2;
}

.contributi-deadlines {
  height: 100%;
  min-height: 188px;
  border-radius: var(--radius-md);
  border: 1px solid var(--glass-border);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.18) 0%, rgba(148, 163, 184, 0.08) 100%);
  padding: 8px 10px;
  display: grid;
  gap: 4px;
  align-items: start;
  align-content: start;
  overflow-y: auto;
  overflow-x: hidden;
}

.contributi-deadlines-table {
  width: 100%;
  min-width: 700px;
  margin: 0;
  table-layout: auto;
  border-collapse: separate;
  border-spacing: 0 2px;
}

.contributi-deadlines-table thead th {
  text-align: left;
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  font-weight: 700;
  padding: 0 8px 3px;
  line-height: 1.25;
  white-space: normal;
  word-break: break-word;
  overflow-wrap: anywhere;
}

.contributi-deadlines-table tbody td {
  background: rgba(148, 163, 184, 0.12);
  border-top: 1px solid var(--glass-border);
  border-bottom: 1px solid var(--glass-border);
  padding: 6px 8px;
  font-size: 11px;
  letter-spacing: 0.02em;
  vertical-align: middle;
  line-height: 1.15;
}

.contributi-deadlines-table tbody td:first-child {
  border-left: 1px solid var(--glass-border);
  border-top-left-radius: var(--radius-sm);
  border-bottom-left-radius: var(--radius-sm);
}

.contributi-deadlines-table tbody td:last-child {
  border-right: 1px solid var(--glass-border);
  border-top-right-radius: var(--radius-sm);
  border-bottom-right-radius: var(--radius-sm);
}

.contributi-deadlines-table thead th:first-child,
.contributi-deadlines-table tbody td:first-child {
  width: 240px;
  text-align: left;
}

.contributi-deadlines-table thead th:not(:first-child),
.contributi-deadlines-table tbody td:not(:first-child) {
  width: 170px;
  text-align: center;
}

.contributi-deadlines-table__name {
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--text);
  font-weight: 700;
}

.contributi-deadlines-table__date {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 2px 7px;
  font-size: 10px;
  letter-spacing: 0.03em;
  white-space: nowrap;
  line-height: 1.1;
}

.contributi-deadlines-table tbody td:not(:first-child) .contributi-deadlines-table__date {
  margin: 0 auto;
}

.contributi-deadlines-table__date--value {
  color: #991b1b;
  border: 1px solid rgba(220, 38, 38, 0.42);
  background: rgba(254, 226, 226, 0.75);
  font-weight: 700;
}

.contributi-deadlines-table__date--empty {
  color: var(--muted);
  border: 1px solid rgba(148, 163, 184, 0.28);
  background: rgba(148, 163, 184, 0.12);
  font-weight: 600;
}

body[data-theme="dark"] .contributi-deadlines-table__date--value {
  color: #fecaca;
  border-color: rgba(248, 113, 113, 0.42);
  background: rgba(127, 29, 29, 0.35);
}

@media (max-width: 1024px) {
  .contributi-deadlines {
    overflow-x: auto;
  }

  .contributi-deadlines-table {
    min-width: 620px;
    margin: 0;
  }
}

.contributi-deadlines__item {
  border-radius: var(--radius-sm);
  border: 1px solid var(--glass-border);
  background: rgba(148, 163, 184, 0.1);
}

.contributi-deadlines__row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  padding: 7px 9px;
}

.contributi-deadlines__summary {
  list-style: none;
  cursor: pointer;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  padding: 7px 9px;
}

.contributi-deadlines__summary::-webkit-details-marker {
  display: none;
}

.contributi-deadlines__name {
  font-size: 11px;
  letter-spacing: 0.03em;
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.contributi-deadlines__date {
  font-size: 10px;
  color: var(--muted);
  letter-spacing: 0.03em;
  white-space: nowrap;
}

.contributi-deadlines__date--alert {
  color: #991b1b;
  border: 1px solid rgba(220, 38, 38, 0.42);
  background: rgba(254, 226, 226, 0.75);
  border-radius: 999px;
  padding: 2px 9px;
  font-weight: 700;
  letter-spacing: 0.02em;
}

body[data-theme="dark"] .contributi-deadlines__date--alert {
  color: #fecaca;
  border-color: rgba(248, 113, 113, 0.42);
  background: rgba(127, 29, 29, 0.35);
}

.contributi-deadlines__content {
  padding: 0 9px 7px;
  font-size: 10px;
  color: var(--muted);
}

.contributi-deadlines__empty {
  margin: 0;
  font-size: 11px;
  color: var(--muted);
  padding: 6px;
}

.board__row--contributi {
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  align-items: start;
}

.board--contributi .company--contributi {
  min-height: 0;
  padding: 16px;
  gap: 10px;
  align-self: start;
}

.board--contributi .company__content {
  display: grid;
  gap: 4px;
}

.board--contributi .company__content h2 {
  text-transform: none;
  letter-spacing: 0.05em;
  font-size: 14px;
}

.board--contributi .company__meta--contributi {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.board--contributi .company__meta-chip {
  border-radius: 999px;
  border: 1px solid var(--glass-border);
  background: rgba(148, 163, 184, 0.2);
  color: var(--muted);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 5px 9px;
}

.board--contributi .company__tools--contributi {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

.board--contributi .company__tool-btn {
  width: 32px;
  height: 32px;
  border-radius: 10px;
  border: 1px solid var(--glass-border);
  background: linear-gradient(160deg, var(--glass-strong) 0%, var(--glass) 100%);
  color: var(--text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: transform var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out), background var(--duration) var(--ease-out);
}

.board--contributi .company__tool-btn .icon-svg,
.board--contributi .company__tool-btn .fa-solid.fa-trash,
.board--contributi .company__tool-btn .fa-regular.fa-trash,
.board--contributi .company__tool-btn .fa-pencil {
  color: currentColor;
}

.board--contributi .company__tool-btn:hover {
  transform: translateY(-1px);
  border-color: var(--accent);
  box-shadow: 0 10px 18px rgba(15, 23, 42, 0.16);
}

.board--contributi .company__tool-btn:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 2px;
}

.board--contributi .company__tool-btn--danger {
  border-color: rgba(239, 68, 68, 0.4);
  background: linear-gradient(160deg, rgba(239, 68, 68, 0.18) 0%, rgba(239, 68, 68, 0.1) 100%);
}

.board--contributi .company__tool-btn--danger:hover {
  border-color: rgba(239, 68, 68, 0.65);
  background: linear-gradient(160deg, rgba(239, 68, 68, 0.26) 0%, rgba(239, 68, 68, 0.14) 100%);
}

.board--contributi .company__tool-btn--disabled,
.board--contributi .company__tool-btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  pointer-events: none;
}

.board--contributi .company__fields {
  grid-template-columns: 1fr;
}

.board--contributi .company__field {
  width: 100%;
  justify-content: center;
  gap: 10px;
  padding: 14px 16px;
  text-align: center;
}

.board--contributi .company__field-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.board--contributi .company__field-icon .icon-svg--github {
  width: 18px;
  height: 18px;
}

.board--contributi .company__field-label {
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: none;
  text-align: center;
}

.board--contributi .company__field--internal {
  background: linear-gradient(145deg, rgba(34, 211, 238, 0.28) 0%, rgba(14, 116, 144, 0.2) 100%);
  border-color: rgba(6, 182, 212, 0.52);
}

.board--contributi .company__progress {
  display: grid;
  gap: 6px;
}

.board--contributi .company__progress-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--muted);
  text-transform: uppercase;
}

.board--contributi .company__progress-track {
  display: block;
  width: 100%;
  height: 8px;
  border-radius: 999px;
  border: 1px solid var(--glass-border);
  background: rgba(148, 163, 184, 0.24);
  overflow: hidden;
}

.board--contributi .company__progress-fill {
  display: block;
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, #22d3ee 0%, #0ea5e9 100%);
}

.board--contributi .company__economics-box {
  display: grid;
  gap: 6px;
}

.board--contributi .company__economics-title {
  margin: 0;
  border: 0;
  background: none;
  color: var(--muted);
  font-size: 11px;
  letter-spacing: 0.04em;
  padding: 0;
  text-transform: uppercase;
  font-weight: 600;
}

.board--contributi .company__economics-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 6px;
}

.board--contributi .company__economics-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  background: rgba(148, 163, 184, 0.1);
  padding: 7px 9px;
}

.board--contributi .company__economics-label {
  font-size: 11px;
  color: var(--muted);
  letter-spacing: 0.03em;
}

.board--contributi .company__economics-value {
  font-size: 11px;
  color: var(--text);
  letter-spacing: 0.03em;
  white-space: nowrap;
}

.board--contributi .company__deadline-title {
  margin: 0;
  border-radius: var(--radius-md);
  border: 1px solid var(--glass-border);
  background: rgba(148, 163, 184, 0.16);
  color: var(--text);
  font-size: 11px;
  letter-spacing: 0.04em;
  padding: 9px 10px;
}

.board--contributi .company__deadline-title.company__deadline-title--alert {
  border-color: rgba(239, 68, 68, 0.35);
  background: linear-gradient(165deg, rgba(254, 226, 226, 0.62) 0%, rgba(254, 202, 202, 0.46) 100%);
  color: #7f1d1d;
}

body[data-theme="dark"] .board--contributi .company__deadline-title.company__deadline-title--alert {
  border-color: rgba(248, 113, 113, 0.42);
  background: linear-gradient(165deg, rgba(127, 29, 29, 0.4) 0%, rgba(69, 10, 10, 0.34) 100%);
  color: #fecaca;
}

.board--contributi .company__deadline-box {
  display: grid;
  gap: 6px;
}

.board--contributi .company__deadline-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 5px;
}

.board--contributi .company__deadline-item {
  border-radius: var(--radius-sm);
  border: 1px solid var(--glass-border);
  background: rgba(148, 163, 184, 0.12);
  padding: 7px 8px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
}

.board--contributi .company__deadline-item.company__deadline-item--alert {
  border-color: rgba(239, 68, 68, 0.35);
  background: linear-gradient(165deg, rgba(254, 226, 226, 0.56) 0%, rgba(254, 202, 202, 0.4) 100%);
}

.board--contributi .company__deadline-item.company__deadline-item--alert .company__deadline-label,
.board--contributi .company__deadline-item.company__deadline-item--alert .company__deadline-date {
  color: #7f1d1d;
}

body[data-theme="dark"] .board--contributi .company__deadline-item.company__deadline-item--alert {
  border-color: rgba(248, 113, 113, 0.42);
  background: linear-gradient(165deg, rgba(127, 29, 29, 0.38) 0%, rgba(69, 10, 10, 0.32) 100%);
}

body[data-theme="dark"] .board--contributi .company__deadline-item.company__deadline-item--alert .company__deadline-label,
body[data-theme="dark"] .board--contributi .company__deadline-item.company__deadline-item--alert .company__deadline-date {
  color: #fecaca;
}

.board--contributi .company__deadline-label {
  min-width: 0;
  font-size: 11px;
  color: var(--muted);
  letter-spacing: 0.03em;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.board--contributi .company__deadline-date {
  font-size: 11px;
  color: var(--text);
  letter-spacing: 0.03em;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.board--contributi .company__deadline-empty {
  margin: 0;
  border-radius: var(--radius-sm);
  border: 1px dashed var(--glass-border);
  background: rgba(148, 163, 184, 0.08);
  color: var(--muted);
  font-size: 11px;
  letter-spacing: 0.03em;
  padding: 7px 8px;
}

.agevolazione-modal__panel {
  width: min(760px, calc(100% - 32px));
}

.agevolazione-form__error {
  margin: 0;
  border-radius: var(--radius-md);
  border: 1px solid rgba(239, 68, 68, 0.45);
  background: rgba(239, 68, 68, 0.12);
  color: #b91c1c;
  padding: 8px 10px;
  font-size: 12px;
  letter-spacing: 0.02em;
}

.company__field:hover {
  transform: translateY(-1px);
  filter: brightness(1.04);
  box-shadow: 0 14px 24px rgba(0, 0, 0, 0.14);
}

.company__field--disabled {
  background: linear-gradient(135deg, rgba(148, 163, 184, 0.45) 0%, rgba(148, 163, 184, 0.2) 100%);
  border-color: rgba(148, 163, 184, 0.45);
  box-shadow: none;
  opacity: 0.7;
  cursor: default;
  pointer-events: none;
}

.company__field--disabled:hover {
  transform: none;
  filter: none;
  box-shadow: none;
}

.company__field:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 2px;
}

.company__field.is-ok {
  background: linear-gradient(135deg, rgba(14, 165, 233, 0.32) 0%, rgba(14, 165, 233, 0.16) 100%);
  box-shadow: inset 0 0 0 2px rgba(14, 165, 233, 0.6), 0 16px 26px rgba(38, 50, 56, 0.16);
}

.company__field.is-ok .company__field-label {
  color: var(--text);
}

.company__field.is-alert {
  background: linear-gradient(135deg, rgba(239, 68, 68, 0.26) 0%, rgba(239, 68, 68, 0.14) 100%);
  box-shadow: inset 0 0 0 2px rgba(239, 68, 68, 0.5), 0 16px 26px rgba(38, 50, 56, 0.18);
}

.company__field.is-alert .company__field-label {
  color: var(--text);
}

.company__deadlines {
  margin-top: 6px;
  padding: 12px 10px;
  border-radius: var(--radius-md);
  border: 1px solid var(--glass-border);
  background: linear-gradient(135deg, rgba(148, 163, 184, 0.35) 0%, rgba(148, 163, 184, 0.18) 100%);
  color: var(--muted);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-align: center;
  cursor: default;
  width: 100%;
  font: inherit;
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  position: relative;
}

body[data-theme="dark"] .company__deadlines {
  background: linear-gradient(135deg, rgba(42, 73, 98, 0.4) 0%, rgba(17, 38, 60, 0.35) 100%);
}

body[data-theme="dark"] .company__deadlines--ok {
  background: linear-gradient(135deg, rgba(14, 165, 233, 0.28) 0%, rgba(11, 94, 136, 0.26) 100%);
  border-color: rgba(56, 189, 248, 0.34);
  color: #e0f2fe;
}

body[data-theme="dark"] .company__deadlines--empty {
  background: linear-gradient(135deg, rgba(127, 29, 29, 0.42) 0%, rgba(69, 10, 10, 0.32) 100%);
  border-color: rgba(248, 113, 113, 0.3);
  color: #fee2e2;
}

.company__deadlines-wrap {
  display: grid;
  gap: 6px;
}

.company__deadlines--ok {
  background: linear-gradient(135deg, rgba(14, 165, 233, 0.32) 0%, rgba(14, 165, 233, 0.16) 100%);
  border-color: rgba(14, 165, 233, 0.45);
  color: var(--text);
  box-shadow: inset 0 0 0 2px rgba(14, 165, 233, 0.45), 0 12px 20px rgba(14, 165, 233, 0.18);
  cursor: pointer;
}

.company__deadlines--empty {
  background: linear-gradient(135deg, rgba(239, 68, 68, 0.26) 0%, rgba(239, 68, 68, 0.14) 100%);
  border-color: rgba(239, 68, 68, 0.45);
  color: var(--text);
  box-shadow: inset 0 0 0 2px rgba(239, 68, 68, 0.4), 0 12px 20px rgba(239, 68, 68, 0.16);
  cursor: default;
}

.company__deadlines--empty[disabled] {
  opacity: 1;
}

.company__deadlines--alert {
  background: linear-gradient(135deg, rgba(251, 191, 36, 0.45) 0%, rgba(249, 115, 22, 0.35) 100%);
  border-color: rgba(234, 179, 8, 0.55);
  color: #3a2500;
  box-shadow: inset 0 0 0 1px rgba(234, 179, 8, 0.45), 0 12px 20px rgba(234, 179, 8, 0.22);
  cursor: pointer;
}

body[data-theme="dark"] .company__deadlines--alert {
  background: linear-gradient(135deg, rgba(180, 83, 9, 0.5) 0%, rgba(146, 64, 14, 0.38) 100%);
  border-color: rgba(251, 191, 36, 0.42);
  color: #f8e7b0;
  box-shadow: inset 0 0 0 1px rgba(251, 191, 36, 0.35), 0 12px 20px rgba(180, 83, 9, 0.28);
}

.company__deadlines-caret {
  width: 0;
  height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid currentColor;
  opacity: 0.65;
  display: none;
} 

.company__deadlines--ok .company__deadlines-caret,
.company__deadlines--alert .company__deadlines-caret {
  display: inline-block;
}

.company__deadlines[aria-expanded="true"] .company__deadlines-caret {
  transform: rotate(180deg);
}

.company__deadlines-badge {
  position: absolute;
  top: -6px;
  right: -6px;
  min-width: 18px;
  height: 18px;
  padding: 0 4px;
  border-radius: 999px;
  border: 1px solid rgba(220, 38, 38, 0.65);
  background: #ef4444;
  color: #fff;
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: none;
  display: grid;
  place-items: center;
  line-height: 1;
  font-variant-numeric: tabular-nums;
  box-shadow: 0 6px 12px rgba(239, 68, 68, 0.35);
}

.company__deadlines-badge[hidden] {
  display: none;
}

.company__deadlines-menu {
  border-radius: var(--radius-md);
  border: 1px solid var(--glass-border);
  background: rgba(255, 255, 255, 0.55);
  padding: 8px;
  display: grid;
  gap: 6px;
  text-align: left;
}

body[data-theme="dark"] .company__deadlines-menu {
  background: rgba(17, 38, 60, 0.55);
}

.company__deadlines-menu[hidden] {
  display: none;
}

.company__deadlines-link {
  display: block;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text);
  text-decoration: none;
}

.company__deadlines-link:hover {
  color: var(--accent-strong);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.company__deadlines-link--alert {
  color: #b91c1c;
  font-weight: 700;
}

body[data-theme="dark"] .company__deadlines-link--alert {
  color: #fca5a5;
}

.company__field.is-pending {
  opacity: 0.8;
  filter: saturate(0.92);
}

.company__field.is-unknown {
  opacity: 0.85;
}

.board--contributi-detail .board__panel {
  display: grid;
  gap: 10px;
}

.agevolazione-detail__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
  border-bottom: 1px solid var(--glass-border);
  padding-bottom: 10px;
}

html.js [data-agevolazione-enter],
html.js .agevolazione-enter-step {
  opacity: 0;
  transform: translate3d(0, 12px, 0);
  transition:
    opacity var(--duration-slow) var(--ease-soft),
    transform var(--duration-slow) var(--ease-soft);
  transition-delay: calc(var(--stagger, 0) * 55ms);
}

html.js [data-agevolazione-enter].is-visible,
html.js .agevolazione-enter-step.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

body.is-page-entering html.js [data-agevolazione-enter].is-visible,
body.is-page-entering html.js .agevolazione-enter-step.is-visible,
body.is-post-login-entering html.js [data-agevolazione-enter].is-visible,
body.is-post-login-entering html.js .agevolazione-enter-step.is-visible {
  transition: none;
}

.agevolazione-detail__headline {
  display: grid;
  gap: 2px;
}

.agevolazione-detail__title-row {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.agevolazione-detail__headline h2 {
  margin: 0;
  font-size: 18px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.agevolazione-info-toggle {
  min-height: 28px;
  padding: 3px 9px 3px 5px;
  border-radius: 999px;
  border: 1px solid var(--glass-border);
  background: rgba(148, 163, 184, 0.12);
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 6px;
  cursor: pointer;
  transition: color var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out), background var(--duration) var(--ease-out), transform var(--duration) var(--ease-out);
}

.agevolazione-info-toggle__glyph {
  width: 16px;
  height: 16px;
  border-radius: 999px;
  border: 1px solid currentColor;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
}

.agevolazione-info-toggle__text {
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-weight: 600;
}

.agevolazione-info-toggle:hover {
  color: var(--text);
  border-color: rgba(59, 130, 246, 0.45);
  background: rgba(59, 130, 246, 0.1);
  transform: translateY(-1px);
}

.agevolazione-info-toggle.is-open {
  color: var(--text);
  border-color: rgba(59, 130, 246, 0.55);
  background: rgba(59, 130, 246, 0.16);
}

.agevolazione-detail__headline p {
  margin: 0;
  color: var(--muted);
  font-size: 11px;
}

.agevolazione-detail__form {
  display: grid;
  gap: 10px;
}

.agevolazione-detail__info-panel {
  border-radius: var(--radius-lg);
  border: 1px solid transparent;
  background: rgba(148, 163, 184, 0.08);
  padding: 0 8px;
  max-height: 0;
  opacity: 0;
  transform: translate3d(0, -8px, 0);
  overflow: hidden;
  visibility: hidden;
  pointer-events: none;
  transition:
    max-height 300ms cubic-bezier(0.22, 1, 0.36, 1),
    opacity 220ms cubic-bezier(0.22, 1, 0.36, 1),
    transform 300ms cubic-bezier(0.22, 1, 0.36, 1),
    padding 300ms cubic-bezier(0.22, 1, 0.36, 1),
    border-color 260ms cubic-bezier(0.22, 1, 0.36, 1),
    visibility 0ms linear 300ms;
}

.agevolazione-detail__info-panel.is-open {
  border-color: var(--glass-border);
  padding: 6px 8px;
  max-height: 800px;
  opacity: 1;
  transform: translate3d(0, 0, 0);
  visibility: visible;
  pointer-events: auto;
  transition:
    max-height 300ms cubic-bezier(0.22, 1, 0.36, 1),
    opacity 220ms cubic-bezier(0.22, 1, 0.36, 1),
    transform 300ms cubic-bezier(0.22, 1, 0.36, 1),
    padding 300ms cubic-bezier(0.22, 1, 0.36, 1),
    border-color 260ms cubic-bezier(0.22, 1, 0.36, 1),
    visibility 0ms linear 0ms;
}

.agevolazione-detail__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
}

.agevolazione-detail__grid .agevolazione-detail__field {
  align-self: start;
}

.agevolazione-detail__field--status select {
  min-height: 34px;
}

.agevolazione-detail__field--companies .account-multi-check {
  min-height: 96px;
  max-height: 96px;
}

.agevolazione-detail__field--investment {
  grid-column: 1 / -1;
}

.board--contributi-detail .agevolazione-detail__info-panel {
  background: linear-gradient(160deg, rgba(148, 163, 184, 0.13) 0%, rgba(148, 163, 184, 0.09) 100%);
  border-color: rgba(31, 77, 122, 0.2);
}

.board--contributi-detail .agevolazione-detail__info-panel:not(.is-open) {
  border-color: transparent;
}

.board--contributi-detail .agevolazione-detail__info-panel .account-field input,
.board--contributi-detail .agevolazione-detail__info-panel .account-field select,
.board--contributi-detail .agevolazione-detail__info-panel .account-field textarea {
  background: rgba(255, 255, 255, 0.78);
  border-color: rgba(31, 77, 122, 0.26);
}

.board--contributi-detail .agevolazione-detail__info-panel .account-field {
  gap: 3px;
}

.board--contributi-detail .agevolazione-detail__info-panel .account-field > span {
  line-height: 1.05;
}

.board--contributi-detail .agevolazione-detail__info-panel .account-field input,
.board--contributi-detail .agevolazione-detail__info-panel .account-field select {
  min-height: 34px;
  padding-top: 6px;
  padding-bottom: 6px;
}

.board--contributi-detail .agevolazione-detail__info-panel .account-multi-check {
  background: rgba(255, 255, 255, 0.7);
  border-color: rgba(31, 77, 122, 0.24);
  padding: 4px;
  gap: 2px;
}

.board--contributi-detail .agevolazione-detail__info-panel .account-multi-check__item {
  padding: 4px 6px;
  font-size: 11px;
  min-height: 24px;
}

.board--contributi-detail .agevolazione-detail__info-panel .account-multi-check__item input[type="checkbox"] {
  width: 14px;
  height: 14px;
}

.board--contributi-detail .agevolazione-detail__info-panel .account-field small {
  font-size: 9px;
  line-height: 1.15;
}

.agevolazione-detail-dashboard {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.agevolazione-detail-card {
  min-width: 0;
  min-height: 218px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--glass-border);
  background:
    radial-gradient(circle at 8% 0%, rgba(34, 211, 238, 0.24) 0%, transparent 45%),
    linear-gradient(160deg, var(--glass-strong) 0%, var(--glass) 100%);
  box-shadow: 0 18px 36px rgba(15, 23, 42, 0.16);
  padding: 8px;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 8px;
}

.agevolazione-detail-card__head {
  display: grid;
  gap: 4px;
}

.agevolazione-detail-card__head h3 {
  margin: 0;
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.agevolazione-detail-card__head p {
  margin: 0;
  color: var(--muted);
  font-size: 11px;
  letter-spacing: 0.04em;
}

.agevolazione-detail-card__metric-shell,
.agevolazione-detail-card__timeline-shell,
.agevolazione-detail-card__progress-shell {
  height: 100%;
  min-height: 154px;
  border-radius: var(--radius-md);
  border: 1px solid var(--glass-border);
  background: rgba(148, 163, 184, 0.1);
  padding: 7px;
}

.agevolazione-detail-card__metric-shell {
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 5px;
  text-align: center;
}

.agevolazione-detail-card__metric-shell--financial {
  align-content: start;
  justify-items: stretch;
  text-align: left;
}

.agevolazione-detail-card__timeline-shell {
  background: rgba(148, 163, 184, 0.08);
  padding: 8px;
}

.agevolazione-detail-card__progress-shell {
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 5px;
}

.agevolazione-detail-card__metric {
  text-align: center;
  font-size: clamp(26px, 2.2vw, 36px);
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--text);
}

.agevolazione-detail-card__metric-hint {
  margin: 0;
  font-size: 10px;
  color: var(--muted);
  letter-spacing: 0.03em;
}

.agevolazione-detail-card__financial-list {
  width: min(100%, 760px);
  display: grid;
  gap: 4px;
}

.agevolazione-detail-card__financial-list p {
  margin: 0;
  border-radius: var(--radius-sm);
  border: 1px solid var(--glass-border);
  background: rgba(148, 163, 184, 0.12);
  padding: 8px 10px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  letter-spacing: 0.03em;
  color: var(--muted);
}

.agevolazione-detail-card__financial-list strong {
  color: var(--text);
  font-size: clamp(17px, 1.4vw, 22px);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.01em;
}

.agevolazione-detail-card__progress-value {
  text-align: center;
  font-size: 20px;
  font-weight: 700;
  color: var(--text);
}

.agevolazione-detail-card__chart {
  width: 100%;
  height: 100%;
  min-height: 146px;
  overflow: auto;
}

.agevolazione-detail-card__chart--small {
  width: 126px;
  height: 126px;
  min-height: 126px;
  margin: 0 auto;
  overflow: hidden;
  border-radius: 999px;
}

.agevolazione-detail-card__chart--progress {
  position: relative;
  display: grid;
  place-items: center;
  background:
    conic-gradient(
      from -90deg,
      var(--progress-accent, var(--accent-strong)) 0,
      var(--progress-accent-strong, var(--accent)) calc(var(--progress-percent, 0) * 1%),
      var(--progress-track, rgba(148, 163, 184, 0.18)) 0
    );
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.28),
    0 18px 36px rgba(15, 23, 42, 0.08);
}

.agevolazione-detail-card__chart--progress::before {
  content: "";
  position: absolute;
  inset: 12px;
  border-radius: 999px;
  background:
    linear-gradient(160deg, rgba(248, 250, 252, 0.96) 0%, rgba(233, 239, 246, 0.92) 100%);
  border: 1px solid rgba(148, 163, 184, 0.18);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.agevolazione-detail-card__chart--progress .agevolazione-detail-card__progress-value {
  position: relative;
  z-index: 1;
}

.agevolazione-detail-timeline-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 5px;
}

.agevolazione-detail-timeline-item {
  border-radius: var(--radius-sm);
  border: 1px solid var(--glass-border);
  background: rgba(148, 163, 184, 0.1);
  padding: 8px 10px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
}

.agevolazione-detail-timeline-label {
  min-width: 0;
  font-size: 11px;
  color: var(--text);
  letter-spacing: 0.03em;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.agevolazione-detail-timeline-date {
  font-size: 10px;
  color: var(--muted);
  letter-spacing: 0.03em;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.agevolazione-detail-timeline-item--alert {
  border-color: rgba(239, 68, 68, 0.35);
  background: linear-gradient(165deg, rgba(254, 226, 226, 0.56) 0%, rgba(254, 202, 202, 0.4) 100%);
}

.agevolazione-detail-timeline-item--alert .agevolazione-detail-timeline-label,
.agevolazione-detail-timeline-item--alert .agevolazione-detail-timeline-date {
  color: #7f1d1d;
}

.agevolazione-detail-timeline-empty {
  margin: 0;
  border-radius: var(--radius-sm);
  border: 1px dashed var(--glass-border);
  background: rgba(148, 163, 184, 0.08);
  color: var(--muted);
  font-size: 12px;
  letter-spacing: 0.03em;
  padding: 8px 10px;
}

.board--contributi-detail .agevolazione-detail-card {
  border-color: var(--glass-border);
}

.agevolazione-checklist {
  border-radius: var(--radius-lg);
  border: 1px solid var(--glass-border);
  background: linear-gradient(165deg, var(--glass-strong) 0%, var(--glass) 100%);
  padding: 10px;
  display: grid;
  gap: 8px;
}

.board--contributi-detail .agevolazione-checklist {
  background: linear-gradient(165deg, rgba(248, 250, 252, 0.92) 0%, rgba(239, 244, 249, 0.86) 100%);
  border-color: rgba(31, 77, 122, 0.16);
}

.agevolazione-checklist__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 8px;
}

.agevolazione-checklist__head h3 {
  margin: 0;
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.agevolazione-checklist__head p {
  margin: 2px 0 0;
  color: var(--muted);
  font-size: 10px;
}

.agevolazione-checklist__add {
  display: inline-flex;
  align-items: center;
  gap: 7px;
}

.agevolazione-checklist__stats {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.agevolazione-checklist__chip {
  border-radius: 999px;
  border: 1px solid var(--glass-border);
  background: rgba(148, 163, 184, 0.2);
  padding: 4px 8px;
  font-size: 10px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--muted);
}

.agevolazione-checklist__chip strong {
  color: var(--text);
}

.agevolazione-checklist__items {
  display: grid;
  gap: 6px;
}

/* Forza la visibilita progressiva: i blocchi con attributo hidden restano nascosti. */
.agevolazione-checklist [hidden] {
  display: none !important;
}

.agevolazione-step {
  border-radius: var(--radius-md);
  border: 1px solid var(--glass-border);
  background: rgba(148, 163, 184, 0.1);
  padding: 8px;
  display: grid;
  gap: 6px;
}

.board--contributi-detail .agevolazione-step {
  background: rgba(148, 163, 184, 0.14);
}

.agevolazione-step__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 6px;
}

.agevolazione-step__title-actions {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.agevolazione-step__discard-btn {
  border-color: rgba(239, 68, 68, 0.45);
  color: #991b1b;
  background: linear-gradient(160deg, rgba(254, 202, 202, 0.52) 0%, rgba(252, 165, 165, 0.22) 100%);
}

.agevolazione-step__discard-btn:hover {
  border-color: rgba(239, 68, 68, 0.62);
  background: linear-gradient(160deg, rgba(254, 202, 202, 0.62) 0%, rgba(252, 165, 165, 0.3) 100%);
}

.agevolazione-step__date {
  display: grid;
  grid-template-columns: auto minmax(150px, 220px);
  align-items: center;
  gap: 6px;
  font-size: 9px;
  font-weight: 400;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--muted);
}

.agevolazione-step__date--range {
  grid-template-columns: 1fr;
  min-width: min(100%, 430px);
  gap: 4px;
}

.agevolazione-step__date-row {
  display: grid;
  grid-template-columns: auto minmax(150px, 220px);
  align-items: center;
  gap: 6px;
}

.agevolazione-step__date-label {
  font-size: 9px;
  font-weight: 400;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--muted);
}

.agevolazione-step__date .agevolazione-task__hint {
  padding: 6px 8px;
  min-height: 36px;
  font-size: 13px;
}

.agevolazione-step__title {
  color: var(--muted);
  font-size: 10px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.agevolazione-financial {
  margin-top: 6px;
  padding: 6px;
  gap: 5px;
}

.agevolazione-financial__title {
  font-size: 13px;
  letter-spacing: 0.03em;
  text-transform: none;
  color: var(--text);
  font-weight: 700;
}

.agevolazione-financial .account-field {
  gap: 3px;
}

.agevolazione-financial .account-field input {
  min-height: 34px;
  padding: 6px 8px;
  font-size: 12px;
}

.agevolazione-financial .agevolazione-docs__head {
  gap: 4px;
}

.agevolazione-financial .agevolazione-step4__credits {
  margin-top: 4px;
  gap: 4px;
}

.agevolazione-financial .agevolazione-step4__credit-row {
  padding: 4px;
  gap: 4px;
}

.agevolazione-financial .agevolazione-task__hint {
  min-height: 34px;
  padding: 6px 8px;
  font-size: 12px;
}

.agevolazione-financial .agevolazione-step4__total {
  padding-top: 4px;
  font-size: 10px;
}

.agevolazione-step[data-step-id="step-3"] {
  padding: 6px;
  gap: 5px;
}

.agevolazione-step[data-step-id="step-3"] .agevolazione-step__head {
  gap: 4px;
}

.agevolazione-step[data-step-id="step-3"] .agevolazione-step__date--range {
  width: min(100%, 620px);
  min-width: min(100%, 620px);
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 4px 10px;
  align-items: start;
}

.agevolazione-step[data-step-id="step-3"] .agevolazione-step__date-row {
  min-width: 0;
  grid-template-columns: 1fr;
  align-items: start;
  gap: 2px;
}

.agevolazione-step[data-step-id="step-3"] .agevolazione-step__date-label {
  line-height: 1.2;
}

.agevolazione-step[data-step-id="step-3"] .agevolazione-step__date .agevolazione-task__hint {
  min-height: 34px;
  padding: 5px 8px;
  font-size: 12px;
}

.agevolazione-step[data-step-id="step-3"] .agevolazione-step__notes-field {
  gap: 3px;
}

.agevolazione-step[data-step-id="step-3"] .agevolazione-note-preview-btn {
  min-height: 54px;
  padding: 6px 8px;
}

.agevolazione-step__substeps {
  display: grid;
  gap: 6px;
}

.agevolazione-step4__options {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.agevolazione-step4__option {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--glass-border);
  background: rgba(148, 163, 184, 0.1);
  padding: 6px 8px;
  font-size: 11px;
}

.agevolazione-step4__accepted,
.agevolazione-step4__non-accepted {
  border-radius: var(--radius-sm);
  border: 1px solid var(--glass-border);
  background: rgba(148, 163, 184, 0.07);
  padding: 10px;
}

.agevolazione-step4__credits {
  margin-top: 6px;
  display: grid;
  gap: 6px;
}

.agevolazione-step4__total {
  margin: 0;
  border-top: 1px dashed var(--glass-border);
  padding-top: 6px;
  font-size: 11px;
  letter-spacing: 0.03em;
  color: var(--text);
  font-weight: 600;
}

.agevolazione-step4__credit-row {
  border-radius: var(--radius-sm);
  border: 1px dashed var(--glass-border);
  background: rgba(148, 163, 184, 0.06);
  padding: 6px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto;
  gap: 6px;
  align-items: center;
}

.agevolazione-step4__list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 6px;
}

.agevolazione-step4__list-item {
  display: grid;
  grid-template-columns: minmax(160px, 200px) minmax(0, 1fr);
  align-items: center;
  gap: 8px;
}

.agevolazione-step4__list-label {
  color: var(--text);
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.02em;
}

.agevolazione-step4__inline-range {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.agevolazione-step4__inline-label {
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 0.03em;
  color: var(--muted);
  text-transform: uppercase;
}

.agevolazione-step4__inline-range .agevolazione-task__hint {
  width: 136px;
  min-width: 0;
  min-height: 36px;
  padding: 8px 10px;
  font-size: 13px;
}

.agevolazione-step4__inline-note {
  width: min(360px, 100%);
  min-height: 36px;
  padding: 8px 10px;
  font-size: 13px;
}

.agevolazione-step4__richtext-field {
  display: grid;
  gap: 6px;
}

.agevolazione-step4__richtext-actions {
  display: grid;
  grid-template-columns: minmax(240px, 1fr) 136px minmax(0, 1fr);
  gap: 6px;
  align-items: center;
  width: 100%;
}

.agevolazione-note-field {
  display: grid;
  gap: 6px;
}

.agevolazione-note-source {
  display: none !important;
}

.agevolazione-note-preview-btn {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  width: 100%;
  min-height: 58px;
  padding: 6px 8px;
  border-radius: var(--radius-md);
  border: 1px solid var(--glass-border);
  background: var(--input-bg);
  cursor: pointer;
  text-align: left;
  font: inherit;
  color: inherit;
  transition:
    border-color var(--duration) var(--ease-out),
    box-shadow var(--duration) var(--ease-out),
    transform var(--duration) var(--ease-out),
    background var(--duration) var(--ease-out);
}

.agevolazione-note-preview-btn:hover {
  transform: translateY(-1px);
  border-color: var(--glass-border-strong);
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 12px 22px rgba(15, 23, 42, 0.08);
}

.agevolazione-note-preview-btn:focus-visible {
  outline: none;
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--focus);
}

.agevolazione-note-preview-btn--large {
  min-height: 82px;
}

.agevolazione-note-preview-btn--step {
  min-height: 72px;
}

.agevolazione-note-preview-btn--compact {
  min-height: 34px;
  padding: 6px 8px;
  align-items: center;
}

.agevolazione-note-preview {
  width: 100%;
  min-width: 0;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
  font-size: 12px;
  line-height: 1.32;
  color: var(--text);
  text-transform: none;
  letter-spacing: 0;
  white-space: normal;
  word-break: break-word;
}

.agevolazione-note-preview-btn--large .agevolazione-note-preview,
.agevolazione-note-preview-btn--step .agevolazione-note-preview {
  -webkit-line-clamp: 4;
}

.agevolazione-note-preview-btn--compact .agevolazione-note-preview {
  -webkit-line-clamp: 1;
  font-size: 12px;
  line-height: 1.25;
}

.agevolazione-note-preview.is-empty {
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: 10px;
}

.agevolazione-step4__attachment-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 38px;
  padding: 7px 12px;
  border-radius: var(--radius-md);
  border: 1px solid var(--glass-border);
  background: rgba(255, 255, 255, 0.18);
  color: var(--text);
  cursor: pointer;
  font: inherit;
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  transition: transform var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out), background var(--duration) var(--ease-out);
}

.agevolazione-step4__attachment-trigger:hover {
  transform: translateY(-1px);
  border-color: var(--glass-border-strong);
  background: rgba(255, 255, 255, 0.26);
}

.agevolazione-step4__attachment-trigger:focus-visible {
  outline: none;
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--focus);
}

.agevolazione-step4__attachment-trigger:disabled {
  cursor: progress;
  opacity: 0.72;
  transform: none;
}

.agevolazione-step4__attachment-list {
  display: grid;
  gap: 6px;
  min-width: 0;
  align-self: center;
}

.agevolazione-step4__attachment-empty {
  margin: 0;
  min-height: 32px;
  display: flex;
  align-items: center;
  color: var(--muted);
  font-size: 12px;
  letter-spacing: 0.02em;
}

.agevolazione-step4__attachment-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  padding: 8px 10px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--glass-border);
  background: rgba(148, 163, 184, 0.08);
}

.agevolazione-step4__attachment-text {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.agevolazione-step4__attachment-link {
  min-width: 0;
  color: var(--text);
  text-decoration: none;
  font-size: 13px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.agevolazione-step4__attachment-link:hover {
  text-decoration: underline;
  text-underline-offset: 3px;
}

.agevolazione-step4__attachment-meta {
  color: var(--muted);
  font-size: 10px;
  letter-spacing: 0.03em;
}

.agevolazione-step4__attachment-delete {
  min-height: 30px;
  padding: 5px 8px;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(239, 68, 68, 0.24);
  background: rgba(239, 68, 68, 0.1);
  color: #b91c1c;
  cursor: pointer;
  font-size: 11px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.agevolazione-step4__attachment-delete:hover {
  background: rgba(239, 68, 68, 0.16);
}

.agevolazione-step4__attachment-delete:disabled {
  cursor: progress;
  opacity: 0.72;
}

.agevolazione-discard-modal__panel {
  width: min(96vw, 560px);
}

.agevolazione-richtext-modal__panel {
  width: min(96vw, 1040px);
  display: grid;
  gap: 10px;
}

.agevolazione-richtext-modal__panel .modal__title {
  font-size: 0.9rem;
  line-height: 1.15;
}

.agevolazione-richtext-modal__subtitle {
  margin: 0;
  color: var(--muted);
  font-size: 0.76rem;
  line-height: 1.2;
}

.agevolazione-richtext-editor-source {
  min-height: 360px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--input-border);
  background: var(--input-bg);
  color: var(--text);
  font: inherit;
  padding: 14px 16px;
}

.agevolazione-task {
  border-radius: var(--radius-md);
  border: 1px solid var(--glass-border);
  background: rgba(148, 163, 184, 0.08);
  padding: 6px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
}

.board--contributi-detail .agevolazione-task {
  background: rgba(148, 163, 184, 0.11);
}

body[data-theme="dark"] .board--contributi-detail .agevolazione-detail__info-panel {
  background: linear-gradient(160deg, rgba(24, 42, 62, 0.9) 0%, rgba(17, 33, 50, 0.85) 100%);
  border-color: rgba(134, 179, 214, 0.24);
}

body[data-theme="dark"] .board--contributi-detail .agevolazione-detail__info-panel .account-field input,
body[data-theme="dark"] .board--contributi-detail .agevolazione-detail__info-panel .account-field select,
body[data-theme="dark"] .board--contributi-detail .agevolazione-detail__info-panel .account-field textarea {
  background: rgba(9, 24, 40, 0.82);
  border-color: rgba(134, 179, 214, 0.3);
}

body[data-theme="dark"] .board--contributi-detail .agevolazione-detail__info-panel .account-multi-check {
  background: rgba(7, 20, 34, 0.78);
  border-color: rgba(134, 179, 214, 0.26);
}

body[data-theme="dark"] .board--contributi-detail .agevolazione-detail-card {
  background:
    radial-gradient(circle at 8% 0%, rgba(34, 211, 238, 0.22) 0%, transparent 45%),
    linear-gradient(160deg, rgba(16, 30, 52, 0.84) 0%, rgba(10, 22, 38, 0.9) 100%);
}

body[data-theme="dark"] .board--contributi-detail .agevolazione-detail-card__metric-shell,
body[data-theme="dark"] .board--contributi-detail .agevolazione-detail-card__timeline-shell,
body[data-theme="dark"] .board--contributi-detail .agevolazione-detail-card__progress-shell {
  background: rgba(15, 23, 42, 0.45);
}

body[data-theme="dark"] .agevolazione-detail-card__chart--progress {
  box-shadow:
    inset 0 0 0 1px rgba(148, 163, 184, 0.12),
    0 20px 40px rgba(2, 6, 23, 0.34);
}

body[data-theme="dark"] .agevolazione-detail-card__chart--progress::before {
  background:
    linear-gradient(160deg, rgba(15, 23, 42, 0.96) 0%, rgba(20, 34, 56, 0.92) 100%);
  border-color: rgba(148, 163, 184, 0.14);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

body[data-theme="dark"] .agevolazione-detail-timeline-item--alert {
  border-color: rgba(248, 113, 113, 0.42);
  background: linear-gradient(165deg, rgba(127, 29, 29, 0.38) 0%, rgba(69, 10, 10, 0.32) 100%);
}

body[data-theme="dark"] .agevolazione-detail-timeline-item--alert .agevolazione-detail-timeline-label,
body[data-theme="dark"] .agevolazione-detail-timeline-item--alert .agevolazione-detail-timeline-date {
  color: #fecaca;
}

body[data-theme="dark"] .board--contributi-detail .agevolazione-checklist {
  background: linear-gradient(165deg, rgba(19, 36, 55, 0.9) 0%, rgba(14, 28, 44, 0.86) 100%);
  border-color: rgba(134, 179, 214, 0.22);
}

body[data-theme="dark"] .agevolazione-step__discard-btn {
  color: #fecaca;
  border-color: rgba(248, 113, 113, 0.5);
  background: linear-gradient(160deg, rgba(127, 29, 29, 0.42) 0%, rgba(69, 10, 10, 0.32) 100%);
}

.agevolazione-task .company__tool-btn,
.agevolazione-doc-item .company__tool-btn {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  border: 1px solid rgba(239, 68, 68, 0.45);
  background: linear-gradient(160deg, rgba(239, 68, 68, 0.2) 0%, rgba(239, 68, 68, 0.12) 100%);
  color: var(--text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: transform var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out);
}

.agevolazione-task .company__tool-btn:hover,
.agevolazione-doc-item .company__tool-btn:hover {
  transform: translateY(-1px);
  border-color: rgba(239, 68, 68, 0.65);
  box-shadow: 0 10px 16px rgba(239, 68, 68, 0.2);
}

.agevolazione-task__done {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: var(--muted);
  font-size: 10px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.agevolazione-task__title,
.agevolazione-task__hint {
  min-width: 0;
  border-radius: var(--radius-sm);
  border: 1px solid var(--glass-border);
  background: rgba(255, 255, 255, 0.65);
  color: var(--text);
  font: inherit;
  padding: 7px 9px;
}

body[data-theme="dark"] .agevolazione-task__title,
body[data-theme="dark"] .agevolazione-task__hint {
  background: rgba(9, 24, 40, 0.7);
}

.agevolazione-task__title:focus-visible,
.agevolazione-task__hint:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 1px;
}

.agevolazione-task__notes {
  min-height: 64px;
  resize: vertical;
}

.agevolazione-step__notes-split {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.agevolazione-step__notes-field {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.agevolazione-step__notes-label {
  font-size: 9px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
}

.agevolazione-task__notes--step1 {
  min-height: 220px;
}

.agevolazione-richtext-modal__panel .tox-tinymce {
  border-radius: var(--radius-md) !important;
  border-color: var(--input-border) !important;
  box-shadow: none !important;
  background: var(--input-bg);
}

.agevolazione-richtext-modal__panel .tox .tox-editor-header {
  border-bottom: 1px solid var(--glass-border);
  background: rgba(148, 163, 184, 0.08);
}

.agevolazione-richtext-modal__panel .tox .tox-toolbar,
.agevolazione-richtext-modal__panel .tox .tox-toolbar__primary,
.agevolazione-richtext-modal__panel .tox .tox-menubar {
  background: transparent;
}

.agevolazione-richtext-modal__panel .tox .tox-edit-area::before {
  border-color: var(--focus);
}

.agevolazione-richtext-modal__panel .tox .tox-statusbar {
  border-top: 1px solid var(--glass-border);
  background: rgba(148, 163, 184, 0.05);
}

.agevolazione-richtext-modal__panel .tox .tox-statusbar__wordcount,
.agevolazione-richtext-modal__panel .tox .tox-statusbar__path {
  color: var(--muted);
}

.agevolazione-richtext-modal__panel .tox .tox-edit-area__iframe {
  background: var(--input-bg);
}

body[data-theme="dark"] .agevolazione-richtext-modal__panel .tox-tinymce {
  border-color: rgba(134, 179, 214, 0.24) !important;
  background: rgba(9, 24, 40, 0.7);
}

body[data-theme="dark"] .agevolazione-note-preview-btn:hover {
  background: rgba(13, 28, 44, 0.84);
}

body[data-theme="dark"] .agevolazione-richtext-modal__panel .tox .tox-editor-header,
body[data-theme="dark"] .agevolazione-richtext-modal__panel .tox .tox-statusbar {
  background: rgba(15, 23, 42, 0.34);
  border-color: rgba(134, 179, 214, 0.24);
}

.agevolazione-docs {
  display: grid;
  gap: 8px;
}

.agevolazione-docs__title {
  font-size: 9px;
  font-weight: 400;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--muted);
}

.agevolazione-docs__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 6px;
}

.agevolazione-docs__items {
  display: grid;
  gap: 4px;
}

.agevolazione-doc-item {
  border-radius: var(--radius-sm);
  border: 1px dashed var(--glass-border);
  background: rgba(148, 163, 184, 0.06);
  padding: 4px 6px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 4px;
  align-items: center;
}

.agevolazione-doc-item__field {
  display: grid;
  gap: 0;
  min-width: 0;
  width: 100%;
  max-width: none;
  justify-self: stretch;
}

.agevolazione-doc-item .agevolazione-task__done {
  gap: 4px;
  font-size: 9px;
}

.agevolazione-doc-item .agevolazione-step__notes-label {
  font-size: 9px;
  letter-spacing: 0.06em;
}

.agevolazione-doc-item .agevolazione-task__title {
  width: 100%;
  font-size: 13px;
  line-height: 1.35;
  padding: 4px 8px;
}

.agevolazione-doc-item .company__tool-btn {
  width: 22px;
  height: 22px;
  border-radius: 6px;
}

.agevolazione-doc-item .company__tool-btn .fa-solid.fa-trash,
.agevolazione-doc-item .company__tool-btn .fa-regular.fa-trash {
  width: 11px;
  height: 11px;
}

.agevolazione-detail__status {
  margin: 0;
  border-radius: var(--radius-md);
  border: 1px solid rgba(16, 185, 129, 0.42);
  background: rgba(16, 185, 129, 0.12);
  color: #065f46;
  padding: 8px 10px;
  font-size: 12px;
}

body[data-theme="dark"] .agevolazione-detail__status {
  color: #6ee7b7;
}

@media (max-width: 1100px) {
  :root {
    --header-height: 138px;
  }

  .app-header {
    height: auto;
    min-height: var(--header-height);
    padding: 12px 14px;
  }

  .app-header__inner {
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-areas:
      "brand actions"
      "search search";
    gap: 12px;
  }

  .app-header__brand {
    grid-area: brand;
  }

  .app-header__search {
    grid-area: search;
    max-width: none;
    justify-self: stretch;
  }

  .app-header__actions {
    grid-area: actions;
    padding-right: 0;
  }

  .app-header__menu-toggle {
    display: inline-grid;
  }

  .app-logo {
    width: 48px;
    height: 48px;
  }

  .app-title {
    font-size: 18px;
    letter-spacing: 0.1em;
  }

  .user-menu__summary,
  .user-menu__login {
    min-width: 0;
  }

  .page {
    grid-template-columns: 1fr;
    gap: 14px;
    padding: 14px;
    height: calc(var(--viewport-height) - var(--header-offset));
  }

  .page-overlay {
    display: block;
  }

  body.is-sidebar-open .page-overlay {
    opacity: 1;
    pointer-events: auto;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
  }

  .sidebar {
    position: fixed;
    top: calc(var(--header-offset) + 14px);
    left: 14px;
    bottom: 14px;
    width: min(320px, calc(100vw - 28px));
    height: auto;
    z-index: 58;
    transform: translate3d(calc(-100% - 28px), 0, 0);
  }

  body.is-sidebar-open .sidebar {
    transform: translate3d(0, 0, 0);
    box-shadow: var(--shadow-strong);
  }

  .sidebar__close {
    display: inline-grid;
  }

  .sidebar__floating-actions {
    position: static;
    margin-top: auto;
    justify-content: flex-end;
    padding-top: 6px;
  }

  .content {
    padding-right: 0;
  }

  .search-results {
    top: calc(100% + 8px);
  }
}

@media (max-width: 1180px) {
  .contributi-dashboard {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .contributi-chart-card {
    min-height: 0;
    padding: 12px;
  }

  .agevolazione-step__notes-split {
    grid-template-columns: 1fr;
  }

  .agevolazione-step4__list-item {
    grid-template-columns: 1fr;
  }

  .agevolazione-step4__richtext-actions,
  .agevolazione-step4__attachment-item {
    grid-template-columns: 1fr;
  }

  .agevolazione-step__date,
  .agevolazione-step__date-row {
    grid-template-columns: 1fr;
  }

  .agevolazione-step[data-step-id="step-3"] .agevolazione-step__date--range {
    width: 100%;
    min-width: 0;
    grid-template-columns: 1fr;
  }

  .contributi-filters__form {
    grid-template-columns: 1fr;
  }

  .contributi-filters__actions {
    justify-content: flex-start;
  }

  .contributi-overview-table {
    min-width: 640px;
  }

  .contributi-overview-table__index-col,
  .contributi-overview-table__index {
    width: 24px;
    min-width: 24px;
    max-width: 24px;
  }

  .contributi-overview-table__company-col,
  .contributi-overview-table__company {
    min-width: 168px;
    max-width: 168px;
  }
}

@media (max-width: 860px) {
  .agevolazione-detail__grid {
    grid-template-columns: 1fr;
  }

  .agevolazione-detail-dashboard {
    grid-template-columns: 1fr;
  }

  .agevolazione-detail-card {
    min-height: 280px;
  }

  .agevolazione-detail-card__metric-shell,
  .agevolazione-detail-card__timeline-shell,
  .agevolazione-detail-card__progress-shell {
    min-height: 205px;
  }

  .agevolazione-detail-card__chart {
    min-height: 190px;
  }

  .agevolazione-detail-card__chart--small {
    width: 152px;
    height: 152px;
    min-height: 152px;
  }

  .agevolazione-detail__field--investment {
    grid-column: auto;
  }

  .agevolazione-doc-item {
    grid-template-columns: 1fr;
  }

  .agevolazione-step4__credit-row {
    grid-template-columns: 1fr;
  }

  .agevolazione-step__date {
    width: 100%;
    grid-template-columns: 1fr;
  }

  .agevolazione-step__date-row {
    grid-template-columns: 1fr;
  }

  .agevolazione-detail__head {
    flex-direction: column;
    align-items: stretch;
  }
}

/* Schede elenco (home) */
[data-home-compact-view] {
  display: none;
}

body[data-density="compact"] [data-home-default-view] {
  display: none;
}

body[data-density="compact"] [data-home-compact-view] {
  display: grid;
}

.company--list {
  min-height: 520px;
  padding: 16px 14px 12px;
  gap: 12px;
}

.company--list-unified {
  grid-column: 1 / -1;
  min-height: 620px;
}

body[data-density="compact"] .company--list {
  min-height: 420px;
}

body[data-density="compact"] .company--list-unified {
  min-height: 500px;
}

.company__logo--list {
  margin-top: 0;
  height: 86px;
}

.company__logo-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  text-decoration: none;
}

.company__logo-link--static {
  cursor: default;
  pointer-events: none;
}

.company__list-header {
  padding: 6px 6px 12px;
  border-bottom: 1px solid var(--glass-border);
  text-align: center;
}

.company__list-title {
  font-size: 15px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.company__list-body {
  flex: 1;
  overflow: auto;
  padding-right: 6px;
}

.company__group-block + .company__group-block {
  margin-top: 14px;
}

.company__group-title {
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin: 0 0 6px;
  padding: 0 6px;
  color: var(--muted);
}

.company__table {
  width: 100%;
  border-collapse: collapse;
}

.company__list-link {
  color: var(--text);
  text-decoration: none;
  display: block;
  position: relative;
  transition: color var(--duration-fast) var(--ease-out), text-decoration-color var(--duration-fast) var(--ease-out);
}

.company__list-link--static {
  cursor: default;
  pointer-events: none;
}

.company__list-link--locked {
  cursor: default;
  pointer-events: none;
  color: rgba(100, 116, 139, 0.92);
  opacity: 0.82;
}

.company__table .company__list-link {
  padding: 5px 6px 5px 16px;
  font-size: 11px;
  text-decoration: underline;
  text-decoration-color: transparent;
  text-underline-offset: 3px;
}

.company__table .company__list-link--locked {
  padding-right: 24px;
}

.company__table .company__list-link::before {
  content: "-";
  position: absolute;
  left: 5px;
  top: 5px;
  color: var(--muted);
}

.company__table .company__list-link--locked::after {
  content: "\1F512";
  font-size: 12px;
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--muted);
  opacity: 0.9;
}

.company__list-link:hover {
  color: var(--accent-strong);
  text-decoration-color: currentColor;
}

.company__table td {
  position: relative;
  padding: 0;
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--text);
  line-height: 1.3;
}

.company__table tr + tr td {
  border-top: 1px solid var(--glass-border);
}

.board__row--home-compact {
  grid-template-columns: 1fr;
}

body[data-density="compact"] .board__row--home-compact {
  grid-template-columns: 1fr;
}

.home-nationality-card {
  min-height: 0;
  max-height: 430px;
}

.home-nationality-card--full {
  max-height: none;
}

.home-nationality-card > summary {
  padding-right: 16px;
}

.home-nationality-card > summary::after {
  right: auto;
  left: 16px;
}

.home-nationality-card__summary .company__content {
  display: grid;
  gap: 4px;
}

.home-nationality-card .company__accordion-body {
  min-height: 0;
  overflow: hidden;
}

body[data-density="compact"] .home-nationality-card > summary {
  padding-left: 34px;
  padding-right: 16px;
}

body[data-density="compact"] .home-nationality-card > summary::after {
  left: 12px;
  right: auto;
}

.home-nationality-card__table-wrap {
  max-height: 320px;
  overflow: auto;
  padding-right: 4px;
}

.home-nationality-card__table-wrap--full {
  max-height: none;
  overflow: visible;
}

.home-nationality-card .company__subtitle {
  margin: 0;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.home-nationality-table__index {
  width: 42px;
  min-width: 42px;
  text-align: center;
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--muted);
}

.home-nationality-table .company__list-link {
  padding: 5px 6px;
}

.home-nationality-table .company__list-link::before {
  display: none;
}

.home-nationality-table td:last-child {
  width: 100%;
}

.company__table--employees th {
  text-align: left;
  padding: 8px 7px;
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  border-bottom: 1px solid var(--glass-border);
}

.company__table--employees td {
  padding: 8px 7px;
  font-size: 12px;
  letter-spacing: 0.02em;
}

.company__table--employees td:last-child {
  white-space: nowrap;
}

/* Pagina dettaglio azienda */
.company-page__header {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 16px;
  align-items: center;
  padding: 6px 6px 18px;
  border-bottom: 1px solid var(--glass-border);
}

.company__logo--page {
  margin-top: 0;
  border-bottom: none;
  padding-bottom: 0;
  height: 96px;
}

.company-page__meta h2 {
  font-size: 18px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.company-page__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 18px;
}

.company-bucket {
  margin-top: 18px;
}

body[data-density="compact"] .company-bucket {
  margin-top: 12px;
}

.company-bucket__header {
  display: grid;
  gap: 4px;
  padding: 10px 6px 12px;
  border-bottom: 1px solid var(--glass-border);
}

.company-bucket__title {
  font-size: 14px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.company-bucket__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(310px, 1fr));
  gap: 16px;
  margin-top: 18px;
  align-items: start;
}

body[data-density="compact"] .company-bucket__grid {
  gap: 8px;
  margin-top: 12px;
}

body[data-density="compact"] .company-bucket__grid,
body[data-density="compact"] .company-page__grid {
  grid-template-columns: 1fr;
}

.company-bucket__grid,
.company-page__grid {
  gap: 10px;
}

body[data-density="compact"] .company-bucket__header {
  padding: 6px 6px 8px;
}

.company--accordion {
  display: block;
  padding: 0;
  min-height: 0;
}

.company--accordion > summary {
  cursor: pointer;
  padding: 12px 14px 12px 44px;
  padding-right: 54px;
  list-style: none;
  display: flex;
  align-items: flex-start;
  gap: 12px;
  position: relative;
}

.company--accordion > summary::-webkit-details-marker {
  display: none;
}

.company--accordion > summary::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 6px solid currentColor;
  opacity: 0.7;
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-2px);
  transition: transform var(--duration) var(--ease-out), opacity var(--duration) var(--ease-out);
}

.company--accordion[open] > summary::after {
  transform: translateY(-2px) rotate(180deg);
}

body[data-density="comfortable"] .company--accordion > summary::after {
  display: none;
}

.company--accordion > summary .company__content h2 {
  font-size: 13px;
  letter-spacing: 0.12em;
}

body[data-density="compact"] .company--accordion > summary .company__content h2 {
  font-size: 11px;
  letter-spacing: 0.1em;
}

.company__accordion-body {
  display: grid;
  gap: 10px;
  padding: 0 12px 12px;
}

body[data-density="compact"] .company--accordion > summary {
  padding: 10px 12px 10px 38px;
  padding-right: 48px;
}

.company__category-delete {
  position: absolute;
  left: 10px;
  top: 6px;
  width: 22px;
  height: 22px;
  border-radius: 8px;
  border: 1px solid var(--glass-border);
  background: rgba(255, 255, 255, 0.08);
  color: var(--muted);
  display: grid;
  place-items: center;
  cursor: pointer;
  padding: 0;
  line-height: 1;
  font-size: 14px;
  transition: background var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out), color var(--duration) var(--ease-out);
}

.company__category-delete .fa-solid.fa-trash,
.company__category-delete .fa-regular.fa-trash {
  width: 12px;
  height: 12px;
}

.company__category-delete:hover {
  background: var(--nav-hover);
  color: var(--text);
  border-color: var(--glass-border-strong);
}

body[data-density="compact"] .company__category-delete {
  top: 5px;
  left: 8px;
  width: 20px;
  height: 20px;
  border-radius: 7px;
  font-size: 13px;
}

body[data-density="compact"] .company__accordion-body {
  padding: 0 10px 10px;
}

body[data-density="compact"] .company-bucket__grid .company--accordion.company--category,
body[data-density="compact"] .company-page__grid .company--accordion.company--tile {
  padding: 0;
}

.company--category {
  min-height: 190px;
  padding: 14px;
  gap: 10px;
}

.company--accordion.company--category,
.company--accordion.company--tile {
  padding: 0;
  min-height: 0;
}

.company--accordion.company--category .company__phrases {
  min-height: 44px;
  max-height: 92px;
  padding: 6px;
  gap: 8px;
}

.company--category .company__content h2 {
  font-size: 13px;
  letter-spacing: 0.12em;
}

.company--category .company__phrases {
  min-height: 92px;
  max-height: 160px;
  overflow: auto;
}

.company__phrases--pool {
  max-height: 140px;
  overflow: auto;
}

.company__subcats {
  border-top: 1px solid var(--glass-border);
  padding-top: 10px;
}

.company__subcats > summary {
  cursor: pointer;
  padding: 6px 10px;
  border-radius: var(--radius-sm);
  list-style: none;
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  transition: background var(--duration) var(--ease-out), color var(--duration) var(--ease-out);
}

.company__subcats-label {
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.company__subcats > summary:hover {
  background: var(--nav-hover);
  color: var(--text);
}

.company__subcats > summary:hover .company__subcats-label {
  color: var(--text);
}

.company__subcats > summary::-webkit-details-marker {
  display: none;
}

.company__subcats-label::after {
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 6px solid currentColor;
  opacity: 0.7;
  transform: translateY(1px);
  transition: transform var(--duration) var(--ease-out);
}

.company__subcats[open] .company__subcats-label::after {
  content: "";
  transform: translateY(1px) rotate(180deg);
}

.company__subcats-form {
  margin: 8px 0 10px;
  padding: 8px;
  border-radius: var(--radius-md);
  border: 1px solid var(--glass-border);
  background: rgba(255, 255, 255, 0.35);
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 8px;
  align-items: center;
}

body[data-theme="dark"] .company__subcats-form {
  background: rgba(0, 0, 0, 0.14);
}

.company__subcats-form[hidden] {
  display: none;
}

.company__phrase-add--ghost {
  background: transparent;
  border-color: var(--glass-border);
}

.company__phrase-add--ghost:hover {
  box-shadow: none;
  transform: none;
}

.company__subcats-add {
  margin-left: auto;
  width: 22px;
  height: 22px;
  flex-shrink: 0;
  border-radius: 999px;
  border: 1px solid var(--glass-border);
  background: rgba(255, 255, 255, 0.2);
  color: var(--text);
  display: grid;
  place-items: center;
  font-size: 14px;
  line-height: 1;
  cursor: pointer;
  transition: transform var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out);
}

.company__subcats-add:hover {
  transform: translate3d(0, -1px, 0);
  box-shadow: 0 10px 18px rgba(0, 0, 0, 0.14);
}

.company__subcats-grid {
  margin-top: 12px;
  display: grid;
  gap: 10px;
}

.company__phrases--mini {
  max-height: 90px;
  overflow: auto;
}

.company__subcat {
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.06);
  overflow: hidden;
}

body[data-theme="dark"] .company__subcat {
  background: rgba(0, 0, 0, 0.1);
}

.company__subcat--card {
  padding: 10px;
  display: grid;
  gap: 8px;
}

.company__subcat-label {
  display: block;
  padding: 0;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text);
}

.company__subcat > summary {
  cursor: pointer;
  padding: 10px 12px;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text);
  list-style: none;
  transition: background var(--duration) var(--ease-out), color var(--duration) var(--ease-out);
}

.company__subcat > summary::-webkit-details-marker {
  display: none;
}

.company__subcat[open] > summary {
  border-bottom: 1px solid var(--glass-border);
}

.company__subcat > summary:hover {
  background: var(--nav-hover);
}

.company__subcat > .company__notes {
  border: 0;
  border-radius: 0;
}

.company--tile {
  min-height: 220px;
  padding: 16px;
}

body[data-density="compact"] .company--tile {
  min-height: 180px;
}

.company--tile .company__content h2 {
  font-size: 14px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.company-page__notes {
  margin-top: 18px;
  padding: 0;
  border-radius: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
  display: flex;
  justify-content: flex-start;
}

body[data-density="compact"] .board__row .company__notes {
  display: none;
}

body[data-density="compact"] .company-bucket__grid .company__notes,
body[data-density="compact"] .company-page__grid .company__notes {
  display: block;
  max-height: 0;
  min-height: 0;
  opacity: 0;
  overflow: hidden;
  pointer-events: none;
  padding: 0;
  border-width: 0;
  margin-top: 0;
  transition:
    max-height var(--duration-slow) var(--ease-soft),
    opacity var(--duration) var(--ease-out),
    padding var(--duration) var(--ease-out),
    border-width var(--duration) var(--ease-out);
}

body[data-density="compact"] .company.is-expanded .company__notes,
body[data-density="compact"] details.company[open] .company__notes {
  max-height: 560px;
  opacity: 1;
  pointer-events: auto;
  padding: 14px;
  border-width: 1px;
}

body[data-density="compact"] .company-page__notes .company__notes {
  max-height: none;
  min-height: 260px;
  opacity: 1;
  pointer-events: auto;
  padding: 14px;
  border-width: 1px;
}

body[data-density="compact"] .company-bucket__grid .company__phrases,
body[data-density="compact"] .company-page__grid .company__phrases {
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  pointer-events: none;
  padding: 0;
  border-width: 0;
  margin-top: 0;
  transition:
    max-height var(--duration-slow) var(--ease-soft),
    opacity var(--duration) var(--ease-out),
    padding var(--duration) var(--ease-out),
    border-width var(--duration) var(--ease-out);
}

body[data-density="compact"] .company.is-expanded .company__phrases,
body[data-density="compact"] details.company[open] .company__phrases {
  max-height: 240px;
  opacity: 1;
  pointer-events: auto;
  padding: 12px;
  border-width: 1px;
}

body[data-density="compact"] .company__phrase-item {
  padding: 6px 10px;
  font-size: 12px;
  line-height: 1.35;
}

body[data-density="compact"] .company-page__notes .company__phrases {
  max-height: none;
  opacity: 1;
  pointer-events: auto;
  padding: 12px;
  border-width: 1px;
}

body[data-density="compact"] .board__row .company {
  min-height: 0;
  gap: 10px;
}

body[data-density="compact"] .company-bucket__grid .company--category:not(.company--accordion),
body[data-density="compact"] .company-page__grid .company--tile:not(.company--accordion) {
  min-height: 92px;
  padding: 12px;
  gap: 10px;
}

body[data-density="compact"] .company-bucket__grid .company--category:not(.is-expanded):not([open]) .company__subcats {
  display: none;
}

body[data-density="compact"] .company-bucket__grid .company--category.is-expanded,
body[data-density="compact"] .company-page__grid .company--tile.is-expanded,
body[data-density="compact"] .company-bucket__grid details.company--category[open],
body[data-density="compact"] .company-page__grid details.company--tile[open] {
  min-height: 92px;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    transition: none !important;
    animation: none !important;
    scroll-behavior: auto !important;
  }

  html.js .company {
    opacity: 1;
    transform: none;
  }
}

/* Adattamento responsivo */
@media (max-width: 1100px) {
  body {
    overflow-y: auto;
  }

  .page {
    grid-template-columns: 1fr;
    height: auto;
    overflow: visible;
    padding: 14px;
  }

  .sidebar {
    height: auto;
  }

  .content {
    height: auto;
    overflow: visible;
    padding-right: 0;
  }
}

@media (max-width: 1200px) {
  .company-page__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .app-header__inner {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .app-header__actions {
    justify-content: flex-start;
  }

  .company-tools__grid {
    grid-template-columns: 1fr;
  }

  .company-tools__split {
    grid-template-columns: 1fr;
  }

  .company-tools__divider {
    width: 100%;
    height: 1px;
  }

  .company__subcats-form {
    grid-template-columns: minmax(0, 1fr);
  }

  .company__fields {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 800px) {
  .company-page__header {
    grid-template-columns: 1fr;
    text-align: center;
    justify-items: center;
  }

  .company-page__grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 1300px) {
  .board__row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  body[data-density="compact"] .board__row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 1050px) {
  .board__row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-density="compact"] .board__row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1500px) {
  .board__row--home {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  body[data-density="compact"] .board__row--home {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 1200px) {
  .board__row--home {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  body[data-density="compact"] .board__row--home {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .board__row--home {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-density="compact"] .board__row--home {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 520px) {
  .home-overview__metrics {
    grid-template-columns: 1fr;
  }

  .company__fields--developer {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .app-header {
    padding: 10px 12px;
    height: auto;
  }

  :root {
    --header-height: 124px;
  }

  .auth-grid {
    grid-template-columns: 1fr;
  }

  .auth-actions {
    grid-template-columns: 1fr;
  }

  .account-meta {
    grid-template-columns: 1fr;
  }

  .account-grid {
    grid-template-columns: 1fr;
  }

  .board__panel {
    padding: 14px;
  }

  .contributi-overview-sticky {
    margin: -14px -14px 12px;
    padding: 14px 14px 12px;
  }

  .board__row {
    grid-template-columns: 1fr;
  }
}

/* Calendario */
.calendar-page {
  display: grid;
  gap: 16px;
}

.calendar-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}

.calendar-nav {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: nowrap;
  margin: 0;
  padding: 6px 8px;
  border: 1px solid var(--glass-border-strong);
  border-radius: 14px;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.28), rgba(255, 255, 255, 0.1));
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.12);
}

.calendar-nav__arrow {
  width: 40px;
  height: 40px;
  border-radius: 11px;
  border: 1px solid rgba(31, 77, 122, 0.3);
  background: linear-gradient(145deg, rgba(93, 135, 167, 0.28), rgba(93, 135, 167, 0.08));
  color: var(--accent-strong);
  text-decoration: none;
  display: grid;
  place-items: center;
  font-size: 28px;
  font-weight: 700;
  line-height: 1;
  transition: transform var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out), background var(--duration) var(--ease-out);
}

.calendar-nav__arrow:hover {
  transform: translateY(-1px);
  border-color: var(--accent-strong);
  box-shadow: 0 12px 24px rgba(2, 6, 23, 0.16);
}

.calendar-nav__arrow:focus-visible,
.calendar-nav__today:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 2px;
}

.calendar-nav__title {
  min-width: 240px;
  padding: 9px 16px;
  border-radius: 11px;
  border: 1px solid rgba(31, 77, 122, 0.3);
  background: linear-gradient(145deg, rgba(205, 216, 227, 0.9), rgba(248, 250, 252, 0.72));
  text-align: center;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent-strong);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5);
}

.calendar-nav__title.is-current {
  border-color: rgba(31, 77, 122, 0.46);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7), 0 8px 16px rgba(15, 23, 42, 0.14);
}

.calendar-nav__today {
  height: 40px;
  min-width: 80px;
  border-radius: 11px;
  border: 1px solid rgba(31, 77, 122, 0.46);
  background: linear-gradient(145deg, var(--accent) 0%, var(--accent-2) 100%);
  color: #f8fbff;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 14px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  transition: transform var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out), filter var(--duration) var(--ease-out);
}

.calendar-nav__today:hover {
  transform: translateY(-1px);
  border-color: var(--accent-strong);
  box-shadow: 0 12px 24px rgba(15, 23, 42, 0.2);
  filter: brightness(1.04);
}

.calendar-nav__today.is-current {
  border-color: var(--glass-border-strong);
  background: linear-gradient(145deg, rgba(248, 250, 252, 0.84), rgba(205, 216, 227, 0.7));
  color: var(--accent-strong);
}

.calendar-month {
  min-width: 0;
}

.calendar-compact {
  display: none;
  min-width: 0;
  min-height: 0;
  height: 100%;
  border-radius: 12px;
  border: 1px solid var(--glass-border);
  background: linear-gradient(160deg, rgba(255, 255, 255, 0.16), rgba(255, 255, 255, 0.07));
  padding: 8px;
}

.calendar-compact__scroll {
  height: 100%;
  max-height: 100%;
  overflow: auto;
}

.calendar-compact__table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
  min-width: 1060px;
}

.calendar-compact__table th {
  position: sticky;
  top: 0;
  z-index: 2;
  text-align: left;
  padding: 7px 8px;
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent-strong);
  border-bottom: 1px solid var(--glass-border);
  border-right: 1px solid var(--glass-border);
  background: color-mix(in srgb, var(--glass-strong) 92%, transparent);
}

.calendar-compact__table td {
  padding: 6px 8px;
  border-bottom: 1px solid var(--glass-border);
  border-right: 1px solid var(--glass-border);
  vertical-align: top;
  font-size: 12px;
  letter-spacing: 0.01em;
  color: var(--text);
}

.calendar-compact__table th:nth-child(1),
.calendar-compact__table td:nth-child(1) {
  width: 210px;
}

.calendar-compact__table th:nth-child(2),
.calendar-compact__table td:nth-child(2) {
  width: 360px;
}

.calendar-compact__table th:nth-child(3),
.calendar-compact__table td:nth-child(3) {
  width: 240px;
}

.calendar-compact__table th:last-child,
.calendar-compact__table td:last-child {
  border-right: none;
}

.calendar-compact-col-type {
  width: 220px;
  color: var(--muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.calendar-compact-col-name {
  width: 360px;
}

.calendar-compact-col-status {
  width: 250px;
}

.calendar-compact-col-date,
.calendar-compact-col-time {
  white-space: nowrap;
}

.calendar-compact-group-row {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
}

.calendar-compact-group-cell {
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--accent-strong);
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.calendar-compact-group-cell--name {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.calendar-compact-group-name {
  font-size: 13px;
  letter-spacing: 0.03em;
  text-transform: none;
  color: var(--text);
  font-weight: 600;
}

.calendar-compact-group-count {
  border-radius: 999px;
  border: 1px solid var(--glass-border-strong);
  padding: 1px 7px;
  font-size: 11px;
  text-transform: none;
  color: var(--accent-strong);
}

.calendar-compact-event-row:hover td {
  background: color-mix(in srgb, var(--accent-2) 10%, transparent);
}

.calendar-compact-event {
  width: 100%;
  border: none;
  background: transparent;
  padding: 0;
  text-align: left;
  font-size: 12px;
  letter-spacing: 0.01em;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  text-decoration: underline;
  text-decoration-color: transparent;
  text-underline-offset: 3px;
  transition: color var(--duration-fast) var(--ease-out), text-decoration-color var(--duration-fast) var(--ease-out);
}

.calendar-compact-event:hover {
  color: var(--accent-strong);
  text-decoration-color: currentColor;
}

.calendar-compact-status {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: 12px;
}

.calendar-compact-status__dot {
  width: 11px;
  height: 11px;
  border-radius: 3px;
  border: 1px solid transparent;
  flex: 0 0 auto;
}

.calendar-compact-status--approved .calendar-compact-status__dot {
  background: #8ccc5c;
  border-color: #a2da76;
}

.calendar-compact-status--pending .calendar-compact-status__dot {
  background: #f7a531;
  border-color: #ffc062;
}

.calendar-compact-status--rejected .calendar-compact-status__dot {
  background: #e65d5d;
  border-color: #f08c8c;
}

.calendar-compact-status--meeting .calendar-compact-status__dot {
  background: #60a5fa;
  border-color: #93c5fd;
}

.calendar-compact-col-type,
.calendar-compact-col-time {
  color: var(--muted);
}

.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 8px;
}

.calendar-grid__weekday {
  border-radius: 10px;
  border: 1px solid var(--glass-border);
  background: rgba(255, 255, 255, 0.16);
  padding: 8px 10px;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}

.calendar-day {
  min-height: 190px;
  border-radius: 12px;
  border: 1px solid var(--glass-border);
  background: linear-gradient(160deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.06));
  padding: 8px;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  gap: 8px;
  transition: border-color var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out), transform var(--duration) var(--ease-out);
}

.calendar-day:hover {
  border-color: var(--accent);
  box-shadow: 0 10px 20px rgba(2, 6, 23, 0.12);
}

.calendar-day--outside {
  opacity: 0.54;
}

.calendar-day--today {
  border-color: var(--accent);
  box-shadow: inset 0 0 0 1px var(--accent-soft);
}

.calendar-day--weekend {
  background: linear-gradient(160deg, rgba(93, 135, 167, 0.2), rgba(93, 135, 167, 0.08));
  border-color: rgba(93, 135, 167, 0.3);
}

.calendar-day--weekend:hover {
  border-color: rgba(31, 77, 122, 0.46);
}

.calendar-day--holiday {
  background: linear-gradient(160deg, rgba(220, 38, 38, 0.2), rgba(248, 113, 113, 0.1));
  border-color: rgba(220, 38, 38, 0.36);
}

.calendar-day--holiday .calendar-day__header {
  color: #9f1239;
}

.calendar-day--holiday:hover {
  border-color: rgba(185, 28, 28, 0.48);
  box-shadow: 0 10px 20px rgba(127, 29, 29, 0.14);
}

.calendar-day__header {
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text);
}

.calendar-day__holiday {
  grid-row: 2;
  justify-self: start;
  align-self: start;
  display: inline-flex;
  align-items: center;
  font-size: 10px;
  letter-spacing: 0.04em;
  line-height: 1.2;
  color: #7f1d1d;
  background: rgba(254, 226, 226, 0.64);
  border: 1px solid rgba(220, 38, 38, 0.22);
  border-radius: 999px;
  padding: 2px 8px;
  width: fit-content;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.calendar-day__events {
  grid-row: 3;
  min-height: 0;
  overflow: auto;
  display: grid;
  align-content: start;
  gap: 4px;
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}

.calendar-day__events::-webkit-scrollbar {
  width: 8px;
}

.calendar-day__events::-webkit-scrollbar-thumb {
  background: var(--scrollbar-thumb);
  border-radius: 999px;
}

.calendar-day__events::-webkit-scrollbar-track {
  background: transparent;
}

.calendar-day__empty {
  min-height: 8px;
}

.calendar-event {
  width: 100%;
  min-height: 22px;
  padding: 2px 7px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 10px;
  letter-spacing: 0.02em;
  color: #ffffff;
  text-align: left;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  border: 1px solid transparent;
  cursor: pointer;
}

.calendar-event--meeting {
  background: #ad1328;
  border-color: rgba(255, 205, 215, 0.32);
}

.calendar-event--pending {
  background: #b26312;
  border-color: rgba(255, 224, 181, 0.34);
}

.calendar-event--approved {
  background: #137e3e;
  border-color: rgba(183, 255, 209, 0.34);
}

.calendar-event--rejected {
  background: #4b5563;
  border-color: rgba(229, 231, 235, 0.34);
}

.calendar-card {
  border-radius: 12px;
  border: 1px solid var(--glass-border);
  background: linear-gradient(160deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0.08));
  padding: 12px;
}

.calendar-card__title {
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 8px;
}

.calendar-note {
  margin-top: 6px;
  font-size: 12px;
  color: var(--muted);
}

.calendar-approvals {
  display: grid;
  gap: 10px;
  max-height: 280px;
  overflow: auto;
}

.calendar-approval-item {
  border-radius: 10px;
  border: 1px solid var(--glass-border);
  background: rgba(255, 255, 255, 0.08);
  padding: 10px;
  display: grid;
  gap: 6px;
}

.calendar-approval-item__title {
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text);
}

.calendar-approval-item__meta {
  font-size: 10px;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--muted);
}

.calendar-approval-item__text {
  font-size: 12px;
  color: var(--text);
  margin: 0;
}

.calendar-approval-item__actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.calendar-approval-item__actions form {
  margin: 0;
}

.calendar-modal__panel {
  width: min(760px, calc(100% - 32px));
  overflow: visible;
}

.calendar-modal .calendar-modal__panel {
  margin-top: -28px;
}

.calendar-modal__form {
  gap: 6px;
}

.calendar-modal .account-field {
  gap: 3px;
  font-size: 10px;
  letter-spacing: 0.11em;
}

.calendar-modal__invite-shell {
  position: relative;
  min-width: 0;
}

.js .calendar-modal select[data-calendar-invite-select].is-enhanced {
  display: none;
}

.calendar-modal .account-field--invite-selector {
  gap: 4px;
}

.calendar-modal .account-field--invite-selector .calendar-invite-selector.is-ready {
  gap: 5px;
}

.calendar-modal .account-field--invite-selector .work-groups-member-selector__toolbar {
  gap: 10px;
  padding: 6px 0 2px;
}

.calendar-modal .account-field--invite-selector .work-groups-member-selector__selected {
  gap: 12px;
}

.calendar-modal .account-field--invite-selector .work-groups-member-selector__selected-item,
.calendar-modal .account-field--invite-selector .work-groups-member-selector__add {
  gap: 6px;
}

.calendar-modal .account-field--invite-selector .work-groups-member-selector__selected-item-media {
  width: 48px;
  height: 48px;
}

.calendar-modal .account-field--invite-selector .work-groups-member-selector__avatar,
.calendar-modal .account-field--invite-selector .work-groups-member-selector__add-circle {
  min-width: 48px;
  width: 48px;
  max-width: 48px;
  min-height: 48px;
  height: 48px;
  max-height: 48px;
}

.calendar-modal .account-field--invite-selector .work-groups-member-selector__selected-item-name,
.calendar-modal .account-field--invite-selector .work-groups-member-selector__add-label {
  max-width: 84px;
  font-size: 10px;
}

.calendar-modal .account-field--invite-selector .work-groups-member-selector__add-symbol {
  font-size: 24px;
}

.calendar-modal [data-calendar-invite-kind="groups"] .work-groups-member-selector__add {
  justify-items: start;
}

.calendar-modal [data-calendar-invite-kind="groups"] .work-groups-member-selector__add-circle {
  justify-self: start;
}

.calendar-modal [data-calendar-invite-kind="groups"] .work-groups-member-selector__add-label {
  text-align: left;
}

.calendar-modal .account-field--invite-selector .work-groups-member-selector__dropdown {
  margin-top: 2px;
  border-radius: 14px;
}

.calendar-modal .account-field--invite-selector .work-groups-member-selector__search {
  padding: 6px;
}

.calendar-modal .account-field--invite-selector .work-groups-member-selector__search input {
  min-height: 34px;
  font-size: 10px;
}

.calendar-modal .account-field--invite-selector .work-groups-member-selector__list {
  max-height: 210px;
}

.calendar-modal .account-field--invite-selector .work-groups-member-selector__option {
  padding: 7px 8px;
}

.calendar-modal .account-field--invite-selector .work-groups-member-selector__option-name {
  font-size: 11px;
}

.calendar-modal .account-field--invite-selector .work-groups-member-selector__option-email,
.calendar-modal .account-field--invite-selector .work-groups-member-selector__status,
.calendar-modal .account-field--invite-selector .work-groups-member-selector__list-empty {
  font-size: 11px;
}

.calendar-modal .account-field > input:not([type="hidden"]):not(.calendar-datetime-source),
.calendar-modal .account-field > select,
.calendar-modal .account-static {
  min-height: 30px;
  height: 30px;
  box-sizing: border-box;
  padding-top: 0;
  padding-bottom: 0;
  font-size: 12px;
  line-height: 1.2;
}

.calendar-modal .account-field > input:not([type="hidden"]):not(.calendar-datetime-source),
.calendar-modal .account-static {
  padding-left: 10px;
  padding-right: 10px;
}

.calendar-modal .account-field > select {
  padding-left: 10px;
  padding-right: 28px;
}

.calendar-modal .account-field > .filter-combobox {
  width: 100%;
  min-width: 0;
}

.calendar-modal .account-field > .filter-combobox .filter-combobox__control {
  min-height: 30px;
  height: 30px;
  padding-left: 10px;
  padding-right: 3px;
  box-sizing: border-box;
}

.calendar-modal .account-field > .filter-combobox .filter-combobox__input {
  height: 28px;
  padding-top: 4px;
  padding-bottom: 4px;
  font-size: 12px;
}

.calendar-modal .account-field > .filter-combobox .filter-combobox__clear,
.calendar-modal .account-field > .filter-combobox .filter-combobox__toggle {
  width: 28px;
  height: 28px;
}

.calendar-modal .account-field > .filter-combobox .filter-combobox__menu {
  top: calc(100% + 4px);
  padding: 3px;
  border-radius: 12px;
}

.calendar-modal .account-field > .filter-combobox .filter-combobox__list {
  gap: 2px;
}

.calendar-modal .account-field > .filter-combobox .filter-combobox__option {
  padding: 7px 10px;
  font-size: 12px;
  line-height: 1.15;
}

.calendar-modal .account-field > textarea {
  min-height: 74px;
  padding: 8px 10px;
  font-size: 12px;
  line-height: 1.4;
}

.calendar-modal .account-field small {
  font-size: 10px;
}

.calendar-modal .account-actions--spaced {
  margin-top: 6px;
}

.calendar-modal .btn {
  min-height: 30px;
  padding: 5px 10px;
  font-size: 10px;
  letter-spacing: 0.1em;
}

.calendar-detail__panel {
  width: min(780px, calc(100% - 32px));
}

.calendar-modal,
.calendar-detail-modal {
  opacity: 1;
  visibility: hidden;
  pointer-events: none;
  transition: visibility 0ms linear 280ms;
}

.calendar-modal.is-closing,
.calendar-detail-modal.is-closing {
  pointer-events: none;
}

.calendar-modal .modal__backdrop,
.calendar-detail-modal .modal__backdrop {
  opacity: 0;
  backdrop-filter: blur(0px) saturate(100%);
  -webkit-backdrop-filter: blur(0px) saturate(100%);
  transition:
    opacity 240ms cubic-bezier(0.22, 1, 0.36, 1),
    backdrop-filter 240ms cubic-bezier(0.22, 1, 0.36, 1),
    -webkit-backdrop-filter 240ms cubic-bezier(0.22, 1, 0.36, 1);
  will-change: opacity, backdrop-filter;
}

.calendar-modal .calendar-modal__panel,
.calendar-detail-modal .calendar-modal__panel {
  opacity: 0;
  transform: translate3d(0, 20px, 0) scale(0.965);
  transform-origin: var(--calendar-origin-x, 50%) var(--calendar-origin-y, 50%);
  transform-style: preserve-3d;
  filter: blur(1.2px);
  transition:
    transform 260ms cubic-bezier(0.22, 1, 0.36, 1),
    opacity 220ms cubic-bezier(0.22, 1, 0.36, 1),
    filter 220ms cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 260ms cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform, opacity, filter;
}

.calendar-modal.is-open,
.calendar-detail-modal.is-open {
  visibility: visible;
  pointer-events: auto;
  transition-delay: 0ms;
}

.calendar-modal.is-open .modal__backdrop,
.calendar-detail-modal.is-open .modal__backdrop {
  opacity: 1;
  backdrop-filter: blur(10px) saturate(140%);
  -webkit-backdrop-filter: blur(10px) saturate(140%);
}

.calendar-modal.is-open .calendar-modal__panel,
.calendar-detail-modal.is-open .calendar-modal__panel {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
  filter: blur(0);
}

.calendar-modal.is-closing .modal__backdrop,
.calendar-detail-modal.is-closing .modal__backdrop {
  transition-duration: 190ms;
}

.calendar-modal.is-closing .calendar-modal__panel,
.calendar-detail-modal.is-closing .calendar-modal__panel {
  transition-duration: 180ms;
}

.calendar-modal.is-gsap-opening .modal__backdrop,
.calendar-detail-modal.is-gsap-opening .modal__backdrop,
.calendar-modal.is-gsap-opening .calendar-modal__panel,
.calendar-detail-modal.is-gsap-opening .calendar-modal__panel,
.calendar-modal.is-gsap-closing .modal__backdrop,
.calendar-detail-modal.is-gsap-closing .modal__backdrop,
.calendar-modal.is-gsap-closing .calendar-modal__panel,
.calendar-detail-modal.is-gsap-closing .calendar-modal__panel {
  transition: none !important;
}

@media (prefers-reduced-motion: reduce) {
  .calendar-modal,
  .calendar-detail-modal,
  .calendar-modal .modal__backdrop,
  .calendar-detail-modal .modal__backdrop,
  .calendar-modal .calendar-modal__panel,
  .calendar-detail-modal .calendar-modal__panel {
    transition: none !important;
    animation: none !important;
  }
}

.calendar-recurrence-shell {
  display: grid;
  gap: 8px;
  padding: 6px 0 2px;
}

.calendar-recurrence__toggle {
  align-self: start;
}

.calendar-recurrence-grid {
  gap: 10px;
}

.calendar-recurrence-grid[hidden] {
  display: none !important;
}

.calendar-modal .calendar-recurrence-grid .account-field > input[type="date"],
.calendar-modal .calendar-recurrence-grid .account-field > select {
  width: 100%;
}

.calendar-time-grid.is-hidden {
  display: none;
}

.calendar-datetime-shell {
  position: relative;
  overflow: visible;
}

.calendar-time-grid {
  position: relative;
  overflow: visible;
  gap: 8px;
  align-items: start;
}

.calendar-manual-time-grid {
  margin-top: 6px;
}

.calendar-datetime-field {
  position: relative;
  min-width: 0;
}

.calendar-manual-time-field {
  min-width: 0;
}

.calendar-manual-time-field input[type="time"] {
  min-height: 30px;
}

.calendar-modal .calendar-datetime-trigger,
.calendar-modal .calendar-manual-time-field input[type="time"] {
  border-radius: var(--radius-md);
}

.calendar-datetime-source {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  opacity: 0;
  pointer-events: none;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
  overflow: hidden;
}

.calendar-datetime-trigger {
  width: 100%;
  min-height: 30px;
  height: 30px;
  padding: 0 8px;
  border-radius: var(--radius-md);
  border: 1px solid var(--input-border);
  background: var(--input-bg);
  box-shadow: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  text-align: left;
  cursor: pointer;
  transition: box-shadow var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out);
}

.calendar-modal .calendar-datetime-trigger:hover {
  transform: none;
  border-color: var(--input-border);
  background: var(--input-bg);
  box-shadow: none;
}

.calendar-modal .calendar-datetime-trigger:focus-visible,
.calendar-modal .calendar-datetime-field.is-active .calendar-datetime-trigger {
  outline: none;
  transform: none;
  border-color: var(--focus);
  background: var(--input-bg);
  box-shadow: 0 0 0 3px var(--focus);
}

.calendar-datetime-trigger__label {
  min-width: 0;
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
  font-weight: 500;
  line-height: 1.2;
  color: var(--accent-strong);
}

.calendar-datetime-trigger__meta {
  flex: 0 0 auto;
  font-size: 8px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
  white-space: nowrap;
}

.calendar-datetime-picker {
  position: absolute;
  left: var(--calendar-datetime-left, 0px);
  width: min(var(--calendar-datetime-width, 344px), calc(100vw - 64px));
  max-height: calc(100vh - 36px);
  margin-top: 0;
  padding: 10px;
  border-radius: 18px;
  border: 1px solid rgba(31, 77, 122, 0.16);
  background:
    radial-gradient(circle at top right, rgba(93, 135, 167, 0.18), transparent 38%),
    linear-gradient(165deg, rgba(255, 255, 255, 0.94), rgba(240, 245, 250, 0.86));
  box-shadow:
    0 20px 34px rgba(15, 23, 42, 0.16),
    0 0 0 1px rgba(255, 255, 255, 0.34);
  display: grid;
  gap: 10px;
  z-index: 18;
  overflow-y: auto;
  backdrop-filter: blur(18px) saturate(150%);
  -webkit-backdrop-filter: blur(18px) saturate(150%);
  will-change: transform, opacity;
}

.calendar-datetime-picker[hidden] {
  display: none !important;
}

.calendar-datetime-picker__header,
.calendar-datetime-picker__footer,
.calendar-datetime-picker__quick {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.calendar-datetime-picker__month,
.calendar-datetime-picker__summary {
  min-width: 0;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent-strong);
}

.calendar-datetime-picker__summary {
  color: var(--muted);
  letter-spacing: 0.04em;
  text-transform: none;
}

.calendar-datetime-picker__nav,
.calendar-datetime-picker__chip,
.calendar-datetime-picker__close,
.calendar-datetime-picker__day,
.calendar-datetime-picker__time-option {
  appearance: none;
  -webkit-appearance: none;
}

.calendar-datetime-picker__nav,
.calendar-datetime-picker__close,
.calendar-datetime-picker__chip {
  border: 1px solid rgba(31, 77, 122, 0.16);
  background: rgba(255, 255, 255, 0.72);
  color: var(--accent-strong);
  cursor: pointer;
  transition:
    transform var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out),
    background var(--duration-fast) var(--ease-out);
}

.calendar-datetime-picker__nav:hover,
.calendar-datetime-picker__close:hover,
.calendar-datetime-picker__chip:hover {
  transform: translateY(-1px);
  border-color: rgba(31, 77, 122, 0.3);
  box-shadow: 0 12px 22px rgba(15, 23, 42, 0.1);
}

.calendar-datetime-picker__nav {
  width: 28px;
  height: 28px;
  border-radius: 10px;
  font-size: 18px;
  line-height: 1;
}

.calendar-datetime-picker__close,
.calendar-datetime-picker__chip {
  padding: 6px 9px;
  border-radius: 10px;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.calendar-datetime-picker__quick {
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 6px;
}

.calendar-datetime-picker__body {
  display: grid;
  gap: 10px;
}

.calendar-datetime-picker__calendar,
.calendar-datetime-picker__time-panel {
  padding: 9px;
  border-radius: 14px;
  border: 1px solid rgba(31, 77, 122, 0.12);
  background: rgba(255, 255, 255, 0.68);
}

.calendar-datetime-picker__weekdays,
.calendar-datetime-picker__days {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 4px;
}

.calendar-datetime-picker__weekdays {
  margin-bottom: 6px;
}

.calendar-datetime-picker__weekdays span,
.calendar-datetime-picker__time-title {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}

.calendar-datetime-picker__day {
  min-height: 30px;
  border-radius: 10px;
  border: 1px solid transparent;
  background: rgba(255, 255, 255, 0.76);
  color: var(--accent-strong);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition:
    transform var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out),
    background var(--duration-fast) var(--ease-out),
    color var(--duration-fast) var(--ease-out);
}

.calendar-datetime-picker__day:hover,
.calendar-datetime-picker__time-option:hover {
  transform: translateY(-1px);
  border-color: rgba(31, 77, 122, 0.24);
}

.calendar-datetime-picker__day.is-outside {
  background: rgba(255, 255, 255, 0.34);
  color: rgba(100, 116, 139, 0.72);
}

.calendar-datetime-picker__day.is-today {
  border-color: rgba(31, 77, 122, 0.26);
}

.calendar-datetime-picker__day.is-selected,
.calendar-datetime-picker__time-option.is-selected,
.calendar-datetime-picker__chip.is-active {
  background: linear-gradient(145deg, var(--accent) 0%, var(--accent-2) 100%);
  color: #f8fbff;
  border-color: transparent;
  box-shadow: 0 10px 18px rgba(31, 77, 122, 0.22);
}

.calendar-datetime-picker__times {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.calendar-datetime-picker__time-panel {
  display: grid;
  gap: 8px;
}

.calendar-datetime-picker__time-list {
  max-height: 124px;
  overflow: auto;
  display: grid;
  gap: 4px;
  padding-right: 2px;
}

.calendar-datetime-picker__time-option {
  min-height: 30px;
  padding: 0 8px;
  border-radius: 10px;
  border: 1px solid rgba(31, 77, 122, 0.12);
  background: rgba(255, 255, 255, 0.76);
  color: var(--accent-strong);
  font-size: 12px;
  font-weight: 500;
  text-align: center;
  cursor: pointer;
}

.calendar-day-only {
  display: none;
}

.calendar-day-only.is-visible {
  display: grid;
}

.calendar-modal input.is-readonly {
  opacity: 0.72;
  cursor: default;
}

.calendar-modal .account-field .errorlist {
  list-style: none;
  margin: 4px 0 0;
  padding: 0;
  color: #ef4444;
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: none;
}

.calendar-detail__header {
  align-items: flex-start;
  gap: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(31, 77, 122, 0.1);
}

.calendar-detail__heading {
  min-width: 0;
  display: grid;
  gap: 10px;
}

.calendar-detail__eyebrow {
  margin: 0;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}

.calendar-detail__title {
  margin: 0;
  font-size: clamp(22px, 2.8vw, 30px);
  line-height: 1.08;
  letter-spacing: -0.03em;
}

.calendar-detail__subtitle {
  margin: 0;
  font-size: 13px;
  line-height: 1.45;
  color: color-mix(in srgb, var(--muted) 78%, white 22%);
}

.calendar-detail__badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.calendar-detail__pill {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 11px;
  border-radius: 999px;
  border: 1px solid rgba(31, 77, 122, 0.14);
  background: rgba(255, 255, 255, 0.72);
  color: var(--accent-strong);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.calendar-detail__pill[data-kind="approved"] {
  border-color: rgba(22, 163, 74, 0.22);
  background: rgba(220, 252, 231, 0.92);
  color: #166534;
}

.calendar-detail__pill[data-kind="pending"] {
  border-color: rgba(245, 158, 11, 0.24);
  background: rgba(254, 243, 199, 0.94);
  color: #b45309;
}

.calendar-detail__pill[data-kind="rejected"] {
  border-color: rgba(239, 68, 68, 0.2);
  background: rgba(254, 226, 226, 0.92);
  color: #b91c1c;
}

.calendar-detail__pill[data-kind="meeting"] {
  border-color: rgba(59, 130, 246, 0.2);
  background: rgba(219, 234, 254, 0.92);
  color: #1d4ed8;
}

.calendar-detail__pill[data-kind="absence"] {
  border-color: rgba(139, 92, 246, 0.18);
  background: rgba(237, 233, 254, 0.92);
  color: #6d28d9;
}

.calendar-detail__pill[data-kind="travel"] {
  border-color: rgba(14, 165, 233, 0.2);
  background: rgba(224, 242, 254, 0.92);
  color: #0369a1;
}

.calendar-detail-content {
  margin-top: 16px;
  display: grid;
  gap: 14px;
}

.calendar-detail__meta-grid,
.calendar-detail__section-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.calendar-detail__meta-card,
.calendar-detail__section {
  min-width: 0;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(31, 77, 122, 0.1);
  background:
    radial-gradient(circle at top right, rgba(93, 135, 167, 0.08), transparent 40%),
    linear-gradient(165deg, rgba(255, 255, 255, 0.82), rgba(244, 247, 251, 0.74));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.42),
    0 12px 24px rgba(15, 23, 42, 0.06);
}

.calendar-detail__section--description {
  gap: 12px;
}

.calendar-detail__meta-card {
  display: grid;
  gap: 6px;
}

.calendar-detail__meta-label,
.calendar-detail__section-label {
  margin: 0;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}

.calendar-detail__meta-value {
  font-size: 15px;
  font-weight: 600;
  line-height: 1.35;
  color: var(--text);
  word-break: break-word;
}

.calendar-detail__meta-value.is-empty,
.calendar-detail__description.is-empty {
  color: color-mix(in srgb, var(--muted) 80%, white 20%);
  font-weight: 500;
}

.calendar-detail__description {
  margin: 0;
  font-size: 14px;
  line-height: 1.65;
  color: var(--text);
  white-space: pre-wrap;
  word-break: break-word;
}

.calendar-detail__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.calendar-detail__chip {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  max-width: 100%;
  padding: 0 11px;
  border-radius: 999px;
  border: 1px solid rgba(31, 77, 122, 0.12);
  background: rgba(255, 255, 255, 0.74);
  color: var(--accent-strong);
  font-size: 11px;
  font-weight: 600;
  line-height: 1.2;
  word-break: break-word;
}

.calendar-detail__chip.is-empty {
  color: var(--muted);
  background: rgba(255, 255, 255, 0.42);
}

.calendar-detail__actions {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid rgba(31, 77, 122, 0.1);
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.calendar-detail__actions .btn {
  min-height: 34px;
  padding: 7px 14px;
}

.calendar-detail__actions form {
  margin: 0;
  padding: 0;
  border: none;
}

.calendar-detail__actions form[hidden],
.calendar-detail__actions[hidden] {
  display: none !important;
}

.calendar-checkbox {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  text-transform: none;
  letter-spacing: 0.04em;
}

.calendar-checkbox input[type="checkbox"] {
  width: 14px;
  height: 14px;
  margin: 0;
}

.calendar-checkbox > span {
  text-transform: none;
  letter-spacing: 0.04em;
  font-size: 11px;
}

body[data-theme="dark"] .calendar-datetime-trigger,
body[data-theme="dark"] .calendar-datetime-picker,
body[data-theme="dark"] .calendar-datetime-picker__calendar,
body[data-theme="dark"] .calendar-datetime-picker__time-panel,
body[data-theme="dark"] .calendar-datetime-picker__nav,
body[data-theme="dark"] .calendar-datetime-picker__chip,
body[data-theme="dark"] .calendar-datetime-picker__close,
body[data-theme="dark"] .calendar-datetime-picker__day,
body[data-theme="dark"] .calendar-datetime-picker__time-option {
  border-color: rgba(134, 179, 214, 0.22);
}

body[data-theme="dark"] .calendar-datetime-trigger,
body[data-theme="dark"] .calendar-datetime-picker {
  background:
    radial-gradient(circle at top right, rgba(93, 135, 167, 0.18), transparent 36%),
    linear-gradient(165deg, rgba(17, 38, 60, 0.88), rgba(10, 22, 36, 0.66));
}

body[data-theme="dark"] .calendar-datetime-picker__calendar,
body[data-theme="dark"] .calendar-datetime-picker__time-panel,
body[data-theme="dark"] .calendar-datetime-picker__nav,
body[data-theme="dark"] .calendar-datetime-picker__chip,
body[data-theme="dark"] .calendar-datetime-picker__close,
body[data-theme="dark"] .calendar-datetime-picker__day,
body[data-theme="dark"] .calendar-datetime-picker__time-option {
  background: rgba(17, 38, 60, 0.74);
}

body[data-theme="dark"] .calendar-datetime-trigger__label,
body[data-theme="dark"] .calendar-datetime-picker__month {
  color: rgba(241, 245, 249, 0.94);
}

body[data-theme="dark"] .calendar-datetime-trigger__meta,
body[data-theme="dark"] .calendar-datetime-picker__summary,
body[data-theme="dark"] .calendar-datetime-picker__weekdays span,
body[data-theme="dark"] .calendar-datetime-picker__time-title {
  color: rgba(205, 216, 227, 0.72);
}

body[data-theme="dark"] .calendar-datetime-picker__day.is-outside {
  color: rgba(148, 163, 184, 0.72);
}

@media (max-width: 760px) {
  .calendar-modal .calendar-modal__panel {
    margin-top: -10px;
  }

  .calendar-detail__meta-grid,
  .calendar-detail__section-grid {
    grid-template-columns: 1fr;
  }

  .calendar-detail__header {
    gap: 14px;
  }

  .calendar-detail__title {
    font-size: 22px;
  }

  .calendar-detail__actions .btn {
    width: 100%;
  }

  .calendar-datetime-picker {
    left: 0 !important;
    width: min(100%, calc(100vw - 48px));
  }

  .calendar-datetime-picker__times {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

body[data-theme="dark"] .calendar-grid__weekday {
  background: rgba(255, 255, 255, 0.04);
}

body[data-theme="dark"] .calendar-day {
  background: linear-gradient(160deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.02));
}

body[data-theme="dark"] .calendar-day--weekend {
  background: linear-gradient(160deg, rgba(90, 143, 180, 0.22), rgba(90, 143, 180, 0.1));
  border-color: rgba(134, 179, 214, 0.32);
}

body[data-theme="dark"] .calendar-day--holiday {
  background: linear-gradient(160deg, rgba(220, 38, 38, 0.28), rgba(153, 27, 27, 0.18));
  border-color: rgba(248, 113, 113, 0.42);
}

body[data-theme="dark"] .calendar-day--holiday .calendar-day__header {
  color: rgba(254, 202, 202, 0.96);
}

body[data-theme="dark"] .calendar-day__holiday {
  color: rgba(254, 242, 242, 0.96);
  background: rgba(185, 28, 28, 0.3);
  border-color: rgba(248, 113, 113, 0.42);
}

body[data-theme="dark"] .calendar-compact {
  background: linear-gradient(160deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.02));
}

body[data-theme="dark"] .calendar-compact__table th {
  color: #d7e3f0;
  border-right-color: rgba(205, 216, 227, 0.18);
  background: rgba(10, 22, 36, 0.92);
}

body[data-theme="dark"] .calendar-compact-event {
  color: #e8edf3;
}

body[data-theme="dark"] .calendar-compact__table td {
  border-right-color: rgba(205, 216, 227, 0.12);
}

body[data-theme="dark"] .calendar-compact-group-row {
  background: rgba(42, 73, 98, 0.58);
}

body[data-theme="dark"] .calendar-card {
  background: linear-gradient(160deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.02));
}

body[data-theme="dark"] .calendar-detail__header,
body[data-theme="dark"] .calendar-detail__actions,
body[data-theme="dark"] .calendar-detail__panel [data-calendar-delete-form] {
  border-color: rgba(134, 179, 214, 0.16);
}

body[data-theme="dark"] .calendar-detail__eyebrow,
body[data-theme="dark"] .calendar-detail__meta-label,
body[data-theme="dark"] .calendar-detail__section-label {
  color: rgba(148, 163, 184, 0.88);
}

body[data-theme="dark"] .calendar-detail__title,
body[data-theme="dark"] .calendar-detail__meta-value,
body[data-theme="dark"] .calendar-detail__description {
  color: rgba(241, 245, 249, 0.96);
}

body[data-theme="dark"] .calendar-detail__subtitle,
body[data-theme="dark"] .calendar-detail__meta-value.is-empty,
body[data-theme="dark"] .calendar-detail__description.is-empty {
  color: rgba(205, 216, 227, 0.74);
}

body[data-theme="dark"] .calendar-detail__meta-card,
body[data-theme="dark"] .calendar-detail__section,
body[data-theme="dark"] .calendar-detail__pill,
body[data-theme="dark"] .calendar-detail__chip {
  border-color: rgba(134, 179, 214, 0.18);
  background:
    radial-gradient(circle at top right, rgba(93, 135, 167, 0.14), transparent 42%),
    linear-gradient(165deg, rgba(17, 38, 60, 0.82), rgba(10, 22, 36, 0.74));
  color: rgba(226, 232, 240, 0.94);
}

body[data-theme="dark"] .calendar-detail__chip.is-empty {
  background: rgba(17, 38, 60, 0.58);
  color: rgba(148, 163, 184, 0.9);
}

body[data-theme="dark"] .calendar-detail__pill[data-kind="approved"] {
  border-color: rgba(74, 222, 128, 0.24);
  background: rgba(20, 83, 45, 0.72);
  color: rgba(220, 252, 231, 0.96);
}

body[data-theme="dark"] .calendar-detail__pill[data-kind="pending"] {
  border-color: rgba(251, 191, 36, 0.26);
  background: rgba(120, 53, 15, 0.76);
  color: rgba(254, 243, 199, 0.98);
}

body[data-theme="dark"] .calendar-detail__pill[data-kind="rejected"] {
  border-color: rgba(248, 113, 113, 0.26);
  background: rgba(127, 29, 29, 0.76);
  color: rgba(254, 226, 226, 0.98);
}

body[data-theme="dark"] .calendar-detail__pill[data-kind="meeting"] {
  border-color: rgba(96, 165, 250, 0.24);
  background: rgba(30, 64, 175, 0.72);
  color: rgba(219, 234, 254, 0.98);
}

body[data-theme="dark"] .calendar-detail__pill[data-kind="absence"] {
  border-color: rgba(167, 139, 250, 0.24);
  background: rgba(91, 33, 182, 0.74);
  color: rgba(237, 233, 254, 0.98);
}

body[data-theme="dark"] .calendar-detail__pill[data-kind="travel"] {
  border-color: rgba(56, 189, 248, 0.24);
  background: rgba(12, 74, 110, 0.74);
  color: rgba(224, 242, 254, 0.98);
}

body[data-theme="dark"] .calendar-approval-item {
  background: rgba(255, 255, 255, 0.03);
}

body[data-theme="dark"] .calendar-nav__arrow {
  border-color: rgba(134, 179, 214, 0.34);
  background: linear-gradient(145deg, rgba(90, 143, 180, 0.3), rgba(90, 143, 180, 0.1));
  color: var(--accent-strong);
}

body[data-theme="dark"] .calendar-nav {
  background: linear-gradient(145deg, rgba(17, 38, 60, 0.82), rgba(10, 22, 36, 0.66));
  border-color: rgba(205, 216, 227, 0.24);
}

body[data-theme="dark"] .calendar-nav__title {
  border-color: rgba(134, 179, 214, 0.34);
  background: linear-gradient(145deg, rgba(17, 38, 60, 0.9), rgba(42, 73, 98, 0.76));
  color: var(--accent-strong);
}

body[data-theme="dark"] .calendar-nav__title.is-current {
  border-color: rgba(134, 179, 214, 0.5);
}

body[data-theme="dark"] .calendar-nav__today {
  border-color: rgba(134, 179, 214, 0.5);
  background: linear-gradient(145deg, rgba(90, 143, 180, 0.9), rgba(42, 73, 98, 0.95));
  color: #f8fbff;
}

body[data-theme="dark"] .calendar-nav__today.is-current {
  border-color: rgba(205, 216, 227, 0.32);
  background: linear-gradient(145deg, rgba(17, 38, 60, 0.9), rgba(10, 22, 36, 0.84));
  color: var(--accent-strong);
}

@media (max-width: 1200px) {
  .calendar-day {
    min-height: 165px;
  }
}

@media (max-width: 920px) {
  .calendar-header {
    align-items: stretch;
  }

  .calendar-nav {
    width: 100%;
    justify-content: center;
    flex-wrap: wrap;
    gap: 8px;
  }

  .calendar-nav__title {
    min-width: 180px;
    width: auto;
    flex: 1 1 180px;
  }

  .calendar-nav__arrow,
  .calendar-nav__today {
    height: 36px;
  }

  .calendar-nav__today {
    min-width: 74px;
    padding: 0 12px;
  }

  .calendar-grid {
    gap: 6px;
  }

  .calendar-day {
    min-height: 130px;
  }
}

/* Calendar fit + palette weekdays */
.content.content--calendar {
  overflow: hidden;
  padding-right: 0;
  padding-bottom: 0;
}

.board--calendar {
  height: 100%;
}

.board--calendar .calendar-page {
  height: 100%;
  grid-template-rows: auto minmax(0, 1fr);
}

.board--calendar .calendar-month {
  min-height: 0;
}

.board--calendar .calendar-compact {
  min-height: 0;
}

.board--calendar .calendar-grid {
  height: 100%;
  grid-template-rows: auto;
  grid-auto-rows: minmax(0, 1fr);
}

.board--calendar .calendar-day {
  min-height: 0;
}

.board--calendar .calendar-grid__weekday:nth-child(1) {
  background: color-mix(in srgb, var(--accent) 16%, transparent);
  color: var(--accent-strong);
}

.board--calendar .calendar-grid__weekday:nth-child(2) {
  background: color-mix(in srgb, var(--accent-2) 18%, transparent);
  color: var(--accent-strong);
}

.board--calendar .calendar-grid__weekday:nth-child(3) {
  background: color-mix(in srgb, var(--silver-2) 24%, transparent);
  color: var(--accent-strong);
}

.board--calendar .calendar-grid__weekday:nth-child(4) {
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent-strong);
}

.board--calendar .calendar-grid__weekday:nth-child(5) {
  background: color-mix(in srgb, var(--accent-2) 15%, transparent);
  color: var(--accent-strong);
}

.board--calendar .calendar-grid__weekday:nth-child(6) {
  background: color-mix(in srgb, var(--silver-3) 24%, transparent);
  color: var(--accent-strong);
}

.board--calendar .calendar-grid__weekday:nth-child(7) {
  background: color-mix(in srgb, var(--accent-strong) 20%, transparent);
  color: var(--accent-strong);
}

body[data-theme="dark"] .board--calendar .calendar-grid__weekday:nth-child(1),
body[data-theme="dark"] .board--calendar .calendar-grid__weekday:nth-child(2),
body[data-theme="dark"] .board--calendar .calendar-grid__weekday:nth-child(3),
body[data-theme="dark"] .board--calendar .calendar-grid__weekday:nth-child(4),
body[data-theme="dark"] .board--calendar .calendar-grid__weekday:nth-child(5),
body[data-theme="dark"] .board--calendar .calendar-grid__weekday:nth-child(6),
body[data-theme="dark"] .board--calendar .calendar-grid__weekday:nth-child(7) {
  color: var(--accent-strong);
}

body[data-density="compact"] .board--calendar .calendar-month {
  display: none;
}

body[data-density="compact"] .board--calendar .calendar-compact {
  display: block;
}

@media (max-width: 1200px) {
  .board--calendar .calendar-page {
    gap: 12px;
  }

  .board--calendar .calendar-grid {
    gap: 6px;
  }
}

@media (max-width: 920px) {
  .calendar-compact {
    padding: 6px;
  }

  .calendar-compact__table {
    min-width: 920px;
  }

  .calendar-compact__table th {
    padding: 6px 7px;
    font-size: 9px;
  }

  .calendar-compact__table td {
    padding: 5px 7px;
    font-size: 11px;
  }

  .calendar-compact-status {
    font-size: 11px;
  }

  .board--calendar .calendar-grid__weekday {
    padding: 6px 8px;
    font-size: 10px;
    letter-spacing: 0.1em;
  }

  .board--calendar .calendar-day {
    padding: 6px;
    gap: 6px;
  }

  .calendar-detail-content {
    gap: 7px;
  }
}

@media (max-width: 860px) {
  .board__row--home-compact,
  body[data-density="compact"] .board__row--home-compact {
    grid-template-columns: 1fr;
  }
}

.board--marketing .board__panel {
  display: grid;
  gap: 18px;
  overflow: hidden;
}

.marketing-shell {
  --marketing-accent: var(--accent);
}

.marketing-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
}

.marketing-header__copy {
  display: grid;
  gap: 8px;
}

.marketing-header__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--input-border);
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent-2) 14%, transparent), rgba(255, 255, 255, 0.92));
  color: var(--accent-strong);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.marketing-header__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}

.marketing-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.marketing-summary__item {
  min-width: 130px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(148, 163, 184, 0.22);
  background: linear-gradient(155deg, rgba(255, 247, 237, 0.92), rgba(255, 255, 255, 0.62));
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.08);
}

.marketing-summary__label {
  display: block;
  color: var(--muted);
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.marketing-summary__item strong {
  display: block;
  margin-top: 4px;
  color: var(--text);
  font-size: 19px;
  line-height: 1.1;
}

.marketing-hint {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.55;
}

.marketing-layout {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) 320px;
  gap: 16px;
  align-items: start;
}

.marketing-views,
.marketing-detail__card,
.marketing-table-wrap,
.marketing-calendar-group,
.marketing-empty {
  border: 1px solid rgba(148, 163, 184, 0.22);
  border-radius: 18px;
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--accent-2) 14%, transparent), transparent 34%),
    linear-gradient(160deg, rgba(255, 255, 255, 0.92), rgba(248, 250, 252, 0.82));
  box-shadow: 0 18px 34px rgba(15, 23, 42, 0.08);
}

.marketing-views {
  position: sticky;
  top: 12px;
  display: grid;
  gap: 8px;
  padding: 14px;
}

.marketing-views__head {
  margin-bottom: 6px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.marketing-view {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 12px;
  border-radius: 12px;
  border: 1px solid transparent;
  color: var(--text);
  font-size: 14px;
  font-weight: 600;
  transition: transform var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out), background var(--duration) var(--ease-out);
}

.marketing-view:hover {
  transform: translateX(2px);
  border-color: var(--input-border);
  background: color-mix(in srgb, var(--accent-soft) 38%, var(--glass-strong));
}

.marketing-view.is-active {
  border-color: var(--input-border);
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent-2) 16%, transparent), rgba(255, 255, 255, 0.98));
  color: var(--accent-strong);
}

.marketing-view--ghost {
  opacity: 0.5;
  cursor: default;
  pointer-events: none;
}

.marketing-view__icon {
  width: 12px;
  height: 12px;
  border-radius: 4px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  box-shadow: 0 0 0 1px var(--input-border);
}

.marketing-view__icon--calendar {
  border-radius: 3px;
  position: relative;
}

.marketing-view__icon--calendar::before,
.marketing-view__icon--calendar::after {
  content: "";
  position: absolute;
  inset-inline: 2px;
  height: 1px;
  background: rgba(255, 255, 255, 0.92);
}

.marketing-view__icon--calendar::before {
  top: 3px;
}

.marketing-view__icon--calendar::after {
  top: 6px;
}

.marketing-main {
  min-width: 0;
}

.marketing-table-wrap {
  overflow: auto;
}

.marketing-table {
  width: 100%;
  min-width: 1040px;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 13px;
}

.marketing-table th,
.marketing-table td {
  padding: 12px 14px;
  border-bottom: 1px solid rgba(148, 163, 184, 0.18);
  border-right: 1px solid rgba(148, 163, 184, 0.14);
  vertical-align: top;
  background: rgba(255, 255, 255, 0.38);
}

.marketing-table thead th {
  position: sticky;
  top: 0;
  z-index: 3;
  background: color-mix(in srgb, var(--glass-strong) 88%, var(--accent-2-soft));
  color: var(--text);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.marketing-table th:last-child,
.marketing-table td:last-child {
  border-right: none;
}

.marketing-table__index-col,
.marketing-table__index {
  width: 44px;
  min-width: 44px;
  text-align: center;
}

.marketing-row {
  cursor: pointer;
  transition: transform var(--duration) var(--ease-out);
}

.marketing-row:hover td,
.marketing-row.is-selected td {
  background: color-mix(in srgb, var(--accent-soft) 42%, var(--glass-strong));
}

.marketing-row.is-selected td {
  box-shadow: inset 3px 0 0 var(--marketing-accent);
}

.marketing-cell strong,
.marketing-cell span,
.marketing-cell a {
  display: block;
}

.marketing-cell--title strong {
  color: var(--text);
  font-size: 14px;
}

.marketing-cell--title span,
.marketing-cell--date {
  margin-top: 6px;
  color: var(--muted);
  font-size: 12px;
}

.marketing-cell--body,
.marketing-cell--notes {
  min-width: 260px;
  max-width: 360px;
  white-space: pre-line;
  line-height: 1.55;
}

.marketing-cell--graphic {
  min-width: 150px;
}

.marketing-cell--graphic img {
  width: 118px;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  border-radius: 12px;
  border: 1px solid rgba(148, 163, 184, 0.18);
  background: rgba(255, 255, 255, 0.8);
}

.marketing-cell--graphic a {
  color: var(--accent-strong);
  font-weight: 600;
  word-break: break-word;
}

.marketing-cell__empty {
  color: var(--muted);
}

.marketing-calendar {
  display: grid;
  gap: 14px;
}

.marketing-calendar-group {
  padding: 16px;
}

.marketing-calendar-group__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.marketing-calendar-group__head h3 {
  margin: 0;
  color: var(--text);
  font-size: 18px;
}

.marketing-calendar-group__head span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.marketing-calendar-group__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 12px;
}

.marketing-calendar-card {
  display: grid;
  gap: 10px;
  padding: 14px;
  border-radius: 16px;
  border: 1px solid rgba(148, 163, 184, 0.18);
  background: rgba(255, 255, 255, 0.5);
  cursor: pointer;
  transition: transform var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out);
}

.marketing-calendar-card:hover,
.marketing-calendar-card.is-selected {
  transform: translateY(-2px);
  border-color: var(--input-border);
  box-shadow: 0 16px 28px rgba(15, 23, 42, 0.1);
}

.marketing-calendar-card__status {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 5px 9px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent-soft) 34%, var(--glass-strong));
  color: var(--accent-strong);
  font-size: 11px;
  font-weight: 700;
}

.marketing-calendar-card h4 {
  margin: 0;
  color: var(--text);
  font-size: 15px;
}

.marketing-calendar-card p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
}

.marketing-calendar-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 12px;
  color: var(--muted);
  font-size: 12px;
}

.marketing-detail {
  display: grid;
  gap: 14px;
  position: sticky;
  top: 12px;
  align-self: start;
}

.marketing-detail__card {
  display: grid;
  gap: 12px;
  padding: 16px;
}

.marketing-detail__card--primary {
  gap: 10px;
}

.marketing-detail__eyebrow {
  color: var(--accent-strong);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.marketing-detail__card h3,
.marketing-detail__card h4 {
  margin: 0;
  color: var(--text);
}

.marketing-detail__subtitle,
.marketing-detail__text,
.marketing-detail__notes p {
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
}

.marketing-detail__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.marketing-detail__actions .btn.is-disabled {
  opacity: 0.5;
  pointer-events: none;
}

.marketing-detail__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.marketing-detail__grid span,
.marketing-detail__chips > div > span,
.marketing-detail__notes span {
  display: block;
  color: var(--muted);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.marketing-detail__grid strong {
  display: block;
  margin-top: 6px;
  color: var(--text);
  font-size: 14px;
}

.marketing-detail__chips {
  display: grid;
  gap: 14px;
}

.marketing-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}

.marketing-chip {
  display: inline-flex;
  align-items: center;
  padding: 6px 10px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent-soft) 58%, transparent);
  color: var(--accent-strong);
  font-size: 12px;
  font-weight: 600;
}

.marketing-chip--muted {
  background: rgba(148, 163, 184, 0.12);
  color: var(--muted);
}

.marketing-detail__asset {
  min-height: 140px;
  border-radius: 16px;
  border: 1px dashed rgba(148, 163, 184, 0.28);
  background: rgba(255, 255, 255, 0.52);
  display: grid;
  place-items: center;
  padding: 14px;
  overflow: hidden;
}

.marketing-detail__asset img {
  width: 100%;
  height: 100%;
  max-height: 260px;
  object-fit: cover;
  border-radius: 12px;
}

.marketing-detail__asset a {
  color: var(--accent-strong);
  font-weight: 700;
  text-align: center;
  word-break: break-word;
}

.marketing-empty {
  padding: 48px 24px;
  text-align: center;
}

.marketing-empty h3 {
  margin: 0 0 8px;
  color: var(--text);
}

.marketing-empty p {
  margin: 0;
  color: var(--muted);
}

body[data-theme="dark"] .marketing-views,
body[data-theme="dark"] .marketing-detail__card,
body[data-theme="dark"] .marketing-table-wrap,
body[data-theme="dark"] .marketing-calendar-group,
body[data-theme="dark"] .marketing-empty {
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--accent-2) 16%, transparent), transparent 34%),
    linear-gradient(160deg, rgba(15, 23, 42, 0.84), rgba(15, 23, 42, 0.72));
}

body[data-theme="dark"] .marketing-summary__item {
  background: linear-gradient(160deg, rgba(30, 41, 59, 0.88), rgba(15, 23, 42, 0.72));
}

body[data-theme="dark"] .marketing-header__eyebrow,
body[data-theme="dark"] .marketing-view.is-active,
body[data-theme="dark"] .marketing-calendar-card__status,
body[data-theme="dark"] .marketing-chip {
  color: var(--accent-strong);
}

body[data-theme="dark"] .marketing-table th,
body[data-theme="dark"] .marketing-table td,
body[data-theme="dark"] .marketing-calendar-card,
body[data-theme="dark"] .marketing-detail__asset {
  background: rgba(15, 23, 42, 0.46);
}

body[data-theme="dark"] .marketing-row:hover td,
body[data-theme="dark"] .marketing-row.is-selected td {
  background: rgba(30, 41, 59, 0.86);
}

@media (max-width: 1440px) {
  .marketing-layout {
    grid-template-columns: 220px minmax(0, 1fr);
  }

  .marketing-detail {
    grid-column: 1 / -1;
    position: static;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 1080px) {
  .marketing-header {
    flex-direction: column;
  }

  .marketing-layout {
    grid-template-columns: 1fr;
  }

  .marketing-views,
  .marketing-detail {
    position: static;
  }

  .marketing-detail {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .marketing-summary {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .marketing-detail__grid {
    grid-template-columns: 1fr;
  }

  .marketing-table {
    min-width: 860px;
  }
}

/* Marketing overview refresh */
.marketing-shell {
  --marketing-accent: var(--accent);
}

.marketing-header__eyebrow {
  border-color: var(--input-border);
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent-2) 14%, transparent), rgba(255, 255, 255, 0.78));
  color: var(--accent-strong);
}

.marketing-header {
  gap: 16px;
}

.marketing-header__actions {
  gap: 10px;
}

.marketing-header__actions .btn {
  height: 40px;
  padding-inline: 15px;
}

.marketing-summary {
  gap: 10px;
}

.marketing-summary__item {
  border: 1px solid var(--glass-border);
  background: linear-gradient(155deg, var(--glass-strong), rgba(255, 255, 255, 0.54));
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.08);
  border-radius: 15px;
  padding: 12px 14px;
  min-height: 84px;
  gap: 4px;
}

.marketing-summary__item--primary {
  border-color: var(--input-border);
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--accent-2) 16%, transparent), transparent 42%),
    linear-gradient(155deg, var(--glass-strong), rgba(255, 255, 255, 0.56));
}

.marketing-summary__label {
  font-size: 10px;
  letter-spacing: 0.08em;
}

.marketing-summary__item strong {
  font-size: 26px;
  line-height: 1;
}

.marketing-hint {
  margin: 8px 0 14px;
  font-size: 11px;
  line-height: 1.5;
}

.marketing-layout--overview {
  grid-template-columns: minmax(0, 1fr) 468px;
  gap: 14px;
}

.marketing-main {
  min-width: 0;
}

.marketing-analytics {
  display: grid;
  gap: 12px;
  position: sticky;
  top: 10px;
  align-self: start;
}

.marketing-chart-card {
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--accent-2) 14%, transparent), transparent 34%),
    linear-gradient(160deg, var(--glass-strong), var(--glass));
  box-shadow: 0 18px 34px rgba(15, 23, 42, 0.08);
  padding: 14px;
  display: grid;
  gap: 12px;
}

.marketing-chart-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.marketing-chart-card__head h3 {
  margin: 0;
  color: var(--text);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.marketing-chart-card__head p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 11px;
  line-height: 1.42;
}

.marketing-chart-card__counter {
  min-width: 38px;
  height: 38px;
  border-radius: 12px;
  border: 1px solid var(--glass-border);
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.76), color-mix(in srgb, var(--accent-2) 12%, transparent));
  display: inline-grid;
  place-items: center;
  color: var(--accent-strong);
  font-size: 16px;
  font-weight: 700;
}

.marketing-donut-panel {
  display: grid;
  gap: 12px;
}

.marketing-donut {
  position: relative;
  width: 154px;
  height: 154px;
  margin: 0 auto;
}

.marketing-donut__ring {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  border: 1px solid var(--glass-border);
  background: linear-gradient(180deg, rgba(148, 163, 184, 0.16), rgba(148, 163, 184, 0.04));
}

.marketing-donut__ring::after {
  content: "";
  position: absolute;
  inset: 22px;
  border-radius: 50%;
  background: linear-gradient(180deg, var(--glass-strong), rgba(255, 255, 255, 0.84));
  border: 1px solid var(--glass-border);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.48);
}

.marketing-donut__center {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  align-content: center;
  text-align: center;
  z-index: 1;
  pointer-events: none;
}

.marketing-donut__center strong {
  color: var(--text);
  font-size: 30px;
  line-height: 1;
}

.marketing-donut__center span {
  margin-top: 4px;
  color: var(--muted);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.marketing-legend,
.marketing-bar-list,
.marketing-progress-list {
  display: grid;
  gap: 8px;
}

.marketing-legend__item,
.marketing-bar-list__item {
  border-radius: 12px;
  border: 1px solid var(--glass-border);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.22), rgba(148, 163, 184, 0.08));
  padding: 6px 8px;
}

.marketing-legend__item {
  display: grid;
  grid-template-columns: 10px minmax(0, 1fr);
  gap: 6px;
  align-items: center;
}

.marketing-legend__swatch {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  box-shadow: 0 0 0 1px rgba(15, 23, 42, 0.08);
}

.marketing-legend__text strong,
.marketing-bar-list__head strong {
  display: block;
  color: var(--text);
  font-size: 12px;
}

.marketing-legend__text span,
.marketing-bar-list__head span {
  display: block;
  margin-top: 2px;
  color: var(--muted);
  font-size: 10px;
  letter-spacing: 0.03em;
}

.marketing-bar-list__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 8px;
}

.marketing-bar-list__track {
  height: 7px;
  border-radius: 999px;
  background: rgba(148, 163, 184, 0.14);
  overflow: hidden;
}

.marketing-bar-list__fill {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
}

.marketing-chart-empty {
  margin: 0;
  color: var(--muted);
  font-size: 11px;
  line-height: 1.45;
}

.marketing-table-wrap {
  border-radius: 16px;
  border: 1px solid var(--glass-border);
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--accent-2) 10%, transparent), transparent 30%),
    linear-gradient(160deg, var(--glass-strong), var(--glass));
  box-shadow: 0 18px 34px rgba(15, 23, 42, 0.08);
}

.marketing-table {
  min-width: 980px;
}

.marketing-table thead th {
  padding: 10px 12px;
  font-size: 11px;
}

.marketing-col--title {
  width: 250px;
}

.marketing-col--date {
  width: 98px;
}

.marketing-col--body {
  width: 430px;
}

.marketing-col--notes {
  width: 238px;
}

.marketing-col--graphic {
  width: 176px;
}

.marketing-table tbody td {
  padding: 6px 8px;
  font-size: 11px;
  line-height: 1.4;
}

.marketing-table th,
.marketing-table td {
  background: color-mix(in srgb, var(--glass-strong) 74%, transparent);
  border-bottom: 1px solid var(--glass-border);
  border-right: 1px solid rgba(148, 163, 184, 0.12);
}

.marketing-table thead th {
  background: color-mix(in srgb, var(--glass-strong) 88%, var(--accent-2-soft));
}

.marketing-row:hover td {
  background: color-mix(in srgb, var(--accent-2-soft) 40%, var(--glass-strong));
}

.marketing-row__title-link,
.marketing-asset-link {
  color: var(--text);
}

.marketing-row__title-link:hover,
.marketing-asset-link:hover {
  color: var(--accent-strong);
}

.marketing-row__stack {
  display: grid;
  gap: 4px;
  align-items: start;
}

.marketing-row__title,
.marketing-row__title-link {
  display: block;
  min-width: 0;
  color: var(--text);
  font-weight: 700;
  font-size: 11px;
  line-height: 1.28;
  text-wrap: pretty;
}

.marketing-row__title-link--stacked {
  text-decoration: none;
}

.marketing-label-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 5px;
  min-height: 18px;
}

.marketing-github-label {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 18px;
  max-width: 100%;
  padding: 2px 7px;
  border-radius: 999px;
  background: var(--marketing-label-bg, #d0d7de);
  color: var(--marketing-label-fg, #1f2328);
  font-size: 10px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0;
  white-space: nowrap;
  box-shadow: inset 0 0 0 1px rgba(31, 35, 40, 0.08);
}

.marketing-github-label--fallback {
  background: color-mix(in srgb, var(--accent-soft) 42%, white);
  color: var(--accent-strong);
}

.marketing-row__context {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  min-width: 0;
  color: var(--muted);
  font-size: 11px;
  line-height: 1.3;
}

.marketing-row__issue-ref {
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.marketing-cell--title {
  width: 250px;
  min-width: 250px;
  max-width: 280px;
}

.marketing-cell--date {
  min-width: 94px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}

.marketing-cell--body {
  width: 430px;
  min-width: 390px;
}

.marketing-cell--notes {
  width: 238px;
  min-width: 220px;
}

.marketing-cell--graphic {
  width: 176px;
  min-width: 176px;
}

.marketing-asset-gallery {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
  max-height: 148px;
  overflow: auto;
  padding-right: 4px;
}

.marketing-asset-gallery--single {
  grid-template-columns: 1fr;
  max-height: none;
  overflow: visible;
  padding-right: 0;
}

.marketing-asset-gallery::-webkit-scrollbar {
  width: 6px;
}

.marketing-asset-gallery::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: var(--scrollbar-thumb);
}

.marketing-asset-gallery::-webkit-scrollbar-track {
  background: transparent;
}

.marketing-cell__scroll {
  max-height: 8.4em;
  overflow: auto;
  padding-right: 4px;
  white-space: pre-line;
  line-height: 1.4;
}

.marketing-cell__scroll::-webkit-scrollbar {
  width: 8px;
}

.marketing-cell__scroll::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: var(--scrollbar-thumb);
}

.marketing-cell__scroll::-webkit-scrollbar-track {
  background: transparent;
}

.marketing-note-stack {
  display: grid;
  gap: 6px;
}

.marketing-note-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 6px 10px;
  min-height: 16px;
}

.marketing-note-meta[hidden] {
  display: none;
}

.marketing-note-meta__author {
  color: var(--text);
  font-size: 11px;
  font-weight: 700;
  line-height: 1.2;
}

.marketing-note-meta__time,
.marketing-note-meta__status,
.marketing-note-empty {
  color: var(--muted);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  line-height: 1.2;
}

.marketing-note-meta__status[hidden],
.marketing-note-empty[hidden] {
  display: none;
}

.marketing-note-empty {
  margin: 0;
}

.marketing-note-field {
  width: 100%;
  min-height: 56px;
  max-height: 180px;
  resize: none;
  padding: 8px 10px;
  border-radius: 14px;
  border: 1px solid var(--notes-border);
  background: var(--notes-bg);
  color: var(--text);
  font: inherit;
  font-size: 11px;
  line-height: 1.4;
  outline: none;
  overflow: hidden;
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
}

.marketing-note-field:focus {
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--focus);
}

.marketing-asset-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 64px;
  border-radius: 10px;
  border: 1px solid var(--glass-border);
  background: rgba(255, 255, 255, 0.5);
  overflow: hidden;
}

.marketing-asset-link img {
  width: 100%;
  height: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  border-radius: 9px;
}

.marketing-asset-link--gallery {
  min-height: 52px;
}

.marketing-asset-link--single {
  min-height: 72px;
}

.marketing-asset-link--text {
  width: auto;
  min-width: 0;
  padding: 9px 10px;
  text-align: center;
  font-size: 11px;
  font-weight: 600;
  word-break: break-word;
}

.marketing-asset-link--resource {
  display: grid;
  grid-column: 1 / -1;
  align-content: start;
  justify-items: start;
  gap: 4px;
  min-height: 64px;
  padding: 10px 11px;
  text-align: left;
}

.marketing-asset-link__eyebrow {
  color: var(--accent-strong);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.marketing-asset-link--resource strong {
  color: var(--text);
  font-size: 12px;
  line-height: 1.35;
  text-wrap: balance;
}

.marketing-asset-link__meta {
  color: var(--muted);
  font-size: 10px;
  line-height: 1.35;
  word-break: break-word;
}

body[data-theme="dark"] .marketing-chart-card,
body[data-theme="dark"] .marketing-table-wrap {
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--accent-2) 16%, transparent), transparent 30%),
    linear-gradient(160deg, rgba(10, 22, 36, 0.84), rgba(17, 38, 60, 0.74));
}

body[data-theme="dark"] .marketing-donut__ring::after {
  background: linear-gradient(180deg, rgba(10, 22, 36, 0.92), rgba(17, 38, 60, 0.86));
}

body[data-theme="dark"] .marketing-table th,
body[data-theme="dark"] .marketing-table td,
body[data-theme="dark"] .marketing-legend__item,
body[data-theme="dark"] .marketing-bar-list__item,
body[data-theme="dark"] .marketing-asset-link {
  background: rgba(15, 23, 42, 0.46);
}

body[data-theme="dark"] .marketing-github-label--fallback {
  background: color-mix(in srgb, var(--accent-2-soft) 42%, rgba(15, 23, 42, 0.94));
}

body[data-theme="dark"] .marketing-row:hover td {
  background: color-mix(in srgb, var(--accent-soft) 42%, rgba(15, 23, 42, 0.88));
}

@media (max-width: 1440px) {
  .marketing-layout--overview {
    grid-template-columns: minmax(0, 1fr) 408px;
  }
}

@media (max-width: 1180px) {
  .marketing-layout--overview {
    grid-template-columns: 1fr;
  }

  .marketing-analytics {
    position: static;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 920px) {
  .marketing-analytics {
    grid-template-columns: 1fr;
  }

  .marketing-chart-card__head {
    flex-direction: column;
    align-items: stretch;
  }
}

.board--developer-kanban {
  height: calc(100% - 10px);
  min-height: 0;
}

/* Developer Kanban */
.board__panel--developer-kanban {
  height: 100%;
  min-height: 0;
  padding: 18px;
  display: flex;
  flex-direction: column;
  overflow: visible;
}

.board__head--developer-kanban {
  display: grid;
  gap: 6px;
  flex: 0 0 auto;
}

.board__head--developer-kanban .board__head-actions {
  margin-left: 0;
  padding-top: 0;
  justify-content: flex-end;
  flex: 0 0 auto;
}

.developer-board__head-main {
  display: grid;
  min-width: 0;
  gap: 4px;
}

.developer-board__head-row {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.developer-board__back {
  width: fit-content;
  text-decoration: none;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
}

.developer-board__back:hover {
  color: var(--accent-strong);
}

.developer-board__company {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
  flex: 0 1 360px;
}

.company__badge--developer {
  position: static;
  top: auto;
  right: auto;
  inset: auto;
  flex: 0 0 auto;
  transform: translateZ(0);
}

.developer-board__copy {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.developer-board-views {
  flex: 1 1 auto;
  min-width: 0;
  margin-top: 0;
  padding: 4px 8px;
  border-radius: 12px;
  border: 1px solid rgba(93, 135, 167, 0.12);
  background: rgba(255, 255, 255, 0.22);
  box-shadow: none;
  display: flex;
  align-items: center;
}

.developer-board-views__bar {
  width: 100%;
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 8px;
}

.developer-board-views__topline {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  flex: 0 1 auto;
  min-width: 0;
}

.developer-board-views__tabs {
  flex: 0 1 190px;
  min-width: 0;
  max-width: 230px;
  display: flex;
  gap: 6px;
  overflow-x: auto;
  overflow-y: hidden;
  padding-block: 2px;
  margin-block: -2px;
  scrollbar-width: thin;
}

.developer-board-view-tab,
.developer-board-views__new {
  border-radius: 10px;
  border: 1px solid rgba(93, 135, 167, 0.16);
  background: rgba(255, 255, 255, 0.12);
  color: var(--text);
  transition:
    transform var(--duration) var(--ease-out),
    border-color var(--duration) var(--ease-out),
    background var(--duration) var(--ease-out),
    color var(--duration) var(--ease-out);
}

.developer-board-view-tab {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 9px;
  white-space: nowrap;
  cursor: pointer;
  font-size: 11px;
  font-weight: 600;
  line-height: 1.15;
}

.developer-board-view-tab:hover,
.developer-board-views__new:hover {
  transform: translateY(-1px);
  border-color: var(--accent);
  background: rgba(255, 255, 255, 0.18);
}

.developer-board-view-tab.is-active {
  border-color: color-mix(in srgb, var(--accent) 42%, rgba(15, 23, 42, 0.1));
  background: rgba(93, 135, 167, 0.11);
  box-shadow: none;
}

.developer-board-view-tab.is-dirty::after {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 68%, #ffffff);
  box-shadow: 0 0 0 1px rgba(15, 23, 42, 0.08);
}

.developer-board-views__new {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 9px;
  cursor: pointer;
  font-size: 11px;
  font-weight: 600;
  line-height: 1.15;
}

.developer-board-views__filterbar {
  display: flex;
  align-items: center;
  gap: 6px;
  flex: 1 1 auto;
  min-width: 0;
  flex-wrap: nowrap;
}

.developer-board-views__filters {
  flex: 1 1 auto;
  width: auto;
  max-width: none;
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 6px;
  justify-content: flex-start;
  flex-wrap: nowrap;
}

.developer-board-filter-group--labels {
  flex: 1 1 auto;
  width: auto;
  min-width: 180px;
  max-width: none;
}

.developer-board-filter-group--compact {
  flex: 0 0 160px;
  min-width: 160px;
}

.developer-board-filter-group {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 8px;
  border-radius: 10px;
  border: 1px solid rgba(93, 135, 167, 0.12);
  background: rgba(255, 255, 255, 0.18);
  box-sizing: border-box;
}

.developer-board-filter-group > span,
.developer-board-filter-group__title {
  display: inline-flex;
  align-items: center;
  flex: 0 0 auto;
  font-size: 9px;
  line-height: 1.15;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--muted);
  white-space: nowrap;
}

.developer-board-filter-group select {
  width: 100%;
  min-height: 30px;
  padding: 0 9px;
  border-radius: 10px;
  border: 1px solid rgba(93, 135, 167, 0.14);
  background: rgba(255, 255, 255, 0.62);
  color: var(--text);
  box-sizing: border-box;
  font-size: 12px;
}

.developer-board-filter-group select:focus {
  border-color: var(--focus);
  box-shadow: 0 0 0 2px var(--focus);
  outline: none;
}

.developer-board-filter-group .filter-combobox {
  flex: 1 1 auto;
  width: 100%;
  min-width: 0;
}

.developer-board-filter-group .filter-combobox__control {
  min-height: 30px;
  padding-left: 9px;
  padding-right: 4px;
  border-radius: 10px;
  border: 1px solid rgba(93, 135, 167, 0.14);
  background: rgba(255, 255, 255, 0.62);
  box-sizing: border-box;
}

.developer-board-filter-group .filter-combobox__input {
  height: 28px;
  padding-top: 5px;
  padding-bottom: 5px;
  font-size: 12px;
}

.developer-board-filter-group .filter-combobox__clear,
.developer-board-filter-group .filter-combobox__toggle {
  width: 28px;
  height: 28px;
}

.developer-board-filter-group .filter-combobox__menu {
  left: 0;
  right: 0;
  top: calc(100% + 4px);
  padding: 3px;
  border-radius: 10px;
}

.developer-board-filter-group .filter-combobox__list {
  gap: 2px;
}

.developer-board-filter-group .filter-combobox__option {
  padding: 7px 9px;
  border-radius: 8px;
  font-size: 12px;
  line-height: 1.1;
}

.developer-board-filter-group__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  align-items: center;
  width: auto;
  max-width: 100%;
}

.developer-board-filter-group__chips--compact {
  min-height: 0;
}

.developer-board-filter-chip {
  --developer-filter-chip-color: #5d87a7;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 7px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--developer-filter-chip-color) 18%, rgba(93, 135, 167, 0.12));
  background: color-mix(in srgb, var(--developer-filter-chip-color) 8%, rgba(255, 255, 255, 0.22));
  color: var(--text);
  cursor: pointer;
  font-size: 10px;
  font-weight: 600;
  line-height: 1.2;
  transition:
    transform var(--duration) var(--ease-out),
    border-color var(--duration) var(--ease-out),
    background var(--duration) var(--ease-out);
}

.developer-board-filter-chip:hover {
  transform: translateY(-1px);
}

.developer-board-filter-chip.is-active {
  border-color: color-mix(in srgb, var(--developer-filter-chip-color) 28%, rgba(15, 23, 42, 0.18));
  background: color-mix(in srgb, var(--developer-filter-chip-color) 16%, rgba(255, 255, 255, 0.32));
  box-shadow: none;
}

.developer-board-filter-chip--ghost {
  cursor: default;
  border-style: dashed;
  opacity: 0.72;
}

.developer-board-views__actions {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  flex-wrap: nowrap;
  justify-content: center;
}

.developer-board-views__actions .btn {
  min-height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
}

.developer-board-views__hint {
  display: none;
}

.developer-board-views__hint code,
.developer-view-form .developer-form__hint code {
  padding: 1px 5px;
  border-radius: 999px;
  background: rgba(93, 135, 167, 0.12);
  color: var(--text);
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  font-size: 0.96em;
}

.developer-kanban {
  flex: 1 1 auto;
  height: 100%;
  min-height: 0;
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(320px, 336px);
  gap: 16px;
  align-items: stretch;
  overflow-x: auto;
  overflow-y: hidden;
  overscroll-behavior-x: contain;
  padding: 8px 2px 2px;
  margin-top: 8px;
}

@media (max-width: 1420px) {
  .developer-board__head-row {
    flex-direction: column;
    align-items: stretch;
  }

  .developer-board__company {
    flex: 0 1 auto;
    max-width: none;
  }

  .developer-board-views__bar,
  .developer-board-views__filterbar,
  .developer-board-views__filters {
    flex-wrap: wrap;
  }

  .developer-board-views__tabs {
    flex: 1 1 100%;
    max-width: none;
  }

  .developer-board-filter-group--labels,
  .developer-board-filter-group--compact {
    flex: 1 1 auto;
  }
}

.developer-column {
  --developer-column-color: #5d87a7;
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 0;
  height: 100%;
  max-height: 100%;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid var(--glass-border);
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--developer-column-color) 10%, transparent), transparent 40%),
    linear-gradient(168deg, color-mix(in srgb, var(--glass-strong) 95%, white) 0%, color-mix(in srgb, var(--glass) 97%, transparent) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.26);
  overflow: hidden;
  isolation: isolate;
}

.developer-column.is-filter-empty {
  opacity: 0.5;
}

.developer-column__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.developer-column__title-wrap {
  display: flex;
  align-items: center;
  gap: 9px;
  min-width: 0;
  flex-wrap: wrap;
}

.developer-column__dot {
  width: 14px;
  height: 14px;
  border-radius: 999px;
  flex: 0 0 auto;
  background: var(--developer-column-color);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--developer-column-color) 74%, rgba(15, 23, 42, 0.24)),
    0 0 0 5px color-mix(in srgb, var(--developer-column-color) 16%, transparent);
}

.developer-column__title {
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.01em;
  color: var(--text);
}

.developer-column__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 26px;
  padding: 3px 8px 2px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--developer-column-color) 18%, var(--glass-border));
  background: color-mix(in srgb, var(--developer-column-color) 14%, transparent);
  font-size: 11px;
  font-weight: 600;
  color: var(--text);
}

.developer-column__edit,
.developer-column__add {
  border-radius: 12px;
  border: 1px solid var(--glass-border-strong);
  background: rgba(255, 255, 255, 0.18);
  color: var(--text);
  cursor: pointer;
  transition:
    transform var(--duration) var(--ease-out),
    border-color var(--duration) var(--ease-out),
    background var(--duration) var(--ease-out);
}

.developer-column__edit:hover,
.developer-column__add:hover {
  transform: translateY(-1px);
  border-color: var(--accent);
  background: rgba(255, 255, 255, 0.28);
}

.developer-column__edit {
  padding: 8px 10px;
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.developer-column__list {
  min-height: 0;
  flex: 1 1 auto;
  display: grid;
  align-content: start;
  justify-items: stretch;
  gap: 8px;
  padding: 4px 2px 2px;
  border-radius: 14px;
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-width: thin;
  transition:
    background var(--duration) var(--ease-out),
    box-shadow var(--duration) var(--ease-out);
}

.developer-column__list.is-drop-target {
  background: rgba(93, 135, 167, 0.1);
  box-shadow: inset 0 0 0 1px rgba(93, 135, 167, 0.22);
}

.developer-column__empty {
  width: 100%;
  box-sizing: border-box;
  padding: 14px 12px;
  border-radius: 14px;
  border: 1px dashed var(--glass-border-strong);
  background: rgba(255, 255, 255, 0.08);
  color: var(--muted);
  font-size: 12px;
}

.developer-task[hidden],
.developer-column__empty[hidden] {
  display: none !important;
}

.developer-column__add {
  width: 100%;
  margin-top: 8px;
  padding: 11px 14px;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.developer-task {
  width: 100%;
  box-sizing: border-box;
  display: block;
  cursor: grab;
}

.developer-task--readonly {
  cursor: pointer;
}

.developer-task__surface {
  display: grid;
  gap: 9px;
  padding: 7px 11px;
  border-radius: 16px;
  border: 1px solid var(--glass-border-strong);
  border-left: 4px solid var(--developer-task-accent, var(--accent));
  background:
    linear-gradient(160deg, color-mix(in srgb, var(--card-bg) 96%, white) 0%, color-mix(in srgb, var(--notes-bg) 95%, transparent) 100%);
  box-shadow: 0 6px 14px rgba(15, 23, 42, 0.08);
  transition:
    transform var(--duration) var(--ease-out),
    box-shadow var(--duration) var(--ease-out),
    border-color var(--duration) var(--ease-out);
  will-change: transform, box-shadow;
}

.developer-task:hover .developer-task__surface {
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(15, 23, 42, 0.12);
}

.developer-task.is-dragging {
  cursor: grabbing;
  z-index: 2;
}

.developer-task.is-dragging .developer-task__surface {
  box-shadow: 0 16px 30px rgba(15, 23, 42, 0.14);
}

.developer-task.is-drag-hidden {
  opacity: 0.24;
}

.developer-task__top,
.developer-task__meta {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.developer-task__top {
  align-items: center;
  justify-content: space-between;
}

.developer-task__meta {
  align-items: center;
  justify-content: flex-start;
}

.developer-task__footer {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 6px;
}

.developer-task__footer .developer-task__meta {
  min-width: 0;
  flex: 1 1 auto;
}

.developer-task__ref {
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  min-width: 0;
  max-width: calc(100% - 48px);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.developer-task__title {
  margin: 0;
  font-size: 14px;
  line-height: 1.32;
  color: var(--text);
}

.developer-task__people,
.developer-task__assignees {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-left: auto;
  flex: 0 0 auto;
}

.developer-task__avatar {
  width: 24px;
  height: 24px;
  border-radius: 999px;
  overflow: hidden;
  display: inline-grid;
  place-items: center;
  background: var(--avatar-bg, rgba(15, 23, 42, 0.08));
  border: 1px solid var(--glass-border-strong);
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.62);
  color: var(--avatar-fg, var(--text));
}

.developer-task__avatar-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.developer-task__avatar-initial {
  font-size: 12px;
  line-height: 1;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: inherit;
}

.developer-task__label {
  --developer-label-color: var(--accent);
  display: inline-flex;
  align-items: center;
  min-height: 21px;
  padding: 3px 9px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--developer-label-color) 42%, transparent);
  background: color-mix(in srgb, var(--developer-label-color) 16%, transparent);
  color: var(--developer-label-color);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.developer-task__due,
.developer-task__assignee,
.developer-task__author {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 9px;
  border-radius: 999px;
  font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.developer-task__due {
  background: rgba(93, 135, 167, 0.14);
  color: var(--text);
}

.developer-task__due--overdue {
  background: rgba(239, 68, 68, 0.14);
  color: #b91c1c;
}

.developer-task__due--today {
  background: rgba(217, 119, 6, 0.16);
  color: #b45309;
}

.developer-task__attachment-badge {
  margin-left: auto;
  flex: 0 0 auto;
  align-self: flex-end;
  min-width: 20px;
  min-height: 20px;
  padding: 2px 6px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--developer-task-accent, var(--accent)) 24%, var(--glass-border-strong));
  background: color-mix(in srgb, white 88%, var(--developer-task-accent, var(--accent)) 12%);
  color: color-mix(in srgb, var(--developer-task-accent, var(--accent)) 76%, var(--text));
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 700;
  line-height: 1;
}

.developer-task-modal {
  inset: var(--header-offset) 0 0 0;
  min-height: calc(var(--viewport-height) - var(--header-offset));
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 18px 24px 24px;
  overflow-y: auto;
  overflow-x: hidden;
  box-sizing: border-box;
}

.developer-task-modal__panel {
  width: min(720px, calc(100% - 32px));
  margin: auto 0;
  max-height: calc(var(--viewport-height) - var(--header-offset) - 42px);
  padding: 12px 14px 14px;
  overflow-y: auto;
  overflow-x: hidden;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  transform-origin: var(--developer-task-origin-x, 50%) var(--developer-task-origin-y, 50%);
  flex: 0 0 auto;
}

.developer-column-modal__panel {
  width: min(560px, calc(100% - 32px));
}

.developer-view-modal__panel {
  width: min(620px, calc(100% - 32px));
}

.developer-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 12px;
  margin-top: 10px;
  align-items: start;
}

.developer-form__field {
  gap: 3px;
}

.developer-form__field input,
.developer-form__field select,
.developer-form__field textarea {
  width: 100%;
}

.developer-form__field input:not([type="hidden"]),
.developer-form__field select {
  min-height: 38px;
  box-sizing: border-box;
}

.developer-form__hint {
  margin: 0;
  font-size: 10px;
  line-height: 1.45;
  color: var(--muted);
}

.developer-form__field--full {
  grid-column: 1 / -1;
}

.developer-task-title-row {
  display: flex;
  gap: 10px;
  align-items: center;
}

.developer-task-title-row > input {
  flex: 1 1 auto;
  min-width: 0;
}

.developer-task-title-meta {
  min-width: 170px;
  padding: 6px 10px;
  border-radius: 12px;
  border: none;
  background: rgba(255, 255, 255, 0.56);
  display: grid;
  gap: 1px;
  align-content: center;
  box-sizing: border-box;
}

.developer-task-title-meta[hidden] {
  display: none;
}

.developer-task-title-meta__label {
  font-size: 10px;
  line-height: 1.15;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.developer-task-title-meta__value {
  font-size: 12px;
  line-height: 1.25;
  font-weight: 400;
  color: var(--text);
}

.developer-task-form__meta-grid {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 12px;
  align-items: stretch;
}

.developer-task-form__meta-grid > .developer-form__field {
  min-height: 0;
  min-width: 0;
  display: grid;
  grid-template-rows: auto auto;
  align-content: start;
}

.developer-task-form__meta-grid > .developer-form__field > .developer-form__hint {
  min-height: 12px;
}

.developer-form__hint--ghost {
  visibility: hidden;
}

.developer-task-form__meta-grid .developer-label-picker__selection {
  min-height: 38px;
  height: 38px;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 0 8px;
  border-radius: var(--radius-md);
  border: 1px solid var(--input-border);
  background: var(--input-bg);
  box-shadow: none;
  box-sizing: border-box;
  overflow: hidden;
}

.developer-task-form__meta-grid .developer-label-picker__selection:focus-within,
.developer-task-form__meta-grid .developer-label-picker.is-open .developer-label-picker__selection {
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--focus);
}

.developer-task-form__meta-grid .developer-color-picker__trigger {
  min-height: 38px;
  height: 38px;
  padding-top: 4px;
  padding-bottom: 4px;
}

.developer-form__field textarea {
  min-height: 152px;
  resize: vertical;
}

.developer-task-form .tox-tinymce {
  border-radius: 14px;
  border-color: var(--input-border);
  background: var(--input-bg);
  box-shadow: none;
}

.developer-task-form .tox .tox-editor-header {
  border-bottom-color: var(--glass-border-strong);
}

.developer-task-form .tox .tox-toolbar,
.developer-task-form .tox .tox-toolbar__primary,
.developer-task-form .tox .tox-toolbar-overlord {
  background: transparent;
}

.developer-task-form .tox .tox-edit-area::before {
  border-radius: 0 0 14px 14px;
}

.developer-task-attachments {
  gap: 8px;
}

.developer-task-attachments__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.developer-task-attachments__copy {
  min-width: 0;
  display: grid;
  gap: 0;
}

.developer-task-attachments__copy > span {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  line-height: 1;
  text-transform: uppercase;
  color: var(--muted);
}

.developer-task-attachments__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  min-height: 26px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid var(--glass-border-strong);
  background: rgba(255, 255, 255, 0.16);
  color: var(--text);
  font-size: 11px;
  font-weight: 700;
  flex: 0 0 auto;
}

.developer-task-attachments__upload {
  display: grid;
  place-items: center;
  min-height: 46px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px dashed color-mix(in srgb, var(--accent) 28%, var(--glass-border-strong));
  background:
    linear-gradient(160deg, color-mix(in srgb, var(--card-bg) 96%, white) 0%, color-mix(in srgb, var(--notes-bg) 94%, transparent) 100%);
  color: var(--text);
  font-family: var(--font-body);
  letter-spacing: 0;
  text-transform: none;
  text-align: center;
  cursor: pointer;
  transition:
    border-color var(--duration) var(--ease-out),
    background var(--duration) var(--ease-out),
    box-shadow var(--duration) var(--ease-out),
    transform var(--duration) var(--ease-out);
}

.developer-task-attachments__file-input {
  display: none;
}

.developer-task-attachments__upload:hover,
.developer-task-attachments__upload:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 42%, var(--glass-border-strong));
  background:
    linear-gradient(160deg, color-mix(in srgb, var(--card-bg) 98%, white) 0%, color-mix(in srgb, var(--notes-bg) 96%, transparent) 100%);
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.08);
  transform: translateY(-1px);
  outline: none;
}

.developer-task-attachments__upload.is-disabled {
  opacity: 0.72;
  cursor: default;
  transform: none;
  box-shadow: none;
}

.developer-task-attachments__upload-text {
  font-family: inherit;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0;
  text-transform: none;
  color: color-mix(in srgb, var(--muted) 88%, var(--text));
}

.developer-task-attachments__copy > .developer-form__hint:empty {
  display: none;
}

.developer-task-attachments__list {
  display: grid;
  gap: 10px;
}

.developer-task-attachments__empty {
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px dashed var(--glass-border-strong);
  background: rgba(255, 255, 255, 0.08);
  color: var(--muted);
  font-size: 12px;
  line-height: 1.5;
}

.developer-task-attachment {
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 11px 12px;
  border-radius: 16px;
  border: 1px solid var(--glass-border-strong);
  background:
    linear-gradient(160deg, color-mix(in srgb, var(--card-bg) 96%, white) 0%, color-mix(in srgb, var(--notes-bg) 96%, transparent) 100%);
  box-shadow: 0 12px 24px rgba(15, 23, 42, 0.08);
}

.developer-task-attachment--queued {
  border-style: dashed;
}

.developer-task-attachment--uploading {
  border-color: color-mix(in srgb, var(--accent) 32%, var(--glass-border-strong));
}

.developer-task-attachment--error {
  border-color: rgba(239, 68, 68, 0.22);
}

.developer-task-attachment__preview {
  width: 92px;
  height: 72px;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid var(--glass-border-strong);
  background: color-mix(in srgb, var(--glass) 90%, var(--card-bg));
  display: grid;
  place-items: center;
  flex: 0 0 auto;
}

.developer-task-attachment__preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.developer-task-attachment__placeholder {
  font-size: 22px;
  font-weight: 700;
  color: color-mix(in srgb, var(--accent) 54%, var(--muted));
}

.developer-task-attachment__content {
  min-width: 0;
  display: grid;
  gap: 4px;
}

.developer-task-attachment__name {
  font-size: 12px;
  font-weight: 700;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.developer-task-attachment__meta,
.developer-task-attachment__error {
  font-size: 11px;
  line-height: 1.45;
}

.developer-task-attachment__meta {
  color: var(--muted);
}

.developer-task-attachment__error {
  color: #b91c1c;
}

.developer-task-attachment__actions {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
}

.developer-task-attachment__action {
  width: 30px;
  height: 30px;
  border-radius: 10px;
  border: 1px solid var(--glass-border-strong);
  background: rgba(255, 255, 255, 0.7);
  color: var(--text);
  display: inline-grid;
  place-items: center;
  font-size: 18px;
  line-height: 1;
  transition:
    transform var(--duration) var(--ease-out),
    border-color var(--duration) var(--ease-out),
    background var(--duration) var(--ease-out),
    box-shadow var(--duration) var(--ease-out);
}

.developer-task-attachment__action .fa-solid.fa-trash,
.developer-task-attachment__action .fa-regular.fa-trash {
  width: 14px;
  height: 14px;
}

.developer-task-attachment__action:hover,
.developer-task-attachment__action:focus-visible {
  transform: translateY(-1px);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 10px 20px rgba(15, 23, 42, 0.1);
  outline: none;
}

.developer-task-attachment__action--delete {
  border-color: rgba(239, 68, 68, 0.18);
  color: #b91c1c;
}

.developer-task-attachment__action--delete:hover,
.developer-task-attachment__action--delete:focus-visible {
  border-color: rgba(239, 68, 68, 0.32);
  background: rgba(254, 242, 242, 0.96);
  box-shadow: 0 10px 20px rgba(239, 68, 68, 0.12);
}

.developer-task-form [hidden],
.developer-task-comments__form [hidden] {
  display: none !important;
}

.developer-task-form.is-readonly .developer-form__field input:not([type="hidden"]):read-only,
.developer-task-form.is-readonly .developer-form__field textarea:read-only,
.developer-task-form.is-readonly .developer-form__field input:disabled,
.developer-task-form.is-readonly .developer-form__field select:disabled {
  opacity: 0.82;
  cursor: default;
  background: color-mix(in srgb, var(--glass) 86%, var(--card-bg));
  color: var(--text);
  -webkit-text-fill-color: var(--text);
}

.developer-task-form.is-readonly .developer-form__field textarea:disabled,
.developer-task-form.is-readonly .developer-form__field input:disabled,
.developer-task-form.is-readonly .developer-form__field select:disabled,
.developer-task-form.is-readonly .developer-mention-field {
  pointer-events: none;
}

.developer-task-form.is-readonly .developer-form__hint {
  color: color-mix(in srgb, var(--muted) 86%, var(--text));
}

.developer-label-picker {
  position: relative;
  isolation: isolate;
  min-width: 0;
  --developer-label-menu-bg:
    linear-gradient(180deg, rgba(255, 255, 255, 0.97) 0%, rgba(244, 247, 251, 0.94) 100%);
  --developer-label-menu-border: rgba(148, 163, 184, 0.24);
  --developer-label-menu-shadow: 0 22px 40px rgba(15, 23, 42, 0.18);
  --developer-label-menu-item-hover: rgba(148, 163, 184, 0.14);
  --developer-label-menu-name: var(--text);
  --developer-label-menu-meta: var(--muted);
  --developer-label-menu-empty-bg: rgba(148, 163, 184, 0.08);
  --developer-label-menu-empty-color: var(--muted);
}

.developer-label-picker__selection {
  display: grid;
  gap: 10px;
  min-height: 48px;
  padding: 10px 12px;
  border-radius: 16px;
  border: 1px solid rgba(148, 163, 184, 0.22);
  background: rgba(255, 255, 255, 0.84);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.34);
}

.developer-label-picker__chips {
  display: inline-flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 4px;
  flex: 0 1 auto;
  max-width: 100%;
  min-width: 0;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: none;
  scroll-behavior: smooth;
}

.developer-label-picker__chips::-webkit-scrollbar {
  display: none;
}

.developer-label-picker__composer {
  display: flex;
  align-items: center;
  gap: 6px;
  flex: 1 1 auto;
  min-width: 0;
  height: 100%;
}

.developer-label-picker.is-empty .developer-label-picker__composer {
  flex: 1 1 auto;
  min-width: 0;
}

.developer-label-picker input {
  width: 84px;
  flex: 1 1 84px;
  min-width: 0;
  min-height: 20px;
  border: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
  font-size: 12px;
  line-height: 1.3;
}

.developer-label-picker.is-empty input {
  width: 100%;
  flex: 1 1 auto;
}

.developer-label-picker input:focus {
  box-shadow: none;
}

.developer-label-picker__add {
  flex: 0 0 auto;
  height: 24px;
  min-height: 24px;
  padding: 0 8px;
  border: 1px solid rgba(93, 135, 167, 0.22);
  border-radius: 999px;
  background: rgba(93, 135, 167, 0.12);
  color: var(--text);
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 0.01em;
  text-transform: none;
  cursor: pointer;
  transition:
    transform var(--duration) var(--ease-out),
    background var(--duration) var(--ease-out),
    border-color var(--duration) var(--ease-out);
}

.developer-label-picker__add:hover,
.developer-label-picker__add:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(93, 135, 167, 0.34);
  background: rgba(93, 135, 167, 0.18);
  outline: none;
}

.developer-label-picker__add:disabled {
  cursor: default;
  opacity: 0.55;
  transform: none;
}

.developer-label-picker__toggle {
  position: relative;
  width: 14px;
  height: 10px;
  flex: 0 0 auto;
  margin: 0 2px 0 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: color-mix(in srgb, var(--text) 68%, var(--muted));
  display: inline-grid;
  place-items: center;
  cursor: pointer;
  transition:
    color var(--duration) var(--ease-out),
    transform var(--duration) var(--ease-out);
}

.developer-label-picker__toggle::before {
  content: none;
}

.developer-label-picker__toggle:hover,
.developer-label-picker.is-open .developer-label-picker__toggle {
  background: transparent;
  color: var(--text);
  box-shadow: none;
}

.developer-label-picker__toggle:disabled {
  cursor: default;
  opacity: 0.5;
}

.developer-label-picker__toggle:focus-visible {
  outline: none;
  color: var(--text);
}

.developer-label-picker__caret {
  width: 10px;
  height: 6px;
  display: inline-block;
  background-image:
    linear-gradient(45deg, transparent 50%, currentColor 50%),
    linear-gradient(135deg, currentColor 50%, transparent 50%);
  background-position: left center, right center;
  background-size: 50% 100%;
  background-repeat: no-repeat;
  opacity: 0.72;
  transition: transform var(--duration) var(--ease-out);
}

.developer-label-picker.is-open .developer-label-picker__caret {
  transform: rotate(180deg);
}

.developer-label-picker__menu {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  z-index: 32;
  width: min(220px, 100%);
  max-height: 160px;
  overflow-y: auto;
  padding: 8px;
  border-radius: 16px;
  border: 1px solid var(--developer-label-menu-border);
  background: var(--developer-label-menu-bg);
  box-shadow: var(--developer-label-menu-shadow);
  backdrop-filter: blur(10px) saturate(140%);
  -webkit-backdrop-filter: blur(10px) saturate(140%);
  transform-origin: top right;
}

.developer-task-form .developer-label-picker__menu {
  top: auto;
  bottom: calc(100% + 8px);
  transform-origin: bottom right;
}

.developer-label-picker__menu[hidden] {
  display: none !important;
}

.developer-label-picker__list {
  display: grid;
  gap: 4px;
}

.developer-label-picker__item,
.developer-label-picker__empty {
  width: 100%;
  border: 0;
  border-radius: 10px;
  padding: 8px 10px;
  text-align: left;
}

.developer-label-picker__item {
  display: grid;
  gap: 4px;
  background: transparent;
  color: var(--developer-label-menu-name);
  cursor: pointer;
  transition: background var(--duration) var(--ease-out), transform var(--duration) var(--ease-out);
}

.developer-label-picker__item:hover,
.developer-label-picker__item:focus-visible {
  background: var(--developer-label-menu-item-hover);
  transform: translateY(-1px);
  outline: none;
}

.developer-label-chip {
  --developer-label-color: #5d87a7;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-height: 20px;
  padding: 0 5px 0 7px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--developer-label-color) 34%, transparent);
  background: color-mix(in srgb, var(--developer-label-color) 14%, transparent);
  color: var(--developer-label-color);
  flex: 0 0 auto;
  white-space: nowrap;
}

.developer-label-chip__dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: currentColor;
  box-shadow: 0 0 0 3px color-mix(in srgb, currentColor 16%, transparent);
}

.developer-label-chip__name {
  font-size: 8px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.developer-label-chip__remove {
  width: 14px;
  height: 14px;
  border: 0;
  border-radius: 999px;
  background: color-mix(in srgb, var(--developer-label-color) 16%, transparent);
  color: currentColor;
  display: inline-grid;
  place-items: center;
  cursor: pointer;
  font-size: 11px;
  line-height: 1;
  padding: 0;
  transition:
    transform var(--duration) var(--ease-out),
    background var(--duration) var(--ease-out);
}

.developer-label-chip__remove:hover,
.developer-label-chip__remove:focus-visible {
  transform: scale(1.05);
  background: color-mix(in srgb, var(--developer-label-color) 24%, transparent);
  outline: none;
}

.developer-label-picker__item-top,
.developer-label-picker__item-meta {
  display: flex;
  align-items: center;
  gap: 8px;
}

.developer-label-picker__dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--developer-label-dot, #5d87a7);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--developer-label-dot, #5d87a7) 18%, transparent);
  flex: 0 0 auto;
}

.developer-label-picker__name {
  font-size: 13px;
  font-weight: 700;
  color: var(--developer-label-menu-name);
  text-transform: none;
  letter-spacing: 0;
}

.developer-label-picker__meta {
  font-size: 12px;
  color: var(--developer-label-menu-meta);
  text-transform: none;
  letter-spacing: 0;
}

.developer-label-picker__empty {
  font-size: 12px;
  color: var(--developer-label-menu-empty-color);
  text-transform: none;
  letter-spacing: 0;
  background: var(--developer-label-menu-empty-bg);
}

.developer-label-picker__empty--inline {
  width: auto;
  margin: 0;
  padding: 0;
  background: transparent;
  font-size: 10px;
  line-height: 1.2;
}

.developer-color-picker {
  position: relative;
  --developer-picked-color: #5d87a7;
  --developer-picker-hue: 205;
  --developer-picker-x: 42%;
  --developer-picker-y: 35%;
}

.developer-color-picker__trigger {
  width: 100%;
  height: 44px;
  min-height: 44px;
  box-sizing: border-box;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 6px 10px 6px 12px;
  border-radius: var(--radius-md);
  border: 1px solid var(--input-border);
  background: var(--input-bg);
  color: var(--text);
  cursor: pointer;
  transition:
    border-color var(--duration) var(--ease-out),
    box-shadow var(--duration) var(--ease-out);
}

.developer-color-picker__trigger:hover,
.developer-color-picker.is-open .developer-color-picker__trigger {
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--focus);
}

.developer-color-picker__trigger:focus-visible {
  outline: none;
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--focus);
}

.developer-color-picker__caret {
  margin-left: auto;
  width: 10px;
  height: 6px;
  display: inline-block;
  background-image:
    linear-gradient(45deg, transparent 50%, currentColor 50%),
    linear-gradient(135deg, currentColor 50%, transparent 50%);
  background-position: left center, right center;
  background-size: 50% 100%;
  background-repeat: no-repeat;
  opacity: 0.72;
  transition: transform var(--duration) var(--ease-out);
  flex: 0 0 auto;
}

.developer-color-picker.is-open .developer-color-picker__caret {
  transform: rotate(180deg);
}

.developer-color-picker__swatch {
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: var(--developer-picked-color);
  box-shadow:
    0 0 0 1px rgba(15, 23, 42, 0.08),
    0 1px 3px rgba(15, 23, 42, 0.12);
  flex: 0 0 auto;
  display: block;
}

.developer-color-picker__copy {
  min-width: 0;
  display: flex;
  align-items: baseline;
  gap: 6px;
  text-align: left;
}

.developer-color-picker__label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  white-space: nowrap;
}

.developer-color-picker__value {
  font-size: 10px;
  color: var(--muted);
  white-space: nowrap;
}

.developer-color-picker__popover {
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  z-index: 30;
  min-width: 100%;
  width: min(328px, calc(100vw - 64px));
  display: grid;
  gap: 14px;
  padding: 16px;
  border-radius: 24px;
  border: 1px solid var(--glass-border-strong);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(246, 248, 252, 0.94) 100%);
  box-shadow: 0 28px 60px rgba(15, 23, 42, 0.18);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  transform-origin: top left;
}

.developer-color-picker__popover[hidden] {
  display: none !important;
}

.developer-color-picker__popover::before {
  content: "";
  position: absolute;
  top: -8px;
  left: 24px;
  width: 16px;
  height: 16px;
  border-top: 1px solid var(--glass-border-strong);
  border-left: 1px solid var(--glass-border-strong);
  background: rgba(250, 251, 253, 0.96);
  transform: rotate(45deg);
}

.developer-task-form .developer-color-picker__popover {
  top: auto;
  bottom: calc(100% + 10px);
  transform-origin: bottom left;
}

.developer-task-form .developer-color-picker__popover::before {
  top: auto;
  bottom: -8px;
  border-top: 0;
  border-left: 0;
  border-right: 1px solid var(--glass-border-strong);
  border-bottom: 1px solid var(--glass-border-strong);
}

.developer-color-picker__swatches {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 2px 2px 12px;
  border-bottom: 1px solid rgba(148, 163, 184, 0.24);
}

.developer-color-picker__preset {
  width: 24px;
  height: 24px;
  border-radius: 999px;
  border: 2px solid rgba(255, 255, 255, 0.72);
  background: var(--developer-swatch-color, var(--developer-picked-color));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.3),
    0 6px 14px rgba(15, 23, 42, 0.14);
  cursor: pointer;
  transition:
    transform var(--duration) var(--ease-out),
    box-shadow var(--duration) var(--ease-out),
    border-color var(--duration) var(--ease-out);
}

.developer-color-picker__preset:hover,
.developer-color-picker__preset.is-active {
  transform: translateY(-1px) scale(1.08);
  border-color: color-mix(in srgb, var(--developer-swatch-color, var(--developer-picked-color)) 48%, white);
  box-shadow:
    0 0 0 4px color-mix(in srgb, var(--developer-swatch-color, var(--developer-picked-color)) 18%, transparent),
    0 10px 18px rgba(15, 23, 42, 0.16);
}

.developer-color-picker__area {
  position: relative;
  width: 100%;
  min-height: 172px;
  border-radius: 16px;
  overflow: hidden;
  cursor: crosshair;
  border: 1px solid rgba(148, 163, 184, 0.22);
  background: hsl(var(--developer-picker-hue) 100% 50%);
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.08);
  isolation: isolate;
}

.developer-color-picker__area::before,
.developer-color-picker__area::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
}

.developer-color-picker__area::before {
  background: linear-gradient(90deg, #fff 0%, rgba(255, 255, 255, 0) 100%);
}

.developer-color-picker__area::after {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, #000 100%);
}

.developer-color-picker__area:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--developer-picked-color) 55%, var(--focus));
  outline-offset: 2px;
}

.developer-color-picker__area-thumb {
  position: absolute;
  left: var(--developer-picker-x);
  top: var(--developer-picker-y);
  width: 16px;
  height: 16px;
  border-radius: 999px;
  border: 2px solid rgba(255, 255, 255, 0.96);
  box-shadow:
    0 0 0 1px rgba(15, 23, 42, 0.16),
    0 3px 10px rgba(15, 23, 42, 0.14);
  transform: translate(-50%, -50%);
  background: var(--developer-picked-color);
  pointer-events: none;
}

.developer-color-picker__slider,
.developer-color-picker__hex {
  display: grid;
  gap: 8px;
}

.developer-color-picker__slider {
  gap: 4px;
  margin-block: -6px;
}

.developer-color-picker__slider-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}

.developer-color-picker__slider-head > :last-child {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 56px;
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, 0.24);
  background: rgba(255, 255, 255, 0.76);
  color: var(--text);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: none;
}

.developer-color-picker__slider input[type="range"] {
  width: 100%;
  margin: 0;
  padding: 0;
  border: 0;
  -webkit-appearance: none;
  appearance: none;
  height: 8px;
  border-radius: 999px;
  background: none;
  box-shadow: none;
  outline: none;
  cursor: pointer;
}

.developer-color-picker__slider input[type="range"]:focus {
  outline: none;
  box-shadow: none;
}

.developer-color-picker__slider input[type="range"]::-webkit-slider-runnable-track {
  height: 8px;
  border-radius: 999px;
  background:
    linear-gradient(90deg, #ef4444 0%, #f97316 14%, #eab308 28%, #22c55e 42%, #06b6d4 56%, #3b82f6 70%, #8b5cf6 84%, #ec4899 100%);
}

.developer-color-picker__slider input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 14px;
  height: 14px;
  border-radius: 999px;
  background: #fff;
  border: 2px solid rgba(15, 23, 42, 0.14);
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.14);
  margin-top: -3px;
}

.developer-color-picker__slider input[type="range"]::-moz-range-track {
  height: 8px;
  border-radius: 999px;
  border: 0;
  background:
    linear-gradient(90deg, #ef4444 0%, #f97316 14%, #eab308 28%, #22c55e 42%, #06b6d4 56%, #3b82f6 70%, #8b5cf6 84%, #ec4899 100%);
}

.developer-color-picker__slider input[type="range"]::-moz-range-thumb {
  width: 14px;
  height: 14px;
  border-radius: 999px;
  background: #fff;
  border: 2px solid rgba(15, 23, 42, 0.14);
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.14);
}

.developer-color-picker__hex span {
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}

.developer-color-picker__hex input {
  width: 100%;
  min-width: 0;
  padding: 11px 12px;
  border-radius: 14px;
  border: 1px solid var(--input-border);
  background: rgba(255, 255, 255, 0.8);
  color: var(--text);
  font-size: 13px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.developer-color-picker__hex input:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--developer-picked-color) 55%, var(--focus));
  outline-offset: 2px;
}

.developer-form__actions {
  grid-column: 1 / -1;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 0;
  padding-top: 10px;
  border-top: 1px solid var(--glass-border-strong);
}

.developer-form__actions--task {
  justify-content: space-between;
}

.developer-form__actions-slot {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  flex: 1 1 0;
}

.developer-form__actions-slot--end {
  justify-content: flex-end;
}

.developer-form__actions .btn {
  min-height: 40px;
  padding-inline: 14px;
  border-radius: 13px;
}

.developer-form__actions--task .btn {
  min-height: 31px;
  padding-inline: 11px;
  font-size: 10px;
  letter-spacing: 0.08em;
}

.developer-form__submit {
  min-width: 118px;
}

.developer-column-delete {
  min-width: 40px;
  padding-inline: 0;
}

.developer-column-delete .fa-solid.fa-trash,
.developer-column-delete .fa-regular.fa-trash {
  width: 14px;
  height: 14px;
}

.developer-task-comments {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--glass-border-strong);
  display: grid;
  gap: 8px;
}

.developer-task-comments[hidden] {
  display: none;
}

.developer-task-comments__pending {
  margin: 10px 0 0;
  padding: 8px 10px;
  border-radius: 14px;
  border: 1px dashed var(--glass-border-strong);
  background: rgba(255, 255, 255, 0.08);
  color: var(--muted);
  font-size: 11px;
  line-height: 1.4;
}

.developer-task-comments__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.developer-task-comments__title {
  margin: 0;
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}

.developer-task-comments__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 28px;
  min-height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  border: 1px solid var(--glass-border-strong);
  background: rgba(255, 255, 255, 0.14);
  color: var(--text);
  font-size: 10px;
  font-weight: 700;
}

.developer-task-comments__list {
  display: grid;
  gap: 8px;
}

.developer-task-comments__empty {
  margin: 0;
  padding: 8px 10px;
  border-radius: 14px;
  border: 1px dashed var(--glass-border-strong);
  background: rgba(255, 255, 255, 0.08);
  color: var(--muted);
  font-size: 11px;
}

.developer-task-comments__form {
  display: grid;
  gap: 10px;
}

.developer-task-comments__form > .developer-form__actions > .developer-form__hint:not([data-task-comment-form-hint]),
.developer-task-comments__form > .developer-form__actions > .btn:not([data-task-comment-submit]) {
  display: none;
}

.developer-comment {
  display: grid;
  gap: 6px;
  padding: 8px 10px;
  border-radius: 14px;
  border: 1px solid var(--glass-border-strong);
  background:
    linear-gradient(160deg, color-mix(in srgb, var(--card-bg) 96%, white) 0%, color-mix(in srgb, var(--notes-bg) 96%, transparent) 100%);
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.07);
}

.developer-comment__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 6px;
}

.developer-comment__identity {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 7px;
}

.developer-comment__meta {
  min-width: 0;
  display: grid;
  gap: 1px;
}

.developer-comment__author {
  font-size: 11px;
  font-weight: 700;
  color: var(--text);
}

.developer-comment__time {
  font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}

.developer-comment__body {
  margin: 0;
  font-size: 11px;
  line-height: 1.35;
  color: var(--text);
  white-space: normal;
  word-break: break-word;
}

.developer-comment__actions {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  flex: 0 0 auto;
}

.developer-comment__action {
  width: 26px;
  height: 26px;
  flex: 0 0 auto;
  display: inline-grid;
  place-items: center;
  border-radius: 9px;
  border: 1px solid var(--glass-border-strong);
  background: rgba(255, 255, 255, 0.7);
  color: var(--text);
  cursor: pointer;
  transition:
    transform var(--duration) var(--ease-out),
    border-color var(--duration) var(--ease-out),
    background var(--duration) var(--ease-out),
    box-shadow var(--duration) var(--ease-out);
}

.developer-comment__action:hover,
.developer-comment__action:focus-visible {
  transform: translateY(-1px);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 10px 20px rgba(15, 23, 42, 0.1);
  outline: none;
}

.developer-comment__action--edit {
  border-color: color-mix(in srgb, var(--accent) 18%, var(--glass-border-strong));
  color: color-mix(in srgb, var(--accent) 68%, var(--text));
}

.developer-comment__action--edit:hover,
.developer-comment__action--edit:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 30%, var(--glass-border-strong));
  background: color-mix(in srgb, var(--accent) 12%, rgba(255, 255, 255, 0.92));
  box-shadow: 0 10px 20px color-mix(in srgb, var(--accent) 16%, rgba(15, 23, 42, 0.08));
}

.developer-comment__action--delete {
  border-color: rgba(239, 68, 68, 0.18);
  color: #b91c1c;
}

.developer-comment__action--delete:hover,
.developer-comment__action--delete:focus-visible {
  border-color: rgba(239, 68, 68, 0.32);
  background: rgba(254, 242, 242, 0.96);
  box-shadow: 0 10px 20px rgba(239, 68, 68, 0.12);
}

.developer-comment__action:disabled {
  opacity: 0.6;
  cursor: wait;
  transform: none;
  box-shadow: none;
}

.developer-comment__action svg,
.developer-comment__action .fa-solid.fa-trash,
.developer-comment__action .fa-regular.fa-trash,
.developer-comment__action .fa-pencil {
  width: 12px;
  height: 12px;
  display: block;
}

.developer-comment__avatar {
  width: 26px;
  height: 26px;
  border-radius: 999px;
  overflow: hidden;
  display: inline-grid;
  place-items: center;
  background: var(--avatar-bg, rgba(15, 23, 42, 0.08));
  border: 1px solid var(--glass-border-strong);
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.62);
  flex: 0 0 auto;
  color: var(--avatar-fg, var(--text));
}

.developer-comment__avatar-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.developer-comment__avatar-initial {
  font-size: 13px;
  line-height: 1;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: inherit;
}

body[data-theme="dark"] .developer-column,
body[data-theme="dark"] .developer-task__surface {
  background:
    radial-gradient(circle at top right, rgba(90, 143, 180, 0.14), transparent 34%),
    linear-gradient(165deg, rgba(10, 22, 36, 0.86) 0%, rgba(17, 38, 60, 0.78) 100%);
}

body[data-theme="dark"] .developer-board-views {
  background: rgba(11, 18, 28, 0.42);
  border-color: rgba(92, 105, 123, 0.22);
  box-shadow: none;
}

body[data-theme="dark"] .developer-board-view-tab,
body[data-theme="dark"] .developer-board-views__new {
  background: rgba(15, 23, 42, 0.3);
  border-color: rgba(92, 105, 123, 0.28);
}

body[data-theme="dark"] .developer-board-view-tab.is-active {
  background: rgba(93, 135, 167, 0.14);
}

body[data-theme="dark"] .developer-board-filter-group select {
  background: rgba(15, 23, 42, 0.42);
  border-color: rgba(92, 105, 123, 0.26);
}

body[data-theme="dark"] .developer-board-filter-chip {
  border-color: color-mix(in srgb, var(--developer-filter-chip-color) 20%, rgba(92, 105, 123, 0.26));
  background: color-mix(in srgb, var(--developer-filter-chip-color) 12%, rgba(15, 23, 42, 0.34));
}

body[data-theme="dark"] .developer-task-title-meta {
  border-color: rgba(92, 105, 123, 0.48);
  background: rgba(22, 27, 34, 0.82);
}

body[data-theme="dark"] .developer-column {
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--developer-column-color) 14%, transparent), transparent 38%),
    linear-gradient(180deg, rgba(13, 17, 23, 0.96) 0%, rgba(16, 21, 28, 0.98) 100%);
  border-color: rgba(92, 105, 123, 0.42);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

body[data-theme="dark"] .developer-column__dot {
  box-shadow:
    0 0 0 1px rgba(240, 246, 252, 0.14),
    0 0 0 5px color-mix(in srgb, var(--developer-column-color) 20%, transparent);
}

body[data-theme="dark"] .developer-column__count {
  border-color: rgba(92, 105, 123, 0.48);
  background: color-mix(in srgb, var(--developer-column-color) 16%, rgba(255, 255, 255, 0.02));
  color: #f0f6fc;
}

body[data-theme="dark"] .developer-column__edit,
body[data-theme="dark"] .developer-column__add {
  border-color: rgba(92, 105, 123, 0.48);
  background: rgba(22, 27, 34, 0.82);
  color: #f0f6fc;
}

body[data-theme="dark"] .developer-column__empty {
  border-color: rgba(92, 105, 123, 0.48);
  background: rgba(13, 17, 23, 0.68);
}

body[data-theme="dark"] .developer-task__avatar {
  background: var(--avatar-bg, rgba(13, 17, 23, 0.82));
  border-color: rgba(92, 105, 123, 0.48);
  box-shadow: 0 0 0 3px rgba(13, 17, 23, 0.92);
}

body[data-theme="dark"] .developer-task__attachment-badge {
  border-color: rgba(92, 105, 123, 0.48);
  background: color-mix(in srgb, var(--developer-task-accent, #5d87a7) 18%, rgba(13, 17, 23, 0.96));
  color: #f0f6fc;
  box-shadow: 0 10px 20px rgba(2, 6, 23, 0.24);
}

body[data-theme="dark"] .developer-rich-text__link {
  color: #8ab4ff;
}

body[data-theme="dark"] .developer-task__assignee {
  background: rgba(15, 23, 42, 0.42);
}

body[data-theme="dark"] .developer-task__due--overdue {
  color: #fca5a5;
}

body[data-theme="dark"] .developer-task__due--today {
  color: #fbbf24;
}

body[data-theme="dark"] .developer-label-picker__toggle {
  background: rgba(22, 27, 34, 0.82);
  color: #f0f6fc;
}

body[data-theme="dark"] .developer-label-picker {
  --developer-label-menu-bg:
    linear-gradient(180deg, rgba(15, 23, 42, 0.96) 0%, rgba(22, 27, 34, 0.94) 100%);
  --developer-label-menu-border: rgba(92, 105, 123, 0.48);
  --developer-label-menu-shadow: 0 24px 44px rgba(2, 6, 23, 0.34);
  --developer-label-menu-item-hover: rgba(148, 163, 184, 0.14);
  --developer-label-menu-name: #f0f6fc;
  --developer-label-menu-meta: #9fb0c4;
  --developer-label-menu-empty-bg: rgba(255, 255, 255, 0.04);
  --developer-label-menu-empty-color: #9fb0c4;
}

body[data-theme="dark"] .developer-label-picker__toggle::before {
  background: rgba(92, 105, 123, 0.48);
}

body[data-theme="dark"] .developer-color-picker__trigger {
  border-color: rgba(92, 105, 123, 0.48);
  background: rgba(22, 27, 34, 0.82);
  color: #f0f6fc;
}

body[data-theme="dark"] .developer-color-picker__trigger:hover,
body[data-theme="dark"] .developer-color-picker.is-open .developer-color-picker__trigger,
body[data-theme="dark"] .developer-color-picker__trigger:focus-visible {
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--focus);
}

body[data-theme="dark"] .developer-color-picker__value,
body[data-theme="dark"] .developer-color-picker__slider-head,
body[data-theme="dark"] .developer-color-picker__hex span {
  color: #9fb0c4;
}

body[data-theme="dark"] .developer-color-picker__swatches {
  border-bottom-color: rgba(92, 105, 123, 0.42);
}

body[data-theme="dark"] .developer-color-picker__popover {
  border-color: rgba(92, 105, 123, 0.48);
  background:
    linear-gradient(180deg, rgba(13, 17, 23, 0.96) 0%, rgba(16, 21, 28, 0.98) 100%);
}

body[data-theme="dark"] .developer-color-picker__popover::before {
  border-color: rgba(92, 105, 123, 0.48);
  background: rgba(13, 17, 23, 0.96);
}

body[data-theme="dark"] .developer-color-picker__area {
  border-color: rgba(92, 105, 123, 0.48);
}

body[data-theme="dark"] .developer-color-picker__hex input {
  border-color: rgba(92, 105, 123, 0.48);
  background: rgba(22, 27, 34, 0.82);
  color: #f0f6fc;
}

body[data-theme="dark"] .developer-color-picker__slider-head > :last-child {
  border-color: rgba(92, 105, 123, 0.48);
  background: rgba(22, 27, 34, 0.82);
  color: #f0f6fc;
}

body[data-theme="dark"] .developer-task-comments__pending,
body[data-theme="dark"] .developer-task-comments__empty {
  background: rgba(13, 17, 23, 0.68);
  border-color: rgba(92, 105, 123, 0.48);
}

body[data-theme="dark"] .developer-task-comments__count {
  border-color: rgba(92, 105, 123, 0.48);
  background: rgba(22, 27, 34, 0.82);
  color: #f0f6fc;
}

body[data-theme="dark"] .developer-task-attachments__count {
  border-color: rgba(92, 105, 123, 0.48);
  background: rgba(22, 27, 34, 0.82);
  color: #f0f6fc;
}

body[data-theme="dark"] .developer-task-attachments__upload,
body[data-theme="dark"] .developer-task-attachments__empty {
  background: rgba(13, 17, 23, 0.68);
  border-color: rgba(92, 105, 123, 0.48);
}

body[data-theme="dark"] .developer-task-form .tox-tinymce {
  border-color: rgba(92, 105, 123, 0.48);
  background: rgba(22, 27, 34, 0.82);
}

body[data-theme="dark"] .developer-task-attachment {
  background:
    radial-gradient(circle at top right, rgba(90, 143, 180, 0.14), transparent 34%),
    linear-gradient(165deg, rgba(10, 22, 36, 0.86) 0%, rgba(17, 38, 60, 0.78) 100%);
  border-color: rgba(92, 105, 123, 0.42);
}

body[data-theme="dark"] .developer-task-attachment__preview,
body[data-theme="dark"] .developer-task-attachment__action {
  background: rgba(22, 27, 34, 0.88);
  border-color: rgba(92, 105, 123, 0.48);
}

body[data-theme="dark"] .developer-task-attachment__action:hover,
body[data-theme="dark"] .developer-task-attachment__action:focus-visible {
  background: rgba(22, 27, 34, 0.96);
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.2);
}

body[data-theme="dark"] .developer-task-attachment__action--delete {
  border-color: rgba(239, 68, 68, 0.28);
  color: #fda4af;
}

body[data-theme="dark"] .developer-task-attachment__action--delete:hover,
body[data-theme="dark"] .developer-task-attachment__action--delete:focus-visible {
  background: rgba(69, 10, 10, 0.68);
  border-color: rgba(248, 113, 113, 0.4);
  box-shadow: 0 10px 20px rgba(248, 113, 113, 0.12);
}

body[data-theme="dark"] .developer-comment {
  background:
    radial-gradient(circle at top right, rgba(90, 143, 180, 0.14), transparent 34%),
    linear-gradient(165deg, rgba(10, 22, 36, 0.86) 0%, rgba(17, 38, 60, 0.78) 100%);
  border-color: rgba(92, 105, 123, 0.42);
}

body[data-theme="dark"] .developer-comment__action {
  background: rgba(22, 27, 34, 0.88);
}

body[data-theme="dark"] .developer-comment__action:hover,
body[data-theme="dark"] .developer-comment__action:focus-visible {
  background: rgba(22, 27, 34, 0.96);
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.2);
}

body[data-theme="dark"] .developer-comment__action--edit {
  border-color: rgba(92, 105, 123, 0.48);
  color: #9fc0de;
}

body[data-theme="dark"] .developer-comment__action--edit:hover,
body[data-theme="dark"] .developer-comment__action--edit:focus-visible {
  background: rgba(15, 35, 54, 0.94);
  border-color: rgba(111, 168, 204, 0.52);
  box-shadow: 0 10px 20px rgba(44, 110, 152, 0.16);
}

body[data-theme="dark"] .developer-comment__action--delete {
  border-color: rgba(239, 68, 68, 0.28);
  color: #fda4af;
}

body[data-theme="dark"] .developer-comment__action--delete:hover,
body[data-theme="dark"] .developer-comment__action--delete:focus-visible {
  background: rgba(69, 10, 10, 0.68);
  border-color: rgba(248, 113, 113, 0.4);
  box-shadow: 0 10px 20px rgba(248, 113, 113, 0.12);
}

body[data-theme="dark"] .developer-comment__avatar {
  background: var(--avatar-bg, rgba(13, 17, 23, 0.82));
  border-color: rgba(92, 105, 123, 0.48);
  box-shadow: 0 0 0 3px rgba(13, 17, 23, 0.92);
}

@media (max-width: 980px) {
  .developer-kanban {
    grid-auto-columns: minmax(286px, 88vw);
  }

  .developer-column {
    height: 100%;
  }
}

@media (max-width: 720px) {
  .board__panel--developer-kanban {
    padding: 16px;
  }

  .board__head--developer-kanban {
    flex-direction: column;
    align-items: stretch;
  }

  .board__head--developer-kanban .board__head-actions {
    padding-top: 12px;
  }

  .developer-board__company {
    align-items: center;
  }

  .developer-board-views__topline,
  .developer-board-views__filterbar {
    flex-direction: column;
    align-items: stretch;
  }

  .developer-board-views__filters {
    grid-template-columns: 1fr;
  }

  .developer-board-views__actions {
    justify-content: stretch;
  }

  .developer-board-views__actions .btn,
  .developer-board-views__new {
    width: 100%;
    justify-content: center;
  }

  .developer-task-modal {
    padding: 14px 12px 20px;
  }

  .developer-task-modal__panel {
    width: min(100%, calc(100% - 4px));
    max-height: calc(var(--viewport-height) - var(--header-offset) - 34px);
    padding: 12px;
  }

  .developer-view-modal__panel {
    width: min(100%, calc(100% - 4px));
  }

  .developer-form {
    grid-template-columns: 1fr;
  }

  .developer-task-form__meta-grid {
    grid-template-columns: 1fr;
  }

  .developer-task-title-row {
    flex-direction: column;
    align-items: stretch;
  }

  .developer-task-title-meta {
    min-width: 0;
  }

  .developer-task-attachment {
    grid-template-columns: 72px minmax(0, 1fr);
  }

  .developer-task-attachment__preview {
    width: 72px;
    height: 64px;
  }

  .developer-task-attachment__actions {
    grid-column: 1 / -1;
    justify-content: flex-end;
  }

  .developer-form__actions,
  .developer-form__actions--task {
    align-items: stretch;
    flex-direction: column;
  }

  .developer-form__actions-slot,
  .developer-form__actions-slot--end {
    width: 100%;
    justify-content: stretch;
  }

  .developer-form__actions-slot .btn {
    flex: 1 1 auto;
  }
}

/* Calendar redesign */
.board--calendar,
.board--calendar .board__panel {
  height: 100%;
}

.board--calendar .calendar-page {
  display: grid;
  gap: 18px;
  min-height: 0;
}

.calendar-header {
  align-items: flex-start;
  gap: 16px;
}

.calendar-header__copy {
  min-width: min(100%, 320px);
  display: grid;
  gap: 6px;
}

.calendar-toolbar {
  margin-left: auto;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 10px;
}

.calendar-view-switch {
  position: relative;
  display: inline-flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: 4px;
  padding: 4px;
  border-radius: 999px;
  border: 1px solid var(--glass-border-strong);
  background: linear-gradient(160deg, rgba(255, 255, 255, 0.3), rgba(255, 255, 255, 0.14));
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.12);
  overflow-x: auto;
  overflow-y: hidden;
  isolation: isolate;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.calendar-view-switch::-webkit-scrollbar {
  display: none;
}

.calendar-view-switch__cursor {
  position: absolute;
  left: 0;
  top: 4px;
  z-index: 1;
  width: 0;
  height: calc(100% - 8px);
  border-radius: 999px;
  background: linear-gradient(145deg, var(--accent) 0%, var(--accent-2) 100%);
  box-shadow:
    0 10px 20px rgba(31, 77, 122, 0.26),
    inset 0 1px 0 rgba(255, 255, 255, 0.22);
  opacity: 0;
  transform: translateX(0);
  transition:
    transform 280ms cubic-bezier(0.22, 1, 0.36, 1),
    width 280ms cubic-bezier(0.22, 1, 0.36, 1),
    height 280ms cubic-bezier(0.22, 1, 0.36, 1),
    opacity 180ms ease-out;
  pointer-events: none;
}

.calendar-view-switch__item,
.calendar-day__number-link,
.calendar-nav__today,
.calendar-nav__arrow,
.calendar-event,
.calendar-all-day-event,
.calendar-time-event,
.calendar-agenda-event {
  appearance: none;
  -webkit-appearance: none;
}

.calendar-view-switch__item {
  flex: 0 0 auto;
  position: relative;
  z-index: 2;
  min-width: 82px;
  height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
  transition:
    color var(--duration-fast) var(--ease-out),
    transform var(--duration-fast) var(--ease-out);
}

.calendar-view-switch__item:hover {
  color: var(--accent-strong);
  transform: translateY(-1px);
}

.calendar-view-switch__item.is-active {
  color: var(--accent-strong);
}

.calendar-view-switch__item[data-cursor-target="true"] {
  color: #f8fbff;
}

.calendar-nav {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 5px 6px;
  border-radius: 18px;
  border: 1px solid var(--glass-border-strong);
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.28), rgba(255, 255, 255, 0.1));
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.12);
}

.calendar-nav__arrow {
  position: relative;
  width: 34px;
  height: 34px;
  border-radius: 10px;
  border: 1px solid rgba(31, 77, 122, 0.28);
  background: linear-gradient(145deg, rgba(93, 135, 167, 0.24), rgba(93, 135, 167, 0.06));
  color: var(--accent-strong);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0;
  line-height: 0;
  transition:
    transform var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out),
    background var(--duration-fast) var(--ease-out);
}

.calendar-nav__arrow > span {
  display: none;
}

.calendar-nav__arrow::before {
  content: "";
  width: 9px;
  height: 9px;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  transform: rotate(-135deg);
  transform-origin: center;
}

.calendar-nav__arrow[data-calendar-direction="forward"]::before {
  transform: rotate(45deg);
}

.calendar-nav__arrow:hover {
  transform: translateY(-1px);
  border-color: var(--accent-strong);
  box-shadow: 0 10px 18px rgba(2, 6, 23, 0.14);
}

.calendar-nav__arrow:focus-visible,
.calendar-nav__today:focus-visible,
.calendar-view-switch__item:focus-visible,
.calendar-day__number-link:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 2px;
}

.calendar-nav__today {
  height: 34px;
  min-width: 68px;
  padding: 0 12px;
  border-radius: 10px;
  border: 1px solid rgba(31, 77, 122, 0.4);
  background: linear-gradient(145deg, var(--accent) 0%, var(--accent-2) 100%);
  color: #f8fbff;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  transition:
    transform var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out),
    filter var(--duration-fast) var(--ease-out);
}

.calendar-nav__today:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(15, 23, 42, 0.18);
  filter: brightness(1.04);
}

.calendar-nav__today.is-current {
  background: linear-gradient(145deg, rgba(248, 250, 252, 0.92), rgba(205, 216, 227, 0.74));
  color: var(--accent-strong);
}

.calendar-nav__title {
  min-width: 236px;
  min-height: 34px;
  padding: 7px 14px;
  border-radius: 12px;
  border: 1px solid rgba(31, 77, 122, 0.26);
  background: linear-gradient(145deg, rgba(248, 250, 252, 0.84), rgba(205, 216, 227, 0.58));
  display: inline-flex;
  align-items: center;
  text-align: left;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.25;
  color: var(--accent-strong);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.56);
}

.calendar-nav__title.is-current {
  border-color: rgba(31, 77, 122, 0.42);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.68), 0 10px 20px rgba(15, 23, 42, 0.12);
}

.calendar-nav__eyebrow,
.calendar-nav__value {
  display: none;
}

.calendar-shell,
.calendar-range,
.calendar-day-focus,
.calendar-agenda {
  border-radius: 20px;
  border: 1px solid var(--glass-border-strong);
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0.08));
  box-shadow: 0 18px 36px rgba(15, 23, 42, 0.12);
}

.calendar-shell {
  position: relative;
  min-width: 0;
  overflow: hidden;
  padding: 14px;
}

.calendar-shell.is-view-switching {
  isolation: isolate;
}

.calendar-surface.is-switching {
  will-change: opacity, transform;
  animation: employee-pane-enter 240ms var(--ease-out);
}

.calendar-surface {
  min-width: 0;
}

.calendar-surface--incoming {
  position: relative;
  z-index: 1;
}

.calendar-surface--outgoing {
  pointer-events: none;
  user-select: none;
}

.calendar-page--month {
  height: 100%;
  grid-template-rows: auto minmax(0, 1fr);
}

.calendar-page--month .calendar-shell,
.calendar-page--month .calendar-surface,
.calendar-page--month .calendar-month {
  height: 100%;
  min-height: 0;
}

.calendar-page--month .calendar-month {
  display: flex;
}

.calendar-page--month .calendar-grid {
  flex: 1 1 auto;
  height: 100%;
}

.calendar-page--month .calendar-day {
  min-height: 0;
}

.calendar-month {
  min-width: 0;
}

.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 10px;
}

.calendar-grid__weekday {
  border-radius: 14px;
  border: 1px solid rgba(31, 77, 122, 0.12);
  padding: 10px 12px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent-strong);
}

.calendar-day {
  min-height: 176px;
  padding: 10px;
  border-radius: 16px;
  border: 1px solid var(--glass-border);
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.06));
  position: relative;
  overflow: hidden;
  isolation: isolate;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  gap: 10px;
  transition:
    transform var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out);
}

.calendar-day:hover {
  transform: translateY(-2px);
  border-color: rgba(31, 77, 122, 0.38);
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.12);
}

.calendar-day__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.calendar-day__number-link {
  width: 30px;
  height: 30px;
  border-radius: 10px;
  border: 1px solid rgba(31, 77, 122, 0.12);
  background: rgba(255, 255, 255, 0.74);
  text-decoration: none;
  display: grid;
  place-items: center;
  font-size: 15px;
  font-weight: 700;
  color: var(--accent-strong);
  transition:
    transform var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out),
    background var(--duration-fast) var(--ease-out);
}

.calendar-day__number-link:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(15, 23, 42, 0.12);
}

.calendar-day__badge {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 18%, white);
  border: 1px solid color-mix(in srgb, var(--accent) 36%, transparent);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent-strong);
}

.calendar-day__holiday {
  border-radius: 999px;
  padding: 3px 9px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.calendar-day__events {
  min-height: 0;
  overflow: auto;
  display: grid;
  align-content: start;
  gap: 4px;
}

.calendar-day__empty {
  min-height: 10px;
}

.calendar-event {
  width: 100%;
  min-height: 22px;
  padding: 2px 7px;
  border-radius: 8px;
  border: 1px solid transparent;
  display: flex;
  align-items: center;
  gap: 6px;
  text-align: left;
  color: #ffffff;
  white-space: nowrap;
  overflow: hidden;
  cursor: pointer;
  box-shadow: 0 8px 14px rgba(15, 23, 42, 0.12);
  transition:
    transform var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out),
    filter var(--duration-fast) var(--ease-out);
}

.calendar-event:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(15, 23, 42, 0.15);
  filter: saturate(1.02);
}

.calendar-event__time {
  flex: 0 0 auto;
  font-size: 9px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  opacity: 0.84;
}

.calendar-event__label {
  flex: 1 1 auto;
  min-width: 0;
  font-size: 10px;
  line-height: 1.1;
  font-weight: 700;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.calendar-range,
.calendar-day-focus,
.calendar-agenda {
  padding: 14px;
}

.calendar-range__scroll {
  overflow: auto;
  max-height: clamp(560px, 74vh, 1120px);
  padding-right: 6px;
  padding-bottom: 44px;
  overscroll-behavior: contain;
  scroll-padding-bottom: 44px;
  scrollbar-gutter: stable both-edges;
}

.calendar-range__grid {
  display: grid;
  gap: 10px;
}

.calendar-range__grid--week {
  grid-template-columns: 86px repeat(7, minmax(148px, 1fr));
  grid-template-rows: auto minmax(720px, 1fr);
  min-width: 1180px;
  align-items: stretch;
}

.calendar-range__corner,
.calendar-range__day-head,
.calendar-range__axis-label,
.calendar-all-day-slot,
.calendar-time-column,
.calendar-day-focus__hero,
.calendar-day-focus__all-day {
  border-radius: 16px;
  border: 1px solid rgba(31, 77, 122, 0.14);
}

.calendar-range__corner {
  padding: 12px;
  background: linear-gradient(165deg, rgba(31, 77, 122, 0.1), rgba(255, 255, 255, 0.08));
  display: grid;
  gap: 2px;
}

.calendar-range__corner--ghost {
  padding: 0;
  border: none;
  position: sticky;
  top: 0;
  z-index: 4;
  background: linear-gradient(165deg, rgba(245, 249, 252, 0.82), rgba(245, 249, 252, 0.42));
  backdrop-filter: blur(14px);
  box-shadow: none;
}

.calendar-range__corner-eyebrow,
.calendar-day-focus__eyebrow,
.calendar-agenda__title,
.calendar-agenda-day__header,
.calendar-day-focus__all-day-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
}

.calendar-range__corner-value {
  font-size: 15px;
  font-weight: 700;
  color: var(--accent-strong);
}

.calendar-range__day-head {
  min-height: 84px;
  padding: 10px 12px 8px;
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.24), rgba(255, 255, 255, 0.08));
  position: sticky;
  top: 0;
  z-index: 5;
  backdrop-filter: blur(14px);
  overflow: hidden;
  isolation: isolate;
  display: grid;
  gap: 1px;
  align-content: start;
  align-self: start;
  text-decoration: none;
  color: inherit;
  transition:
    transform var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out);
}

.calendar-range__day-head::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 42px;
  background:
    linear-gradient(180deg, rgba(19, 45, 71, 0.24), rgba(19, 45, 71, 0.1) 72%, rgba(19, 45, 71, 0));
  pointer-events: none;
  z-index: 0;
}

.calendar-range__day-head:hover {
  transform: translateY(-1px);
  border-color: rgba(31, 77, 122, 0.28);
  box-shadow: 0 10px 20px rgba(15, 23, 42, 0.1);
}

.calendar-range__day-name {
  position: relative;
  z-index: 1;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--accent-strong) 62%, #64748b);
}

.calendar-range__day-number {
  position: relative;
  z-index: 1;
  font-size: 28px;
  line-height: 1;
  font-weight: 700;
  color: var(--accent-strong);
}

.calendar-range__day-month {
  position: relative;
  z-index: 1;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent-strong);
}

.calendar-range__day-holiday,
.calendar-day-focus__holiday {
  display: inline-flex;
  width: fit-content;
  max-width: 100%;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(254, 226, 226, 0.78);
  border: 1px solid rgba(220, 38, 38, 0.22);
  color: #7f1d1d;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.calendar-range__day-head.is-holiday {
  padding-right: 96px;
}

.calendar-range__day-holiday {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 2;
  margin-top: 0;
  max-width: calc(100% - 104px);
  padding: 4px 8px;
  font-size: 9px;
  letter-spacing: 0.06em;
}

.calendar-day-focus__holiday {
  margin-top: 4px;
}

.calendar-range__day-head.is-today,
.calendar-all-day-slot.is-today,
.calendar-time-column.is-today {
  border-color: rgba(31, 77, 122, 0.34);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 28%, transparent);
}

.calendar-range__day-head.is-weekend,
.calendar-all-day-slot.is-weekend,
.calendar-time-column.is-weekend {
  background: linear-gradient(165deg, rgba(93, 135, 167, 0.14), rgba(255, 255, 255, 0.08));
}

.calendar-range__day-head.is-holiday {
  border-color: rgba(220, 38, 38, 0.24);
}

.calendar-range__axis-label {
  padding: 12px;
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0.06));
  display: flex;
  align-items: center;
  justify-content: flex-end;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
}

.calendar-all-day-slot {
  min-height: 84px;
  padding: 8px;
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.06));
  display: grid;
  align-content: start;
  gap: 6px;
}

.calendar-all-day-slot__empty {
  min-height: 8px;
}

.calendar-all-day-event,
.calendar-time-event,
.calendar-agenda-event {
  border: none;
  color: #ffffff;
  cursor: pointer;
}

.calendar-event.is-draggable,
.calendar-all-day-event.is-draggable,
.calendar-time-event.is-draggable {
  cursor: grab;
}

.calendar-event.is-dragging,
.calendar-all-day-event.is-dragging,
.calendar-time-event.is-dragging {
  opacity: 0.58;
  transform: scale(0.985);
  cursor: grabbing;
}

.calendar-all-day-event {
  width: 100%;
  padding: 8px 9px;
  border-radius: 12px;
  display: grid;
  gap: 2px;
  text-align: left;
  box-shadow: 0 10px 18px rgba(15, 23, 42, 0.14);
}

.calendar-all-day-event__title,
.calendar-time-event__title,
.calendar-agenda-event__title {
  font-size: 12px;
  line-height: 1.25;
  font-weight: 700;
}

.calendar-all-day-event__meta,
.calendar-time-event__meta,
.calendar-agenda-event__meta {
  font-size: 10px;
  line-height: 1.2;
  opacity: 0.84;
}

.calendar-time-axis {
  display: grid;
  grid-template-rows: repeat(24, minmax(52px, 1fr));
  align-self: stretch;
}

.calendar-time-axis__slot {
  height: 52px;
  padding-right: 12px;
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
  transform: translateY(-0.35em);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}

.calendar-time-column {
  position: relative;
  min-height: 1248px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.05));
  isolation: isolate;
  overflow: hidden;
  cursor: context-menu;
}

.calendar-time-column__lane {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-rows: repeat(24, 1fr);
  pointer-events: none;
}

.calendar-time-column__hour {
  border-top: 1px solid rgba(31, 77, 122, 0.1);
}

.calendar-time-column__hour:first-child {
  border-top: none;
}

.calendar-day.is-drop-target,
.calendar-time-column.is-drop-target,
.calendar-day-focus__all-day.is-drop-target {
  box-shadow: inset 0 0 0 2px rgba(41, 105, 171, 0.28);
  filter: saturate(1.05);
}

.calendar-now-line {
  position: absolute;
  left: 10px;
  right: 10px;
  height: 2px;
  background: #ef4444;
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.18);
  z-index: 4;
  pointer-events: none;
}

.calendar-now-line__dot {
  position: absolute;
  left: -3px;
  top: 50%;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #ef4444;
  transform: translateY(-50%);
}

.calendar-time-event {
  position: absolute;
  top: var(--calendar-event-top);
  left: calc(var(--calendar-event-left) + 6px);
  width: calc(var(--calendar-event-width) - 12px);
  height: var(--calendar-event-height);
  min-height: 40px;
  padding: 8px 9px;
  border-radius: 14px;
  display: grid;
  gap: 2px;
  align-content: start;
  text-align: left;
  box-shadow: 0 16px 28px rgba(15, 23, 42, 0.18);
  z-index: 2;
  overflow: hidden;
  transition:
    transform var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out),
    filter var(--duration-fast) var(--ease-out);
}

.calendar-time-event:hover,
.calendar-all-day-event:hover,
.calendar-agenda-event:hover {
  transform: translateY(-1px);
  box-shadow: 0 18px 30px rgba(15, 23, 42, 0.22);
  filter: saturate(1.04);
}

.calendar-time-event__time,
.calendar-agenda-event__time {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  opacity: 0.86;
}

.calendar-day-focus {
  display: grid;
  gap: 14px;
}

.calendar-day-focus__hero {
  padding: 18px;
  background:
    radial-gradient(circle at top right, rgba(93, 135, 167, 0.18), transparent 44%),
    linear-gradient(165deg, rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0.08));
  position: relative;
  overflow: hidden;
  isolation: isolate;
  display: grid;
  gap: 6px;
}

.calendar-day-focus__headline {
  display: flex;
  align-items: flex-end;
  gap: 10px;
}

.calendar-day-focus__number {
  font-size: 60px;
  line-height: 0.88;
  font-weight: 700;
  color: var(--accent-strong);
}

.calendar-day-focus__month {
  padding-bottom: 8px;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent-strong);
}

.calendar-day-focus__caption,
.calendar-day-focus__empty,
.calendar-agenda__subtitle {
  margin: 0;
  font-size: 12px;
  color: var(--muted);
}

.calendar-day-focus__panel {
  display: grid;
  grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.calendar-day-focus__all-day {
  padding: 14px;
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.06));
  position: relative;
  overflow: hidden;
  isolation: isolate;
  display: grid;
  gap: 12px;
}

.calendar-day-focus__all-day-list {
  display: grid;
  gap: 8px;
  align-content: start;
}

.calendar-day-focus__timeline {
  min-width: 0;
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr);
  gap: 10px;
  max-height: clamp(560px, 74vh, 1120px);
  align-items: start;
  overflow: auto;
  padding-right: 6px;
  padding-bottom: 44px;
  overscroll-behavior: contain;
  scroll-padding-bottom: 44px;
  scrollbar-gutter: stable both-edges;
}

.calendar-time-axis--day {
  min-width: 82px;
}

.calendar-time-column--day {
  min-height: 1248px;
}

.calendar-day-focus__empty--timeline {
  position: absolute;
  top: 16px;
  left: 16px;
  z-index: 1;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px dashed rgba(31, 77, 122, 0.18);
  background: rgba(255, 255, 255, 0.72);
}

.calendar-click-bloom {
  position: absolute;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  pointer-events: none;
  z-index: 6;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle, rgba(93, 135, 167, 0.56) 0%, rgba(93, 135, 167, 0.22) 42%, rgba(93, 135, 167, 0) 76%);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.34),
    0 0 32px rgba(93, 135, 167, 0.28);
}

.calendar-agenda {
  display: grid;
  gap: 14px;
}

.calendar-agenda__header {
  display: grid;
  gap: 4px;
}

.calendar-agenda__title {
  margin: 0;
  color: var(--accent-strong);
}

.calendar-agenda__days {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 12px;
}

.calendar-agenda-day {
  padding: 12px;
  border-radius: 16px;
  border: 1px solid rgba(31, 77, 122, 0.14);
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.06));
  display: grid;
  gap: 10px;
}

.calendar-agenda-day__header {
  color: var(--accent-strong);
}

.calendar-agenda-day__list {
  display: grid;
  gap: 8px;
}

.calendar-agenda-event {
  width: 100%;
  padding: 10px 12px;
  border-radius: 14px;
  display: grid;
  grid-template-columns: 96px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  text-align: left;
  box-shadow: 0 14px 24px rgba(15, 23, 42, 0.18);
}

.calendar-agenda-event__main {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.calendar-page .account-title,
.calendar-page .account-subtitle,
.calendar-view-switch__item,
.calendar-nav__today,
.calendar-nav__title,
.calendar-grid__weekday,
.calendar-day__number-link,
.calendar-day__badge,
.calendar-day__holiday,
.calendar-event__time,
.calendar-event__label,
.calendar-range__corner-eyebrow,
.calendar-range__corner-value,
.calendar-range__day-name,
.calendar-range__day-number,
.calendar-range__day-month,
.calendar-range__day-holiday,
.calendar-range__axis-label,
.calendar-all-day-event__title,
.calendar-all-day-event__meta,
.calendar-time-event__time,
.calendar-time-event__title,
.calendar-time-event__meta,
.calendar-agenda__title,
.calendar-agenda__subtitle,
.calendar-agenda-day__header,
.calendar-agenda-event__time,
.calendar-agenda-event__title,
.calendar-agenda-event__meta,
.calendar-time-axis__slot,
.calendar-day-focus__eyebrow,
.calendar-day-focus__number,
.calendar-day-focus__month,
.calendar-day-focus__caption,
.calendar-day-focus__empty,
.calendar-day-focus__all-day-label,
.calendar-day-focus__holiday {
  font-family: var(--font-title);
}

.calendar-page .account-title {
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.calendar-page .account-subtitle {
  font-size: 12px;
  line-height: 1.45;
  letter-spacing: 0.01em;
}

.calendar-view-switch__item,
.calendar-nav__today,
.calendar-grid__weekday,
.calendar-day__badge,
.calendar-day__holiday,
.calendar-range__corner-eyebrow,
.calendar-range__day-name,
.calendar-range__day-month,
.calendar-range__day-holiday,
.calendar-range__axis-label,
.calendar-agenda__title,
.calendar-agenda-day__header,
.calendar-day-focus__eyebrow,
.calendar-day-focus__all-day-label,
.calendar-event__time,
.calendar-time-event__time,
.calendar-agenda-event__time,
.calendar-all-day-event__meta,
.calendar-time-event__meta,
.calendar-agenda-event__meta {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.calendar-nav__title {
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.04em;
}

.calendar-range__corner-value,
.calendar-day__number-link,
.calendar-range__day-number,
.calendar-day-focus__number {
  font-weight: 500;
}

.calendar-day__number-link {
  font-size: 14px;
}

.calendar-event__label,
.calendar-all-day-event__title,
.calendar-time-event__title,
.calendar-agenda-event__title {
  font-size: 12px;
  line-height: 1.32;
  font-weight: 500;
  letter-spacing: 0.01em;
}

.calendar-event__time {
  font-size: 8px;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.calendar-event__label {
  font-size: 10px;
  line-height: 1;
  font-weight: 700;
}

.calendar-day-focus__month {
  font-weight: 500;
  letter-spacing: 0.12em;
}

.calendar-day-focus__caption,
.calendar-day-focus__empty,
.calendar-agenda__subtitle {
  font-size: 12px;
  font-weight: 400;
  letter-spacing: 0.01em;
}

body[data-theme="dark"] .calendar-view-switch {
  background: linear-gradient(145deg, rgba(17, 38, 60, 0.88), rgba(10, 22, 36, 0.72));
  border-color: rgba(205, 216, 227, 0.22);
}

body[data-theme="dark"] .calendar-view-switch__cursor {
  background: linear-gradient(145deg, rgba(44, 104, 158, 0.96) 0%, rgba(28, 76, 118, 0.98) 100%);
  box-shadow:
    0 12px 24px rgba(0, 0, 0, 0.32),
    inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

body[data-theme="dark"] .calendar-view-switch__item {
  color: rgba(205, 216, 227, 0.72);
}

body[data-theme="dark"] .calendar-view-switch__item:hover,
body[data-theme="dark"] .calendar-view-switch__item:focus-visible {
  color: #e5eef8;
}

body[data-theme="dark"] .calendar-view-switch__item.is-active {
  color: rgba(205, 216, 227, 0.9);
}

body[data-theme="dark"] .calendar-view-switch__item[data-cursor-target="true"] {
  color: #f8fbff;
}

body[data-theme="dark"] .calendar-nav {
  background: linear-gradient(145deg, rgba(17, 38, 60, 0.86), rgba(10, 22, 36, 0.7));
  border-color: rgba(205, 216, 227, 0.22);
}

body[data-theme="dark"] .calendar-nav__arrow,
body[data-theme="dark"] .calendar-nav__title,
body[data-theme="dark"] .calendar-day__number-link,
body[data-theme="dark"] .calendar-range__corner,
body[data-theme="dark"] .calendar-range__day-head,
body[data-theme="dark"] .calendar-range__axis-label,
body[data-theme="dark"] .calendar-all-day-slot,
body[data-theme="dark"] .calendar-time-column,
body[data-theme="dark"] .calendar-day-focus__hero,
body[data-theme="dark"] .calendar-day-focus__all-day,
body[data-theme="dark"] .calendar-agenda-day {
  border-color: rgba(134, 179, 214, 0.22);
}

body[data-theme="dark"] .calendar-shell,
body[data-theme="dark"] .calendar-range,
body[data-theme="dark"] .calendar-day-focus,
body[data-theme="dark"] .calendar-agenda {
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.02));
}

body[data-theme="dark"] .calendar-nav__title,
body[data-theme="dark"] .calendar-day__number-link,
body[data-theme="dark"] .calendar-range__corner,
body[data-theme="dark"] .calendar-range__day-head,
body[data-theme="dark"] .calendar-range__axis-label,
body[data-theme="dark"] .calendar-all-day-slot,
body[data-theme="dark"] .calendar-time-column,
body[data-theme="dark"] .calendar-day-focus__hero,
body[data-theme="dark"] .calendar-day-focus__all-day,
body[data-theme="dark"] .calendar-agenda-day {
  background: linear-gradient(165deg, rgba(17, 38, 60, 0.76), rgba(10, 22, 36, 0.46));
}

body[data-theme="dark"] .calendar-day,
body[data-theme="dark"] .calendar-grid__weekday {
  border-color: rgba(134, 179, 214, 0.18);
}

body[data-theme="dark"] .calendar-day {
  background: linear-gradient(165deg, rgba(17, 38, 60, 0.72), rgba(10, 22, 36, 0.4));
}

body[data-theme="dark"] .calendar-day__empty--timeline {
  background: rgba(10, 22, 36, 0.82);
  border-color: rgba(134, 179, 214, 0.22);
}

body[data-theme="dark"] .calendar-range__day-holiday,
body[data-theme="dark"] .calendar-day-focus__holiday {
  background: rgba(127, 29, 29, 0.44);
  border-color: rgba(248, 113, 113, 0.36);
  color: rgba(254, 242, 242, 0.96);
}

body[data-theme="dark"] .calendar-range__corner--ghost {
  background: linear-gradient(165deg, rgba(17, 38, 60, 0.84), rgba(10, 22, 36, 0.52));
}

body[data-theme="dark"] .calendar-range__day-head::before {
  background:
    linear-gradient(180deg, rgba(2, 6, 23, 0.42), rgba(15, 23, 42, 0.24) 72%, rgba(15, 23, 42, 0));
}

body[data-theme="dark"] .calendar-range__day-name {
  color: rgba(226, 232, 240, 0.82);
}

body[data-theme="dark"] .calendar-time-column__hour {
  border-top-color: rgba(134, 179, 214, 0.12);
}

@media (max-width: 1100px) {
  .calendar-toolbar {
    justify-items: stretch;
    width: 100%;
  }

  .calendar-view-switch,
  .calendar-nav {
    width: 100%;
  }

  .calendar-view-switch {
    justify-content: space-between;
  }

  .calendar-nav {
    justify-content: center;
  }

  .calendar-nav__title {
    min-width: 0;
    flex: 1 1 auto;
  }

  .calendar-day-focus__panel {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 820px) {
  .calendar-shell,
  .calendar-range,
  .calendar-day-focus,
  .calendar-agenda {
    padding: 10px;
    border-radius: 18px;
  }

  .calendar-month {
    overflow: auto;
  }

  .calendar-grid {
    min-width: 700px;
    gap: 8px;
  }

  .calendar-day {
    min-height: 152px;
    padding: 8px;
  }

  .calendar-day-focus__hero {
    padding: 16px;
  }

  .calendar-day-focus__headline {
    gap: 8px;
  }

  .calendar-day-focus__number {
    font-size: 48px;
  }
}

@media (max-width: 640px) {
  .calendar-header {
    gap: 12px;
  }

  .calendar-view-switch__item {
    min-width: 0;
    flex: 1 1 0;
    padding: 0 10px;
  }

  .calendar-nav {
    gap: 6px;
    padding: 4px;
  }

  .calendar-nav__arrow,
  .calendar-nav__today {
    width: auto;
    min-width: 0;
    height: 32px;
  }

  .calendar-nav__today {
    padding: 0 10px;
  }

  .calendar-nav__title {
    padding: 7px 10px;
  }

  .calendar-agenda__days {
    grid-template-columns: 1fr;
  }

  .calendar-agenda-event {
    grid-template-columns: 1fr;
  }

  .calendar-day-focus__timeline {
    grid-template-columns: 64px minmax(0, 1fr);
  }

  .calendar-time-axis--day {
    min-width: 64px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .calendar-view-switch__cursor,
  .calendar-view-switch__item,
  .calendar-surface.is-switching {
    transition: none;
    animation: none;
  }
}

@media (max-width: 720px) {
  .work-groups__layout {
    grid-template-columns: 1fr;
  }

  .work-groups__list-head {
    flex-direction: column;
    align-items: stretch;
  }

  .work-groups__editor {
    position: static;
    margin-bottom: 0;
  }

  .work-groups__editor-head,
  .work-groups__card-head,
  .work-groups__card-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .work-groups-member-selector__dropdown {
    position: static;
    width: 100%;
    margin-top: 0;
  }

  :root {
    --header-height: 150px;
  }

  .app-header {
    padding: 10px 10px 12px;
  }

  .app-header__brand-main {
    gap: 10px;
  }

  .app-header__brand-controls {
    gap: 8px;
    flex-wrap: wrap;
  }

  .app-title {
    font-size: 16px;
    letter-spacing: 0.08em;
  }

  .app-subtitle,
  .toggle__label,
  .user-menu__name {
    font-size: 10px;
  }

  .search {
    padding: 10px 12px;
  }

  .search__shortcut {
    display: none;
  }

  .search-results {
    padding: 10px;
  }

  .search-results__groups {
    max-height: min(52vh, 360px);
  }

  .page {
    padding: 10px;
  }

  .sidebar {
    top: calc(var(--header-offset) + 10px);
    left: 10px;
    bottom: 10px;
    width: min(320px, calc(100vw - 20px));
    transform: translate3d(calc(-100% - 20px), 0, 0);
  }

  .user-menu__summary,
  .user-menu__login {
    grid-template-columns: 26px 1fr;
    min-width: 0;
  padding: 6px 8px;
}
}

/* Unified button system */
:root {
  --eyeq-button-surface:
    linear-gradient(
      160deg,
      color-mix(in srgb, var(--glass-strong) 74%, rgba(255, 255, 255, 0.82)) 0%,
      color-mix(in srgb, var(--glass) 88%, rgba(238, 244, 249, 0.94)) 100%
    );
  --eyeq-button-surface-hover:
    linear-gradient(
      160deg,
      color-mix(in srgb, var(--glass-strong) 68%, rgba(255, 255, 255, 0.94)) 0%,
      color-mix(in srgb, var(--glass) 82%, rgba(246, 249, 252, 0.98)) 100%
    );
  --eyeq-button-primary-surface:
    linear-gradient(
      135deg,
      color-mix(in srgb, var(--silver-1) 74%, rgba(255, 255, 255, 0.98)) 0%,
      color-mix(in srgb, var(--accent-2) 84%, rgba(191, 221, 255, 0.94)) 100%
    );
  --eyeq-button-primary-surface-hover:
    linear-gradient(
      135deg,
      color-mix(in srgb, var(--silver-1) 64%, rgba(255, 255, 255, 1)) 0%,
      color-mix(in srgb, var(--accent-2) 76%, rgba(207, 230, 255, 0.98)) 100%
    );
  --eyeq-button-secondary-surface:
    linear-gradient(
      160deg,
      color-mix(in srgb, var(--glass-strong) 58%, rgba(255, 255, 255, 0.92)) 0%,
      color-mix(in srgb, var(--glass) 70%, rgba(255, 255, 255, 0.62)) 100%
    );
  --eyeq-button-secondary-surface-hover:
    linear-gradient(
      160deg,
      color-mix(in srgb, var(--glass-strong) 50%, rgba(255, 255, 255, 0.98)) 0%,
      color-mix(in srgb, var(--glass) 64%, rgba(255, 255, 255, 0.74)) 100%
    );
  --eyeq-button-danger-surface:
    linear-gradient(160deg, rgba(254, 226, 226, 0.94) 0%, rgba(254, 202, 202, 0.76) 100%);
  --eyeq-button-danger-surface-hover:
    linear-gradient(160deg, rgba(254, 202, 202, 0.98) 0%, rgba(252, 165, 165, 0.84) 100%);
  --eyeq-button-border: color-mix(in srgb, var(--glass-border-strong) 78%, rgba(255, 255, 255, 0.72));
  --eyeq-button-border-hover: color-mix(in srgb, var(--accent) 42%, rgba(255, 255, 255, 0.66));
  --eyeq-button-focus: color-mix(in srgb, var(--accent) 22%, transparent);
  --eyeq-button-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.42),
    0 10px 22px rgba(15, 23, 42, 0.1);
  --eyeq-button-shadow-hover:
    inset 0 1px 0 rgba(255, 255, 255, 0.52),
    0 16px 30px rgba(15, 23, 42, 0.14);
}

body[data-theme="dark"] {
  --eyeq-button-surface:
    linear-gradient(160deg, rgba(24, 34, 52, 0.92) 0%, rgba(37, 49, 70, 0.9) 100%);
  --eyeq-button-surface-hover:
    linear-gradient(160deg, rgba(32, 45, 67, 0.96) 0%, rgba(47, 63, 88, 0.94) 100%);
  --eyeq-button-primary-surface:
    linear-gradient(135deg, rgba(66, 89, 120, 0.92) 0%, rgba(92, 134, 182, 0.88) 100%);
  --eyeq-button-primary-surface-hover:
    linear-gradient(135deg, rgba(79, 104, 138, 0.98) 0%, rgba(111, 156, 206, 0.94) 100%);
  --eyeq-button-secondary-surface:
    linear-gradient(160deg, rgba(30, 41, 59, 0.86) 0%, rgba(51, 65, 85, 0.78) 100%);
  --eyeq-button-secondary-surface-hover:
    linear-gradient(160deg, rgba(38, 51, 72, 0.92) 0%, rgba(63, 80, 103, 0.84) 100%);
  --eyeq-button-danger-surface:
    linear-gradient(160deg, rgba(127, 29, 29, 0.44) 0%, rgba(69, 10, 10, 0.34) 100%);
  --eyeq-button-danger-surface-hover:
    linear-gradient(160deg, rgba(153, 27, 27, 0.54) 0%, rgba(91, 13, 13, 0.42) 100%);
  --eyeq-button-border: color-mix(in srgb, var(--glass-border-strong) 68%, rgba(148, 163, 184, 0.22));
  --eyeq-button-border-hover: color-mix(in srgb, var(--accent) 46%, rgba(148, 163, 184, 0.32));
  --eyeq-button-focus: color-mix(in srgb, var(--accent) 28%, transparent);
  --eyeq-button-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 12px 24px rgba(2, 6, 23, 0.28);
  --eyeq-button-shadow-hover:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 18px 32px rgba(2, 6, 23, 0.36);
}

.btn,
.login-submit,
.auth-secondary,
.company__phrase-add,
.profile-avatar-panel__action,
.search__shortcut,
.notification-context-menu__item,
.agevolazione-note-preview-btn,
.agevolazione-info-toggle,
.calendar-datetime-trigger,
.calendar-datetime-picker__nav,
.calendar-datetime-picker__chip,
.calendar-datetime-picker__close,
.rubrica-row-action,
.board--contributi .company__tool-btn,
.agevolazione-task .company__tool-btn,
.agevolazione-doc-item .company__tool-btn,
.company__category-delete,
.company__subcats-add,
.notification-card__delete,
.sidebar__edit,
.sidebar__close,
.app-header__menu-toggle,
.modal__close,
.developer-color-picker__trigger,
.developer-label-picker__toggle {
  cursor: pointer;
  border: 1px solid var(--eyeq-button-border);
  background: var(--eyeq-button-bg, var(--eyeq-button-surface));
  color: var(--eyeq-button-color, var(--text));
  box-shadow: var(--eyeq-button-shadow);
  transition:
    transform var(--duration) var(--ease-out),
    border-color var(--duration) var(--ease-out),
    background var(--duration) var(--ease-out),
    color var(--duration) var(--ease-out),
    box-shadow var(--duration) var(--ease-out),
    filter var(--duration) var(--ease-out);
}

.btn:hover,
.login-submit:hover,
.auth-secondary:hover,
.company__phrase-add:hover,
.profile-avatar-panel__action:hover,
.search__shortcut:hover,
.notification-context-menu__item:hover,
.agevolazione-note-preview-btn:hover,
.agevolazione-info-toggle:hover,
.calendar-datetime-trigger:hover,
.calendar-datetime-picker__nav:hover,
.calendar-datetime-picker__chip:hover,
.calendar-datetime-picker__close:hover,
.rubrica-row-action:hover,
.board--contributi .company__tool-btn:hover,
.agevolazione-task .company__tool-btn:hover,
.agevolazione-doc-item .company__tool-btn:hover,
.company__category-delete:hover,
.company__subcats-add:hover,
.notification-card__delete:hover,
.sidebar__edit:hover,
.sidebar__close:hover,
.app-header__menu-toggle:hover,
.modal__close:hover,
.developer-color-picker__trigger:hover,
.developer-label-picker__toggle:hover,
.developer-label-picker.is-open .developer-label-picker__toggle,
.developer-color-picker.is-open .developer-color-picker__trigger {
  transform: translate3d(0, -1px, 0);
  border-color: var(--eyeq-button-border-hover);
  background: var(--eyeq-button-bg-hover, var(--eyeq-button-surface-hover));
  color: var(--eyeq-button-color-hover, var(--eyeq-button-color, var(--text)));
  box-shadow: var(--eyeq-button-shadow-hover);
}

.btn:focus-visible,
.login-submit:focus-visible,
.auth-secondary:focus-visible,
.company__phrase-add:focus-visible,
.profile-avatar-panel__action:focus-visible,
.search__shortcut:focus-visible,
.notification-context-menu__item:focus-visible,
.agevolazione-note-preview-btn:focus-visible,
.agevolazione-info-toggle:focus-visible,
.calendar-datetime-trigger:focus-visible,
.calendar-datetime-picker__nav:focus-visible,
.calendar-datetime-picker__chip:focus-visible,
.calendar-datetime-picker__close:focus-visible,
.rubrica-row-action:focus-visible,
.board--contributi .company__tool-btn:focus-visible,
.agevolazione-task .company__tool-btn:focus-visible,
.agevolazione-doc-item .company__tool-btn:focus-visible,
.company__category-delete:focus-visible,
.company__subcats-add:focus-visible,
.notification-card__delete:focus-visible,
.sidebar__edit:focus-visible,
.sidebar__close:focus-visible,
.app-header__menu-toggle:focus-visible,
.modal__close:focus-visible,
.developer-color-picker__trigger:focus-visible,
.developer-label-picker__toggle:focus-visible {
  outline: none;
  border-color: var(--eyeq-button-border-hover);
  box-shadow: 0 0 0 3px var(--eyeq-button-focus), var(--eyeq-button-shadow);
}

.btn:disabled,
.login-submit:disabled,
.auth-secondary:disabled,
.company__phrase-add:disabled,
.profile-avatar-panel__action:disabled,
.search__shortcut:disabled,
.notification-context-menu__item:disabled,
.agevolazione-note-preview-btn:disabled,
.agevolazione-info-toggle:disabled,
.calendar-datetime-trigger:disabled,
.calendar-datetime-picker__nav:disabled,
.calendar-datetime-picker__chip:disabled,
.calendar-datetime-picker__close:disabled,
.rubrica-row-action:disabled,
.board--contributi .company__tool-btn:disabled,
.agevolazione-task .company__tool-btn:disabled,
.agevolazione-doc-item .company__tool-btn:disabled,
.company__category-delete:disabled,
.company__subcats-add:disabled,
.notification-card__delete:disabled,
.sidebar__edit:disabled,
.sidebar__close:disabled,
.app-header__menu-toggle:disabled,
.modal__close:disabled,
.developer-color-picker__trigger:disabled,
.developer-label-picker__toggle:disabled,
.btn[aria-disabled="true"],
.notification-context-menu__item[aria-disabled="true"] {
  cursor: not-allowed;
  pointer-events: none;
  opacity: 0.56;
  box-shadow: none;
  filter: saturate(0.8);
}

.btn,
.login-submit,
.company__phrase-add {
  --eyeq-button-bg: var(--eyeq-button-primary-surface);
  --eyeq-button-bg-hover: var(--eyeq-button-primary-surface-hover);
  --eyeq-button-border: color-mix(in srgb, var(--accent-strong) 26%, rgba(255, 255, 255, 0.7));
  --eyeq-button-border-hover: color-mix(in srgb, var(--accent-strong) 46%, rgba(255, 255, 255, 0.64));
  --eyeq-button-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.52),
    0 12px 24px rgba(64, 114, 159, 0.18);
  --eyeq-button-shadow-hover:
    inset 0 1px 0 rgba(255, 255, 255, 0.62),
    0 18px 32px rgba(64, 114, 159, 0.24);
}

.btn--secondary,
.auth-secondary,
.company__phrase-add--ghost,
.profile-avatar-panel__action,
.search__shortcut,
.notification-context-menu__item,
.agevolazione-info-toggle,
.calendar-datetime-trigger,
.calendar-datetime-picker__nav,
.calendar-datetime-picker__chip,
.calendar-datetime-picker__close,
.rubrica-row-action,
.sidebar__edit,
.sidebar__close,
.app-header__menu-toggle,
.modal__close,
.developer-color-picker__trigger,
.developer-label-picker__toggle {
  --eyeq-button-bg: var(--eyeq-button-secondary-surface);
  --eyeq-button-bg-hover: var(--eyeq-button-secondary-surface-hover);
}

.btn--danger,
.notification-card__delete,
.notification-context-menu__item.is-danger,
.rubrica-row-action--danger,
.board--contributi .company__tool-btn--danger,
.agevolazione-task .company__tool-btn,
.agevolazione-doc-item .company__tool-btn,
.company__category-delete {
  --eyeq-button-bg: var(--eyeq-button-danger-surface);
  --eyeq-button-bg-hover: var(--eyeq-button-danger-surface-hover);
  --eyeq-button-border: color-mix(in srgb, #ef4444 42%, rgba(255, 255, 255, 0.56));
  --eyeq-button-border-hover: color-mix(in srgb, #dc2626 64%, rgba(255, 255, 255, 0.48));
  --eyeq-button-color: #b91c1c;
  --eyeq-button-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.24),
    0 10px 22px rgba(239, 68, 68, 0.16);
  --eyeq-button-shadow-hover:
    inset 0 1px 0 rgba(255, 255, 255, 0.32),
    0 14px 28px rgba(239, 68, 68, 0.22);
}

body[data-theme="dark"] .btn--danger,
body[data-theme="dark"] .notification-card__delete,
body[data-theme="dark"] .notification-context-menu__item.is-danger,
body[data-theme="dark"] .rubrica-row-action--danger,
body[data-theme="dark"] .board--contributi .company__tool-btn--danger,
body[data-theme="dark"] .agevolazione-task .company__tool-btn,
body[data-theme="dark"] .agevolazione-doc-item .company__tool-btn,
body[data-theme="dark"] .company__category-delete {
  --eyeq-button-color: #fecaca;
}

.profile-avatar-panel__action.is-active,
.agevolazione-info-toggle.is-open,
.rubrica-row-action.is-active,
.calendar-datetime-field.is-active .calendar-datetime-trigger,
.developer-label-picker.is-open .developer-label-picker__toggle,
.developer-color-picker.is-open .developer-color-picker__trigger {
  border-color: var(--eyeq-button-border-hover);
  background: var(--eyeq-button-bg-hover, var(--eyeq-button-surface-hover));
  color: var(--eyeq-button-color-active, var(--eyeq-button-color, var(--text)));
  box-shadow: 0 0 0 3px var(--eyeq-button-focus), var(--eyeq-button-shadow-hover);
}

.profile-avatar-panel__action,
.search__shortcut,
.agevolazione-info-toggle,
.calendar-datetime-picker__chip,
.calendar-datetime-picker__close {
  border-radius: 999px;
}

.modal__close,
.company__category-delete,
.company__subcats-add {
  display: inline-grid;
  place-items: center;
}

.developer-color-picker__trigger,
.developer-label-picker__toggle {
  --eyeq-button-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.3),
    0 8px 18px rgba(15, 23, 42, 0.08);
  --eyeq-button-shadow-hover:
    inset 0 1px 0 rgba(255, 255, 255, 0.38),
    0 12px 22px rgba(15, 23, 42, 0.12);
}

body[data-theme="dark"] .developer-color-picker__trigger,
body[data-theme="dark"] .developer-label-picker__toggle {
  --eyeq-button-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.06),
    0 10px 20px rgba(2, 6, 23, 0.22);
  --eyeq-button-shadow-hover:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 14px 24px rgba(2, 6, 23, 0.3);
}

.developer-label-picker__toggle,
.developer-label-picker__toggle:hover,
.developer-label-picker.is-open .developer-label-picker__toggle,
.developer-label-picker__toggle:focus-visible {
  --eyeq-button-bg: transparent;
  --eyeq-button-bg-hover: transparent;
  --eyeq-button-border: transparent;
  --eyeq-button-border-hover: transparent;
  --eyeq-button-shadow: none;
  --eyeq-button-shadow-hover: none;
  --eyeq-button-focus: transparent;
  border-color: transparent;
  background: transparent;
  box-shadow: none;
}

.chat-widget {
  position: fixed;
  right: 24px;
  bottom: 20px;
  z-index: 70;
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  pointer-events: none;
}

.chat-widget > * {
  pointer-events: auto;
}

.chat-widget__panel {
  position: fixed;
  right: 24px;
  bottom: 88px;
  width: min(432px, calc(100vw - 32px));
  height: min(548px, calc(var(--viewport-height) - 146px));
  opacity: 0;
  transform: translateY(14px) scale(0.985);
  transform-origin: bottom right;
  transition:
    opacity var(--duration) var(--ease-out),
    transform var(--duration) var(--ease-out);
}

.chat-widget.is-open .chat-widget__panel {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.chat-widget__surface {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid color-mix(in srgb, var(--glass-border-strong) 90%, transparent);
  background:
    radial-gradient(110% 110% at 12% 0%, rgba(93, 135, 167, 0.1), transparent 56%),
    linear-gradient(180deg, color-mix(in srgb, var(--glass-strong) 98%, transparent) 0%, color-mix(in srgb, var(--glass) 99%, transparent) 100%);
  box-shadow:
    0 20px 44px rgba(2, 6, 23, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.22);
  backdrop-filter: blur(18px) saturate(132%);
  -webkit-backdrop-filter: blur(18px) saturate(132%);
}

.chat-widget__header {
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr) 36px;
  align-items: center;
  gap: 10px;
  padding: 12px 14px 8px;
  border-bottom: 1px solid color-mix(in srgb, var(--glass-border) 82%, transparent);
}

.chat-widget__header [data-chat-back] {
  grid-column: 1;
  justify-self: start;
}

.chat-widget__header-copy {
  grid-column: 2;
  min-width: 0;
  display: grid;
  gap: 2px;
  text-align: left;
  justify-items: start;
}

.chat-widget__header [data-chat-back][hidden] + .chat-widget__header-copy {
  grid-column: 1 / 3;
}

.chat-widget__header [data-chat-close] {
  grid-column: 3;
  justify-self: end;
}

.chat-widget__eyebrow {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--accent) 74%, var(--muted));
}

.chat-widget__title {
  font-size: 15px;
  line-height: 1.15;
  font-weight: 700;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.chat-widget__subtitle {
  font-size: 10px;
  color: var(--muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.chat-widget__nav-btn {
  width: 36px;
  height: 36px;
  border: 1px solid color-mix(in srgb, var(--glass-border-strong) 74%, transparent);
  border-radius: 11px;
  background: color-mix(in srgb, var(--glass) 94%, transparent);
  color: var(--text);
  display: inline-grid;
  place-items: center;
  cursor: pointer;
  transition:
    transform var(--duration-fast) var(--ease-out),
    background var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out);
}

.chat-widget__nav-btn:hover,
.chat-widget__nav-btn:focus-visible {
  transform: translateY(-1px);
  background: color-mix(in srgb, var(--accent-soft) 24%, var(--glass-strong));
  border-color: color-mix(in srgb, var(--accent) 28%, var(--glass-border-strong));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--focus) 34%, transparent);
  outline: none;
}

.chat-widget__nav-btn svg,
.chat-widget__nav-btn i,
.chat-widget__composer-send i {
  display: block;
  width: 16px;
  height: 16px;
  font-size: 15px;
  line-height: 1;
}

.chat-widget__toggle-icon {
  display: block;
  width: 36px;
  height: 36px;
  font-size: 36px;
  line-height: 1;
}

.chat-widget__toggle .chat-widget__toggle-icon.fa-regular.fa-comment-dots {
  width: 36px;
  height: 36px;
}

.chat-widget__search {
  padding: 8px 14px 0;
}

.chat-widget__search input,
.chat-widget__composer-input {
  width: 100%;
  border: 1px solid color-mix(in srgb, var(--input-border) 90%, transparent);
  border-radius: 12px;
  background: color-mix(in srgb, var(--input-bg) 98%, transparent);
  color: var(--text);
  font: inherit;
  font-size: 13px;
  transition:
    border-color var(--duration-fast) var(--ease-out),
    background var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out);
}

.chat-widget__search input {
  min-height: 36px;
  padding: 0 12px;
}

.chat-widget__search input::placeholder,
.chat-widget__composer-input::placeholder {
  color: color-mix(in srgb, var(--muted) 88%, transparent);
}

.chat-widget__search input:focus-visible,
.chat-widget__composer-input:focus-visible {
  outline: none;
  border-color: color-mix(in srgb, var(--accent) 46%, transparent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--focus) 32%, transparent);
  background: color-mix(in srgb, var(--glass-strong) 94%, transparent);
}

.chat-widget__body {
  min-height: 0;
  flex: 1 1 auto;
  display: flex;
  overflow: hidden;
}

.chat-widget__contacts,
.chat-widget__thread {
  min-height: 0;
  flex: 1 1 auto;
  width: 100%;
}

.chat-widget__panel[hidden],
.chat-widget__contacts[hidden],
.chat-widget__thread[hidden],
.chat-widget__nav-btn[hidden],
.chat-widget__contact-unread[hidden],
.chat-widget__toggle-badge[hidden] {
  display: none !important;
}

.chat-widget__contacts {
  display: flex;
  flex-direction: column;
  padding: 8px 14px 12px;
  gap: 6px;
}

.chat-widget__status {
  font-size: 10px;
  color: var(--muted);
}

.chat-widget__contact-list,
.chat-widget__messages {
  min-height: 0;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) transparent;
}

.chat-widget__contact-list::-webkit-scrollbar,
.chat-widget__messages::-webkit-scrollbar {
  width: 8px;
}

.chat-widget__contact-list::-webkit-scrollbar-thumb,
.chat-widget__messages::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: var(--scrollbar-thumb);
}

.chat-widget__contact-list {
  flex: 1 1 auto;
  display: grid;
  gap: 6px;
  align-content: start;
  padding: 4px 0 6px;
}

.chat-widget__contact {
  width: 100%;
  border: 1px solid color-mix(in srgb, var(--glass-border) 78%, transparent);
  border-radius: 12px;
  background: color-mix(in srgb, var(--glass) 96%, transparent);
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 9px;
  padding: 8px 10px;
  text-align: left;
  color: inherit;
  cursor: pointer;
  transition:
    transform var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out),
    background var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out);
}

.chat-widget__contact:hover,
.chat-widget__contact:focus-visible {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--accent) 26%, var(--glass-border-strong));
  background: color-mix(in srgb, var(--accent-soft) 14%, var(--glass-strong));
  box-shadow: 0 10px 18px rgba(15, 23, 42, 0.08);
  outline: none;
}

.chat-widget__contact.is-unread {
  border-color: color-mix(in srgb, var(--accent) 34%, var(--glass-border-strong));
}

.chat-widget__contact-media {
  position: relative;
  width: 36px;
  height: 36px;
}

.chat-widget__avatar {
  width: 36px;
  height: 36px;
  border-radius: 999px;
  border: none;
  background: var(--avatar-bg, #5D87A7);
  color: var(--avatar-fg, #FFFFFF);
  display: inline-grid;
  place-items: center;
  box-shadow: none;
  overflow: hidden;
}

.chat-widget__avatar--message {
  width: 30px;
  height: 30px;
  border-radius: 999px;
}

.chat-widget__avatar-image,
.chat-widget__avatar--message-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.chat-widget__avatar-initial {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.chat-widget__presence {
  position: absolute;
  right: -2px;
  bottom: -2px;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: 2px solid color-mix(in srgb, var(--glass-strong) 98%, transparent);
  background: #94a3b8;
}

.chat-widget__presence.is-online {
  background: #22c55e;
}

.chat-widget__presence.is-offline {
  background: #94a3b8;
}

.chat-widget__contact-copy,
.chat-widget__contact-heading,
.chat-widget__contact-meta {
  min-width: 0;
  display: grid;
}

.chat-widget__contact-copy {
  gap: 2px;
}

.chat-widget__contact-heading {
  gap: 1px;
}

.chat-widget__contact-name {
  font-size: 12px;
  font-weight: 700;
  line-height: 1.15;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.chat-widget__contact-company,
.chat-widget__contact-preview,
.chat-widget__contact-time {
  font-size: 10px;
  line-height: 1.2;
  color: var(--muted);
}

.chat-widget__contact-preview {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.chat-widget__contact-meta {
  gap: 4px;
  justify-items: end;
}

.chat-widget__contact-unread {
  width: 12px;
  height: 12px;
  min-width: 12px;
  padding: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
  color: #fff;
  font-size: 0;
  font-weight: 700;
  display: inline-grid;
  place-items: center;
  box-shadow: 0 8px 14px rgba(220, 38, 38, 0.2);
}

.chat-widget__thread {
  display: flex !important;
  flex-direction: column;
  justify-content: flex-end;
  padding: 0 14px 12px;
}

.chat-widget__messages {
  flex: 1 1 auto;
  display: grid;
  gap: 8px;
  min-height: 0;
  overflow-y: auto;
  padding: 8px 0 8px;
  align-content: start;
}

.chat-widget__date-divider {
  display: flex;
  justify-content: center;
  margin: 2px 0;
}

.chat-widget__date-divider-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 20px;
  padding: 3px 10px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--glass-border) 82%, transparent);
  background: color-mix(in srgb, var(--glass) 94%, white 6%);
  color: var(--muted);
  font-size: 10px;
  font-weight: 700;
  line-height: 1;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.05);
}

.chat-widget__message-row {
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr);
  gap: 7px;
  align-items: end;
}

.chat-widget__message-row.is-outbound {
  grid-template-columns: minmax(0, 1fr) 30px;
}

.chat-widget__message-row.is-outbound > .chat-widget__avatar {
  order: 2;
}

.chat-widget__message-row.is-outbound > .chat-widget__message {
  order: 1;
  justify-items: end;
}

.chat-widget__message {
  display: grid;
  gap: 3px;
  justify-items: start;
}

.chat-widget__message-sender,
.chat-widget__message-time {
  font-size: 10px;
  color: var(--muted);
}

.chat-widget__message-meta {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.chat-widget__message-bubble {
  width: fit-content;
  max-width: min(100%, 320px);
  justify-self: start;
  padding: 8px 11px;
  border-radius: 12px 12px 12px 4px;
  border: 1px solid color-mix(in srgb, var(--glass-border) 82%, transparent);
  background: color-mix(in srgb, var(--glass) 96%, transparent);
  color: var(--text);
  box-shadow: 0 8px 16px rgba(15, 23, 42, 0.06);
  font-size: 12px;
  line-height: 1.45;
  white-space: pre-wrap;
  word-break: break-word;
}

.chat-widget__message-row.is-outbound .chat-widget__message-bubble {
  justify-self: end;
  border-radius: 12px 12px 4px 12px;
  border-color: color-mix(in srgb, var(--accent) 24%, transparent);
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--accent) 90%, white 10%) 0%, color-mix(in srgb, var(--accent-2) 86%, white 14%) 100%);
  color: #fff;
}

.chat-widget__message-row.is-outbound .chat-widget__message-sender,
.chat-widget__message-row.is-outbound .chat-widget__message-time,
.chat-widget__message-row.is-outbound .chat-widget__message-meta {
  text-align: right;
  justify-self: end;
}

.chat-widget__message-status {
  width: 14px;
  height: 10px;
  display: inline-grid;
  place-items: center;
  color: #94a3b8;
}

.chat-widget__message-status svg {
  width: 100%;
  height: 100%;
  display: block;
  overflow: visible;
}

.chat-widget__message-status path {
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.chat-widget__message-status.is-read {
  color: #38bdf8;
}

.chat-widget__composer {
  position: static !important;
  flex: 0 0 auto;
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr) 38px;
  gap: 6px;
  align-items: center;
  margin-top: 8px;
  padding-top: 8px;
  background: transparent !important;
  border-top: 1px solid color-mix(in srgb, var(--glass-border) 78%, transparent);
  overflow: visible;
}

.chat-widget__emoji-shell {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: visible;
}

.chat-widget__composer-emoji {
  width: 38px;
  height: 38px;
  border: 1px solid color-mix(in srgb, var(--input-border) 88%, transparent);
  border-radius: 12px;
  background: color-mix(in srgb, var(--input-bg) 96%, transparent);
  color: color-mix(in srgb, var(--accent) 76%, var(--text));
  display: inline-grid;
  place-items: center;
  cursor: pointer;
  box-shadow: 0 8px 16px rgba(15, 23, 42, 0.06);
  transition:
    transform var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out),
    background var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out),
    color var(--duration-fast) var(--ease-out);
}

.chat-widget__composer-emoji svg {
  display: block;
  width: 18px;
  height: 18px;
}

.chat-widget__composer-emoji:hover,
.chat-widget__composer-emoji:focus-visible,
.chat-widget__emoji-shell.is-open .chat-widget__composer-emoji {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--accent) 34%, var(--glass-border-strong));
  background: color-mix(in srgb, var(--accent-soft) 16%, var(--glass-strong));
  box-shadow: 0 12px 20px rgba(31, 77, 122, 0.12);
  outline: none;
}

.chat-widget__composer-emoji:disabled {
  cursor: default;
  opacity: 0.46;
  transform: none;
  box-shadow: none;
}

.chat-widget__emoji-picker {
  position: absolute;
  left: 0;
  bottom: calc(100% + 10px);
  width: min(320px, calc(100vw - 48px));
  max-height: 320px;
  padding: 10px;
  border: 1px solid color-mix(in srgb, var(--glass-border-strong) 82%, transparent);
  border-radius: 16px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--glass-strong) 98%, transparent) 0%, color-mix(in srgb, var(--glass) 96%, transparent) 100%);
  backdrop-filter: blur(18px) saturate(142%);
  box-shadow:
    0 20px 40px rgba(15, 23, 42, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
  z-index: 35;
}

.chat-widget__emoji-search {
  margin-bottom: 8px;
}

.chat-widget__emoji-search input {
  width: 100%;
  min-height: 34px;
  padding: 0 11px;
  border: 1px solid color-mix(in srgb, var(--input-border) 88%, transparent);
  border-radius: 11px;
  background: color-mix(in srgb, var(--input-bg) 98%, transparent);
  color: var(--text);
  font: inherit;
  font-size: 12px;
  transition:
    border-color var(--duration-fast) var(--ease-out),
    background var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out);
}

.chat-widget__emoji-search input::placeholder {
  color: color-mix(in srgb, var(--muted) 88%, transparent);
}

.chat-widget__emoji-search input:focus-visible {
  outline: none;
  border-color: color-mix(in srgb, var(--accent) 42%, transparent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--focus) 26%, transparent);
  background: color-mix(in srgb, var(--glass-strong) 94%, transparent);
}

.chat-widget__emoji-content {
  max-height: 258px;
  overflow-y: auto;
  padding-right: 2px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) transparent;
}

.chat-widget__emoji-content::-webkit-scrollbar {
  width: 7px;
}

.chat-widget__emoji-content::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: var(--scrollbar-thumb);
}

.chat-widget__emoji-section {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.chat-widget__emoji-title {
  margin: 0;
  padding: 0 2px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--muted);
}

.chat-widget__emoji-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 4px;
}

.chat-widget__emoji-button {
  min-height: 36px;
  border: none;
  border-radius: 10px;
  background: transparent;
  color: inherit;
  display: inline-grid;
  place-items: center;
  cursor: pointer;
  font-size: 21px;
  line-height: 1;
  transition:
    transform var(--duration-fast) var(--ease-out),
    background var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out);
}

.chat-widget__emoji-button:hover,
.chat-widget__emoji-button:focus-visible {
  transform: translateY(-1px) scale(1.03);
  background: color-mix(in srgb, var(--accent-soft) 16%, var(--glass-strong));
  box-shadow: 0 8px 16px rgba(31, 77, 122, 0.08);
  outline: none;
}

.chat-widget__emoji-empty {
  padding: 14px 10px;
  border: 1px dashed color-mix(in srgb, var(--glass-border-strong) 78%, transparent);
  border-radius: 12px;
  color: var(--muted);
  text-align: center;
  font-size: 12px;
  line-height: 1.45;
}

.chat-widget__composer-input {
  min-height: 36px;
  padding: 0 12px;
}

.chat-widget__composer-send {
  width: 38px;
  height: 38px;
  border: none;
  border-radius: 12px;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--accent) 94%, white 6%) 0%, color-mix(in srgb, var(--accent-2) 90%, white 10%) 100%);
  color: #fff;
  display: inline-grid;
  place-items: center;
  cursor: pointer;
  box-shadow: 0 10px 18px rgba(31, 77, 122, 0.2);
  transition:
    transform var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out),
    opacity var(--duration-fast) var(--ease-out);
}

.chat-widget__composer-send:hover,
.chat-widget__composer-send:focus-visible {
  transform: translateY(-1px) scale(1.02);
  box-shadow: 0 14px 22px rgba(31, 77, 122, 0.24);
  outline: none;
}

.chat-widget__composer-send:disabled {
  cursor: default;
  opacity: 0.44;
  transform: none;
  box-shadow: none;
}

.chat-widget__empty {
  min-height: 100%;
  border: 1px dashed color-mix(in srgb, var(--glass-border-strong) 82%, transparent);
  border-radius: 14px;
  background: color-mix(in srgb, var(--glass) 54%, transparent);
  color: var(--muted);
  display: grid;
  place-items: center;
  padding: 18px;
  text-align: center;
  font-size: 12px;
  line-height: 1.45;
}

.chat-widget__toggle {
  position: relative;
  width: 64px;
  height: 64px;
  border: none;
  border-radius: 999px;
  background:
    linear-gradient(135deg, #2b7fd4 0%, #4a96e2 100%);
  color: #fff;
  display: inline-grid;
  place-items: center;
  cursor: pointer;
  box-shadow:
    0 16px 28px rgba(43, 127, 212, 0.24),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
  transition:
    transform var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out);
}

.chat-widget__toggle:hover,
.chat-widget__toggle:focus-visible {
  transform: translateY(-2px) scale(1.03);
  box-shadow:
    0 20px 34px rgba(43, 127, 212, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.24);
  outline: none;
}

.chat-widget__toggle-glow {
  position: absolute;
  inset: -5px;
  border-radius: inherit;
  background: inherit;
  opacity: 0.18;
  filter: blur(14px);
  z-index: -1;
}

.chat-widget__toggle-badge {
  position: absolute;
  top: -6px;
  right: -6px;
  min-width: 22px;
  height: 22px;
  padding: 0 6px;
  border-radius: 999px;
  border: 2px solid rgba(255, 255, 255, 0.92);
  background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
  color: #fff;
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
  font-variant-numeric: tabular-nums;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  box-shadow: 0 10px 18px rgba(220, 38, 38, 0.24);
}

body[data-theme="dark"] .chat-widget__message-row.is-outbound .chat-widget__message-bubble {
  color: #f8fbff;
}

@media (max-width: 760px) {
  .chat-widget,
  .chat-widget__panel {
    right: 14px;
  }

  .chat-widget {
    bottom: 16px;
  }

  .chat-widget__panel {
    bottom: 78px;
    width: calc(100vw - 28px);
    height: min(68vh, 540px);
  }
}

@media (max-width: 540px) {
  .chat-widget__panel {
    right: 10px;
    bottom: 74px;
    width: calc(100vw - 20px);
    height: min(72vh, calc(var(--viewport-height) - 104px));
  }

  .chat-widget__surface {
    border-radius: 16px;
  }

  .chat-widget__contact {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .chat-widget__contact-meta {
    grid-column: 2;
    grid-auto-flow: column;
    justify-content: start;
    gap: 10px;
  }
}


