/* ==========================================================================
   Portal — CSS Theme (Kebnekaise Design System)
   ========================================================================== */

@layer reset, tokens, base, layout, components, utilities;

/* ==========================================================================
   @font-face — Self-hosted fonts (no third-party requests)
   ========================================================================== */

@font-face {
  font-family: 'Bebas Neue';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/static/fonts/bebas-neue-400.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6,
    U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122,
    U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'Space Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/static/fonts/space-mono-400.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6,
    U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122,
    U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'Space Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('/static/fonts/space-mono-700.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6,
    U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122,
    U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'Sora';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('/static/fonts/sora-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6,
    U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122,
    U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'Sora';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/static/fonts/sora-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6,
    U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122,
    U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'Sora';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('/static/fonts/sora-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6,
    U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122,
    U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'Sora';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('/static/fonts/sora-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6,
    U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122,
    U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'Sora';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('/static/fonts/sora-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6,
    U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122,
    U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* ==========================================================================
   @property — Animatable custom properties
   ========================================================================== */

@property --accent-hue {
  syntax: '<number>';
  inherits: true;
  initial-value: 155;
}

@property --glow-opacity {
  syntax: '<number>';
  inherits: false;
  initial-value: 0;
}

@property --glow-spread {
  syntax: '<length>';
  inherits: false;
  initial-value: 0px;
}

/* ==========================================================================
   @layer reset — Modern CSS reset (Josh Comeau inspired)
   ========================================================================== */

@layer reset {
  *,
  *::before,
  *::after {
    box-sizing: border-box;
  }

  * {
    margin: 0;
    padding: 0;
  }

  html {
    -webkit-text-size-adjust: none;
    text-size-adjust: none;
    -moz-text-size-adjust: none;
  }

  body {
    min-block-size: 100dvh;
    -webkit-font-smoothing: antialiased;
  }

  img,
  picture,
  video,
  canvas,
  svg {
    display: block;
    max-inline-size: 100%;
  }

  input,
  button,
  textarea,
  select {
    font: inherit;
    color: inherit;
  }

  p,
  h1,
  h2,
  h3,
  h4,
  h5,
  h6 {
    overflow-wrap: break-word;
  }

  h1,
  h2,
  h3,
  h4 {
    text-wrap: balance;
  }

  p {
    text-wrap: pretty;
  }

  a {
    text-decoration: none;
    color: inherit;
  }

  ul,
  ol {
    list-style: none;
  }

  table {
    border-collapse: collapse;
  }
}

/* ==========================================================================
   @layer tokens — Design tokens as CSS custom properties
   ========================================================================== */

@layer tokens {
  :root {
    /* -- Surfaces (oklch) ------------------------------------------------ */
    --color-black: oklch(0.07 0 0);
    --color-dark: oklch(0.12 0 0);
    --color-charcoal: oklch(0.16 0.005 260);
    --color-graphite: oklch(0.21 0.005 260);
    --color-steel: oklch(0.30 0.01 260);

    /* -- Text (oklch) --------------------------------------------------- */
    --color-slate: oklch(0.50 0.01 260);
    --color-silver: oklch(0.68 0.01 260);
    --color-light: oklch(0.92 0 0);
    --color-white: oklch(1.0 0 0);

    /* -- Brand (oklch) -------------------------------------------------- */
    --color-accent: oklch(0.87 0.29 var(--accent-hue));
    --color-warning: oklch(0.72 0.20 45);
    --color-danger: oklch(0.65 0.25 27);
    --color-success: oklch(0.75 0.18 155);
    --color-info: oklch(0.70 0.15 240);

    /* -- Derived (color-mix) -------------------------------------------- */
    --color-accent-dim: color-mix(in oklch, var(--color-accent) 40%, transparent);
    --color-accent-subtle: color-mix(in oklch, var(--color-accent) 15%, transparent);
    --color-accent-hover: color-mix(in oklch, var(--color-accent) 85%, white);
    --color-danger-dim: color-mix(in oklch, var(--color-danger) 40%, transparent);
    --color-danger-subtle: color-mix(in oklch, var(--color-danger) 15%, transparent);
    --color-warning-dim: color-mix(in oklch, var(--color-warning) 40%, transparent);
    --color-success-dim: color-mix(in oklch, var(--color-success) 40%, transparent);
    --color-info-dim: color-mix(in oklch, var(--color-info) 40%, transparent);

    /* -- Semantic (light-dark ready) ------------------------------------ */
    --surface-base: light-dark(var(--color-white), var(--color-black));
    --surface-raised: light-dark(oklch(0.97 0 0), var(--color-dark));
    --surface-overlay: light-dark(oklch(0.95 0 0), var(--color-charcoal));
    --text-primary: light-dark(oklch(0.15 0 0), var(--color-light));
    --text-secondary: light-dark(oklch(0.40 0 0), var(--color-silver));
    --text-muted: light-dark(oklch(0.55 0 0), var(--color-slate));
    --border-color: light-dark(oklch(0.88 0 0), var(--color-graphite));

    /* -- Typography ----------------------------------------------------- */
    --font-display: 'Bebas Neue', Impact, sans-serif;
    --font-mono: 'Space Mono', ui-monospace, 'Cascadia Code', monospace;
    --font-body: 'Sora', system-ui, -apple-system, sans-serif;

    --text-xs: clamp(0.694rem, 0.66vi + 0.53rem, 0.8rem);
    --text-sm: clamp(0.833rem, 0.8vi + 0.63rem, 0.95rem);
    --text-base: clamp(0.938rem, 0.95vi + 0.7rem, 1.063rem);
    --text-md: clamp(1.063rem, 1.1vi + 0.8rem, 1.25rem);
    --text-lg: clamp(1.25rem, 1.4vi + 0.9rem, 1.5rem);
    --text-xl: clamp(1.5rem, 2vi + 1rem, 2rem);
    --text-2xl: clamp(2rem, 3vi + 1.2rem, 2.75rem);
    --text-3xl: clamp(2.5rem, 4.5vi + 1.3rem, 4rem);
    --text-4xl: clamp(3rem, 6vi + 1.5rem, 5.5rem);

    --leading-tight: 1.1;
    --leading-snug: 1.3;
    --leading-normal: 1.6;
    --leading-relaxed: 1.8;

    --tracking-tight: -0.02em;
    --tracking-normal: 0;
    --tracking-wide: 0.05em;
    --tracking-wider: 0.1em;

    /* -- Spacing -------------------------------------------------------- */
    --space-xs: 0.5rem;
    --space-sm: 0.75rem;
    --space-md: 1rem;
    --space-lg: 1.5rem;
    --space-xl: 2rem;
    --space-2xl: 4rem;
    --space-3xl: 10rem;

    /* -- Motion --------------------------------------------------------- */
    --ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
    --ease-out-quart: cubic-bezier(0.25, 1, 0.5, 1);
    --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
    --duration-fast: 150ms;
    --duration-normal: 250ms;
    --duration-slow: 400ms;
    --duration-slower: 800ms;

    /* -- Radii ---------------------------------------------------------- */
    --radius-sm: 0.25rem;
    --radius-md: 0.5rem;
    --radius-lg: 0.75rem;
    --radius-xl: 1rem;
    --radius-full: 9999px;

    /* -- Shadows (oklch alpha) ------------------------------------------ */
    --shadow-sm: 0 1px 2px oklch(0 0 0 / 0.3);
    --shadow-md: 0 4px 12px oklch(0 0 0 / 0.4);
    --shadow-lg: 0 8px 30px oklch(0 0 0 / 0.5);
    --shadow-glow: 0 0 var(--glow-spread, 20px) var(--color-accent-dim);

    /* -- Z-index -------------------------------------------------------- */
    --z-base: 0;
    --z-raised: 10;
    --z-nav: 100;
    --z-overlay: 200;
    --z-modal: 300;
  }
}

/* ==========================================================================
   @layer base — Element-level defaults
   ========================================================================== */

@layer base {
  html {
    color-scheme: dark;
    scroll-behavior: smooth;
  }

  body {
    font-family: var(--font-body);
    font-size: var(--text-base);
    font-weight: 400;
    line-height: var(--leading-normal);
    color: var(--text-primary);
    background-color: var(--surface-base);
  }

  h1,
  h2,
  h3,
  h4,
  h5,
  h6 {
    font-family: var(--font-display);
    font-weight: 400;
    line-height: var(--leading-tight);
    letter-spacing: var(--tracking-wide);
    text-transform: uppercase;
    color: var(--color-white);
  }

  h1 { font-size: var(--text-4xl); }
  h2 { font-size: var(--text-3xl); }
  h3 { font-size: var(--text-2xl); }
  h4 { font-size: var(--text-xl); }
  h5 { font-size: var(--text-lg); }
  h6 { font-size: var(--text-md); }

  p {
    color: var(--text-secondary);
    max-inline-size: 65ch;
  }

  a {
    color: var(--color-accent);
    transition: color var(--duration-fast) var(--ease-out-quart);

    &:hover {
      color: var(--color-accent-hover);
    }

    &:focus-visible {
      outline: 2px solid var(--color-accent);
      outline-offset: 2px;
      border-radius: var(--radius-sm);
    }
  }

  strong,
  b {
    font-weight: 600;
    color: var(--color-light);
  }

  code,
  kbd {
    font-family: var(--font-mono);
    font-size: 0.9em;
    padding-inline: 0.35em;
    padding-block: 0.15em;
    background-color: var(--surface-raised);
    border-radius: var(--radius-sm);
  }

  kbd {
    border: 1px solid var(--border-color);
  }

  pre {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    background-color: var(--surface-raised);
    padding: var(--space-md);
    border-radius: var(--radius-md);
    overflow-x: auto;

    & code {
      padding: 0;
      background: none;
    }
  }

  hr {
    border: none;
    border-block-start: 1px solid var(--border-color);
    margin-block: var(--space-lg);
  }

  :focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
  }

  ::selection {
    background-color: var(--color-accent-dim);
    color: var(--color-white);
  }

  /* Scrollbar styling */
  :root {
    scrollbar-width: thin;
    scrollbar-color: var(--color-steel) transparent;
  }
}

/* ==========================================================================
   @layer layout — Layout primitives
   ========================================================================== */

@layer layout {
  .container {
    inline-size: min(var(--container-max, 1280px), 100% - var(--space-xl) * 2);
    margin-inline: auto;

    &--narrow {
      --container-max: 720px;
    }

    &--wide {
      --container-max: 1600px;
    }
  }

  .grid {
    display: grid;
    gap: var(--grid-gap, var(--space-lg));
    grid-template-columns: repeat(
      auto-fit,
      minmax(min(100%, var(--grid-min, 280px)), 1fr)
    );

    &--cols-2 { --grid-min: 320px; }
    &--cols-3 { --grid-min: 260px; }
    &--cols-4 { --grid-min: 200px; }
  }

  .stack {
    display: flex;
    flex-direction: column;
    gap: var(--stack-gap, var(--space-md));
  }

  .cluster {
    display: flex;
    flex-wrap: wrap;
    gap: var(--cluster-gap, var(--space-md));
    align-items: center;
  }

  .with-sidebar {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-lg);

    & > :first-child {
      flex-basis: var(--sidebar-width, 280px);
      flex-grow: 1;
    }

    & > :last-child {
      flex-basis: 0;
      flex-grow: 999;
      min-inline-size: 60%;
    }
  }

  .center-page {
    display: grid;
    place-items: center;
    min-block-size: 100dvh;
    padding: var(--space-lg);
  }
}

/* ==========================================================================
   @layer components — UI components
   ========================================================================== */

@layer components {
  /* -- Nav -------------------------------------------------------------- */

  .nav {
    position: sticky;
    inset-block-start: 0;
    z-index: var(--z-nav);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-md);
    padding-block: var(--space-sm);
    padding-inline: var(--space-lg);
    background-color: oklch(0.07 0 0 / 0.8);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-block-end: 1px solid var(--border-color);
  }

  .nav__brand {
    font-family: var(--font-display);
    font-size: var(--text-xl);
    letter-spacing: var(--tracking-wider);
    text-transform: uppercase;
    color: var(--color-white);
  }

  .nav__links {
    display: flex;
    gap: var(--space-md);
    align-items: center;
  }

  .nav__link {
    font-size: var(--text-sm);
    font-weight: 500;
    color: var(--text-secondary);
    transition: color var(--duration-fast) var(--ease-out-quart);
    padding-block: var(--space-xs);

    &:hover {
      color: var(--color-white);
    }

    &--active {
      color: var(--color-accent);
    }
  }

  /* -- Card ------------------------------------------------------------- */

  .card {
    container-type: inline-size;
    background-color: var(--surface-raised);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    transition:
      transform var(--duration-normal) var(--ease-out-expo),
      box-shadow var(--duration-normal) var(--ease-out-expo),
      border-color var(--duration-normal) var(--ease-out-expo);

    @starting-style {
      opacity: 0;
      transform: translateY(8px);
    }

    opacity: 1;
    transform: translateY(0);
    transition:
      opacity var(--duration-slow) var(--ease-out-expo),
      transform var(--duration-slow) var(--ease-out-expo),
      box-shadow var(--duration-normal) var(--ease-out-expo),
      border-color var(--duration-normal) var(--ease-out-expo);

    &--accent {
      border-color: var(--color-accent-dim);
    }

    &--interactive {
      cursor: pointer;

      &:hover {
        transform: translateY(-2px);
        box-shadow: var(--shadow-md);
        border-color: var(--color-accent-dim);
      }
    }

    &--stat {
      text-align: center;
      padding: var(--space-xl);
    }
  }

  .card__title {
    font-size: var(--text-lg);
    margin-block-end: var(--space-xs);
  }

  .card__body {
    color: var(--text-secondary);
    font-size: var(--text-sm);
  }

  .card__stat-value {
    font-family: var(--font-display);
    font-size: var(--text-3xl);
    color: var(--color-accent);
    line-height: 1;
  }

  .card__stat-label {
    font-size: var(--text-sm);
    color: var(--text-muted);
    margin-block-start: var(--space-xs);
  }

  @container (max-width: 300px) {
    .card {
      padding: var(--space-md);
    }
  }

  /* -- Button ----------------------------------------------------------- */

  .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-xs);
    font-family: var(--font-body);
    font-size: var(--text-sm);
    font-weight: 600;
    line-height: 1;
    padding-block: 0.75em;
    padding-inline: 1.5em;
    border: 1px solid transparent;
    border-radius: var(--radius-md);
    cursor: pointer;
    text-decoration: none;
    white-space: nowrap;
    transition:
      background-color var(--duration-fast) var(--ease-out-quart),
      color var(--duration-fast) var(--ease-out-quart),
      border-color var(--duration-fast) var(--ease-out-quart),
      box-shadow var(--duration-fast) var(--ease-out-quart),
      transform var(--duration-fast) var(--ease-out-expo);
  }

  .btn:active {
    transform: scale(0.97);
  }

  .btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
  }

  /* -- Button Variants */

  .btn--primary {
    background-color: var(--color-accent);
    color: var(--color-black);
  }

  .btn--primary:hover {
    background-color: var(--color-accent-hover);
    box-shadow: 0 0 20px var(--color-accent-dim);
  }

  .btn--secondary {
    background-color: transparent;
    color: var(--color-accent);
    border-color: var(--color-accent-dim);
  }

  .btn--secondary:hover {
    background-color: var(--color-accent-subtle);
    border-color: var(--color-accent);
  }

  .btn--ghost {
    background-color: transparent;
    color: var(--text-muted);
    font-weight: 500;
  }

  .btn--ghost:hover {
    background-color: transparent;
    color: var(--text-primary);
  }

  .btn--danger {
    background-color: var(--color-danger);
    color: var(--color-white);
  }

  .btn--danger:hover {
    background-color: color-mix(in oklch, var(--color-danger) 85%, white);
    box-shadow: 0 0 20px var(--color-danger-dim);
  }

  /* -- Button Sizes */

  .btn--sm {
    font-size: var(--text-xs);
    padding-block: 0.5em;
    padding-inline: 1em;
  }

  .btn--lg {
    font-size: var(--text-md);
    padding-block: 1em;
    padding-inline: 2em;
  }

  .btn--full {
    inline-size: 100%;
  }

  /* -- Form ------------------------------------------------------------- */

  .form-group {
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);

    &:has(.form-input:focus) .form-label {
      color: var(--color-accent);
    }
  }

  .form-label {
    font-size: var(--text-sm);
    font-weight: 500;
    color: var(--text-secondary);
    transition: color var(--duration-fast) var(--ease-out-quart);
  }

  .form-input {
    background-color: var(--surface-raised);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding-block: 0.75em;
    padding-inline: 1em;
    font-size: var(--text-base);
    color: var(--text-primary);
    transition:
      border-color var(--duration-fast) var(--ease-out-quart),
      box-shadow var(--duration-fast) var(--ease-out-quart);

    &::placeholder {
      color: var(--text-muted);
    }

    &:focus {
      outline: none;
      border-color: var(--color-accent);
      box-shadow: 0 0 0 3px var(--color-accent-subtle);
    }

    &--error {
      border-color: var(--color-danger);

      &:focus {
        box-shadow: 0 0 0 3px var(--color-danger-subtle);
      }
    }
  }

  .form-hint {
    font-size: var(--text-xs);
    color: var(--text-muted);
  }

  .form-error {
    font-size: var(--text-xs);
    color: var(--color-danger);
  }

  /* -- Alert ------------------------------------------------------------ */

  .alert {
    padding: var(--space-md) var(--space-lg);
    border-radius: var(--radius-md);
    font-size: var(--text-sm);
    border: 1px solid transparent;

    @starting-style {
      opacity: 0;
      transform: translateY(-8px);
    }

    opacity: 1;
    transform: translateY(0);
    transition:
      opacity var(--duration-normal) var(--ease-out-expo),
      transform var(--duration-normal) var(--ease-out-expo);

    &--error {
      background-color: var(--color-danger-subtle);
      border-color: var(--color-danger-dim);
      color: color-mix(in oklch, var(--color-danger) 60%, white);
    }

    &--success {
      background-color: color-mix(in oklch, var(--color-success) 15%, transparent);
      border-color: var(--color-success-dim);
      color: color-mix(in oklch, var(--color-success) 60%, white);
    }

    &--info {
      background-color: color-mix(in oklch, var(--color-info) 15%, transparent);
      border-color: var(--color-info-dim);
      color: color-mix(in oklch, var(--color-info) 60%, white);
    }

    &--warning {
      background-color: color-mix(in oklch, var(--color-warning) 15%, transparent);
      border-color: var(--color-warning-dim);
      color: color-mix(in oklch, var(--color-warning) 60%, white);
    }
  }

  /* -- Badge ------------------------------------------------------------ */

  .badge {
    display: inline-flex;
    align-items: center;
    gap: 0.3em;
    font-size: var(--text-xs);
    font-weight: 600;
    padding-block: 0.25em;
    padding-inline: 0.75em;
    border-radius: var(--radius-full);
    white-space: nowrap;

    &--accent {
      background-color: var(--color-accent-subtle);
      color: var(--color-accent);
    }

    &--warning {
      background-color: color-mix(in oklch, var(--color-warning) 15%, transparent);
      color: var(--color-warning);
    }

    &--success {
      background-color: color-mix(in oklch, var(--color-success) 15%, transparent);
      color: var(--color-success);
    }

    &--neutral {
      background-color: var(--surface-overlay);
      color: var(--text-secondary);
    }
  }

  /* -- Table ------------------------------------------------------------ */

  .table-wrap {
    overflow-x: auto;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
  }

  .table {
    inline-size: 100%;
    text-align: start;
    font-size: var(--text-sm);
  }

  .table th {
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: var(--tracking-wider);
    color: var(--text-muted);
    padding: var(--space-sm) var(--space-md);
    background-color: var(--surface-raised);
    border-block-end: 1px solid var(--border-color);
  }

  .table td {
    padding: var(--space-sm) var(--space-md);
    border-block-end: 1px solid color-mix(in oklch, var(--border-color) 50%, transparent);
    color: var(--text-secondary);
  }

  .table tr:last-child td {
    border-block-end: none;
  }

  .table tr {
    transition: background-color var(--duration-fast) var(--ease-out-quart);

    &:hover td {
      background-color: var(--surface-raised);
    }
  }

  /* -- Auth card -------------------------------------------------------- */

  .auth-card {
    inline-size: min(440px, 100%);
    background-color: var(--surface-raised);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-xl);
    padding: var(--space-2xl) var(--space-xl);

    @starting-style {
      opacity: 0;
      transform: scale(0.96);
    }

    opacity: 1;
    transform: scale(1);
    transition:
      opacity var(--duration-slow) var(--ease-out-expo),
      transform var(--duration-slow) var(--ease-out-expo);
  }

  .auth-card__title {
    text-align: center;
    margin-block-end: var(--space-xs);
  }

  .auth-card__subtitle {
    text-align: center;
    font-size: var(--text-sm);
    color: var(--text-muted);
    margin-block-end: var(--space-xl);
  }

  /* -- OTP input -------------------------------------------------------- */

  .otp-input {
    font-family: var(--font-mono);
    font-size: var(--text-2xl);
    letter-spacing: 0.5em;
    text-align: center;
    text-indent: 0.25em;
  }

  /* -- HTMX indicators -------------------------------------------------- */

  .htmx-indicator {
    display: none;
  }

  .htmx-request .htmx-indicator {
    display: inline-flex;
  }

  .htmx-request.htmx-indicator {
    display: inline-flex;
  }

  .spinner {
    display: inline-block;
    inline-size: 1em;
    block-size: 1em;
    border: 2px solid var(--color-accent-dim);
    border-inline-start-color: var(--color-accent);
    border-radius: var(--radius-full);
    animation: spin var(--duration-slower) linear infinite;
  }

  @keyframes spin {
    to {
      transform: rotate(1turn);
    }
  }

  /* -- App Shell (Dashboard Layout) --------------------------------- */

  .app-shell {
    --sidebar-width: 240px;
    --sidebar-width-collapsed: 64px;
    --header-height: 56px;

    display: flex;
    min-block-size: 100dvh;
  }

  .app-shell--collapsed {
    --sidebar-current-width: var(--sidebar-width-collapsed);
  }

  .app-shell:not(.app-shell--collapsed) {
    --sidebar-current-width: var(--sidebar-width);
  }

  /* -- Sidebar ------------------------------------------------------ */

  .app-sidebar {
    position: fixed;
    inset-block-start: 0;
    inset-inline-start: 0;
    z-index: var(--z-nav);
    display: flex;
    flex-direction: column;
    inline-size: var(--sidebar-current-width);
    block-size: 100dvh;
    background-color: var(--surface-raised);
    border-inline-end: 1px solid var(--border-color);
    transition: inline-size var(--duration-normal) var(--ease-out-expo);
    overflow: hidden;
  }

  .sidebar-header {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-md);
    block-size: var(--header-height);
    border-block-end: 1px solid var(--border-color);
  }

  .sidebar-brand {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    text-decoration: none;
    overflow: hidden;
  }

  .sidebar-brand__logo {
    flex-shrink: 0;
    inline-size: 32px;
    block-size: 32px;
  }

  .sidebar-brand__text {
    font-family: var(--font-display);
    font-size: var(--text-lg);
    letter-spacing: var(--tracking-wider);
    text-transform: uppercase;
    color: var(--color-white);
    white-space: nowrap;
    opacity: 1;
    transition: opacity var(--duration-fast) var(--ease-out-quart);
  }

  .app-shell--collapsed .sidebar-brand__text {
    opacity: 0;
  }

  .sidebar-nav {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
    padding: var(--space-md);
    overflow-y: auto;
    overflow-x: hidden;
  }

  .sidebar-nav__item {
    list-style: none;
  }

  .sidebar-nav__link {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-sm) var(--space-sm);
    border-radius: var(--radius-md);
    color: var(--text-secondary);
    text-decoration: none;
    font-size: var(--text-sm);
    font-weight: 500;
    white-space: nowrap;
    transition:
      background-color var(--duration-fast) var(--ease-out-quart),
      color var(--duration-fast) var(--ease-out-quart);
  }

  .sidebar-nav__link:hover {
    background-color: var(--surface-overlay);
    color: var(--color-white);
  }

  .sidebar-nav__link--active {
    background-color: var(--color-accent-subtle);
    color: var(--color-accent);
  }

  .sidebar-nav__link--active:hover {
    background-color: var(--color-accent-subtle);
    color: var(--color-accent);
  }

  .sidebar-nav__icon {
    flex-shrink: 0;
    inline-size: 20px;
    block-size: 20px;
  }

  .sidebar-nav__icon svg {
    inline-size: 100%;
    block-size: 100%;
  }

  .sidebar-nav__label {
    opacity: 1;
    transition: opacity var(--duration-fast) var(--ease-out-quart);
  }

  .app-shell--collapsed .sidebar-nav__label {
    opacity: 0;
  }

  .sidebar-nav__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    margin-left: auto;
    background: var(--color-accent);
    color: #0a0a0a;
    font-size: 11px;
    font-weight: 600;
    border-radius: 10px;
    opacity: 1;
    transition: opacity var(--duration-fast) var(--ease-out-quart);
  }

  .app-shell--collapsed .sidebar-nav__badge {
    opacity: 0;
  }

  .sidebar-footer {
    padding: var(--space-md);
    border-block-start: 1px solid var(--border-color);
  }

  /* -- App Main Area ------------------------------------------------ */

  .app-main {
    flex: 1;
    display: flex;
    flex-direction: column;
    margin-inline-start: var(--sidebar-current-width);
    min-block-size: 100dvh;
    transition: margin-inline-start var(--duration-normal) var(--ease-out-expo);
  }

  /* -- App Header --------------------------------------------------- */

  .app-header {
    position: sticky;
    inset-block-start: 0;
    z-index: calc(var(--z-nav) - 1);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-md);
    block-size: var(--header-height);
    padding-inline: var(--space-lg);
    background-color: oklch(0.07 0 0 / 0.8);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-block-end: 1px solid var(--border-color);
  }

  .header-start {
    display: flex;
    align-items: center;
    gap: var(--space-md);
  }

  .header-end {
    display: flex;
    align-items: center;
    gap: var(--space-md);
  }

  /* -- Sidebar Toggle ----------------------------------------------- */

  .sidebar-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    inline-size: 32px;
    block-size: 32px;
    padding: 0;
    background-color: transparent;
    border: none;
    border-radius: var(--radius-md);
    color: var(--text-muted);
    cursor: pointer;
    transition:
      background-color var(--duration-fast) var(--ease-out-quart),
      color var(--duration-fast) var(--ease-out-quart);
  }

  .sidebar-toggle:hover {
    background-color: var(--surface-overlay);
    color: var(--color-white);
  }

  .sidebar-toggle:active {
    transform: scale(0.95);
  }

  .sidebar-toggle svg {
    inline-size: 18px;
    block-size: 18px;
  }

  /* -- Breadcrumbs -------------------------------------------------- */

  .breadcrumbs {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
    font-size: var(--text-sm);
  }

  .breadcrumbs__item {
    color: var(--text-muted);
    transition: color var(--duration-fast) var(--ease-out-quart);
  }

  .breadcrumbs__item:hover {
    color: var(--text-secondary);
  }

  .breadcrumbs__item--current {
    color: var(--text-primary);
    font-weight: 500;
  }

  .breadcrumbs__item--current:hover {
    color: var(--text-primary);
  }

  .breadcrumbs__separator {
    color: var(--text-muted);
    font-size: var(--text-xs);
  }

  .breadcrumbs__separator svg {
    inline-size: 14px;
    block-size: 14px;
  }

  /* -- User Menu ---------------------------------------------------- */

  .user-menu {
    display: flex;
    align-items: center;
    gap: var(--space-md);
  }

  .user-menu__info {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
  }

  .user-menu__avatar {
    display: flex;
    align-items: center;
    justify-content: center;
    inline-size: 32px;
    block-size: 32px;
    background-color: var(--color-accent-subtle);
    border-radius: var(--radius-full);
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--color-accent);
    text-transform: uppercase;
  }

  .user-menu__name {
    font-size: var(--text-sm);
    font-weight: 500;
    color: var(--text-primary);
  }

  /* -- App Content -------------------------------------------------- */

  .app-content {
    flex: 1;
    padding: var(--space-lg);
  }

  /* -- Page Header -------------------------------------------------- */

  .page-header {
    margin-block-end: var(--space-xl);
  }

  .page-header__title {
    font-size: var(--text-2xl);
    margin-block-end: var(--space-xs);
  }

  .page-header__description {
    color: var(--text-secondary);
    font-size: var(--text-sm);
  }

  /* -- Dashboard Components ----------------------------------------- */

  .stats-grid {
    display: grid;
    gap: var(--space-md);
    grid-template-columns: repeat(4, 1fr);
    margin-block-end: var(--space-lg);
  }

  @media (max-width: 900px) {
    .stats-grid {
      grid-template-columns: repeat(2, 1fr);
    }
  }

  @media (max-width: 500px) {
    .stats-grid {
      grid-template-columns: 1fr;
    }
  }

  .dashboard-grid {
    display: grid;
    gap: var(--space-lg);
    grid-template-columns: 2fr 1fr;
    margin-block-end: var(--space-lg);
  }

  @media (max-width: 900px) {
    .dashboard-grid {
      grid-template-columns: 1fr;
    }
  }

  /* -- Progress Bar ------------------------------------------------- */

  .progress-bar {
    position: relative;
    block-size: 8px;
    background-color: var(--surface-overlay);
    border-radius: var(--radius-full);
    overflow: hidden;
  }

  .progress-bar--lg {
    block-size: 12px;
  }

  .progress-bar__fill {
    position: absolute;
    inset-block: 0;
    inset-inline-start: 0;
    background: linear-gradient(90deg, var(--color-accent), var(--color-accent-hover));
    border-radius: var(--radius-full);
    transition: inline-size var(--duration-slow) var(--ease-out-expo);
  }

  .progress-info {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-block-end: var(--space-xs);
  }

  .progress-info__label {
    font-size: var(--text-sm);
    color: var(--text-secondary);
  }

  .progress-info__value {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    font-weight: 700;
    color: var(--color-accent);
  }

  /* -- Cycle Card --------------------------------------------------- */

  .cycle-header {
    display: flex;
    align-items: baseline;
    gap: var(--space-sm);
    margin-block-end: var(--space-md);
  }

  .cycle-header__number {
    font-family: var(--font-display);
    font-size: var(--text-xl);
    color: var(--color-white);
  }

  .cycle-header__badge {
    font-size: var(--text-xs);
    color: var(--color-accent);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wider);
  }

  .cycle-stats {
    display: flex;
    gap: var(--space-lg);
    margin-block-start: var(--space-md);
    padding-block-start: var(--space-md);
    border-block-start: 1px solid var(--border-color);
  }

  .cycle-stats__item {
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
  }

  .cycle-stats__value {
    font-family: var(--font-mono);
    font-size: var(--text-lg);
    font-weight: 700;
    color: var(--color-white);
  }

  .cycle-stats__label {
    font-size: var(--text-xs);
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wide);
  }

  .cycle-list {
    margin-block-start: var(--space-lg);
  }

  .cycle-list__title {
    font-size: var(--text-xs);
    font-weight: 600;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wider);
    margin-block-end: var(--space-sm);
  }

  .cycle-list__item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-block: var(--space-xs);
    font-size: var(--text-sm);
  }

  .cycle-list__item + .cycle-list__item {
    border-block-start: 1px solid color-mix(in oklch, var(--border-color) 50%, transparent);
  }

  .cycle-list__name {
    color: var(--text-secondary);
  }

  .cycle-list__progress {
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    color: var(--text-muted);
  }

  /* -- Activity List ------------------------------------------------ */

  .activity-list {
    display: flex;
    flex-direction: column;
  }

  .activity-item {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding-block: var(--space-sm);
    border-block-end: 1px solid color-mix(in oklch, var(--border-color) 50%, transparent);
  }

  .activity-item:last-child {
    border-block-end: none;
  }

  .activity-item__icon {
    flex-shrink: 0;
    inline-size: 8px;
    block-size: 8px;
    border-radius: var(--radius-full);
    background-color: var(--text-muted);
  }

  .activity-item__icon--created {
    background-color: var(--color-accent);
  }

  .activity-item__icon--updated {
    background-color: var(--color-info);
  }

  .activity-item__icon--resolved {
    background-color: var(--color-success);
  }

  .activity-item__badge {
    flex-shrink: 0;
    inline-size: 70px;
    font-size: var(--text-xs);
    font-weight: 600;
    text-transform: capitalize;
  }

  .activity-item__badge--created {
    color: var(--color-accent);
  }

  .activity-item__badge--updated {
    color: var(--color-info);
  }

  .activity-item__badge--resolved {
    color: var(--color-success);
  }

  .activity-item__id {
    flex-shrink: 0;
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    font-weight: 700;
    color: var(--text-secondary);
    inline-size: 90px;
  }

  .activity-item__title {
    flex: 1;
    font-size: var(--text-sm);
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .activity-item__time {
    flex-shrink: 0;
    font-size: var(--text-xs);
    color: var(--text-muted);
    text-align: end;
    min-inline-size: 90px;
  }

  @media (max-width: 700px) {
    .activity-item {
      flex-wrap: wrap;
      gap: var(--space-xs) var(--space-sm);
    }

    .activity-item__title {
      flex-basis: 100%;
      order: 10;
      padding-inline-start: calc(8px + var(--space-sm));
    }

    .activity-item__time {
      margin-inline-start: auto;
    }
  }

  /* -- Chart Container ---------------------------------------------- */

  .chart-container {
    position: relative;
    block-size: 280px;
    inline-size: 100%;
    margin-block-start: var(--space-md);
  }

  /* -- Page Header Row ---------------------------------------------- */

  .page-header__row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-md);
    flex-wrap: wrap;
  }

  /* -- Project Selector --------------------------------------------- */

  .project-selector {
    flex-shrink: 0;
  }

  .project-selector__select {
    appearance: none;
    background-color: var(--surface-raised);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: var(--space-sm) var(--space-xl) var(--space-sm) var(--space-md);
    font-family: var(--font-body);
    font-size: var(--text-sm);
    font-weight: 500;
    color: var(--text-primary);
    cursor: pointer;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right var(--space-sm) center;
    background-size: 16px;
    min-width: 200px;
    transition: 
      border-color var(--duration-fast) var(--ease-out-quart),
      box-shadow var(--duration-fast) var(--ease-out-quart);
  }

  .project-selector__select:hover {
    border-color: var(--color-accent-dim);
  }

  .project-selector__select:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px var(--color-accent-subtle);
  }

  .project-selector__select option {
    background-color: var(--surface-raised);
    color: var(--text-primary);
    padding: var(--space-sm);
  }

  /* -- Skeleton Loading --------------------------------------------- */

  .skeleton {
    position: relative;
    overflow: hidden;
  }

  .skeleton::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(
      90deg,
      transparent 0%,
      var(--surface-overlay) 50%,
      transparent 100%
    );
    animation: skeleton-shimmer 1.5s ease-in-out infinite;
  }

  .skeleton-content {
    min-height: 60px;
  }

  @keyframes skeleton-shimmer {
    0% {
      transform: translateX(-100%);
    }
    100% {
      transform: translateX(100%);
    }
  }

  .dashboard-skeleton .card {
    min-height: 100px;
  }

  /* -- Empty State -------------------------------------------------- */

  .empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: var(--space-3xl) var(--space-xl);
    color: var(--text-muted);
  }

  .empty-state--compact {
    padding: var(--space-xl) var(--space-md);
  }

  .empty-state__icon {
    margin-block-end: var(--space-lg);
    color: var(--text-muted);
    opacity: 0.5;
  }

  .empty-state__icon svg {
    inline-size: 48px;
    block-size: 48px;
  }

  .empty-state__title {
    font-size: var(--text-xl);
    color: var(--text-secondary);
    margin-block-end: var(--space-sm);
  }

  .empty-state__description {
    font-size: var(--text-sm);
    max-inline-size: 400px;
  }

  /* -- Dashboard Error ---------------------------------------------- */

  .dashboard-error {
    padding: var(--space-xl);
  }

  .dashboard-error .alert {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-lg);
  }

  .dashboard-error .alert__content {
    flex: 1;
  }

  .dashboard-error .alert__title {
    display: block;
    margin-block-end: var(--space-xs);
  }

  .dashboard-error .alert__message {
    margin: 0;
    font-size: var(--text-sm);
    opacity: 0.9;
  }

  /* -- Issues Filters --------------------------------------------- */

  .issues-filters {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-sm);
    margin-block-end: var(--space-lg);
    padding: var(--space-md);
    background-color: var(--surface-raised);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
  }

  .filter-group {
    flex-shrink: 0;
  }

  .filter-group--search {
    flex: 1;
    min-inline-size: 200px;
  }

  .filter-select {
    appearance: none;
    background-color: var(--surface-overlay);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: var(--space-xs) var(--space-xl) var(--space-xs) var(--space-sm);
    font-family: var(--font-body);
    font-size: var(--text-sm);
    color: var(--text-primary);
    cursor: pointer;
    min-inline-size: 140px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right var(--space-xs) center;
    background-size: 16px;
    transition:
      border-color var(--duration-fast) var(--ease-out-quart),
      box-shadow var(--duration-fast) var(--ease-out-quart);
  }

  .filter-select:hover {
    border-color: var(--color-accent-dim);
  }

  .filter-select:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px var(--color-accent-subtle);
  }

  .filter-select option {
    background-color: var(--surface-overlay);
    color: var(--text-primary);
  }

  .filter-input {
    appearance: none;
    background-color: var(--surface-overlay);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: var(--space-xs) var(--space-sm);
    font-family: var(--font-body);
    font-size: var(--text-sm);
    color: var(--text-primary);
    inline-size: 100%;
    transition:
      border-color var(--duration-fast) var(--ease-out-quart),
      box-shadow var(--duration-fast) var(--ease-out-quart);
  }

  .filter-input::placeholder {
    color: var(--text-muted);
  }

  .filter-input:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px var(--color-accent-subtle);
  }

  .search-input-wrap {
    position: relative;
    display: flex;
    align-items: center;
  }

  .search-input__icon {
    position: absolute;
    inset-inline-start: var(--space-sm);
    color: var(--text-muted);
    pointer-events: none;
  }

  .search-input {
    padding-inline-start: calc(var(--space-sm) + 20px);
  }

  .sort-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    inline-size: 36px;
    block-size: 36px;
    padding: 0;
    background-color: var(--surface-overlay);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    color: var(--text-secondary);
    cursor: pointer;
    transition:
      border-color var(--duration-fast) var(--ease-out-quart),
      color var(--duration-fast) var(--ease-out-quart),
      background-color var(--duration-fast) var(--ease-out-quart);
  }

  .sort-toggle:hover {
    border-color: var(--color-accent);
    color: var(--color-accent);
  }

  .sort-toggle:active {
    transform: scale(0.95);
  }

  /* -- Issues Table ------------------------------------------------- */

  .issues-table {
    table-layout: fixed;
  }

  .issues-table__col--id {
    inline-size: 100px;
  }

  .issues-table__col--title {
    inline-size: auto;
  }

  .issues-table__col--priority {
    inline-size: 70px;
    text-align: center;
  }

  .issues-table__col--estimate {
    inline-size: 80px;
    text-align: center;
  }

  .issues-table__col--state {
    inline-size: 120px;
  }

  .issues-table__col--labels {
    inline-size: 180px;
  }

  .issues-table__col--milestone {
    inline-size: 140px;
  }

  .issues-table__col--created {
    inline-size: 110px;
  }

  .issue-id {
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    font-weight: 700;
    white-space: nowrap;
  }

  .issue-id a {
    color: var(--color-accent);
    text-decoration: none;
    transition: color var(--duration-fast) var(--ease-out-quart);
  }

  .issue-id a:hover {
    color: var(--color-accent-hover);
    text-decoration: underline;
  }

  .issue-title {
    max-inline-size: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: var(--text-primary);
  }

  .issue-priority {
    text-align: center;
  }

  .issue-estimate {
    text-align: center;
  }

  .issue-created {
    font-size: var(--text-xs);
    color: var(--text-muted);
    white-space: nowrap;
  }

  /* -- Priority Icons ----------------------------------------------- */

  .priority-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .priority-icon svg {
    display: block;
  }

  .priority-icon--urgent {
    color: var(--color-danger);
  }

  .priority-icon--high {
    color: var(--color-warning);
  }

  .priority-icon--medium {
    color: oklch(0.72 0.15 90);
  }

  .priority-icon--low {
    color: var(--text-muted);
  }

  .priority-icon--none {
    color: var(--text-muted);
    opacity: 0.5;
  }

  /* -- Estimate Badge ----------------------------------------------- */

  .estimate-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    font-weight: 700;
    min-inline-size: 28px;
    padding: 0.2em 0.5em;
    background-color: var(--surface-overlay);
    border-radius: var(--radius-sm);
    color: var(--text-secondary);
  }

  /* -- State Badge -------------------------------------------------- */

  .state-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.4em;
    font-size: var(--text-xs);
    font-weight: 600;
    padding: 0.25em 0.75em;
    border-radius: var(--radius-full);
    background-color: color-mix(in oklch, var(--state-color, var(--text-muted)) 15%, transparent);
    color: var(--state-color, var(--text-secondary));
    white-space: nowrap;
  }

  .state-badge::before {
    content: '';
    inline-size: 8px;
    block-size: 8px;
    border-radius: var(--radius-full);
    background-color: var(--state-color, var(--text-muted));
  }

  /* -- Label Pills -------------------------------------------------- */

  .labels-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.25em;
  }

  .label-pill {
    display: inline-flex;
    font-size: var(--text-xs);
    font-weight: 500;
    padding: 0.15em 0.5em;
    border-radius: var(--radius-sm);
    background-color: color-mix(in oklch, var(--label-color, var(--text-muted)) 20%, transparent);
    color: var(--label-color, var(--text-secondary));
    white-space: nowrap;
    max-inline-size: 100px;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  /* -- Pagination --------------------------------------------------- */

  .pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-md);
    margin-block-start: var(--space-md);
    background-color: var(--surface-raised);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
  }

  .pagination__info {
    font-size: var(--text-sm);
    color: var(--text-muted);
  }

  .pagination__controls {
    display: flex;
    gap: var(--space-sm);
  }

  .pagination__controls .btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
  }

  .pagination__controls .btn svg {
    flex-shrink: 0;
  }

  /* -- Issues Skeleton ---------------------------------------------- */

  .issues-skeleton .skeleton-text {
    block-size: 14px;
    background-color: var(--surface-overlay);
    border-radius: var(--radius-sm);
  }

  .issues-skeleton .skeleton-text--xs {
    inline-size: 60px;
  }

  .issues-skeleton .skeleton-text--sm {
    inline-size: 80px;
  }

  .issues-skeleton .skeleton-text--md {
    inline-size: 100px;
  }

  .issues-skeleton .skeleton-text--lg {
    inline-size: 200px;
  }

  .issues-skeleton .skeleton-text--icon {
    inline-size: 20px;
    margin-inline: auto;
  }

  .issues-filters.skeleton .skeleton-select {
    inline-size: 140px;
    block-size: 36px;
    background-color: var(--surface-overlay);
    border-radius: var(--radius-md);
  }

  .issues-filters.skeleton .skeleton-input {
    inline-size: 100%;
    block-size: 36px;
    background-color: var(--surface-overlay);
    border-radius: var(--radius-md);
  }

  .issues-filters.skeleton .skeleton-button {
    inline-size: 36px;
    block-size: 36px;
    background-color: var(--surface-overlay);
    border-radius: var(--radius-md);
  }

  /* -- Issue Detail ------------------------------------------------- */

  .issue-detail__identifier {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    margin-block-end: var(--space-xs);
  }

  .issue-detail__id {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    font-weight: 700;
    color: var(--color-accent);
  }

  .issue-detail__title {
    font-size: var(--text-xl);
    line-height: var(--leading-snug);
    text-transform: none;
    font-family: var(--font-body);
    font-weight: 600;
    letter-spacing: normal;
  }

  .issue-detail__grid {
    display: grid;
    gap: var(--space-lg);
    grid-template-columns: 1fr 320px;
  }

  @media (max-width: 900px) {
    .issue-detail__grid {
      grid-template-columns: 1fr;
    }

    .issue-detail__sidebar {
      order: -1;
    }
  }

  .issue-detail__main {
    min-inline-size: 0;
  }

  .issue-detail__sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
  }

  .issue-detail__description {
    font-size: var(--text-sm);
    line-height: var(--leading-relaxed);
    color: var(--text-secondary);
  }

  /* Prose styles for markdown content */
  .prose {
    max-inline-size: none;
  }

  .prose h1,
  .prose h2,
  .prose h3,
  .prose h4,
  .prose h5,
  .prose h6 {
    font-family: var(--font-body);
    font-weight: 600;
    text-transform: none;
    letter-spacing: normal;
    color: var(--text-primary);
    margin-block-start: var(--space-lg);
    margin-block-end: var(--space-sm);
  }

  .prose h1 { font-size: var(--text-xl); }
  .prose h2 { font-size: var(--text-lg); }
  .prose h3 { font-size: var(--text-md); }
  .prose h4,
  .prose h5,
  .prose h6 { font-size: var(--text-base); }

  .prose p {
    margin-block-end: var(--space-md);
    max-inline-size: none;
  }

  .prose ul,
  .prose ol {
    margin-block-end: var(--space-md);
    padding-inline-start: var(--space-lg);
  }

  .prose ul {
    list-style-type: disc;
  }

  .prose ol {
    list-style-type: decimal;
  }

  .prose li {
    margin-block-end: var(--space-xs);
    color: var(--text-secondary);
  }

  .prose code {
    font-size: 0.875em;
  }

  .prose pre {
    margin-block-end: var(--space-md);
  }

  .prose blockquote {
    border-inline-start: 3px solid var(--color-accent-dim);
    padding-inline-start: var(--space-md);
    margin-block: var(--space-md);
    color: var(--text-muted);
    font-style: italic;
  }

  .prose a {
    color: var(--color-accent);
    text-decoration: underline;
    text-underline-offset: 2px;
  }

  .prose a:hover {
    color: var(--color-accent-hover);
  }

  .prose hr {
    margin-block: var(--space-lg);
  }

  .prose img {
    max-inline-size: 100%;
    block-size: auto;
    border-radius: var(--radius-md);
  }

  /* Meta list for sidebar */
  .meta-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
  }

  .meta-item {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-md);
  }

  .meta-item--labels {
    flex-direction: column;
    gap: var(--space-xs);
  }

  .meta-item__label {
    font-size: var(--text-xs);
    font-weight: 600;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wide);
    flex-shrink: 0;
  }

  .meta-item__value {
    font-size: var(--text-sm);
    color: var(--text-primary);
    text-align: end;
  }

  .meta-item--labels .meta-item__value {
    text-align: start;
  }

  /* Type badge */
  .type-badge {
    display: inline-flex;
    align-items: center;
    font-size: var(--text-xs);
    font-weight: 600;
    padding: 0.2em 0.6em;
    border-radius: var(--radius-sm);
    text-transform: capitalize;
  }

  .type-badge--bug {
    background-color: var(--color-danger-subtle);
    color: var(--color-danger);
  }

  .type-badge--feature {
    background-color: var(--color-accent-subtle);
    color: var(--color-accent);
  }

  .type-badge--improvement {
    background-color: var(--color-info-dim);
    color: var(--color-info);
  }

  /* Priority display */
  .priority-display {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    font-size: var(--text-sm);
    text-transform: capitalize;
  }

  .priority-display--urgent {
    color: var(--color-danger);
  }

  .priority-display--high {
    color: var(--color-warning);
  }

  .priority-display--medium {
    color: oklch(0.72 0.15 90);
  }

  .priority-display--low {
    color: var(--text-muted);
  }

  .priority-display--none {
    color: var(--text-muted);
  }

  /* Assignee display */
  .assignee-display {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
  }

  .assignee-display__avatar {
    inline-size: 24px;
    block-size: 24px;
    border-radius: var(--radius-full);
    object-fit: cover;
  }

  .assignee-display__avatar--initials {
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--color-accent-subtle);
    color: var(--color-accent);
    font-size: var(--text-xs);
    font-weight: 600;
    text-transform: uppercase;
  }

  .assignee-display__name {
    font-size: var(--text-sm);
    color: var(--text-primary);
    max-inline-size: 150px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  /* Milestone display */
  .milestone-display {
    font-size: var(--text-sm);
    color: var(--text-primary);
  }

  /* Labels list wrap variant */
  .labels-list--wrap {
    flex-wrap: wrap;
    gap: var(--space-xs);
  }

  /* Issue detail error */
  .issue-detail-error {
    padding: var(--space-xl);
  }

  /* Issue detail skeleton */
  .issue-detail-skeleton .skeleton-text {
    display: inline-block;
    background-color: var(--surface-overlay);
    border-radius: var(--radius-sm);
  }

  /* Activity item link styles */
  .activity-item__id {
    transition: color var(--duration-fast) var(--ease-out-quart);
  }

  a.activity-item__id:hover {
    color: var(--color-accent);
    text-decoration: underline;
  }

  /* -- Issues Error ------------------------------------------------- */

  .issues-error {
    padding: var(--space-xl);
  }

  .issues-error .alert {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-lg);
  }

  .issues-error .alert__content {
    flex: 1;
  }

  .issues-error .alert__title {
    display: block;
    margin-block-end: var(--space-xs);
  }

  .issues-error .alert__message {
    margin: 0;
    font-size: var(--text-sm);
    opacity: 0.9;
  }

  /* -- Issues Responsive -------------------------------------------- */

  @media (max-width: 1200px) {
    .issues-table__col--milestone {
      display: none;
    }

    .issues-table td:nth-child(7),
    .issues-table th:nth-child(7) {
      display: none;
    }
  }

  @media (max-width: 900px) {
    .issues-filters {
      flex-direction: column;
      align-items: stretch;
    }

    .filter-group {
      inline-size: 100%;
    }

    .filter-select {
      inline-size: 100%;
    }

    .sort-toggle {
      inline-size: 100%;
    }

    .issues-table__col--labels,
    .issues-table__col--estimate {
      display: none;
    }

    .issues-table td:nth-child(4),
    .issues-table th:nth-child(4),
    .issues-table td:nth-child(6),
    .issues-table th:nth-child(6) {
      display: none;
    }

    .pagination {
      flex-direction: column;
      gap: var(--space-md);
      text-align: center;
    }
  }

  @media (max-width: 600px) {
    .issues-table__col--state,
    .issues-table__col--created {
      display: none;
    }

    .issues-table td:nth-child(5),
    .issues-table th:nth-child(5),
    .issues-table td:nth-child(8),
    .issues-table th:nth-child(8) {
      display: none;
    }
  }
}

/* ==========================================================================
   @layer utilities — Override classes
   ========================================================================== */

@layer utilities {
  /* -- Text ------------------------------------------------------------- */
  .text-accent { color: var(--color-accent); }
  .text-muted { color: var(--text-muted); }
  .text-secondary { color: var(--text-secondary); }
  .text-white { color: var(--color-white); }
  .text-danger { color: var(--color-danger); }
  .text-mono { font-family: var(--font-mono); }
  .text-center { text-align: center; }
  .text-end { text-align: end; }
  .text-uppercase { text-transform: uppercase; }
  .text-xs { font-size: var(--text-xs); }
  .text-sm { font-size: var(--text-sm); }
  .text-md { font-size: var(--text-md); }
  .text-lg { font-size: var(--text-lg); }
  .text-xl { font-size: var(--text-xl); }

  /* -- Spacing ---------------------------------------------------------- */
  .mt-sm { margin-block-start: var(--space-sm); }
  .mt-md { margin-block-start: var(--space-md); }
  .mt-lg { margin-block-start: var(--space-lg); }
  .mt-xl { margin-block-start: var(--space-xl); }
  .mb-sm { margin-block-end: var(--space-sm); }
  .mb-md { margin-block-end: var(--space-md); }
  .mb-lg { margin-block-end: var(--space-lg); }
  .mb-xl { margin-block-end: var(--space-xl); }
  .p-sm { padding: var(--space-sm); }
  .p-md { padding: var(--space-md); }
  .p-lg { padding: var(--space-lg); }
  .p-xl { padding: var(--space-xl); }

  /* -- Layout ----------------------------------------------------------- */
  .flex { display: flex; }
  .flex-col { flex-direction: column; }
  .flex-1 { flex: 1; }
  .items-center { align-items: center; }
  .items-start { align-items: flex-start; }
  .justify-between { justify-content: space-between; }
  .justify-center { justify-content: center; }
  .gap-xs { gap: var(--space-xs); }
  .gap-sm { gap: var(--space-sm); }
  .gap-md { gap: var(--space-md); }
  .gap-lg { gap: var(--space-lg); }

  /* -- Surface ---------------------------------------------------------- */
  .surface-raised { background-color: var(--surface-raised); }
  .surface-overlay { background-color: var(--surface-overlay); }
  .border { border: 1px solid var(--border-color); }
  .rounded-md { border-radius: var(--radius-md); }
  .rounded-lg { border-radius: var(--radius-lg); }
  .rounded-xl { border-radius: var(--radius-xl); }

  /* -- Accessibility ---------------------------------------------------- */
  .sr-only {
    position: absolute;
    inline-size: 1px;
    block-size: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
  }

  .hidden {
    display: none;
  }
}

/* ==========================================================================
   View Transitions (outside layers — opt-in via meta tag)
   ========================================================================== */

@view-transition {
  navigation: auto;
}

::view-transition-old(root) {
  animation: fade-out var(--duration-normal) var(--ease-out-quart);
}

::view-transition-new(root) {
  animation: fade-in var(--duration-normal) var(--ease-out-quart);
}

@keyframes fade-in {
  from { opacity: 0; }
}

@keyframes fade-out {
  to { opacity: 0; }
}

/* Keep nav stable during transitions */
.nav {
  view-transition-name: nav;
}

::view-transition-old(nav),
::view-transition-new(nav) {
  animation: none;
}

/* ==========================================================================
   Scroll-driven progress bar
   ========================================================================== */

.scroll-progress {
  position: fixed;
  inset-block-start: 0;
  inset-inline-start: 0;
  inline-size: 100%;
  block-size: 3px;
  background-color: var(--color-accent);
  transform-origin: left;
  z-index: calc(var(--z-nav) + 1);
  animation: scroll-progress linear;
  animation-timeline: scroll();
  scale: 0 1;
}

@keyframes scroll-progress {
  to {
    scale: 1 1;
  }
}

/* ==========================================================================
   Print styles
   ========================================================================== */

@media print {
  .nav,
  .scroll-progress {
    display: none;
  }

  body {
    background-color: white;
    color: black;
  }

  .card,
  .auth-card {
    border: 1px solid #ccc;
    box-shadow: none;
  }
}

/* ==========================================================================
   Roadmap Page
   ========================================================================== */

.roadmap {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

/* -- Cycle Groups -------------------------------------------------------- */

.cycle-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.cycle-group__header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-muted);
  padding-block-end: var(--space-xs);
  border-block-end: 1px solid var(--color-border);
}

.cycle-group__label {
  /* Default styling from parent */
}

.cycle-group__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-inline-size: 1.5rem;
  padding-inline: var(--space-2xs);
  font-size: var(--text-2xs);
  font-weight: 600;
  background-color: var(--color-surface-raised);
  border-radius: var(--radius-full);
}

.cycle-group--current .cycle-group__header {
  color: var(--color-accent);
  border-color: var(--color-accent-dim);
}

/* -- Cycle Card ---------------------------------------------------------- */

.cycle-card {
  background-color: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: border-color var(--duration-fast) var(--ease-out);
}

.cycle-card:hover {
  border-color: var(--color-border-hover);
}

.cycle-card--current {
  border-color: var(--color-accent-dim);
}

.cycle-card--current:hover {
  border-color: var(--color-accent);
}

.cycle-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  inline-size: 100%;
  padding: var(--space-md);
  background: transparent;
  border: none;
  cursor: pointer;
  text-align: left;
  transition: background-color var(--duration-fast) var(--ease-out);
}

.cycle-card__header:hover {
  background-color: var(--color-surface-hover);
}

.cycle-card__header-left {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  min-width: 0;
}

.cycle-card__header-right {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  flex-shrink: 0;
}

.cycle-card__chevron {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-muted);
  transition: transform var(--duration-fast) var(--ease-out);
}

.cycle-card__chevron svg {
  inline-size: 16px;
  block-size: 16px;
}

.cycle-card--expanded .cycle-card__chevron {
  transform: rotate(180deg);
}

.cycle-card:not(.cycle-card--expanded) .cycle-card__chevron {
  transform: rotate(-90deg);
}

.cycle-card__name {
  font-weight: 600;
  color: var(--color-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cycle-card__dates {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  white-space: nowrap;
}

/* -- Cycle Status Badge -------------------------------------------------- */

.cycle-card__status {
  display: inline-flex;
  align-items: center;
  padding: var(--space-3xs) var(--space-xs);
  font-size: var(--text-2xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  border-radius: var(--radius-sm);
  white-space: nowrap;
}

.cycle-card__status--current {
  background-color: oklch(from var(--color-accent) l c h / 0.15);
  color: var(--color-accent);
}

.cycle-card__status--upcoming {
  background-color: oklch(from var(--color-warning) l c h / 0.15);
  color: var(--color-warning);
}

.cycle-card__status--completed {
  background-color: oklch(from var(--color-success) l c h / 0.15);
  color: var(--color-success);
}

/* -- Cycle Summary ------------------------------------------------------- */

.cycle-card__summary {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  padding: 0 var(--space-md) var(--space-md);
}

.cycle-card__progress {
  block-size: 6px;
  background-color: var(--color-surface-raised);
  border-radius: var(--radius-full);
  overflow: hidden;
}

.cycle-card__progress-bar {
  block-size: 100%;
  inline-size: var(--progress, 0%);
  background-color: var(--color-accent);
  border-radius: var(--radius-full);
  transition: inline-size var(--duration-normal) var(--ease-out);
}

.cycle-card--completed .cycle-card__progress-bar {
  background-color: var(--color-success);
}

.cycle-card__stats {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

.cycle-card__stat {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

/* -- Cycle Content (Expandable) ------------------------------------------ */

.cycle-card__content {
  display: none;
  border-block-start: 1px solid var(--color-border);
  background-color: var(--color-surface-inset);
}

.cycle-card--expanded .cycle-card__content {
  display: block;
}

.cycle-card__loading {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  padding: var(--space-lg);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}

.cycle-card__content .table-wrap {
  margin: 0;
  border-radius: 0;
}

.cycle-card__content .table {
  border-radius: 0;
}

.cycle-card__content .issues-table {
  font-size: var(--text-sm);
}

.cycle-card__content .pagination {
  padding: var(--space-sm) var(--space-md);
  border-block-start: 1px solid var(--color-border);
  background-color: var(--color-surface);
}

.cycle-card__content .pagination--compact {
  justify-content: flex-end;
  gap: var(--space-md);
}

.cycle-card__content .pagination--compact .pagination__info {
  margin-inline-end: auto;
}

/* -- Empty State Inline -------------------------------------------------- */

.empty-state--inline {
  padding: var(--space-lg);
  text-align: center;
}

.empty-state--inline .empty-state__description {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}

/* -- Cycle Card Skeleton ------------------------------------------------- */

.cycle-card--skeleton {
  pointer-events: none;
}

.cycle-card--skeleton .cycle-card__header {
  cursor: default;
}

.cycle-card--skeleton .cycle-card__header:hover {
  background-color: transparent;
}

/* ==========================================================================
   Modal System
   ========================================================================== */

.modal-overlay {
  position: fixed;
  inset: 0;
  z-index: var(--z-overlay);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-lg);
  background-color: oklch(0 0 0 / 0.7);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  opacity: 0;
  visibility: hidden;
  transition: 
    opacity var(--duration-normal) var(--ease-out-quart),
    visibility var(--duration-normal) var(--ease-out-quart);
}

.modal-overlay--open {
  opacity: 1;
  visibility: visible;
}

.modal {
  position: relative;
  z-index: var(--z-modal);
  inline-size: min(560px, 100%);
  max-block-size: calc(100dvh - var(--space-2xl));
  background-color: var(--surface-raised);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transform: scale(0.95) translateY(10px);
  transition: transform var(--duration-normal) var(--ease-out-expo);
}

.modal-overlay--open .modal {
  transform: scale(1) translateY(0);
}

.modal--wide {
  inline-size: min(720px, 100%);
}

.modal--issue-type {
  inline-size: min(640px, 100%);
}

.modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  padding: var(--space-lg);
  border-block-end: 1px solid var(--border-color);
  flex-shrink: 0;
}

.modal__title {
  font-size: var(--text-lg);
  margin: 0;
}

.modal__close {
  display: flex;
  align-items: center;
  justify-content: center;
  inline-size: 32px;
  block-size: 32px;
  padding: 0;
  background-color: transparent;
  border: none;
  border-radius: var(--radius-md);
  color: var(--text-muted);
  cursor: pointer;
  transition: 
    background-color var(--duration-fast) var(--ease-out-quart),
    color var(--duration-fast) var(--ease-out-quart);
}

.modal__close:hover {
  background-color: var(--surface-overlay);
  color: var(--text-primary);
}

.modal__close svg {
  inline-size: 20px;
  block-size: 20px;
}

.modal__body {
  flex: 1;
  padding: var(--space-lg);
  overflow-y: auto;
}

.modal__footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-sm);
  padding: var(--space-md) var(--space-lg);
  border-block-start: 1px solid var(--border-color);
  background-color: var(--surface-overlay);
  flex-shrink: 0;
}

/* ==========================================================================
   Toast Notifications
   ========================================================================== */

.toast-container {
  position: fixed;
  inset-block-end: var(--space-lg);
  inset-inline-end: var(--space-lg);
  z-index: calc(var(--z-modal) + 1);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  pointer-events: none;
}

.toast {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-md) var(--space-lg);
  background-color: var(--surface-raised);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  font-size: var(--text-sm);
  pointer-events: auto;
  transform: translateX(calc(100% + var(--space-lg)));
  opacity: 0;
  animation: toast-in var(--duration-normal) var(--ease-out-expo) forwards;
}

.toast--removing {
  animation: toast-out var(--duration-fast) var(--ease-out-quart) forwards;
}

@keyframes toast-in {
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

@keyframes toast-out {
  to {
    transform: translateX(calc(100% + var(--space-lg)));
    opacity: 0;
  }
}

.toast__icon {
  flex-shrink: 0;
  inline-size: 20px;
  block-size: 20px;
}

.toast__message {
  flex: 1;
  color: var(--text-primary);
}

.toast__close {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  inline-size: 24px;
  block-size: 24px;
  padding: 0;
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  color: var(--text-muted);
  cursor: pointer;
  transition: color var(--duration-fast) var(--ease-out-quart);
}

.toast__close:hover {
  color: var(--text-primary);
}

.toast__close svg {
  inline-size: 16px;
  block-size: 16px;
}

.toast--success {
  border-color: var(--color-success-dim);
}

.toast--success .toast__icon {
  color: var(--color-success);
}

.toast--error {
  border-color: var(--color-danger-dim);
}

.toast--error .toast__icon {
  color: var(--color-danger);
}

.toast--info {
  border-color: var(--color-info-dim);
}

.toast--info .toast__icon {
  color: var(--color-info);
}

/* ==========================================================================
   Issue Type Selector
   ========================================================================== */

.issue-type-grid {
  display: grid;
  gap: var(--space-md);
  grid-template-columns: repeat(3, 1fr);
}

@media (max-width: 600px) {
  .issue-type-grid {
    grid-template-columns: 1fr;
  }
}

.issue-type-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-xl) var(--space-md);
  background-color: var(--surface-overlay);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  cursor: pointer;
  text-align: center;
  min-inline-size: 160px;
  transition: 
    border-color var(--duration-fast) var(--ease-out-quart),
    background-color var(--duration-fast) var(--ease-out-quart),
    transform var(--duration-fast) var(--ease-out-expo);
}

.issue-type-card:hover {
  border-color: var(--color-accent-dim);
  background-color: var(--color-accent-subtle);
  transform: translateY(-2px);
}

.issue-type-card:active {
  transform: translateY(0) scale(0.98);
}

.issue-type-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  inline-size: 48px;
  block-size: 48px;
  border-radius: var(--radius-lg);
}

.issue-type-card__icon svg {
  inline-size: 28px;
  block-size: 28px;
}

.issue-type-card--bug .issue-type-card__icon {
  background-color: var(--color-danger-subtle);
  color: var(--color-danger);
}

.issue-type-card--improvement .issue-type-card__icon {
  background-color: var(--color-info-dim);
  color: var(--color-info);
}

.issue-type-card--feature .issue-type-card__icon {
  background-color: var(--color-accent-subtle);
  color: var(--color-accent);
}

.issue-type-card__title {
  font-size: var(--text-md);
  font-weight: 600;
  color: var(--text-primary);
}

.issue-type-card__description {
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin: 0;
}

/* ==========================================================================
   Create Issue Form
   ========================================================================== */

.create-issue-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.create-issue-form .form-group {
  gap: var(--space-xs);
}

.create-issue-form .form-label {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
}

.create-issue-form .form-label__required {
  color: var(--color-danger);
}

.create-issue-form .form-input,
.create-issue-form .form-textarea,
.create-issue-form .form-select {
  background-color: var(--surface-overlay);
}

.create-issue-form .form-textarea {
  min-block-size: 100px;
  resize: vertical;
}

.create-issue-form .form-select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-sm) center;
  background-size: 16px;
  padding-inline-end: var(--space-xl);
}

.form-row {
  display: grid;
  gap: var(--space-md);
  grid-template-columns: repeat(2, 1fr);
}

@media (max-width: 500px) {
  .form-row {
    grid-template-columns: 1fr;
  }
}

.issue-form-header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding-block-end: var(--space-md);
  border-block-end: 1px solid var(--border-color);
  margin-block-end: var(--space-sm);
}

.issue-form-header__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  inline-size: 32px;
  block-size: 32px;
  border-radius: var(--radius-md);
}

.issue-form-header__icon svg {
  inline-size: 18px;
  block-size: 18px;
}

.issue-form-header--bug .issue-form-header__icon {
  background-color: var(--color-danger-subtle);
  color: var(--color-danger);
}

.issue-form-header--improvement .issue-form-header__icon {
  background-color: var(--color-info-dim);
  color: var(--color-info);
}

.issue-form-header--feature .issue-form-header__icon {
  background-color: var(--color-accent-subtle);
  color: var(--color-accent);
}

.issue-form-header__title {
  font-size: var(--text-md);
  font-weight: 600;
  color: var(--text-primary);
  margin: 0;
}

.issue-form-header__back {
  margin-inline-start: auto;
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--text-sm);
  color: var(--text-muted);
  cursor: pointer;
  background: none;
  border: none;
  padding: var(--space-xs) var(--space-sm);
  border-radius: var(--radius-md);
  transition: 
    color var(--duration-fast) var(--ease-out-quart),
    background-color var(--duration-fast) var(--ease-out-quart);
}

.issue-form-header__back:hover {
  color: var(--text-primary);
  background-color: var(--surface-overlay);
}

.issue-form-header__back svg {
  inline-size: 16px;
  block-size: 16px;
}
