/* DM Sans — self-hosted (SIL Open Font License 1.1) */
/* latin-ext */
@font-face {
  font-family: "DM Sans";
  font-style: normal;
  font-weight: 300 700;
  font-display: swap;
  src: url("/static/fonts/dm-sans-latin-ext.woff2") format("woff2");
  unicode-range:
    U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304,
    U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB,
    U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: "DM Sans";
  font-style: normal;
  font-weight: 300 700;
  font-display: swap;
  src: url("/static/fonts/dm-sans-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;
}

@layer kelp.theme {
  :root {
    --color-pink-hue: 13;
    --color-pink-chroma: 1;
  }
  :where(:root),
  .light {
    --color-primary-fill-muted: var(--color-pink-95);
    --color-primary-fill-accent: var(--color-pink-90);
    --color-primary-fill-vivid: var(--color-pink-50);
    --color-primary-border-muted: var(--color-pink-90);
    --color-primary-border-accent: var(--color-pink-80);
    --color-primary-border-vivid: var(--color-pink-60);
    --color-primary-on-muted: var(--color-pink-30);
    --color-primary-on-accent: var(--color-pink-20);
    --color-primary-on-vivid: white;
    --color-primary-outline: var(--color-pink-50);
  }
  .dark {
    --color-primary-fill-muted: var(--color-pink-15);
    --color-primary-fill-accent: var(--color-pink-20);
    --color-primary-fill-vivid: var(--color-pink-50);
    --color-primary-border-muted: var(--color-pink-20);
    --color-primary-border-accent: var(--color-pink-30);
    --color-primary-border-vivid: var(--color-pink-40);
    --color-primary-on-muted: var(--color-pink-75);
    --color-primary-on-accent: var(--color-pink-80);
    --color-primary-on-vivid: white;
    --color-primary-outline: var(--color-pink-50);
  }
}
h1,
h2,
h3 {
  font-family: "DM Sans", system-ui, sans-serif;
  font-weight: 700;
}
h1 {
  font-size: var(--size-2xl);
}
h2 {
  font-size: var(--size-l);
}
h3 {
  font-size: var(--size-m);
}
fieldset,
form > button {
  font-size: var(--size-2xs);
}
.info-list {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0 var(--size-s);
}
.info-list dt {
  font-weight: 700;
  padding-block: var(--size-4xs);
}
.info-list dd {
  margin: 0;
  padding-block: var(--size-4xs);
  border-bottom: 1px solid var(--border-color, #e0e0e0);
}
.info-list dt {
  border-bottom: 1px solid var(--border-color, #e0e0e0);
}
.pq-title {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-family: "DM Sans", system-ui, sans-serif;
}
.pq-title-brand {
  display: flex;
  flex-direction: column;
}
.pq-title .pq-text-sub {
  font-weight: 300;
  font-size: 0.7rem;
  letter-spacing: 0.15em;
  color: #ec1e52;
  opacity: 0.55;
  line-height: 1.2;
}
.pq-title .pq-text-main {
  font-weight: 700;
  font-size: 1.4rem;
  letter-spacing: 0.02em;
  color: #ec1e52;
  line-height: 1.1;
}
.pq-title-id {
  font-weight: 700;
  font-size: var(--size-2xl);
  line-height: 1;
}
.login-page {
  min-height: 100dvh;
}
.login-page .login-content {
  max-width: 24rem;
  margin-inline: auto;
  padding: var(--size-l);
}
.login-page .login-accent {
  display: none;
  background:
    radial-gradient(
      ellipse 60% 60% at 50% 50%,
      rgba(236, 30, 82, 0.25),
      transparent
    ),
    #0e0e11;
  overflow: hidden;
}
.pq-logo-stacked {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.5rem;
  text-align: center;
  font-family: "DM Sans", system-ui, sans-serif;
  -webkit-font-smoothing: antialiased;
}
.pq-logo-stacked svg {
  width: 140px;
  height: 140px;
}
.pq-logo-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  border-top: 1px solid rgba(236, 30, 82, 0.15);
  padding-top: 1rem;
}
.pq-text-sub {
  font-weight: 300;
  font-size: 0.85rem;
  letter-spacing: 0.15em;
  color: #ec1e52;
  opacity: 0.55;
  line-height: 1.2;
}
.pq-text-main {
  font-weight: 700;
  font-size: 1.8rem;
  letter-spacing: 0.06em;
  color: #ec1e52;
  line-height: 1.1;
}
@media (min-width: 60em) {
  .login-page {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
  .login-page .login-accent {
    display: flex;
    align-items: center;
    justify-content: center;
  }
}
.navbar.primary .nav-brand {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.navbar.primary .logo {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  text-decoration: none;
}
.navbar.primary .logo svg {
  flex-shrink: 0;
}
.navbar.primary .pq-nav-text {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-family: "DM Sans", system-ui, sans-serif;
  border-left: 1px solid rgba(236, 30, 82, 0.15);
  padding-left: 0.5rem;
}
.navbar.primary .pq-nav-brand {
  display: flex;
  flex-direction: column;
}
.navbar.primary .pq-nav-text .pq-text-sub {
  font-weight: 300;
  font-size: 0.55rem;
  letter-spacing: 0.18em;
  color: #ec1e52;
  opacity: 0.55;
  line-height: 1.2;
}
.navbar.primary .pq-nav-text .pq-text-main {
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: 0.02em;
  color: #ec1e52;
  line-height: 1.1;
}
.navbar.primary .pq-nav-id {
  font-weight: 700;
  font-size: 1.4rem;
  color: var(--color-primary-on-vivid);
  line-height: 1;
}
.navbar.primary {
  background:
    radial-gradient(
      ellipse 60% 100% at 0% 50%,
      rgba(236, 30, 82, 0.25),
      transparent
    ),
    #0e0e11;
  color: var(--color-primary-on-vivid);
  padding-inline: var(--size-m);
}
.navbar.primary a,
.navbar.primary summary,
.navbar.primary button.plain {
  color: var(--color-primary-on-vivid);
  --color-hover: var(--color-primary-on-vivid);
  --decoration-hover: none;
  --background-color-hover: transparent;
}
.navbar.primary details > ul {
  color: initial;
}
.navbar.primary details > ul a {
  color: var(--color-primary-on-accent);
}
main.wide {
  padding-inline: var(--size-m);
}
#nav-drawer {
  font-size: var(--size-2xs);
}
#nav-drawer .action-header {
  background-color: var(--color-primary-fill-vivid);
  color: var(--color-primary-on-vivid);
}
#nav-drawer .action-header {
  padding-block: var(--size-s);
}
#nav-drawer .action-header button.plain {
  color: var(--color-primary-on-vivid);
  --background-color-hover: transparent;
}
