@import url('./wd-tokens.css');

/*
 * WilsonDesk — main presentation layer (theme via html[data-theme])
 * ------------------------------------------------------------------
 * Tokens live in ./wd-tokens.css (imported above). This file holds layout
 * and component rules only.
 *
 * Naming: `wd-` prefix + BEM-like `__` (element) and `--` (modifier).
 * Bootstrap utilities and components are composed alongside `wd-*` blocks.
 *
 * Section anchors — search this file for the tag in brackets:
 *   [wd-base]          Body, background, overlay, caption HUD
 *   [wd-shell]         Top bar, mode carousel, per-mode chrome
 *   [wd-calendar-ui]   Fixed day layer, sliding panel, calendar shell
 *   [wd-brand]         Logo / wordmark micro-interactions
 *   [wd-account]       Account trigger + glass panel
 *   [wd-dashboard]     Quote card, hero clock
 *   [wd-notes]         Editor, rail, list, preview, meta toolbar
 *   [wd-highlight]     highlight.js overlay (editor + day panel)
 *   [wd-cal-year]      Year wall grid
 *   [wd-auth]          Auth modal
 *   [wd-legal-pages]   Privacy / Terms — Desk Ledger layout
 *   [wd-modals]        Shared modal chrome + misc dialogs
 *   [wd-bg-fallback]   Desk when no background image
 *   [wd-theme-light]   Light-theme component tuning
 *
 * Maintenance: prefer design tokens in wd-tokens.css for color, motion, and radii.
 * Shared short transitions use --wd-ui-dur-sm / --wd-ui-dur-sm-tight + --wd-ui-ease.
 *
 * Organization: one primary sheet (this file) + wd-tokens.css; admin UI uses admin.css.
 * When adding `prefers-reduced-motion: reduce` rules, merge selectors into the nearest
 * existing block if declarations match (same duration / transition: none pattern).
 */

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

html {
  height: 100%;
  scroll-behavior: auto;
}

/* [wd-base] */
.wd-body {
  margin: 0;
  height: 100%;
  min-height: 100dvh;
  font-family: var(--wd-font);
  color: var(--wd-text);
  background: var(--wd-bg);
  overflow: hidden;
  touch-action: manipulation;
  -webkit-font-smoothing: antialiased;
}

.wd-bg {
  position: fixed;
  inset: 0;
  z-index: 0;
  background-color: var(--wd-bg);
  background-size: cover;
  background-position: center;
  transform: scale(1.02);
  opacity: 1;
  transition: opacity 0.9s var(--wd-ease-out);
}

.wd-bg.wd-bg--pending {
  opacity: 0;
}

/* Vignette + vertical wash: photo stays visible, type stays readable */
.wd-overlay {
  position: fixed;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: var(--wd-overlay-radial), var(--wd-overlay);
  transition: opacity var(--wd-dur-reveal) var(--wd-ease-out);
}

/* Background photo — city + short intro (bottom-left, subtle) */
.wd-bg-caption {
  position: fixed;
  z-index: 3;
  left: max(var(--wd-pad-x), env(safe-area-inset-left, 0px));
  bottom: var(--wd-bottom-hud-y);
  max-width: min(22rem, calc(100vw - 2 * var(--wd-pad-x)));
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--wd-dur-reveal) var(--wd-ease-out);
}

.wd-bg-caption.wd-bg-caption--visible {
  opacity: 1;
}

/* Shown only on Dashboard; hidden on Notes/Calendar without clearing caption text. */
.wd-bg-caption.wd-bg-caption--off-dashboard {
  opacity: 0 !important;
}

@media (prefers-reduced-motion: reduce) {
  .wd-bg,
  .wd-bg-caption {
    transition-duration: 0.01ms;
  }
}

.wd-bg-caption__inner {
  position: relative;
  padding: 0.65rem 0.85rem 0.7rem 0.95rem;
  border-radius: var(--wd-radius-sm);
}

/* Localized scrim so type stays legible on bright or busy photos */
.wd-bg-caption__inner::before {
  content: '';
  position: absolute;
  inset: -0.35rem -0.5rem -0.45rem -0.65rem;
  z-index: -1;
  border-radius: inherit;
  background: radial-gradient(
    ellipse 125% 115% at 0% 100%,
    rgba(5, 6, 10, 0.78) 0%,
    rgba(5, 6, 10, 0.42) 52%,
    transparent 74%
  );
  pointer-events: none;
}

[data-theme='light'] .wd-bg-caption__inner::before {
  background: radial-gradient(
    ellipse 125% 115% at 0% 100%,
    rgba(250, 248, 242, 0.82) 0%,
    rgba(250, 248, 242, 0.38) 52%,
    transparent 74%
  );
}

.wd-bg-caption__place {
  margin: 0;
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 1.35;
  color: rgba(255, 255, 255, 0.94);
  text-shadow:
    0 1px 2px rgba(0, 0, 0, 0.55),
    0 0 1.25rem rgba(0, 0, 0, 0.35);
}

.wd-bg-caption__intro {
  margin: 0.28rem 0 0;
  font-size: 0.6875rem;
  font-weight: 400;
  letter-spacing: 0.06em;
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.68);
  text-shadow:
    0 1px 2px rgba(0, 0, 0, 0.45),
    0 0 1rem rgba(0, 0, 0, 0.28);
}

[data-theme='light'] .wd-bg-caption__place {
  color: rgba(22, 22, 24, 0.92);
  text-shadow:
    0 1px 0 rgba(255, 255, 255, 0.35),
    0 0 1.25rem rgba(255, 255, 255, 0.45);
}

[data-theme='light'] .wd-bg-caption__intro {
  color: rgba(22, 22, 24, 0.62);
  text-shadow:
    0 1px 0 rgba(255, 255, 255, 0.28),
    0 0 0.85rem rgba(255, 255, 255, 0.35);
}

@media (max-width: 575.98px) {
  .wd-bg-caption {
    max-width: min(18rem, calc(100vw - 1.5rem));
  }

  .wd-bg-caption__place {
    font-size: 0.75rem;
  }

  .wd-bg-caption__intro {
    font-size: 0.625rem;
  }
}

/* [wd-shell] ——— Top bar + immersive modes (horizontal slides) ——— */
.wd-topbar {
  position: fixed;
  z-index: 20;
  top: var(--wd-safe-top);
  left: 0;
  right: 0;
  padding: 0.65rem 1rem 0;
  background: transparent;
  pointer-events: none;
}

.wd-topbar button,
.wd-topbar a {
  pointer-events: auto;
}

.wd-modes-root {
  position: fixed;
  inset: 0;
  z-index: 2;
  overflow: hidden;
  outline: none;
}

.wd-persistence-warning-wrap {
  position: fixed;
  z-index: 19;
  top: calc(var(--wd-safe-top) + 3.8rem);
  left: 0;
  right: 0;
  padding: 0 1rem;
  pointer-events: none;
}

.wd-persistence-warning {
  margin: 0 auto;
  max-width: 52rem;
  padding: 0.65rem 0.85rem;
  border-radius: var(--wd-radius-sm);
  color: #ffd8a8;
  font-size: 0.86rem;
  line-height: 1.35;
  text-align: center;
  pointer-events: auto;
}

.wd-modes-track {
  display: flex;
  flex-direction: row;
  height: 100%;
  width: 300%;
  will-change: transform;
  transition: transform var(--wd-slide-dur) var(--wd-slide-ease);
}

.wd-modes-track.wd-modes-track--no-transition {
  transition: none;
}

.wd-modes-track.wd-modes-track--dragging {
  cursor: grabbing;
  -webkit-user-select: none;
  user-select: none;
}

.wd-mode {
  position: relative;
  flex: 0 0 33.333333%;
  width: 33.333333%;
  height: 100%;
  min-height: 0;
  min-width: 0;
  box-sizing: border-box;
}

.wd-mode--dashboard {
  display: flex;
  flex-direction: column;
  padding-bottom: var(--wd-safe-bottom);
  padding-top: calc(var(--wd-safe-top) + 3rem);
}

.wd-mode--calendar {
  display: flex;
  flex-direction: column;
  padding-top: calc(var(--wd-safe-top) + 3rem);
  padding-bottom: calc(2.75rem + var(--wd-safe-bottom));
  padding-left: max(var(--wd-space-2), env(safe-area-inset-left, 0px));
  padding-right: max(var(--wd-space-2), env(safe-area-inset-right, 0px));
}

.wd-mode-scroll {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

.wd-calendar-scroll {
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  touch-action: pan-y;
}

.wd-calendar-head {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-bottom: clamp(0.65rem, 1.5vh, 1rem);
  width: 100%;
}

/* [wd-calendar-ui] Calendar + sliding day detail panel (layer is outside transformed #wd-modes-track so fixed positioning works) */
.wd-calendar-day-layer {
  position: fixed;
  inset: 0;
  z-index: 19;
  pointer-events: none;
}

.wd-calendar-layout {
  position: relative;
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-height: 0;
  width: 100%;
  isolation: isolate;
}

.wd-calendar-main {
  position: relative;
  z-index: 0;
  flex: 1 1 auto;
  min-height: 0;
  min-width: 0;
  transition:
    filter 0.38s var(--wd-ease-out),
    opacity 0.38s var(--wd-ease-out);
}

.wd-calendar-layout--open .wd-calendar-main {
  filter: saturate(0.92);
  opacity: 0.92;
}

@media (prefers-reduced-motion: reduce) {
  .wd-modes-track,
  .wd-calendar-main {
    transition-duration: 0.01ms;
  }
}

.wd-day-panel-scrim {
  position: fixed;
  inset: 0;
  z-index: 0;
  background: rgba(4, 6, 11, 0.32);
  -webkit-backdrop-filter: blur(5px);
  backdrop-filter: blur(5px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.36s var(--wd-ease-out);
}

.wd-calendar-day-layer--open .wd-day-panel-scrim {
  opacity: 1;
  pointer-events: auto;
}

@media (min-width: 560px) {
  /* Left side stays lighter so the highlighted calendar day stays visually linked to the panel */
  .wd-calendar-day-layer--open .wd-day-panel-scrim {
    background: linear-gradient(
      90deg,
      rgba(4, 6, 11, 0.07) 0%,
      rgba(4, 6, 11, 0.14) min(52vw, 42rem),
      rgba(4, 6, 11, 0.28) 100%
    );
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
  }
}

.wd-day-panel {
  --wd-day-panel-w: min(56vw, 42rem);
  position: fixed;
  z-index: 1;
  top: calc(var(--wd-safe-top) + 2.55rem);
  bottom: max(2.85rem, calc(2.75rem + var(--wd-safe-bottom)));
  right: max(0.65rem, env(safe-area-inset-right, 0px));
  width: var(--wd-day-panel-w);
  max-width: 100%;
  display: flex;
  flex-direction: column;
  padding: 0;
  overflow: hidden;
  border-radius: calc(var(--wd-radius) + 6px);
  border: 1px solid var(--wd-glass-border);
  background: color-mix(in srgb, var(--wd-surface-elevated) 72%, transparent);
  -webkit-backdrop-filter: blur(22px) saturate(1.1);
  backdrop-filter: blur(22px) saturate(1.1);
  box-shadow:
    var(--wd-shadow),
    0 0 0 1px color-mix(in srgb, var(--wd-text) 5%, transparent) inset,
    -12px 0 40px color-mix(in srgb, #000 22%, transparent);
  transform: translate3d(calc(100% + 18px), 0, 0);
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
  transition:
    transform 0.38s cubic-bezier(0.22, 1, 0.36, 1),
    opacity 0.3s var(--wd-ease-out),
    visibility 0s linear 0.38s;
}

.wd-calendar-day-layer--open .wd-day-panel {
  transform: translate3d(0, 0, 0);
  opacity: 1;
  pointer-events: auto;
  visibility: visible;
  transition:
    transform 0.38s cubic-bezier(0.22, 1, 0.36, 1),
    opacity 0.3s var(--wd-ease-out),
    visibility 0s linear 0s;
}

.wd-day-panel__accent {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  border-radius: 2px 0 0 2px;
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--wd-accent) 88%, transparent),
    color-mix(in srgb, var(--wd-accent-2, var(--wd-accent)) 55%, transparent)
  );
  opacity: 0.95;
  pointer-events: none;
}

.wd-np-head {
  position: relative;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
  flex-shrink: 0;
  padding: var(--wd-space-3) var(--wd-space-3) var(--wd-space-2);
  border-bottom: 1px solid color-mix(in srgb, var(--wd-border) 80%, transparent);
}

.wd-np-head-main {
  min-width: 0;
  flex: 1;
  padding-left: 0.35rem;
}

.wd-np-title-line {
  margin: 0 0 0.4rem;
  font-size: clamp(1rem, 2.2vw, 1.15rem);
  font-weight: 650;
  letter-spacing: -0.02em;
  line-height: 1.25;
  color: var(--wd-text);
}

/* [wd-calendar-ui] Panel chrome: reuse Notes toolbar pattern (see .wd-notes-chrome) */
.wd-day-panel .wd-np-chrome.wd-notes-chrome {
  padding-left: 0;
  padding-right: 0;
}

.wd-np-date-native-label {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  margin: 0;
  cursor: pointer;
  color: var(--wd-muted);
}

.wd-np-date-native-label .wd-notes-meta__ic {
  color: var(--wd-muted);
}

.wd-np-date-native {
  max-width: 11.5rem;
  font-size: 0.8125rem;
  padding: 0.28rem 0.5rem;
  border-radius: var(--wd-radius-sm);
  background: color-mix(in srgb, var(--wd-text) 5%, transparent) !important;
  border: 1px solid color-mix(in srgb, var(--wd-border-strong) 35%, var(--wd-border) 65%) !important;
  color: var(--wd-text) !important;
}

.wd-np-date-native:focus {
  border-color: var(--wd-a40) !important;
  box-shadow: var(--wd-focus-ring) !important;
  outline: none;
}

.wd-np-day-actions {
  display: inline-flex;
  align-items: center;
  gap: 0.15rem;
  flex-shrink: 0;
}

.wd-day-panel .wd-np-action.wd-icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.05rem;
  height: 2.05rem;
  padding: 0;
  border-radius: var(--wd-radius-sm);
  color: var(--wd-muted);
  border: 1px solid color-mix(in srgb, var(--wd-border) 70%, transparent);
  background: color-mix(in srgb, var(--wd-text) 4%, transparent);
  transition:
    color var(--wd-dur-fast) var(--wd-ease-out),
    border-color var(--wd-dur-fast) var(--wd-ease-out),
    background var(--wd-dur-fast) var(--wd-ease-out);
}

.wd-day-panel .wd-np-action.wd-icon-btn:hover {
  color: var(--wd-text);
  border-color: color-mix(in srgb, var(--wd-border-strong) 55%, var(--wd-border) 45%);
  background: color-mix(in srgb, var(--wd-text) 7%, transparent);
}

.wd-day-panel .wd-np-action.wd-icon-btn:focus-visible {
  outline: none;
  box-shadow: var(--wd-focus-ring);
  border-color: color-mix(in srgb, var(--wd-accent) 45%, var(--wd-border) 55%);
}

.wd-day-panel .wd-np-action--danger.wd-icon-btn:hover {
  color: color-mix(in srgb, #f87171 88%, var(--wd-text) 12%);
  border-color: color-mix(in srgb, #f87171 35%, var(--wd-border) 65%);
}

[data-theme='light'] .wd-day-panel .wd-np-action--danger.wd-icon-btn:hover {
  color: color-mix(in srgb, #dc2626 92%, var(--wd-text) 8%);
  border-color: color-mix(in srgb, #dc2626 38%, var(--wd-border) 62%);
}

.wd-day-panel__close {
  flex-shrink: 0;
  margin-top: -0.15rem;
}

.wd-day-panel:focus {
  outline: none;
}

.wd-day-panel:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--wd-accent) 48%, transparent);
  outline-offset: 3px;
}

.wd-day-panel__body {
  flex: 1 1 auto;
  min-height: 0;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: var(--wd-space-3);
  padding-top: var(--wd-space-2);
}

.wd-np-body {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  min-height: 0;
}

/* Calendar day panel: editor full width; note list is a flyout over the editor (no layout steal) */
.wd-day-panel__split {
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

.wd-day-panel__split--no-rail .wd-day-notes-rail {
  display: none;
}

.wd-day-panel__editor-col--rail-narrow {
  --wd-day-rail-w: min(12.75rem, calc(100% - 2.25rem));
}

.wd-day-panel__editor-col {
  --wd-day-rail-w: min(15.25rem, calc(100% - 2.25rem));
  position: relative;
  flex: 1 1 auto;
  min-width: 0;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

.wd-day-panel__rail-scrim {
  display: none;
  position: absolute;
  left: var(--wd-day-rail-w);
  top: 0;
  right: 0;
  bottom: 0;
  z-index: 7;
  border-radius: inherit;
  background: rgba(2, 5, 12, 0.4);
  -webkit-backdrop-filter: blur(3px);
  backdrop-filter: blur(3px);
}

.wd-day-panel__editor-col--rail-open .wd-day-panel__rail-scrim {
  display: block;
}

/* Notes rail collapsed by default; expanded = overlay (does not shrink editor column) */
.wd-day-panel--notes-rail-collapsed .wd-day-notes-rail {
  display: none !important;
}

.wd-np-toggle-day-notes {
  display: none !important;
}

.wd-day-panel.wd-day-panel--has-notes-rail .wd-np-toggle-day-notes:not([hidden]) {
  display: inline-flex !important;
}

.wd-np-toggle-day-notes .wd-np-toggle-svg {
  display: none;
  flex-shrink: 0;
  width: 1.1rem;
  height: 1.1rem;
  margin: 0;
}

.wd-day-panel--has-notes-rail.wd-day-panel--notes-rail-collapsed .wd-np-toggle-svg--collapsed {
  display: block;
}

.wd-day-panel--has-notes-rail:not(.wd-day-panel--notes-rail-collapsed) .wd-np-toggle-svg--expanded {
  display: block;
}

/* Match Bootstrap icon size to custom SVG toggle in the same row */
.wd-day-panel .wd-np-day-actions > .wd-icon-btn .bi {
  font-size: 1.1rem;
  line-height: 1;
}

.wd-day-notes-rail.wd-day-notes-rail--flyout {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: var(--wd-day-rail-w);
  z-index: 8;
  display: flex;
  flex-direction: column;
  min-height: 0;
  padding: 0.55rem 0.52rem 0.6rem 0.58rem;
  border: 1px solid color-mix(in srgb, var(--wd-border-strong) 35%, var(--wd-border) 65%);
  border-left: none;
  border-radius: 0 var(--wd-radius) var(--wd-radius) 0;
  background: color-mix(in srgb, var(--wd-surface-elevated) 78%, color-mix(in srgb, var(--wd-text) 5%, transparent));
  -webkit-backdrop-filter: blur(20px) saturate(1.08);
  backdrop-filter: blur(20px) saturate(1.08);
  box-shadow:
    10px 0 36px color-mix(in srgb, #000 38%, transparent),
    0 0 0 1px color-mix(in srgb, var(--wd-text) 5%, transparent) inset;
}

.wd-day-notes-rail__chrome {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.45rem;
  flex-shrink: 0;
  padding-bottom: 0.42rem;
  margin-bottom: 0.4rem;
  border-bottom: 1px solid color-mix(in srgb, var(--wd-border) 70%, transparent);
}

.wd-day-notes-rail__title {
  margin: 0;
  font-size: 0.62rem;
  font-weight: 650;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--wd-muted);
}

.wd-day-notes-rail__count-pill {
  font-size: 0.65rem;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  line-height: 1;
  padding: 0.22rem 0.48rem;
  border-radius: 999px;
  color: var(--wd-text);
  background: color-mix(in srgb, var(--wd-accent) 22%, transparent);
  border: 1px solid color-mix(in srgb, var(--wd-accent) 38%, var(--wd-border) 62%);
}

.wd-day-notes-rail__body {
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

.wd-day-notes-rail__list {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  margin: 0;
  padding: 0 0.18rem 0.2rem 0;
  display: flex;
  flex-direction: column;
  gap: 0.38rem;
}

.wd-day-notes-rail__li {
  margin: 0;
  padding: 0;
  list-style: none;
}

.wd-day-notes-rail__item {
  width: 100%;
  display: block;
  text-align: left;
  border: 1px solid color-mix(in srgb, var(--wd-border) 58%, transparent);
  border-radius: 12px;
  padding: 0.48rem 0.52rem 0.48rem 0.55rem;
  background: color-mix(in srgb, var(--wd-text) 4.5%, transparent);
  color: inherit;
  cursor: pointer;
  position: relative;
  transition:
    background 0.22s var(--wd-ease-out),
    border-color 0.22s var(--wd-ease-out),
    box-shadow 0.22s var(--wd-ease-out);
}

.wd-day-notes-rail__item::before {
  content: '';
  position: absolute;
  left: 6px;
  top: 50%;
  transform: translateY(-50%);
  width: 3px;
  height: 0;
  border-radius: 2px;
  background: var(--wd-accent);
  opacity: 0;
  transition:
    height var(--wd-ui-dur-sm) var(--wd-ui-ease),
    opacity var(--wd-ui-dur-sm) var(--wd-ui-ease);
}

.wd-day-notes-rail__item:hover {
  background: color-mix(in srgb, var(--wd-text) 7.5%, transparent);
  border-color: color-mix(in srgb, var(--wd-border-strong) 42%, var(--wd-border) 58%);
}

.wd-day-notes-rail__item:focus-visible {
  outline: none;
  border-color: var(--wd-a45);
  box-shadow: 0 0 0 2px var(--wd-a18);
}

.wd-day-notes-rail__item--active {
  border-color: color-mix(in srgb, var(--wd-accent) 45%, var(--wd-border) 55%);
  background: var(--wd-a15);
  box-shadow: inset 0 0 0 1px var(--wd-a18);
}

.wd-day-notes-rail__item--active::before {
  height: 62%;
  opacity: 1;
}

.wd-day-notes-rail__item-title {
  font-size: 0.8125rem;
  font-weight: 550;
  line-height: 1.3;
  color: var(--wd-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  padding-left: 0.15rem;
}

.wd-day-notes-rail__item--active .wd-day-notes-rail__item-title {
  font-weight: 650;
}

.wd-day-notes-rail__item-preview {
  font-size: 0.66rem;
  color: var(--wd-muted);
  line-height: 1.32;
  margin-top: 0.14rem;
  padding-left: 0.15rem;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* [wd-calendar-ui] Same editor stack as Notes: surface + transparent textarea + syntax highlight overlay */
.wd-day-panel .wd-np-editor-stack.wd-notes-surface {
  flex: 1 1 auto;
  min-height: min(48vh, 22rem);
  border-radius: var(--wd-radius);
  background: color-mix(in srgb, var(--wd-surface) 14%, transparent);
  border: 1px solid color-mix(in srgb, var(--wd-border-strong) 30%, var(--wd-border) 70%);
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--wd-text) 4%, transparent);
}

.wd-day-panel .wd-np-editor-stack .wd-notes-editor-highlight {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: auto;
  height: auto;
  max-width: none;
  z-index: 1;
  padding: 0.5rem 0.75rem 1.1rem;
}

/* Leave room for the Markdown hint rail so the highlight layer does not paint over it. */
.wd-day-panel .wd-np-editor-stack.wd-notes-surface:has(> .wd-notes-md-foot) .wd-notes-editor-highlight {
  bottom: var(--wd-notes-md-foot-h, 1.68rem);
}

.wd-day-panel .wd-np-editor-stack .wd-notes-editor {
  flex: 1 1 auto;
  min-height: min(40vh, 16rem);
  max-width: none;
  margin-left: 0;
  margin-right: 0;
  resize: vertical;
  position: relative;
  z-index: 2;
}

/* Calendar day panel: toggle between Markdown editor and rendered preview */
.wd-day-panel .wd-np-editor-stack.wd-np-surface--preview .wd-notes-editor,
.wd-day-panel .wd-np-editor-stack.wd-np-surface--preview .wd-notes-editor-highlight {
  display: none !important;
}

.wd-day-panel .wd-np-preview.wd-notes-preview {
  display: none;
  flex: 1 1 auto;
  min-height: min(40vh, 16rem);
  max-height: none;
  margin: 0;
  padding: 0.55rem 0.75rem 1rem;
  box-sizing: border-box;
  overflow-x: hidden;
  overflow-y: auto;
  overflow-wrap: break-word;
  word-wrap: break-word;
  -webkit-overflow-scrolling: touch;
  font-size: 1.02rem;
  line-height: 1.68;
  letter-spacing: 0.01em;
  color: var(--wd-notes-preview-prose);
  outline: none;
  cursor: default;
  -webkit-font-smoothing: antialiased;
  background: color-mix(in srgb, var(--wd-surface) 10%, transparent);
  border-radius: inherit;
}

.wd-day-panel .wd-np-editor-stack.wd-np-surface--preview .wd-np-preview.wd-notes-preview {
  display: block;
}

.wd-day-panel .wd-np-preview.wd-notes-preview:focus-visible {
  box-shadow: inset 0 0 0 1px var(--wd-a25);
  border-radius: 8px;
}

.wd-calendar-layout--open .wd-day.is-selected {
  box-shadow:
    0 0 0 2px color-mix(in srgb, var(--wd-accent) 55%, transparent),
    0 4px 14px color-mix(in srgb, var(--wd-accent) 18%, transparent);
  background: color-mix(in srgb, var(--wd-accent) 16%, var(--wd-cal-cell));
  z-index: 2;
  transition:
    background 0.32s var(--wd-ease-out),
    box-shadow 0.32s var(--wd-ease-out),
    transform var(--wd-dur-fast) var(--wd-ease-out);
}

.wd-calendar-layout--open .wd-day.is-selected.wd-cal-col--sun {
  background: color-mix(in srgb, var(--wd-accent) 16%, var(--wd-cal-weekend-sun-cell));
}

.wd-calendar-layout--open .wd-day.is-selected.wd-cal-col--sat {
  background: color-mix(in srgb, var(--wd-accent) 16%, var(--wd-cal-weekend-sat-cell));
}

#wd-day-panel[data-wd-day-iso] .wd-np-title-line {
  color: color-mix(in srgb, var(--wd-text) 90%, var(--wd-accent) 10%);
}

@media (max-width: 559.98px) {
  .wd-day-panel {
    left: max(0.55rem, env(safe-area-inset-left, 0px));
    right: max(0.55rem, env(safe-area-inset-right, 0px));
    width: auto;
    top: auto;
    max-height: min(86vh, 36rem);
    bottom: max(0.45rem, var(--wd-safe-bottom));
    border-radius: 1.05rem 1.05rem calc(var(--wd-radius) + 4px) calc(var(--wd-radius) + 4px);
    transform: translate3d(0, calc(100% + 24px), 0);
    transition:
      transform 0.36s cubic-bezier(0.22, 1, 0.36, 1),
      opacity 0.3s var(--wd-ease-out),
      visibility 0s linear 0.36s;
    box-shadow:
      var(--wd-shadow),
      0 -16px 48px color-mix(in srgb, #000 28%, transparent);
  }

  .wd-calendar-day-layer--open .wd-day-panel {
    transform: translate3d(0, 0, 0);
    transition:
      transform 0.36s cubic-bezier(0.22, 1, 0.36, 1),
      opacity 0.3s var(--wd-ease-out),
      visibility 0s linear 0s;
  }

  .wd-day-panel__accent {
    left: 0;
    right: 0;
    top: 0;
    bottom: auto;
    width: auto;
    height: 4px;
    border-radius: 2px 2px 0 0;
    background: linear-gradient(
      90deg,
      color-mix(in srgb, var(--wd-accent) 88%, transparent),
      color-mix(in srgb, var(--wd-accent-2, var(--wd-accent)) 55%, transparent)
    );
  }

  .wd-np-head-main {
    padding-left: 0;
  }

  .wd-day-panel__editor-col {
    --wd-day-rail-w: min(17.25rem, calc(100% - 1.5rem));
  }

  .wd-day-panel__editor-col--rail-narrow {
    --wd-day-rail-w: min(14.5rem, calc(100% - 1.5rem));
  }

  .wd-day-notes-rail__chrome {
    padding-bottom: 0.32rem;
    margin-bottom: 0.32rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .wd-day-panel,
  .wd-day-panel-scrim {
    transition-duration: 0.01ms !important;
  }

  .wd-calendar-day-layer--open .wd-day-panel {
    transition-delay: 0s;
  }
}

.wd-mode--notes {
  display: flex;
  flex-direction: column;
  min-height: 0;
  flex: 1 1 auto;
  padding: calc(var(--wd-safe-top) + 3rem) max(var(--wd-pad-x), env(safe-area-inset-right, 0px))
    calc(1.15rem + var(--wd-safe-bottom)) max(var(--wd-pad-x), env(safe-area-inset-left, 0px));
  max-width: none;
}

.wd-mode-dots {
  position: fixed;
  z-index: 18;
  left: 50%;
  bottom: max(0.75rem, var(--wd-safe-bottom));
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.35rem 0.5rem;
  border-radius: 999px;
  background: rgba(8, 10, 16, 0.35);
  border: 1px solid rgba(255, 255, 255, 0.08);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  pointer-events: auto;
}

.wd-mode-dot {
  width: 7px;
  height: 7px;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.28);
  cursor: pointer;
  transition: transform var(--wd-dur-fast) var(--wd-ease-out), background var(--wd-dur-fast) var(--wd-ease-out);
}

.wd-mode-dot:hover {
  background: rgba(255, 255, 255, 0.45);
}

.wd-mode-dot.is-active {
  background: rgba(255, 255, 255, 0.92);
  transform: scale(1.15);
}

.wd-mode-dot:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--wd-a45);
}

/* Desk — Privacy / Terms quick links (HUD, menu, account, auth) */
.wd-desk-legal {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  flex-wrap: wrap;
}

.wd-desk-legal-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.32rem 0.55rem 0.32rem 0.45rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(8, 10, 16, 0.38);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  color: rgba(255, 255, 255, 0.82);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-decoration: none;
  transition:
    color var(--wd-dur-fast) var(--wd-ease-out),
    border-color var(--wd-dur-fast) var(--wd-ease-out),
    background var(--wd-dur-fast) var(--wd-ease-out),
    box-shadow var(--wd-dur-fast) var(--wd-ease-out);
}

.wd-desk-legal-chip:hover {
  color: rgba(255, 255, 255, 0.96);
  border-color: color-mix(in srgb, var(--wd-accent) 42%, rgba(255, 255, 255, 0.12));
  background: rgba(12, 14, 20, 0.52);
}

.wd-desk-legal-chip:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--wd-a45);
}

.wd-desk-legal-chip-icon {
  font-size: 0.78rem;
  opacity: 0.88;
  color: var(--wd-accent);
}

/* Privacy/Terms HUD: visible on Dashboard (mode 1) only */
.wd-desk-legal--hud {
  position: fixed;
  z-index: 17;
  left: 50%;
  bottom: calc(max(0.75rem, var(--wd-safe-bottom)) + 2.65rem);
  transform: translateX(-50%);
  max-width: calc(100vw - 2 * var(--wd-pad-x));
  display: flex;
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
  transition:
    opacity var(--wd-dur-fast) var(--wd-ease-out),
    visibility var(--wd-dur-fast) var(--wd-ease-out);
}

html[data-wd-mode='1'] .wd-desk-legal--hud {
  visibility: visible;
  opacity: 1;
  pointer-events: auto;
}

.wd-offcanvas-legal {
  margin-top: var(--wd-space-6);
  padding-top: var(--wd-space-5);
  border-top: 1px solid var(--wd-border);
}

.wd-offcanvas-legal-label {
  margin: 0 0 0.45rem 0.15rem;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--wd-muted2);
}

.wd-desk-legal--offcanvas {
  justify-content: stretch;
  gap: 0.45rem;
}

.wd-desk-legal--offcanvas .wd-desk-legal-chip {
  flex: 1 1 0;
  justify-content: center;
  min-width: 0;
  padding: 0.5rem 0.4rem;
  border-radius: var(--wd-radius-sm);
  font-size: 0.7rem;
  text-transform: none;
  letter-spacing: 0.02em;
  background: color-mix(in srgb, var(--wd-surface) 55%, transparent);
  border-color: var(--wd-border);
  color: var(--wd-text);
}

.wd-desk-legal--offcanvas .wd-desk-legal-chip:hover {
  background: color-mix(in srgb, var(--wd-surface-elevated) 72%, transparent);
  border-color: color-mix(in srgb, var(--wd-accent) 35%, var(--wd-border));
  color: var(--wd-text);
}

.wd-desk-legal--panel {
  margin-top: var(--wd-space-3);
  padding-top: var(--wd-space-3);
  border-top: 1px solid var(--wd-border);
  justify-content: flex-start;
  gap: 0.45rem;
}

.wd-desk-legal--panel .wd-desk-legal-chip {
  flex: 1 1 0;
  justify-content: center;
  min-width: 0;
  padding: 0.45rem 0.4rem;
  border-radius: var(--wd-radius-sm);
  font-size: 0.7rem;
  text-transform: none;
  letter-spacing: 0.02em;
  background: color-mix(in srgb, var(--wd-surface-elevated) 42%, transparent);
  border-color: var(--wd-border);
  color: var(--wd-text);
}

.wd-desk-legal--panel .wd-desk-legal-chip:hover {
  border-color: color-mix(in srgb, var(--wd-accent) 32%, var(--wd-border));
  background: color-mix(in srgb, var(--wd-surface-elevated) 62%, transparent);
}

.wd-desk-legal--auth {
  margin-top: 0.65rem;
  gap: 0.4rem;
}

.wd-desk-legal--auth .wd-desk-legal-chip {
  padding: 0.38rem 0.55rem;
  font-size: 0.65rem;
  background: color-mix(in srgb, var(--wd-surface-elevated) 35%, transparent);
  border-color: var(--wd-border);
  color: var(--wd-muted);
  text-transform: none;
  letter-spacing: 0.02em;
}

.wd-desk-legal--auth .wd-desk-legal-chip:hover {
  color: var(--wd-text);
  border-color: color-mix(in srgb, var(--wd-accent) 28%, var(--wd-border));
}

[data-theme='light'] .wd-desk-legal--hud .wd-desk-legal-chip {
  border-color: rgba(22, 22, 24, 0.1);
  background: rgba(255, 255, 255, 0.42);
  color: rgba(22, 22, 24, 0.72);
}

[data-theme='light'] .wd-desk-legal--hud .wd-desk-legal-chip:hover {
  color: rgba(22, 22, 24, 0.92);
  background: rgba(255, 255, 255, 0.58);
  border-color: color-mix(in srgb, var(--wd-accent) 35%, rgba(22, 22, 24, 0.12));
}

.wd-topbar-inner {
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.wd-topbar-start {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  min-width: 0;
  flex-shrink: 1;
  pointer-events: auto;
}

.wd-topbar-brand {
  display: inline-flex;
  align-items: center;
  min-width: 0;
  margin: 0;
  padding: 0.2rem 0.35rem 0.2rem 0;
  border-radius: 10px;
  text-decoration: none;
  color: var(--wd-text);
}

/* [wd-brand] —— micro-interactions (home links: header, offcanvas) ——
   States: default, hover (lift + layered glow + wordmark pulse + underline), active (press), focus-visible */
a.wd-brand--interactive {
  position: relative;
  isolation: isolate;
  outline: none;
  color: var(--wd-text);
  text-decoration: none;
  transition:
    color var(--wd-brand-dur) var(--wd-brand-ease),
    box-shadow var(--wd-brand-dur) var(--wd-brand-ease),
    background-color var(--wd-brand-dur) var(--wd-brand-ease);
  -webkit-tap-highlight-color: transparent;
}

a.wd-brand--interactive:hover {
  color: color-mix(in srgb, var(--wd-text) 72%, var(--wd-brand-fx));
}

a.wd-brand--interactive:active {
  color: color-mix(in srgb, var(--wd-text) 78%, var(--wd-brand-fx-mid));
  transition-duration: 0.1s;
}

a.wd-brand--interactive:focus-visible {
  outline: none;
  box-shadow: var(--wd-focus-ring);
  background-color: var(--wd-brand-focus-bg);
}

a.wd-brand--interactive .wd-brand-mark-svg {
  flex-shrink: 0;
  transition:
    transform var(--wd-brand-dur) var(--wd-brand-ease-mark),
    filter var(--wd-brand-dur) var(--wd-brand-ease-mark);
}

a.wd-brand--interactive:hover .wd-brand-mark-svg {
  transform: translate3d(0, var(--wd-brand-mark-lift), 0) scale(var(--wd-brand-mark-scale-hover));
  filter:
    drop-shadow(0 1px 2px color-mix(in srgb, var(--wd-brand-fx-mid) 28%, transparent))
    drop-shadow(0 4px 22px color-mix(in srgb, var(--wd-brand-fx-glow) 32%, transparent))
    drop-shadow(0 0 16px color-mix(in srgb, var(--wd-brand-fx) 26%, transparent));
}

a.wd-brand--interactive:active .wd-brand-mark-svg {
  transform: translate3d(0, 0, 0) scale(var(--wd-brand-mark-scale-press));
  filter:
    drop-shadow(0 1px 1px color-mix(in srgb, var(--wd-brand-fx-mid) 22%, transparent))
    drop-shadow(0 2px 14px color-mix(in srgb, var(--wd-brand-fx) 24%, transparent));
}

a.wd-brand--interactive .wd-brand-name {
  position: relative;
  display: inline-block;
}

a.wd-brand--interactive .wd-brand-name::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0.04em;
  width: 100%;
  height: 2px;
  border-radius: 1px;
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--wd-brand-fx) 82%, transparent) 0%,
    color-mix(in srgb, var(--wd-brand-fx-mid) 48%, transparent) 42%,
    color-mix(in srgb, var(--wd-brand-fx-glow) 22%, transparent) 76%,
    transparent 100%
  );
  box-shadow: 0 1px 14px color-mix(in srgb, var(--wd-brand-fx-glow) 30%, transparent);
  transform: scale3d(0, 1, 1);
  transform-origin: left center;
  transition: transform var(--wd-brand-underline-dur) var(--wd-brand-ease);
  pointer-events: none;
  opacity: 1;
}

a.wd-brand--interactive:hover .wd-brand-name::after,
a.wd-brand--interactive:focus-visible .wd-brand-name::after {
  transform: scale3d(1, 1, 1);
}

a.wd-brand--interactive.wd-brand--icon-only .wd-brand-name::after {
  display: none;
}

@media (prefers-reduced-motion: no-preference) {
  a.wd-brand--interactive .wd-brand-name {
    transition:
      color var(--wd-brand-dur) var(--wd-brand-ease),
      letter-spacing var(--wd-brand-dur) var(--wd-brand-ease-mark),
      text-shadow var(--wd-brand-dur) var(--wd-brand-ease);
  }

  a.wd-brand--interactive:hover .wd-brand-name,
  a.wd-brand--interactive:focus-visible .wd-brand-name {
    letter-spacing: 0.04em;
    text-shadow:
      0 0 28px color-mix(in srgb, var(--wd-brand-fx-glow) 38%, transparent),
      0 0 2px color-mix(in srgb, var(--wd-brand-fx) 32%, transparent);
  }
}

@media (prefers-reduced-motion: reduce) {
  a.wd-brand--interactive,
  a.wd-brand--interactive .wd-brand-mark-svg,
  a.wd-brand--interactive .wd-brand-name::after {
    transition: none !important;
  }

  a.wd-brand--interactive:hover .wd-brand-mark-svg,
  a.wd-brand--interactive:active .wd-brand-mark-svg {
    transform: none;
    filter: none;
  }

  a.wd-brand--interactive .wd-brand-name::after {
    display: none;
  }
}

.wd-brand--topbar .wd-brand-mark-svg {
  width: 26px;
  height: 26px;
  flex-shrink: 0;
}

.wd-brand--topbar .wd-brand-name {
  font-size: 0.9375rem;
  font-weight: 600;
  letter-spacing: -0.03em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.wd-topbar-muted {
  color: var(--wd-muted2) !important;
  font-weight: 400;
  letter-spacing: 0.02em;
}

/* [wd-account] ——— Account & settings (top-right) ——— */
.wd-user-pill {
  display: flex;
  align-items: center;
  margin-left: auto;
}

.wd-account {
  position: relative;
  pointer-events: auto;
}

.wd-account-trigger {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 1px solid var(--wd-border);
  border-radius: 999px;
  background: color-mix(in srgb, var(--wd-surface) 55%, transparent);
  cursor: pointer;
  transition:
    border-color var(--wd-dur-fast) var(--wd-ease-out),
    background var(--wd-dur-fast) var(--wd-ease-out),
    box-shadow var(--wd-dur-fast) var(--wd-ease-out),
    transform 0.15s ease;
}

.wd-account-trigger:hover {
  border-color: var(--wd-border-strong);
  background: color-mix(in srgb, var(--wd-surface) 72%, transparent);
}

.wd-account-trigger:focus-visible {
  outline: none;
  box-shadow: var(--wd-focus-ring);
}

.wd-account.is-open .wd-account-trigger {
  border-color: var(--wd-a35);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--wd-accent) 28%, transparent);
}

.wd-account-avatar {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.125rem;
  height: 2.125rem;
  border-radius: 50%;
  background: linear-gradient(
    155deg,
    color-mix(in srgb, var(--wd-accent) 22%, transparent) 0%,
    color-mix(in srgb, var(--wd-accent) 10%, transparent) 100%
  );
  color: var(--wd-accent);
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.03em;
}

.wd-account-avatar--panel {
  width: 2.5rem;
  height: 2.5rem;
  font-size: 0.9375rem;
  flex-shrink: 0;
}

.wd-account-panel {
  position: absolute;
  z-index: 30;
  top: calc(100% + 0.45rem);
  right: 0;
  min-width: min(18rem, calc(100vw - 2rem));
  padding: var(--wd-space-4);
  border-radius: var(--wd-radius);
  border: 1px solid var(--wd-glass-border);
  background: var(--wd-glass);
  -webkit-backdrop-filter: blur(18px);
  backdrop-filter: blur(18px);
  box-shadow: var(--wd-shadow-soft);
  opacity: 0;
  transform: translateY(-6px) scale(0.98);
  pointer-events: none;
  transition:
    opacity var(--wd-dur-fast) var(--wd-ease-out),
    transform var(--wd-dur-fast) var(--wd-ease-out);
}

.wd-account.is-open .wd-account-panel {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

.wd-account-panel:focus {
  outline: none;
}

.wd-account-panel__identity {
  display: flex;
  align-items: center;
  gap: var(--wd-space-3);
  margin-bottom: var(--wd-space-4);
  min-width: 0;
}

.wd-account-panel__id {
  min-width: 0;
  flex: 1;
}

.wd-account-panel__name {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--wd-text);
  letter-spacing: 0.01em;
  line-height: 1.25;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.wd-account-panel__email {
  font-size: 0.75rem;
  margin-top: 0.15rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.wd-account-panel__actions {
  display: flex;
  flex-direction: column;
  gap: var(--wd-space-2);
}

.wd-account-action {
  display: flex;
  align-items: center;
  gap: var(--wd-space-3);
  width: 100%;
  padding: var(--wd-space-2) var(--wd-space-3);
  border: 1px solid var(--wd-border);
  border-radius: var(--wd-radius-sm);
  background: color-mix(in srgb, var(--wd-surface-elevated) 40%, transparent);
  color: var(--wd-text);
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-align: left;
  cursor: pointer;
  transition:
    background var(--wd-dur-fast) var(--wd-ease-out),
    border-color var(--wd-dur-fast) var(--wd-ease-out);
}

.wd-account-action:hover {
  background: color-mix(in srgb, var(--wd-surface-elevated) 65%, transparent);
  border-color: var(--wd-border-strong);
}

.wd-account-action:focus-visible {
  outline: none;
  box-shadow: var(--wd-focus-ring);
}

.wd-account-action .bi {
  font-size: 1.05rem;
  opacity: 0.88;
}

.wd-account-panel__sep {
  height: 1px;
  margin: var(--wd-space-4) 0;
  background: var(--wd-border);
  opacity: 0.85;
}

.wd-account-panel__section {
  margin-bottom: var(--wd-space-2);
}

.wd-account-panel__label {
  display: block;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--wd-muted2);
  margin-bottom: var(--wd-space-3);
}

.wd-account-theme-seg {
  display: inline-flex;
  align-items: center;
  padding: 3px;
  gap: 2px;
  border-radius: 10px;
  border: 1px solid var(--wd-border);
  background: color-mix(in srgb, var(--wd-surface-elevated) 38%, transparent);
}

.wd-account-theme-opt {
  flex: 1;
  min-width: 2.75rem;
  padding: 0.38rem 0.7rem;
  border: none;
  border-radius: 8px;
  background: transparent;
  color: var(--wd-muted);
  cursor: pointer;
  transition:
    background var(--wd-dur-fast) var(--wd-ease-out),
    color var(--wd-dur-fast) var(--wd-ease-out),
    box-shadow var(--wd-dur-fast) var(--wd-ease-out);
}

.wd-account-theme-opt:hover {
  color: var(--wd-text);
  background: rgba(255, 255, 255, 0.06);
}

.wd-account-theme-opt[aria-pressed='true'] {
  color: var(--wd-accent);
  background: color-mix(in srgb, var(--wd-accent) 14%, transparent);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--wd-accent) 32%, transparent);
}

.wd-account-theme-opt:focus-visible {
  outline: none;
  box-shadow: var(--wd-focus-ring);
}

.wd-account-theme-opt .bi {
  font-size: 1.05rem;
  line-height: 1;
  vertical-align: -0.1em;
}

.wd-account-panel__future {
  font-size: 0.6875rem;
  margin: var(--wd-space-3) 0 0;
  letter-spacing: 0.04em;
  line-height: 1.35;
}

@media (prefers-reduced-motion: reduce) {
  .wd-account-panel {
    transition-duration: 0.01ms;
  }
}

/* [wd-dashboard] Dashboard — quote: stacked bottom-right (logo lives in .wd-topbar) */
.wd-dashboard-stack {
  position: absolute;
  z-index: 5;
  right: max(var(--wd-pad-x), env(safe-area-inset-right, 0px));
  bottom: var(--wd-bottom-hud-y);
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.65rem;
  max-width: min(22rem, calc(100vw - 1.35rem));
  pointer-events: none;
}

.wd-dashboard-stack > * {
  pointer-events: auto;
}

.wd-mode--dashboard .wd-hero-wrap {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 var(--wd-pad-x) 4rem;
  transform: translateY(-3vh);
  min-height: 0;
}

.wd-hero {
  text-align: center;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity var(--wd-dur-hero) var(--wd-ease-out), transform var(--wd-dur-hero) var(--wd-ease-out);
}

.wd-hero.wd-hero--visible {
  opacity: 1;
  transform: translateY(0);
}

.wd-clock {
  font-size: clamp(2.5rem, 11vw, 5.25rem);
  font-weight: 200;
  letter-spacing: 0.08em;
  line-height: 1.02;
  text-shadow: 0 2px 40px rgba(0, 0, 0, 0.35);
  font-variant-numeric: tabular-nums;
}

@keyframes wd-clock-tick {
  0% {
    opacity: 1;
  }
  45% {
    opacity: 0.88;
  }
  100% {
    opacity: 1;
  }
}

.wd-clock.wd-clock--tick {
  animation: wd-clock-tick 0.32s var(--wd-ease-out);
}

.wd-date {
  margin-top: 0.65rem;
  font-size: clamp(0.8rem, 2.1vw, 0.98rem);
  color: var(--wd-muted);
  font-weight: 300;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

/* [wd-dashboard] Motivational quote — in .wd-dashboard-stack (bottom-right) */
.wd-mode--dashboard .wd-quote {
  position: relative;
  z-index: 5;
  width: 100%;
  max-width: min(19rem, calc(100vw - 1.35rem));
  margin: 0;
  padding: 0;
  border-radius: var(--wd-radius-lg);
  border: 1px solid rgba(255, 255, 255, 0.09);
  background: linear-gradient(
    155deg,
    rgba(255, 255, 255, 0.11) 0%,
    rgba(255, 255, 255, 0.045) 100%
  );
  box-shadow: 0 12px 48px rgba(0, 0, 0, 0.2);
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 0.55s var(--wd-ease-out), transform 0.55s var(--wd-ease-out),
    box-shadow 0.35s var(--wd-ease-out);
  text-align: left;
}

.wd-mode--dashboard .wd-quote.wd-quote--visible {
  opacity: 1;
  transform: translateY(0);
}

.wd-quote.wd-quote--swap {
  animation: wd-quote-swap 0.45s var(--wd-ease-out);
}

@keyframes wd-quote-swap {
  0% {
    opacity: 0.35;
    transform: scale(0.99);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

@media (prefers-reduced-motion: reduce) {
  .wd-hero {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .wd-clock.wd-clock--tick {
    animation: none;
  }

  .wd-mode--dashboard .wd-quote {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .wd-quote.wd-quote--swap {
    animation: none;
  }
}

.wd-mode--dashboard .wd-quote__inner {
  padding: clamp(0.75rem, 2vw, 1rem) clamp(0.85rem, 2.2vw, 1.15rem) 0.65rem;
}

.wd-quote__body {
  margin: 0;
  padding: 0;
  border: none;
}

.wd-mode--dashboard .wd-quote__text {
  margin: 0;
  font-family: Georgia, 'Times New Roman', serif;
  font-size: clamp(0.8125rem, 2.1vw, 0.95rem);
  font-weight: 400;
  line-height: 1.58;
  letter-spacing: 0.01em;
  color: rgba(255, 255, 255, 0.94);
  text-wrap: balance;
}

[data-theme='light'] .wd-mode--dashboard .wd-quote__text {
  color: rgba(22, 24, 32, 0.92);
}

[data-theme='light'] .wd-mode--dashboard .wd-quote {
  border-color: rgba(0, 0, 0, 0.08);
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.94) 0%, rgba(255, 255, 255, 0.78) 100%);
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.07);
}

[data-theme='light'] .wd-mode--dashboard .wd-quote__btn {
  color: rgba(22, 24, 32, 0.72) !important;
}

.wd-mode--dashboard .wd-quote__cite {
  margin-top: 0.65rem;
  font-size: 0.65rem;
  font-style: normal;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--wd-muted2);
}

.wd-mode--dashboard .wd-quote__toolbar {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.15rem;
  padding: 0.3rem 0 0.45rem;
}

.wd-quote__btn {
  opacity: 0.82;
  color: rgba(255, 255, 255, 0.88) !important;
}

.wd-quote__btn:hover {
  opacity: 1;
}

#wd-quote-save[aria-pressed='true'] {
  color: #f06292 !important;
  opacity: 1;
}

[data-theme='light'] #wd-quote-save[aria-pressed='true'] {
  color: #c2185b !important;
}

.wd-quote__toast {
  position: absolute;
  left: 50%;
  bottom: 100%;
  transform: translateX(-50%) translateY(0.35rem);
  padding: 0.35rem 0.75rem;
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: rgba(255, 255, 255, 0.95);
  background: rgba(12, 14, 22, 0.88);
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.35s var(--wd-ease-out), transform 0.35s var(--wd-ease-out);
  white-space: nowrap;
  z-index: 2;
}

.wd-quote__toast.wd-quote__toast--show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

.wd-quote-collection-empty {
  font-size: 0.875rem;
  color: var(--wd-muted2);
  line-height: 1.55;
  max-width: 22rem;
  margin-left: auto;
  margin-right: auto;
}

.wd-quote-collection-list {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

.wd-quote-collection-item {
  padding: 0.85rem 1rem;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.04);
}

.wd-quote-collection-item__text {
  margin: 0 0 0.5rem;
  font-size: 0.9rem;
  line-height: 1.55;
  color: var(--wd-text);
}

.wd-quote-collection-item__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.wd-quote-collection-item__author {
  margin: 0;
  font-size: 0.65rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--wd-muted2);
}

.wd-panel {
  padding: 1rem 1.1rem;
  border-radius: var(--wd-radius);
  border: 1px solid var(--wd-glass-border);
  background: var(--wd-glass);
  -webkit-backdrop-filter: blur(22px);
  backdrop-filter: blur(22px);
  box-shadow: var(--wd-shadow);
  transition: transform var(--wd-dur-fast) var(--wd-ease-out), box-shadow var(--wd-dur-fast) var(--wd-ease-out),
    border-color var(--wd-dur-fast) var(--wd-ease-out);
}

@media (hover: hover) and (pointer: fine) {
  .wd-panel:hover {
    transform: translateY(-1px);
    border-color: var(--wd-border-strong);
    box-shadow: var(--wd-shadow);
  }
}

.wd-panel-title {
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--wd-muted);
  margin: 0;
}

/* Icon-first section labels */
.wd-panel-title--icon {
  text-transform: none;
  letter-spacing: normal;
  line-height: 1;
}

.wd-panel-title--icon i {
  font-size: 1.125rem;
  font-weight: normal;
  opacity: 0.88;
  display: block;
}

.wd-panel-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-bottom: 0.75rem;
}

.wd-cal-nav {
  display: inline-flex;
  align-items: center;
  gap: clamp(0.25rem, 1vw, 0.5rem);
}

.wd-year-label {
  font-weight: 500;
  letter-spacing: 0.16em;
  font-size: clamp(1.05rem, 2.5vw, 1.4rem);
  font-variant-numeric: tabular-nums;
  min-width: 4rem;
  text-align: center;
  color: var(--wd-text);
}

.wd-mode--calendar .wd-btn-ghost.wd-tap {
  opacity: 0.92;
  border-color: var(--wd-cal-month-border);
  background: color-mix(in srgb, var(--wd-text) 4.5%, transparent);
}

.wd-mode--calendar .wd-btn-ghost.wd-tap:hover:not(:disabled) {
  opacity: 1;
  border-color: var(--wd-border-strong);
  background: color-mix(in srgb, var(--wd-text) 8.5%, transparent);
}

.wd-mode--calendar .wd-btn-ghost.wd-tap:focus-visible {
  outline: none;
  box-shadow: var(--wd-focus-ring);
}

.wd-mode--calendar .wd-btn-ghost.wd-tap:disabled {
  opacity: 0.42;
  cursor: not-allowed;
}

.wd-glass {
  background: var(--wd-glass);
  -webkit-backdrop-filter: blur(24px);
  backdrop-filter: blur(24px);
  border: 1px solid var(--wd-glass-border);
}

.wd-rounded {
  border-radius: var(--wd-radius);
}

.wd-input {
  background: color-mix(in srgb, var(--wd-text) 6%, transparent);
  border: 1px solid color-mix(in srgb, var(--wd-border-strong) 35%, var(--wd-border) 65%);
  color: var(--wd-text);
  border-radius: var(--wd-radius-sm);
}

.wd-input:focus {
  background: color-mix(in srgb, var(--wd-text) 8%, transparent);
  border-color: var(--wd-a35);
  color: var(--wd-text);
  box-shadow: var(--wd-focus-ring);
}

.wd-input::placeholder {
  color: var(--wd-muted2);
}

.wd-tap {
  min-height: 2.75rem;
  min-width: 2.75rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.btn-sm.wd-tap {
  min-height: 2.5rem;
  min-width: 2.5rem;
}

.wd-btn-primary {
  background: var(--wd-btn-primary-bg);
  border: none;
  color: var(--wd-btn-primary-fg);
  font-weight: 600;
  border-radius: var(--wd-radius-sm);
  transition:
    filter var(--wd-dur-fast) var(--wd-ease-out),
    transform 0.15s var(--wd-ease-soft),
    box-shadow var(--wd-dur-fast) var(--wd-ease-out);
  box-shadow: var(--wd-shadow-soft);
}

.wd-btn-primary:hover:not(:disabled) {
  filter: brightness(1.04);
  color: var(--wd-btn-primary-fg);
  box-shadow: var(--wd-shadow);
}

.wd-btn-primary:active {
  transform: scale(0.99);
}

.wd-btn-primary:focus-visible {
  outline: none;
  box-shadow: var(--wd-focus-ring), var(--wd-shadow-soft);
}

.wd-btn-primary:disabled {
  opacity: 0.48;
  cursor: not-allowed;
  filter: grayscale(0.12);
  box-shadow: none;
}

.wd-btn-ghost {
  color: var(--wd-text);
  border-radius: var(--wd-radius-sm);
  border: 1px solid color-mix(in srgb, var(--wd-border) 80%, transparent);
  background: color-mix(in srgb, var(--wd-text) 4.5%, transparent);
  font-weight: 500;
}

.wd-btn-ghost:hover:not(:disabled) {
  background: color-mix(in srgb, var(--wd-text) 8.5%, transparent);
  border-color: var(--wd-border-strong);
  color: var(--wd-text);
}

.wd-btn-ghost:focus-visible {
  outline: none;
  box-shadow: var(--wd-focus-ring);
}

.wd-btn-ghost:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  border-color: color-mix(in srgb, var(--wd-border) 55%, transparent);
}

.wd-icon-btn {
  color: var(--wd-text);
  border-radius: var(--wd-radius-sm);
  padding: 0.35rem 0.55rem;
  background: color-mix(in srgb, var(--wd-text) 4.5%, transparent);
  border: 1px solid var(--wd-border);
  transition:
    background 0.22s var(--wd-ease-out),
    transform 0.15s ease,
    border-color 0.22s var(--wd-ease-out);
}

.wd-icon-btn:hover:not(:disabled) {
  background: color-mix(in srgb, var(--wd-text) 9%, transparent);
  border-color: var(--wd-border-strong);
  color: var(--wd-text);
}

.wd-icon-btn:focus-visible {
  outline: none;
  box-shadow: var(--wd-focus-ring);
}

.wd-icon-btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  border-color: color-mix(in srgb, var(--wd-border) 60%, transparent);
}

@media (hover: none) and (pointer: coarse) {
  .wd-icon-btn {
    min-width: 2.75rem;
    min-height: 2.75rem;
  }
}

/* [wd-notes] ——— Notes — full-canvas editor + rail + floating list ——— */
.wd-notes-shell {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-height: 0;
  width: 100%;
  max-width: none;
  margin: 0;
  transition: none;
}

/* Editor focus: typing vs navigation — split view: rim only; one column: fill + blur shift (below) */
.wd-notes-shell.wd-notes-shell--editor-focused .wd-notes-body {
  box-shadow:
    inset 0 0 0 1px var(--wd-a22),
    0 0 0 1px color-mix(in srgb, var(--wd-text) 8%, transparent);
  transition:
    box-shadow 0.22s var(--wd-ease-out),
    background 0.32s var(--wd-ease-out),
    -webkit-backdrop-filter 0.32s var(--wd-ease-out),
    backdrop-filter 0.32s var(--wd-ease-out);
}

.wd-notes-shell:not(.wd-notes--split).wd-notes-shell--editor-focused .wd-notes-body {
  /* Typing: at least as solid as idle — emphasis is the rim, not weaker glass */
  background: color-mix(in srgb, var(--wd-surface) 38%, transparent);
  -webkit-backdrop-filter: blur(9px) saturate(1.06);
  backdrop-filter: blur(9px) saturate(1.06);
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--wd-accent) 22%, transparent),
    0 0 0 1px color-mix(in srgb, var(--wd-text) 6%, transparent),
    0 18px 56px color-mix(in srgb, #000 28%, transparent);
}

.wd-notes-shell.wd-notes-shell--editor-idle .wd-notes-body {
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--wd-border-strong) 45%, var(--wd-border) 55%);
  transition:
    box-shadow 0.22s var(--wd-ease-out),
    background 0.32s var(--wd-ease-out),
    -webkit-backdrop-filter 0.32s var(--wd-ease-out),
    backdrop-filter 0.32s var(--wd-ease-out);
}

.wd-notes-shell:not(.wd-notes--split).wd-notes-shell--editor-idle .wd-notes-body {
  /* Resting: opaquer sheet + light blur — stays legible, not “frosted mud” */
  background: color-mix(in srgb, var(--wd-surface) 36%, transparent);
  -webkit-backdrop-filter: blur(6px) saturate(1.04);
  backdrop-filter: blur(6px) saturate(1.04);
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, var(--wd-text) 4%, transparent),
    0 10px 40px color-mix(in srgb, #000 20%, transparent);
}

@media (prefers-reduced-motion: reduce) {
  .wd-notes-shell.wd-notes-shell--editor-focused .wd-notes-body,
  .wd-notes-shell.wd-notes-shell--editor-idle .wd-notes-body {
    transition: none;
  }
}

/* Single-column measure + padding: see immersive .wd-notes-body block below */

.wd-notes-shell.wd-notes-shell--wide .wd-notes-body {
  max-width: min(56rem, 100%);
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}

/* Preview (split) mode: use full main width — no narrow column while editing + preview */
.wd-notes-shell.wd-notes--split.wd-notes-shell--wide .wd-notes-body {
  max-width: none;
  width: 100%;
  margin-left: 0;
  margin-right: 0;
}

.wd-notes-workspace {
  display: flex;
  flex-direction: row;
  flex: 1 1 auto;
  min-height: 0;
  width: 100%;
  align-items: stretch;
  gap: clamp(0.2rem, 0.45vw, 0.45rem);
}

/* Transparent rail: desk/hero shows through; controls carry their own surface. */
.wd-notes-rail {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: var(--wd-space-3);
  padding: var(--wd-space-4) var(--wd-space-2);
  padding-left: max(var(--wd-space-2), env(safe-area-inset-left, 0px));
  background: transparent;
  border-right: 1px solid var(--wd-notes-rail-edge);
  box-shadow: inset -1px 0 0 var(--wd-notes-rail-glow);
  transition:
    opacity 0.28s var(--wd-ease-out),
    transform 0.28s var(--wd-ease-out);
}

.wd-notes-rail-btn {
  width: 42px;
  height: 42px;
  padding: 0;
  border-radius: var(--wd-radius-sm);
  border: 1px solid var(--wd-notes-rail-btn-border);
  background: var(--wd-notes-rail-btn-bg);
  color: var(--wd-muted);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: var(--wd-notes-rail-btn-shadow);
  transition:
    background 0.22s var(--wd-ease-out),
    color 0.22s var(--wd-ease-out),
    border-color 0.22s var(--wd-ease-out),
    box-shadow 0.22s var(--wd-ease-out),
    transform var(--wd-ui-dur-sm-tight) var(--wd-ui-ease);
}

.wd-notes-rail-btn:hover {
  color: var(--wd-text);
  background: var(--wd-notes-rail-btn-bg-hover);
  border-color: var(--wd-notes-rail-btn-border-hover);
}

.wd-notes-rail-btn:active {
  transform: scale(0.96);
}

.wd-notes-rail-btn:focus-visible {
  outline: none;
  box-shadow:
    var(--wd-notes-rail-btn-shadow),
    0 0 0 2px var(--wd-a22);
}

.wd-notes-rail-btn[aria-expanded='true'],
.wd-notes-rail-btn[aria-pressed='true'] {
  color: var(--wd-accent);
  border-color: var(--wd-a38);
  background: var(--wd-a11);
  box-shadow:
    inset 0 0 0 1px var(--wd-a12),
    0 1px 0 color-mix(in srgb, var(--wd-text) 8%, transparent);
}

.wd-notes-rail-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

.wd-notes-rail-icon svg {
  display: block;
}

@media (prefers-reduced-motion: reduce) {
  .wd-notes-rail-btn:active {
    transform: none;
  }
}

@media (hover: none) and (pointer: coarse) {
  .wd-notes-rail-btn {
    min-width: 2.75rem;
    min-height: 2.75rem;
  }
}

/* Bootstrap popover styling for icon hints */
.popover.wd-popover {
  --bs-popover-max-width: min(17rem, calc(100vw - 1.5rem));
  --bs-popover-border-color: var(--wd-notes-tip-border);
  --bs-popover-bg: var(--wd-notes-tip-bg);
  --bs-popover-header-bg: transparent;
  --bs-popover-body-color: var(--wd-notes-tip-fg);
  --bs-popover-border-radius: var(--wd-radius-sm);
  z-index: 1090;
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  box-shadow: var(--wd-notes-tip-shadow);
}

.popover.wd-popover .popover-body {
  padding: 0.45rem 0.65rem;
  font-size: 0.72rem;
  font-weight: 500;
  line-height: 1.38;
  letter-spacing: 0.015em;
}

.wd-notes-main {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  min-height: 0;
  padding-right: max(0.65rem, env(safe-area-inset-right, 0px));
}

/* [wd-notes] Calm composition:
   Secondary controls stay available but visually quiet until intent (hover/focus). */
@media (hover: hover) and (pointer: fine) {
  html[data-wd-mode='0'] .wd-topbar {
    opacity: 0.14;
    transition: opacity 0.32s var(--wd-ease-out), transform 0.32s var(--wd-ease-out);
    transform: translateY(-2px);
  }

  html[data-wd-mode='0'] .wd-topbar:hover,
  html[data-wd-mode='0'] .wd-topbar:focus-within {
    opacity: 1;
    transform: translateY(0);
  }

  html[data-wd-mode='0'] .wd-mode-dots {
    opacity: 0.16;
    transition: opacity 0.28s var(--wd-ease-out), transform 0.28s var(--wd-ease-out);
    transform: translateX(-50%) translateY(4px);
  }

  html[data-wd-mode='0'] .wd-mode-dots:hover,
  html[data-wd-mode='0'] .wd-mode-dots:focus-within {
    opacity: 0.95;
    transform: translateX(-50%) translateY(0);
  }

  html[data-wd-mode='0'] .wd-notes-shell .wd-notes-rail {
    opacity: 0.48;
    transform: translateX(-4px);
  }

  html[data-wd-mode='0'] .wd-notes-shell:hover .wd-notes-rail,
  html[data-wd-mode='0'] .wd-notes-shell:focus-within .wd-notes-rail {
    opacity: 1;
    transform: translateX(0);
  }

  html[data-wd-mode='0'] .wd-notes-shell .wd-notes-chrome {
    opacity: 0.06;
    transform: translateY(-7px);
    pointer-events: none;
    transition:
      opacity 0.24s var(--wd-ease-out),
      transform 0.24s var(--wd-ease-out),
      border-color 0.24s var(--wd-ease-out);
  }

  html[data-wd-mode='0'] .wd-notes-shell:hover .wd-notes-chrome,
  html[data-wd-mode='0'] .wd-notes-shell:focus-within .wd-notes-chrome {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }

  html[data-wd-mode='0'] .wd-notes-shell .wd-notes-meta__lbl,
  html[data-wd-mode='0'] .wd-notes-shell .wd-notes-meta__fmt-label {
    opacity: 0;
    max-width: 0;
    overflow: hidden;
    transition: opacity 0.22s var(--wd-ease-out), max-width 0.22s var(--wd-ease-out);
  }

  html[data-wd-mode='0'] .wd-notes-shell:hover .wd-notes-meta__lbl,
  html[data-wd-mode='0'] .wd-notes-shell:hover .wd-notes-meta__fmt-label,
  html[data-wd-mode='0'] .wd-notes-shell:focus-within .wd-notes-meta__lbl,
  html[data-wd-mode='0'] .wd-notes-shell:focus-within .wd-notes-meta__fmt-label {
    opacity: 1;
    max-width: 12rem;
  }

  html[data-wd-mode='0'] .wd-notes-shell .wd-notes-meta__fmt {
    min-width: 2.08rem;
    gap: 0;
    padding-left: 0.42rem;
    padding-right: 0.42rem;
  }
}

.wd-notes-chrome {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--wd-space-2);
  flex-shrink: 0;
  min-height: 2.5rem;
  margin: 0;
  padding: 0 0 var(--wd-space-2);
  width: 100%;
  border-bottom: 1px solid color-mix(in srgb, var(--wd-border-strong) 38%, var(--wd-border) 62%);
  transition:
    border-color var(--wd-dur-fast) var(--wd-ease-out),
    padding var(--wd-split-layout-dur) var(--wd-split-layout-ease);
}

.wd-notes-shell.wd-notes--split .wd-notes-chrome {
  padding-bottom: 0.35rem;
  border-bottom-color: color-mix(in srgb, var(--wd-border) 90%, transparent);
}

.wd-notes-chrome-end {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.65rem;
  flex: 0 0 auto;
  min-width: 0;
}

.wd-notes-undo {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.2rem 0.5rem 0.2rem 0.65rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.1);
  animation: wd-notes-undo-in 0.28s var(--wd-ease-out);
}

.wd-notes-undo[hidden] {
  display: none !important;
}

@keyframes wd-notes-undo-in {
  from {
    opacity: 0;
    transform: translate3d(6px, 0, 0);
  }

  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .wd-notes-undo {
    animation: none;
  }
}

.wd-notes-undo-text {
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  color: var(--wd-muted);
}

.wd-notes-undo-btn {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  padding: 0.2rem 0.55rem;
  border: none;
  border-radius: 999px;
  background: var(--wd-a20);
  color: var(--wd-text);
  cursor: pointer;
  transition: background var(--wd-ui-dur-sm-tight) var(--wd-ui-ease);
}

.wd-notes-undo-btn:hover {
  background: var(--wd-a32);
  color: var(--wd-text);
}

.wd-notes-chrome-start {
  display: flex;
  align-items: flex-start;
  gap: 0.3rem;
  flex: 1 1 auto;
  min-width: 0;
}

/* [wd-notes] ——— Note toolbar: grouped pills (schedule · export) + quiet hover hints ——— */
.wd-notes-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem;
  max-width: 100%;
  padding: 0;
  background: transparent;
  border: none;
  box-shadow: none;
}

.wd-notes-meta--clean {
  row-gap: 0.4rem;
  column-gap: 0.4rem;
}

.wd-notes-meta__group {
  display: inline-flex;
  align-items: stretch;
  padding: 2px;
  border-radius: 12px;
  background: color-mix(in srgb, var(--wd-surface-elevated) 58%, transparent);
  border: 1px solid color-mix(in srgb, var(--wd-border) 86%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--wd-text) 4%, transparent);
  transition:
    border-color var(--wd-dur-fast) var(--wd-ease-out),
    background var(--wd-dur-fast) var(--wd-ease-out),
    box-shadow var(--wd-dur-fast) var(--wd-ease-out);
}

.wd-notes-meta:hover .wd-notes-meta__group {
  border-color: color-mix(in srgb, var(--wd-border-strong) 55%, var(--wd-border) 45%);
}

.wd-notes-meta__flow {
  display: none;
}

@media (max-width: 380px) {
  .wd-notes-meta__flow {
    display: none;
  }
}

.wd-notes-meta__segment {
  display: flex;
  align-items: center;
  min-width: 0;
}

.wd-notes-meta__date {
  flex: 1 1 auto;
  padding: 0 1px 0 2px;
}

.wd-notes-meta__hit {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.38rem;
  flex: 1 1 auto;
  min-width: 0;
  padding: 0.42rem 0.52rem 0.42rem 0.42rem;
  margin: 0;
  border: none;
  border-radius: 9px;
  background: transparent;
  color: var(--wd-muted);
  font-size: 0.74rem;
  font-weight: 500;
  letter-spacing: 0.015em;
  cursor: pointer;
  transition:
    color var(--wd-ui-dur-sm) var(--wd-ui-ease),
    background var(--wd-ui-dur-sm) var(--wd-ui-ease);
}

.wd-notes-meta__hit:hover,
.wd-notes-meta__hit:focus-visible {
  color: var(--wd-text);
  background: color-mix(in srgb, var(--wd-text) 8.5%, transparent);
  outline: none;
}

.wd-notes-meta__hit:focus-visible {
  box-shadow: 0 0 0 2px var(--wd-a38);
}

.wd-notes-meta__ic {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  opacity: 0.78;
  color: var(--wd-muted);
  transition:
    opacity var(--wd-ui-dur-sm) var(--wd-ui-ease),
    color var(--wd-ui-dur-sm) var(--wd-ui-ease);
}

.wd-notes-meta__ic svg {
  display: block;
}

.wd-notes-meta__date.is-set .wd-notes-meta__ic {
  opacity: 0.95;
  color: var(--wd-accent-2);
}

.wd-notes-meta__lbl {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: min(100%, 12.5rem);
  transition: color var(--wd-ui-dur-sm) var(--wd-ui-ease);
}

/* Icon-first: show formatted date only when set */
.wd-notes-meta__date:not(.is-set) .wd-notes-meta__lbl {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.wd-notes-meta__date:not(.is-set) .wd-notes-meta__hit {
  padding-left: 0.42rem;
  padding-right: 0.42rem;
}

.wd-notes-meta__date.is-set .wd-notes-meta__lbl {
  color: var(--wd-text);
  font-weight: 550;
  position: static;
  width: auto;
  height: auto;
  margin: 0;
  clip: auto;
  overflow: visible;
}

.wd-notes-meta__clear {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 1.62rem;
  height: 1.62rem;
  margin: 0 0.14rem 0 0;
  padding: 0;
  border: none;
  border-radius: 8px;
  background: transparent;
  color: var(--wd-muted2);
  font-size: 1rem;
  line-height: 1;
  cursor: pointer;
  opacity: 0.65;
  transition:
    opacity var(--wd-ui-dur-sm) var(--wd-ui-ease),
    background var(--wd-ui-dur-sm) var(--wd-ui-ease),
    color var(--wd-ui-dur-sm) var(--wd-ui-ease);
}

.wd-notes-meta__clear:hover {
  opacity: 1;
  background: color-mix(in srgb, var(--wd-text) 9%, transparent);
  color: var(--wd-text);
}

.wd-notes-meta__clear svg {
  display: block;
}

.wd-notes-meta__save-as {
  flex: 0 0 auto;
  padding: 0 2px;
  gap: 0;
}

.wd-notes-meta__fmt {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.32rem;
  min-width: 2.45rem;
  min-height: 2.2rem;
  padding: 0.36rem 0.56rem;
  margin: 0;
  border: none;
  border-radius: 9px;
  background: transparent;
  color: var(--wd-muted);
  line-height: 1;
  cursor: pointer;
  transition:
    color var(--wd-ui-dur-sm) var(--wd-ui-ease),
    background var(--wd-ui-dur-sm) var(--wd-ui-ease),
    transform var(--wd-ui-dur-sm-tight) var(--wd-ui-ease);
}

.wd-notes-meta__fmt-label {
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  color: inherit;
}

.wd-notes-meta__fmt-ic {
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

.wd-notes-meta__fmt-ic svg {
  display: block;
}

.wd-notes-meta__fmt:hover,
.wd-notes-meta__fmt:focus-visible {
  color: var(--wd-text);
  background: color-mix(in srgb, var(--wd-text) 9%, transparent);
  outline: none;
}

.wd-notes-meta__fmt:hover {
  transform: translateY(-0.5px);
}

.wd-notes-meta__fmt:focus-visible {
  box-shadow: 0 0 0 2px var(--wd-a38);
}

.wd-notes-meta__fmt + .wd-notes-meta__fmt {
  margin-left: 0;
}

@media (prefers-reduced-motion: reduce) {
  .wd-notes-meta,
  .wd-notes-meta__hit,
  .wd-notes-meta__fmt,
  .wd-notes-meta__clear {
    transition: none;
  }

  .wd-notes-meta__fmt:hover {
    transform: none;
  }
}

@media (max-width: 900px) {
  .wd-notes-chrome {
    align-items: center;
    gap: 0.55rem;
  }

  .wd-notes-chrome-start,
  .wd-notes-chrome-end {
    width: 100%;
  }

  .wd-notes-chrome-end {
    justify-content: flex-start;
  }
}

@media (max-width: 560px) {
  .wd-notes-meta__fmt-label {
    display: none;
  }

  .wd-notes-meta__fmt {
    min-width: 2.2rem;
    padding-left: 0.4rem;
    padding-right: 0.4rem;
  }

  .wd-notes-meta__lbl {
    max-width: 8.5rem;
  }
}

.wd-notes-item-cal {
  font-size: 0.65rem;
  opacity: 0.75;
  margin-right: 0.12rem;
  vertical-align: -0.05em;
}

.wd-notes-status {
  font-size: 0.75rem;
  letter-spacing: 0.04em;
  color: var(--wd-muted2);
  opacity: 0;
  transition: opacity 0.35s var(--wd-ease-out);
}

.wd-notes-status.wd-notes-status--on {
  opacity: 1;
}

.wd-notes-column {
  position: relative;
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-height: 0;
  width: 100%;
}

/* [wd-notes] Title → metadata → body (aligned column; calendar panel uses the same title weight) */
.wd-notes-editor-frame {
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
}

.wd-notes-doc-column {
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  width: 100%;
  height: 100%;
}

.wd-notes-doc-column > .wd-notes-chrome {
  grid-area: controls;
}

.wd-notes-doc-column > .wd-notes-surface {
  grid-area: surface;
}

.wd-notes-shell:not(.wd-notes--split) .wd-notes-doc-column {
  /* max-width: min(65ch, 100%); */
  margin-left: auto;
  margin-right: auto;
}

.wd-notes-shell.wd-notes--split .wd-notes-doc-column {
  max-width: none;
}

.wd-notes-doc-column .wd-notes-chrome {
  margin-top: 0;
  padding: 0.1rem 0.15rem 0.45rem;
  border-bottom-color: color-mix(in srgb, var(--wd-border) 70%, transparent);
  border-bottom-style: dashed;
  align-items: center;
}

@media (min-width: 900px) {
  .wd-notes-shell:not(.wd-notes--split) .wd-notes-doc-column {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: auto minmax(0, 1fr);
    grid-template-areas:
      'controls'
      'surface';
    align-items: stretch;
    row-gap: 0.35rem;
  }

  .wd-notes-shell:not(.wd-notes--split) .wd-notes-doc-column > .wd-notes-chrome {
    margin-top: 0;
    padding: 0;
    border-bottom: none;
    min-height: 0;
    width: 100%;
  }

  .wd-notes-shell:not(.wd-notes--split) .wd-notes-doc-column > .wd-notes-chrome .wd-notes-chrome-start {
    flex: 1 1 auto;
  }
}

.wd-notes-scrim {
  position: fixed;
  inset: 0;
  z-index: 24;
  background: rgba(4, 6, 11, 0.28);
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.32s var(--wd-ease-out);
}

.wd-notes-scrim.wd-notes-scrim--open {
  opacity: 1;
  pointer-events: auto;
}

@media (min-width: 900px) {
  .wd-notes-scrim.wd-notes-scrim--open {
    background: rgba(4, 6, 11, 0.18);
    -webkit-backdrop-filter: blur(3px);
    backdrop-filter: blur(3px);
  }
}

.wd-notes-panel-wrap {
  position: fixed;
  z-index: 26;
  left: max(0.65rem, env(safe-area-inset-left, 0px));
  top: calc(var(--wd-safe-top) + 2.65rem);
  width: min(19.5rem, calc(100vw - 1.25rem));
  max-height: min(72vh, 34rem);
  pointer-events: none;
  opacity: 0;
  transform: translate3d(0, -8px, 0) scale(0.985);
  transition:
    opacity 0.3s var(--wd-ease-out),
    transform 0.34s var(--wd-ease-out);
}

.wd-notes-panel-wrap.wd-notes-panel-wrap--open {
  pointer-events: auto;
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
}

@media (min-width: 520px) {
  .wd-notes-panel-wrap {
    left: calc(3.25rem + max(0.65rem, env(safe-area-inset-left, 0px)));
  }
}

@media (prefers-reduced-motion: reduce) {
  .wd-notes-panel-wrap {
    transition-duration: 0.01ms;
  }

  .wd-notes-scrim {
    transition-duration: 0.01ms;
  }
}

.wd-notes-panel {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--wd-space-2);
  height: 100%;
  max-height: min(72vh, 34rem);
  padding: var(--wd-space-3) var(--wd-space-3) 0.75rem;
  border-radius: calc(var(--wd-radius) + 4px);
  border: 1px solid var(--wd-glass-border);
  background: color-mix(in srgb, var(--wd-surface-elevated) 68%, transparent);
  -webkit-backdrop-filter: blur(22px) saturate(1.12);
  backdrop-filter: blur(22px) saturate(1.12);
  box-shadow: var(--wd-shadow), 0 0 0 1px color-mix(in srgb, var(--wd-text) 5%, transparent) inset;
}

.wd-notes-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  flex-shrink: 0;
}

.wd-notes-panel-tools {
  display: flex;
  align-items: center;
  gap: 0.2rem;
  flex-shrink: 0;
}

.wd-notes-panel-title {
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--wd-muted);
}

/* Icon-first add: primary affordance in header, matches wd-icon-btn */
.wd-notes-new.wd-icon-btn {
  color: var(--wd-accent);
  border-color: color-mix(in srgb, var(--wd-accent) 28%, transparent);
  background: color-mix(in srgb, var(--wd-accent) 12%, transparent);
}

.wd-notes-new.wd-icon-btn:hover:not(:disabled),
.wd-notes-new.wd-icon-btn:focus-visible {
  color: var(--wd-accent);
  background: color-mix(in srgb, var(--wd-accent) 20%, transparent);
  border-color: color-mix(in srgb, var(--wd-accent) 40%, transparent);
}

.wd-notes-new.wd-icon-btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  color: var(--wd-muted2);
  border-color: color-mix(in srgb, var(--wd-border) 65%, transparent);
  background: color-mix(in srgb, var(--wd-text) 4%, transparent);
}

.wd-notes-list {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  margin: 0;
  padding: 0 var(--wd-space-1) 0 0;
  display: flex;
  flex-direction: column;
  gap: var(--wd-space-2);
}

.wd-notes-row {
  display: flex;
  align-items: stretch;
  gap: 0.15rem;
  border-radius: 10px;
  transition: background 0.15s ease, box-shadow 0.15s ease;
}

.wd-notes-drag {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.4rem;
  padding: 0.1rem 0;
  border: none;
  border-radius: 8px;
  background: transparent;
  color: var(--wd-muted2);
  cursor: grab;
  touch-action: none;
  transition: color 0.15s ease, background 0.15s ease;
}

.wd-notes-drag:hover,
.wd-notes-drag:focus-visible {
  color: var(--wd-text);
  background: color-mix(in srgb, var(--wd-text) 7%, transparent);
}

.wd-notes-drag:active {
  cursor: grabbing;
}

.wd-notes-row.wd-notes-row--dragging {
  opacity: 0.55;
}

.wd-notes-row.wd-notes-row--insert-before {
  box-shadow: inset 0 3px 0 0 var(--wd-a55);
}

.wd-notes-row.wd-notes-row--insert-after {
  box-shadow: inset 0 -3px 0 0 var(--wd-a55);
}

@media (prefers-reduced-motion: reduce) {
  .wd-notes-row {
    transition: none;
  }
}

.wd-notes-item {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  align-items: flex-start;
  gap: 0.3rem;
  padding: 0.38rem 0.42rem;
  border-radius: 10px;
  border: 1px solid transparent;
  background: color-mix(in srgb, var(--wd-text) 3.5%, transparent);
  text-align: left;
  color: inherit;
  cursor: pointer;
  transition: background 0.22s var(--wd-ease-out), border-color 0.22s var(--wd-ease-out), transform var(--wd-ui-dur-sm) var(--wd-ui-ease);
}

.wd-notes-item:hover {
  background: color-mix(in srgb, var(--wd-text) 7%, transparent);
}

.wd-notes-item.wd-notes-item--active {
  border-color: var(--wd-a45);
  background: var(--wd-a15);
  box-shadow: inset 0 0 0 1px var(--wd-a18);
}

.wd-notes-item:focus-visible {
  outline: none;
  border-color: var(--wd-a45);
  box-shadow: 0 0 0 2px var(--wd-a18);
}

.wd-notes-item.wd-notes-item--active:focus-visible {
  box-shadow: inset 0 0 0 1px var(--wd-a15), 0 0 0 2px var(--wd-a22);
}

.wd-notes-item-main {
  flex: 1 1 auto;
  min-width: 0;
}

.wd-notes-item-title {
  font-size: 0.84rem;
  font-weight: 500;
  line-height: 1.3;
  color: var(--wd-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.wd-notes-item.wd-notes-item--active .wd-notes-item-title {
  font-weight: 600;
}

.wd-notes-item-preview {
  font-size: 0.7rem;
  color: var(--wd-muted);
  line-height: 1.28;
  margin-top: 0.08rem;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.wd-notes-item-meta {
  font-size: 0.6rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--wd-muted2);
  margin-top: 0.18rem;
}

.wd-notes-row-actions {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.08rem;
  padding: 0.12rem 0 0.12rem 0.06rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--wd-ui-dur-sm) var(--wd-ui-ease);
}

.wd-notes-row:hover .wd-notes-row-actions,
.wd-notes-row:focus-within .wd-notes-row-actions {
  opacity: 1;
  pointer-events: auto;
}

.wd-notes-item-pin,
.wd-notes-item-del {
  flex-shrink: 0;
  opacity: 0.75;
  padding: 0.16rem;
  border: none;
  border-radius: 8px;
  background: transparent;
  color: var(--wd-muted);
  cursor: pointer;
  transition: opacity 0.15s ease, background 0.15s ease, color 0.15s ease;
}

.wd-notes-item-pin:hover,
.wd-notes-item-pin:focus-visible {
  opacity: 1;
  background: var(--wd-a11);
  color: var(--wd-accent);
}

.wd-notes-item-pin.wd-notes-item-pin--on {
  opacity: 1;
  color: var(--wd-accent);
}

.wd-notes-item:hover .wd-notes-item-del,
.wd-notes-item-del:focus-visible {
  opacity: 1;
}

.wd-notes-item-del:hover {
  background: rgba(255, 80, 80, 0.15);
  color: #ffb4b4;
}

@media (hover: none) and (pointer: coarse) {
  .wd-notes-row-actions {
    opacity: 1;
    pointer-events: auto;
  }
}

.wd-notes-body,
.wd-calendar-body {
  position: relative;
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
  border-radius: calc(var(--wd-radius) + 4px);
  padding: var(--wd-space-4) var(--wd-space-5) var(--wd-space-5);
  background: color-mix(in srgb, var(--wd-surface) 18%, transparent);
  border: 1px solid color-mix(in srgb, var(--wd-border-strong) 40%, var(--wd-border) 60%);
  -webkit-backdrop-filter: blur(18px) saturate(1.04);
  backdrop-filter: blur(18px) saturate(1.04);
  transition:
    border-color 0.35s var(--wd-ease-out),
    background 0.35s var(--wd-ease-out),
    box-shadow 0.4s var(--wd-ease-out),
    -webkit-backdrop-filter 0.35s var(--wd-ease-out),
    backdrop-filter 0.35s var(--wd-ease-out),
    padding var(--wd-split-layout-dur) var(--wd-split-layout-ease);
}

/* Single column: readable glass (hero was over-blurred at 12% + 18px); toolbar lives inside this sheet */
.wd-notes-shell:not(.wd-notes--split) .wd-notes-body {
  /* max-width: var(--wd-notes-measure); */
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  padding: var(--wd-space-5) var(--wd-space-6) 0 var(--wd-space-6);
  background: color-mix(in srgb, var(--wd-surface) 32%, transparent);
  border-color: color-mix(in srgb, var(--wd-border-strong) 32%, var(--wd-border) 68%);
  -webkit-backdrop-filter: blur(8px) saturate(1.05);
  backdrop-filter: blur(8px) saturate(1.05);
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, var(--wd-text) 4%, transparent),
    0 12px 44px color-mix(in srgb, #000 21%, transparent);
}

@media (max-width: 720px) {
  .wd-notes-shell:not(.wd-notes--split) .wd-notes-body {
    max-width: min(var(--wd-notes-measure), calc(100vw - 1.35rem));
  }
}

@media (max-width: 520px) {
  .wd-notes-shell:not(.wd-notes--split) .wd-notes-body {
    padding: var(--wd-space-4) var(--wd-space-4) var(--wd-space-5);
  }
}

.wd-notes-body {
  perspective: 1680px;
  perspective-origin: 50% 45%;
}

.wd-notes-surface {
  position: relative;
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-height: 0;
  border-radius: var(--wd-radius);
  overflow: hidden;
  transform: translateZ(0);
  transform-style: preserve-3d;
  min-height: 0;
  height: 100%;
  flex: 1 1 100%;
}

/* Persistent, low-noise hint that notes use Markdown (sits below editor / preview). */
.wd-notes-surface:has(> .wd-notes-md-foot) {
  --wd-notes-md-foot-h: 1.68rem;
}

.wd-notes-md-foot {
  flex: 0 0 auto;
  box-sizing: border-box;
  min-height: var(--wd-notes-md-foot-h, 1.68rem);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0.28rem 0.65rem 0.38rem;
  text-align: center;
  font-size: 0.62rem;
  line-height: 1.35;
  letter-spacing: 0.035em;
  font-weight: 450;
  color: color-mix(in srgb, var(--wd-muted) 76%, transparent);
  border-top: 1px solid color-mix(in srgb, var(--wd-border) 52%, transparent);
  background: color-mix(in srgb, var(--wd-surface-elevated) 38%, transparent);
  -webkit-user-select: none;
  user-select: none;
  white-space: normal;
  overflow-wrap: anywhere;
}

/* Note switch: vertical page-flip (3D rotateX + translateZ + opacity; no animated filters). */
.wd-notes-surface.wd-notes-surface--swap,
.wd-notes-surface.wd-notes-surface--swap-up,
.wd-notes-surface.wd-notes-surface--swap-down {
  overflow: visible;
  will-change: transform, opacity;
  animation-duration: var(--wd-note-switch-dur);
  animation-timing-function: var(--wd-note-flip-ease);
  animation-fill-mode: both;
}

.wd-notes-surface.wd-notes-surface--swap {
  animation-name: wd-notes-surface-swap;
  transform-origin: center top;
}

/* Next (Alt+↓): after prior page flips up, new sheet settles from below (hinge at bottom). */
.wd-notes-surface.wd-notes-surface--swap-down {
  animation-name: wd-notes-surface-swap-down;
  transform-origin: center bottom;
}

/* Previous (Alt+↑): new sheet settles from above (hinge at top). */
.wd-notes-surface.wd-notes-surface--swap-up {
  animation-name: wd-notes-surface-swap-up;
  transform-origin: center top;
}

@keyframes wd-notes-surface-swap {
  from {
    opacity: 0.9;
    transform: rotateX(-12deg) translateZ(-5px) translateY(4px);
  }

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

/* Previous note: sheet settles from above (flip downward into place) */
@keyframes wd-notes-surface-swap-up {
  from {
    opacity: 0.82;
    transform: rotateX(calc(-1 * var(--wd-note-flip-deg))) translateZ(var(--wd-note-flip-z))
      translateY(-10px);
  }

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

/* Next note: sheet rises from below (flip upward into place) */
@keyframes wd-notes-surface-swap-down {
  from {
    opacity: 0.82;
    transform: rotateX(var(--wd-note-flip-deg)) translateZ(var(--wd-note-flip-z)) translateY(10px);
  }

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

@media (prefers-reduced-motion: reduce) {
  .wd-notes-surface.wd-notes-surface--swap,
  .wd-notes-surface.wd-notes-surface--swap-up,
  .wd-notes-surface.wd-notes-surface--swap-down {
    animation: none;
    will-change: auto;
    overflow: hidden;
  }
}

.wd-notes-shell.wd-notes--split {
  --wd-editor-ratio: 50;
  --wd-split-gutter: 6px;
}

.wd-notes-shell.wd-notes--split .wd-notes-body {
  padding: var(--wd-space-2) var(--wd-space-2) var(--wd-space-3);
  background: color-mix(in srgb, var(--wd-surface) 18%, transparent);
  border-color: var(--wd-border);
  transition: padding var(--wd-split-layout-dur) var(--wd-split-layout-ease),
    background var(--wd-split-layout-dur) var(--wd-split-layout-ease);
}

/* Toolbar inside sheet: subtract chrome + safe header so split panes don’t overflow the viewport */
.wd-notes-shell.wd-notes--split .wd-notes-surface {
  display: flex;
  flex-direction: row;
  align-items: stretch;
  width: 100%;
  flex: 1 1 auto;
  min-height: min(calc(100dvh - 11rem), 56rem);
  /* max-height: min(calc(100dvh - 10.5rem), 56rem); */
  overflow: hidden;
  gap: 0;
  border-radius: var(--wd-radius);
  transition: opacity 0.32s var(--wd-ease-out);
}

/* Wide + editing: grid animates editor | gutter | preview (single column = preview column width 0) */
@media (min-width: 900px) {
  .wd-notes-shell.wd-notes--editing .wd-notes-surface {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 0 0;
    grid-template-rows: minmax(0, 1fr) auto;
    align-items: stretch;
    width: 100%;
    flex: 1 1 auto;
    min-height: min(calc(100dvh - 11rem), 56rem);
    /* max-height: min(calc(100dvh - 10.5rem), 56rem); */
    overflow: hidden;
    border-radius: var(--wd-radius);
    transition: grid-template-columns var(--wd-split-layout-dur) var(--wd-split-layout-ease);
  }

  .wd-notes-shell.wd-notes--editing .wd-notes-surface > .wd-notes-md-foot {
    grid-column: 1 / -1;
    grid-row: 2;
    align-self: stretch;
  }

  .wd-notes-shell.wd-notes--editing.wd-notes--split .wd-notes-surface {
    display: grid;
    grid-template-columns:
      minmax(min(12rem, 100%), calc((100% - var(--wd-split-gutter)) * (var(--wd-editor-ratio) / 100))) var(--wd-split-gutter)
      minmax(0, 1fr);
    flex-direction: unset;
  }

  .wd-notes-shell.wd-notes--reading:not(.wd-notes--split) .wd-notes-surface {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    grid-template-columns: none;
    transition: none;
    min-height: 0;
    max-height: none;
  }
}

.wd-notes-shell.wd-notes--split .wd-notes-split-gutter {
  flex: 0 0 var(--wd-split-gutter);
  width: var(--wd-split-gutter);
  min-width: var(--wd-split-gutter);
  align-self: stretch;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 999px;
  background: linear-gradient(
    180deg,
    transparent 6%,
    color-mix(in srgb, var(--wd-text) 9%, transparent) 50%,
    transparent 94%
  );
  cursor: col-resize;
  touch-action: none;
  opacity: 0.85;
  transition:
    opacity var(--wd-split-layout-dur) var(--wd-split-layout-ease),
    background var(--wd-ui-dur-sm) var(--wd-ui-ease);
}

.wd-notes-shell.wd-notes--split .wd-notes-split-gutter:hover,
.wd-notes-shell.wd-notes--split .wd-notes-split-gutter.wd-notes-split-gutter--dragging {
  opacity: 1;
  background: linear-gradient(
    180deg,
    transparent 4%,
    var(--wd-a35) 50%,
    transparent 96%
  );
}

.wd-notes-shell:not(.wd-notes--split) .wd-notes-split-gutter {
  display: none;
}

@media (min-width: 900px) {
  .wd-notes-shell.wd-notes--editing:not(.wd-notes--split) .wd-notes-split-gutter {
    display: block;
    width: 0;
    min-width: 0;
    margin: 0;
    padding: 0;
    opacity: 0;
    pointer-events: none;
    overflow: hidden;
    cursor: default;
    transition:
      opacity var(--wd-split-layout-dur) var(--wd-split-layout-ease),
      min-width var(--wd-split-layout-dur) var(--wd-split-layout-ease);
  }
}

@media (max-width: 899px) {
  .wd-notes-shell.wd-notes--split .wd-notes-surface {
    flex-direction: column;
    min-height: min(52vh, 28rem);
    max-height: none;
  }

  .wd-notes-shell.wd-notes--split .wd-notes-split-gutter {
    display: none;
  }

  .wd-notes-shell.wd-notes--split .wd-notes-editor {
    flex: 1 1 auto !important;
    max-width: none !important;
    width: 100% !important;
    min-height: min(40vh, 22rem) !important;
  }

  .wd-notes-shell.wd-notes--split .wd-notes-preview {
    flex: 1 1 auto !important;
    min-height: min(40vh, 22rem) !important;
    border-left: none !important;
    border-top: 1px solid var(--wd-notes-preview-pane-edge);
    margin-top: var(--wd-space-2);
    padding-top: var(--wd-space-3);
    background: var(--wd-notes-preview-pane-bg);
    color: var(--wd-notes-preview-prose);
    border-radius: 0 0 var(--wd-radius-sm) var(--wd-radius-sm);
    box-shadow: inset 0 1px 0 color-mix(in srgb, var(--wd-text) 4%, transparent);
  }
}

.wd-notes-shell.wd-notes--split .wd-notes-editor {
  flex: 0 0 calc((100% - var(--wd-split-gutter)) * (var(--wd-editor-ratio) / 100));
  max-width: calc((100% - var(--wd-split-gutter)) * (var(--wd-editor-ratio) / 100));
  min-width: min(12rem, 100%);
  position: relative !important;
  width: auto !important;
  height: auto !important;
  min-height: 0 !important;
  padding: 0.65rem 0.85rem 1rem !important;
  margin: 0 !important;
  overflow: auto !important;
  clip: auto !important;
  white-space: pre-wrap !important;
  align-self: stretch;
  background: var(--wd-notes-editor-pane-bg);
  border-radius: 10px 0 0 10px;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--wd-border-strong) 35%, var(--wd-border) 65%);
  transition: flex-basis 0.1s ease, max-width 0.1s ease;
}

.wd-notes-shell.wd-notes--split .wd-notes-editor-highlight {
  border-radius: 10px 0 0 10px;
}

@media (min-width: 900px) {
  .wd-notes-shell.wd-notes--editing.wd-notes--split .wd-notes-editor {
    flex: none;
    max-width: none;
    width: 100%;
    min-width: 0;
    transition: none;
  }

  .wd-notes-shell.wd-notes--editing.wd-notes--split .wd-notes-preview {
    flex: none;
    width: 100%;
    min-width: 0;
  }
}

.wd-notes-shell.wd-notes--split-drag .wd-notes-surface {
  transition: none !important;
}

.wd-notes-shell.wd-notes--split-drag .wd-notes-editor {
  transition: none;
}

.wd-notes-shell.wd-notes--split .wd-notes-preview {
  flex: 1 1 auto;
  min-width: 0;
  min-height: 0 !important;
  border-radius: 0 10px 10px 0;
  padding: 0.7rem 0.95rem 1.05rem;
  margin: 0;
  overflow-y: auto !important;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  background: var(--wd-notes-preview-pane-bg);
  color: var(--wd-notes-preview-prose);
  border-left: 1px solid var(--wd-notes-preview-pane-edge);
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, var(--wd-text) 5%, transparent),
    inset 0 0 0 1px color-mix(in srgb, var(--wd-border) 88%, transparent);
  -webkit-font-smoothing: antialiased;
}

.wd-notes-shell.wd-notes--split.wd-notes--editing .wd-notes-preview {
  display: block !important;
}

@media (prefers-reduced-motion: reduce) {
  .wd-notes-shell.wd-notes--split .wd-notes-body,
  .wd-notes-shell.wd-notes--split .wd-notes-surface,
  .wd-notes-shell.wd-notes--split .wd-notes-editor {
    transition: none;
  }

  @media (min-width: 900px) {
    .wd-notes-shell.wd-notes--editing .wd-notes-surface {
      transition: none !important;
    }

    .wd-notes-shell.wd-notes--editing:not(.wd-notes--split) .wd-notes-preview {
      transition: none !important;
      transform: none !important;
    }
  }
}

.wd-notes-editor {
  flex: 1 1 auto;
  min-height: 0;
  height: 100%;
  width: 100%;
  margin: 0;
  padding: 0.65rem 0.82rem 1rem;
  resize: none;
  border: none;
  outline: none;
  box-shadow: none;
  background: transparent;
  color: var(--wd-text);
  font-family: var(--wd-font);
  font-size: 1.0625rem;
  line-height: 1.7;
  caret-color: var(--wd-accent);
  position: relative;
  z-index: 2;
  color: transparent;
  -webkit-text-fill-color: transparent;
}

/* Comfortable measure: doc column caps width; editor fills the column */
.wd-notes-shell:not(.wd-notes--split) .wd-notes-editor {
  max-width: none;
  margin-left: 0;
  margin-right: 0;
}

/* Reading / preview-only: textarea is aria-hidden — remove it from layout so preview fills the surface */
.wd-notes-shell.wd-notes--reading:not(.wd-notes--split) .wd-notes-editor {
  display: none;
}

.wd-notes-editor::placeholder {
  color: var(--wd-muted2);
  -webkit-text-fill-color: var(--wd-muted2);
  opacity: 0.85;
}

.wd-notes-editor-highlight {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 0;
  height: 0;
  margin: 0;
  padding: 0.65rem 0.82rem 1rem;
  white-space: pre-wrap;
  word-break: break-word;
  overflow: hidden;
  border: none;
  background: transparent;
  color: var(--wd-text);
  font-family: var(--wd-font);
  font-size: 1.0625rem;
  line-height: 1.7;
  pointer-events: none;
}

.wd-notes-shell:not(.wd-notes--split) .wd-notes-editor-highlight {
  max-width: none;
}

.wd-notes-shell.wd-notes--reading:not(.wd-notes--split) .wd-notes-editor-highlight {
  display: none;
}

.wd-notes-shell.wd-notes--editing:not(.wd-notes--split) .wd-notes-preview {
  display: none;
}

@media (min-width: 900px) {
  /* Zero-width grid track: no min-height / measure so the row height stays editor-driven */
  .wd-notes-shell.wd-notes--editing:not(.wd-notes--split) .wd-notes-preview {
    display: block;
    min-width: 0;
    min-height: 0 !important;
    max-width: none !important;
    width: 100%;
    height: 100%;
    max-height: 100%;
    margin-left: 0 !important;
    margin-right: 0 !important;
    overflow: hidden;
    opacity: 0;
    pointer-events: none;
    transform: translateX(8px);
    transition:
      opacity var(--wd-split-layout-dur) var(--wd-split-layout-ease),
      transform var(--wd-split-layout-dur) var(--wd-split-layout-ease);
  }

  .wd-notes-shell.wd-notes--editing.wd-notes--split .wd-notes-preview {
    opacity: 1;
    pointer-events: auto;
    transform: translateX(0);
    min-height: 0 !important;
    height: 100%;
    max-height: none;
  }
}

.wd-notes-shell.wd-notes--reading .wd-notes-preview {
  display: block;
}

/* Reading-only: same “rendered page” surface as split preview; flex fills space under toolbar */
.wd-notes-shell.wd-notes--reading:not(.wd-notes--split) .wd-notes-preview {
  flex: 1 1 auto;
  min-height: 0;
  width: 100%;
  /* max-width: 65ch; */
  margin-left: auto;
  margin-right: auto;
  border-radius: var(--wd-radius-sm);
  padding: 0.65rem 0.5rem 1.35rem;
  background: var(--wd-notes-preview-pane-bg);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--wd-border) 88%, transparent);
}

.wd-notes-preview {
  flex: 1 1 auto;
  box-sizing: border-box;
  min-height: 0;
  height: 100%;
  padding: 0.5rem 0.15rem 1.25rem;
  overflow-x: hidden;
  overflow-y: auto;
  overflow-wrap: break-word;
  word-wrap: break-word;
  -webkit-overflow-scrolling: touch;
  font-size: 1.045rem;
  line-height: 1.72;
  letter-spacing: 0.012em;
  color: var(--wd-notes-preview-prose);
  outline: none;
  cursor: text;
  -webkit-font-smoothing: antialiased;
}

/* Cleaner title + controls composition on compact widths */
@media (max-width: 900px) {
  .wd-notes-doc-column {
    gap: 0.55rem;
  }

  .wd-notes-doc-column .wd-notes-chrome {
    padding-left: 0;
    padding-right: 0;
    border-bottom-style: solid;
  }
}

.wd-notes-preview:focus-visible {
  box-shadow: inset 0 0 0 1px var(--wd-a25);
  border-radius: 8px;
}

/* Lightweight markdown preview */
.wd-md .wd-md-h {
  font-weight: 600;
  margin: 0 0 0.65rem;
  line-height: 1.25;
  letter-spacing: -0.02em;
}

.wd-md h1.wd-md-h {
  font-size: 1.65rem;
}

.wd-md h2.wd-md-h {
  font-size: 1.35rem;
}

.wd-md h3.wd-md-h {
  font-size: 1.15rem;
}

.wd-md .wd-md-p {
  margin: 0 0 0.75rem;
}

.wd-md .wd-md-ul {
  margin: 0 0 0.85rem 1.1rem;
  padding: 0;
  list-style: disc;
}

.wd-md .wd-md-ul li {
  margin-bottom: 0.35rem;
}

.wd-md .wd-md-quote {
  margin: 0 0 0.85rem;
  padding: 0.5rem 0 0.5rem 1rem;
  border-left: 3px solid var(--wd-a45);
  color: var(--wd-muted);
}

.wd-md em {
  font-style: italic;
  color: var(--wd-text);
  opacity: 0.92;
}

.wd-md .wd-md-code {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 0.92em;
  padding: 0.12em 0.38em;
  border-radius: 6px;
  background: color-mix(in srgb, var(--wd-text) 8%, transparent);
  border: 1px solid color-mix(in srgb, var(--wd-border) 88%, transparent);
  color: var(--wd-text);
}

.wd-md .wd-md-break {
  height: 0.5rem;
  margin: 0;
}

.wd-md-editor .wd-md-syntax-h {
  color: color-mix(in srgb, var(--wd-accent-2) 72%, var(--wd-text) 28%);
  font-weight: 650;
}

.wd-md-editor .wd-md-syntax-list,
.wd-md-editor .wd-md-syntax-quote {
  color: color-mix(in srgb, var(--wd-accent) 60%, var(--wd-text) 40%);
}

.wd-md-editor .wd-md-syntax-strong {
  color: var(--wd-text);
  font-weight: 700;
}

.wd-md-editor .wd-md-syntax-em {
  color: color-mix(in srgb, var(--wd-accent-2) 55%, var(--wd-text) 45%);
  font-style: italic;
}

.wd-md-editor .wd-md-syntax-code {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  color: color-mix(in srgb, var(--wd-accent) 54%, var(--wd-text) 46%);
}

.wd-md-editor .wd-md-syntax-link {
  color: color-mix(in srgb, var(--wd-accent) 78%, var(--wd-text) 22%);
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* [wd-highlight] highlight.js — editor overlay (Note + Calendar); scoped tokens, minimal noise */
.wd-md-editor .hljs {
  color: var(--wd-text);
  background: transparent;
}

.wd-md-editor .hljs-section {
  color: color-mix(in srgb, var(--wd-accent-2) 70%, var(--wd-text) 30%);
  font-weight: 650;
}

.wd-md-editor .hljs-strong {
  color: var(--wd-text);
  font-weight: 700;
}

.wd-md-editor .hljs-emphasis {
  color: color-mix(in srgb, var(--wd-accent-2) 55%, var(--wd-text) 45%);
  font-style: italic;
}

.wd-md-editor .hljs-code {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 0.94em;
  color: color-mix(in srgb, var(--wd-accent) 52%, var(--wd-text) 48%);
}

.wd-md-editor .hljs-link {
  color: color-mix(in srgb, var(--wd-accent) 78%, var(--wd-text) 22%);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.wd-md-editor .hljs-bullet,
.wd-md-editor .hljs-meta {
  color: color-mix(in srgb, var(--wd-accent) 58%, var(--wd-text) 42%);
}

.wd-md-editor .hljs-quote {
  color: color-mix(in srgb, var(--wd-accent) 52%, var(--wd-muted) 48%);
  font-style: italic;
}

.wd-md-editor .hljs-string,
.wd-md-editor .hljs-section .hljs-string {
  color: color-mix(in srgb, var(--wd-accent-2) 62%, var(--wd-text) 38%);
}

.wd-md-editor .hljs-keyword,
.wd-md-editor .hljs-selector-tag,
.wd-md-editor .hljs-built_in {
  color: color-mix(in srgb, var(--wd-accent) 68%, var(--wd-text) 32%);
  font-weight: 600;
}

.wd-md-editor .hljs-title {
  color: color-mix(in srgb, var(--wd-text) 86%, var(--wd-accent) 14%);
  font-weight: 600;
}

.wd-md-editor .hljs-number,
.wd-md-editor .hljs-literal {
  color: color-mix(in srgb, var(--wd-accent-2) 58%, var(--wd-muted) 42%);
}

.wd-md-editor .hljs-comment,
.wd-md-editor .hljs-doctag {
  color: var(--wd-muted);
  font-style: italic;
}

.wd-md-editor .hljs-attr,
.wd-md-editor .hljs-attribute,
.wd-md-editor .hljs-name,
.wd-md-editor .hljs-tag {
  color: color-mix(in srgb, var(--wd-accent) 55%, var(--wd-text) 45%);
}

.wd-md-editor .hljs-function {
  color: color-mix(in srgb, var(--wd-text) 88%, var(--wd-accent) 12%);
}

.wd-md-editor .hljs-variable,
.wd-md-editor .hljs-template-variable {
  color: color-mix(in srgb, var(--wd-text) 82%, var(--wd-accent-2) 18%);
}

.wd-md-editor .hljs-regexp,
.wd-md-editor .hljs-symbol {
  color: color-mix(in srgb, var(--wd-accent-2) 64%, var(--wd-text) 36%);
}

.wd-md-editor .hljs-subst {
  color: var(--wd-muted);
}

.wd-md-editor .wd-md-hl-fence {
  display: block;
  margin: 0.38rem 0 0.55rem;
  padding: 0.42rem 0 0.48rem 0.55rem;
  border-left: 3px solid color-mix(in srgb, var(--wd-border-strong) 42%, var(--wd-accent) 58%);
  border-radius: 0 8px 8px 0;
  background: color-mix(in srgb, var(--wd-text) 4.5%, transparent);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--wd-border) 75%, transparent);
}

.wd-md-editor .wd-md-hl-fence-edge {
  color: var(--wd-muted);
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 0.9em;
  letter-spacing: 0.02em;
}

.wd-md-editor .wd-md-hl-fence-body {
  display: block;
  margin: 0.12rem 0 0;
  padding: 0;
  line-height: 1.62;
  white-space: pre-wrap;
  word-break: break-word;
}

.wd-md-indicator {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  width: fit-content;
  padding: 0.28rem 0.55rem;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--wd-border-strong) 55%, transparent);
  background: color-mix(in srgb, var(--wd-text) 5.8%, transparent);
  color: var(--wd-muted);
  font-size: 0.72rem;
  letter-spacing: 0.04em;
}

.wd-md-empty {
  margin: 2.5rem auto 1.5rem;
  max-width: 16rem;
  text-align: center;
  color: var(--wd-muted2);
  font-size: 0.98rem;
  line-height: 1.5;
  letter-spacing: 0.02em;
}

/* [wd-cal-year] Year calendar — full-width wall: 1 → 2 → 3 → 4 columns */
.wd-year-grid {
  display: grid;
  width: 100%;
  grid-template-columns: minmax(0, 1fr);
  gap: clamp(0.45rem, 1.1vw, 0.85rem);
}

@media (min-width: 560px) {
  .wd-year-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 880px) {
  .wd-year-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (min-width: 1200px) {
  .wd-year-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

.wd-month-title {
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--wd-muted);
  margin-bottom: 0.35rem;
  text-align: center;
}

.wd-mode--calendar .wd-month {
  border-radius: var(--wd-radius-sm);
  border: 1px solid var(--wd-cal-month-border);
  background: var(--wd-cal-month-surface);
  padding: var(--wd-space-3) var(--wd-space-2) var(--wd-space-3);
}

.wd-mode--calendar .wd-month-title {
  font-size: clamp(0.62rem, 1.1vw, 0.72rem);
  letter-spacing: 0.16em;
  margin-bottom: clamp(0.28rem, 0.8vw, 0.4rem);
}

.wd-dow {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: clamp(1px, 0.35vw, 3px);
  font-size: clamp(0.54rem, 1vw, 0.65rem);
  font-weight: 600;
  letter-spacing: 0.05em;
  color: var(--wd-muted);
  text-align: center;
  margin-bottom: var(--wd-space-2);
}

.wd-dow > div {
  padding: 0.1rem 0;
  border-radius: 5px;
}

.wd-mode--calendar .wd-dow > div.wd-cal-col--sun {
  background: var(--wd-cal-weekend-sun-cell);
  color: color-mix(in srgb, var(--wd-muted) 78%, var(--wd-cal-cell-fg) 22%);
}

.wd-mode--calendar .wd-dow > div.wd-cal-col--sat {
  background: var(--wd-cal-weekend-sat-cell);
  color: color-mix(in srgb, var(--wd-muted) 78%, var(--wd-cal-cell-fg) 22%);
}

.wd-days {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: clamp(1px, 0.35vw, 3px);
}

.wd-day {
  position: relative;
  border: none;
  border-radius: 6px;
  padding: 0;
  height: 22px;
  font-size: 0.62rem;
  line-height: 22px;
  text-align: center;
  color: var(--wd-cal-cell-fg);
  background: var(--wd-cal-cell);
  transition:
    background var(--wd-dur-fast) var(--wd-ease-out),
    transform var(--wd-dur-fast) var(--wd-ease-out),
    box-shadow var(--wd-dur-fast) var(--wd-ease-out);
}

.wd-mode--calendar .wd-day {
  height: clamp(22px, 3.5vw, 30px);
  min-height: 22px;
  font-size: clamp(0.58rem, 1vw, 0.68rem);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  line-height: 1;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--wd-cal-cell);
}

.wd-mode--calendar .wd-day.wd-cal-col--sun:not(.muted) {
  background: var(--wd-cal-weekend-sun-cell);
}

.wd-mode--calendar .wd-day.wd-cal-col--sat:not(.muted) {
  background: var(--wd-cal-weekend-sat-cell);
}

.wd-day.muted {
  color: var(--wd-cal-pad-muted);
  background: transparent;
  pointer-events: none;
}

.wd-day.muted.wd-cal-col--sun {
  background: var(--wd-cal-weekend-sun-pad);
}

.wd-day.muted.wd-cal-col--sat {
  background: var(--wd-cal-weekend-sat-pad);
}

.wd-day:not(.muted):hover {
  background: var(--wd-cal-cell-hover);
}

.wd-day:not(.muted).wd-cal-col--sun:hover {
  background: var(--wd-cal-weekend-sun-hover);
}

.wd-day:not(.muted).wd-cal-col--sat:hover {
  background: var(--wd-cal-weekend-sat-hover);
}

.wd-day:not(.muted):focus-visible {
  outline: none;
  box-shadow: var(--wd-focus-ring);
  z-index: 1;
}

.wd-day:not(.muted):active {
  transform: scale(0.97);
}

@media (prefers-reduced-motion: reduce) {
  .wd-day:not(.muted):active {
    transform: none;
  }
}

.wd-day.today {
  outline: 2px solid var(--wd-a45);
  outline-offset: 0;
  background: var(--wd-a18);
  color: var(--wd-text);
  font-weight: 600;
  z-index: 1;
}

.wd-mode--calendar .wd-day.today:not(.muted) {
  background: var(--wd-a18);
}

.wd-day .wd-day-marks {
  position: absolute;
  bottom: 2px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2px;
  pointer-events: none;
}

.wd-day .wd-dot {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  opacity: 0.95;
  flex-shrink: 0;
}

.wd-day .wd-dot--note {
  width: 3px;
  height: 3px;
  background: var(--wd-cal-note-dot);
  box-shadow: 0 0 0 1px var(--wd-cal-note-dot-ring);
}

.wd-calendar-peek {
  position: fixed;
  z-index: 1085;
  max-width: min(18rem, calc(100vw - 1rem));
  min-width: min(12.5rem, calc(100vw - 1rem));
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, var(--wd-border-strong) 55%, var(--wd-border) 45%);
  background: color-mix(in srgb, var(--wd-surface) 92%, var(--wd-bg) 8%);
  color: var(--wd-text);
  padding: 0.5rem 0.58rem;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.22);
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  pointer-events: none;
  opacity: 0;
  transform: translateY(4px) scale(0.98);
  transition:
    opacity var(--wd-dur-fast) var(--wd-ease-out),
    transform var(--wd-dur-fast) var(--wd-ease-out);
}

.wd-calendar-peek.is-open {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.wd-calendar-peek--bottom {
  transform-origin: top center;
}

.wd-calendar-peek:not(.wd-calendar-peek--bottom) {
  transform-origin: bottom center;
}

.wd-calendar-peek__date {
  margin: 0 0 0.35rem;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--wd-muted);
}

.wd-calendar-peek__list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.35rem;
}

.wd-calendar-peek__item {
  margin: 0;
}

.wd-calendar-peek__title {
  font-size: 0.79rem;
  font-weight: 600;
  line-height: 1.25;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.wd-calendar-peek__preview {
  margin-top: 0.1rem;
  font-size: 0.72rem;
  line-height: 1.32;
  color: var(--wd-muted2);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.wd-calendar-peek__more {
  margin-top: 0.06rem;
  font-size: 0.72rem;
  color: var(--wd-muted2);
}

.wd-calendar-peek__empty {
  display: none;
  margin: 0;
  font-size: 0.78rem;
  color: var(--wd-muted2);
}

.wd-calendar-peek__hint {
  display: none;
  margin: 0.42rem 0 0;
  font-size: 0.68rem;
  color: var(--wd-muted2);
}

.wd-calendar-peek--empty .wd-calendar-peek__list {
  display: none;
}

.wd-calendar-peek--empty .wd-calendar-peek__empty {
  display: block;
}

.wd-calendar-peek--touch .wd-calendar-peek__hint {
  display: block;
}

@media (prefers-reduced-motion: reduce) {
  .wd-calendar-peek {
    transition: none;
  }
}

.wd-day-note-actions {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  flex-wrap: wrap;
}

.wd-day-link-select {
  max-width: 12rem;
  font-size: 0.8125rem;
  border-radius: var(--wd-radius-sm) !important;
  background: color-mix(in srgb, var(--wd-text) 5%, transparent) !important;
  border: 1px solid color-mix(in srgb, var(--wd-border-strong) 35%, var(--wd-border) 65%) !important;
  color: var(--wd-text) !important;
}

.wd-day-link-select:focus {
  border-color: var(--wd-a40) !important;
  box-shadow: var(--wd-focus-ring) !important;
}

.wd-day-section-hd {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--wd-muted);
  margin-bottom: var(--wd-space-2);
}

.wd-day-section-hd i {
  font-size: 1rem;
  opacity: 0.88;
  color: var(--wd-muted);
}

.wd-day-panel__body .wd-day-note-list .wd-day-note-row.wd-day-entry-card {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.55rem 0.5rem;
  margin: 0.35rem 0;
  border: 1px solid color-mix(in srgb, var(--wd-border) 75%, transparent);
  border-radius: var(--wd-radius-sm);
  background: color-mix(in srgb, var(--wd-text) 3.5%, transparent);
}

.wd-day-panel__body .wd-day-note-list .wd-day-note-row.wd-day-entry-card:last-child {
  margin-bottom: 0;
}

.wd-day-note-row__actions {
  display: flex;
  align-items: flex-start;
  gap: 0.15rem;
  opacity: 0.72;
  transition: opacity var(--wd-ui-dur-sm-tight) var(--wd-ui-ease);
}

.wd-day-entry-card:hover .wd-day-note-row__actions,
.wd-day-entry-card:focus-within .wd-day-note-row__actions {
  opacity: 1;
}

.wd-day-note-open {
  display: block;
  width: 100%;
  padding: 0.12rem 0;
  margin: 0;
  border: none;
  background: none;
  font: inherit;
  text-align: inherit;
  cursor: pointer;
  font-size: 0.9375rem;
  font-weight: 600;
  line-height: 1.4;
  color: var(--wd-text);
  transition: color var(--wd-ui-dur-sm-tight) var(--wd-ui-ease);
}

.wd-day-note-open:hover {
  color: var(--wd-accent);
  opacity: 1;
}

.wd-day-note-open:focus-visible {
  outline: none;
  border-radius: 4px;
  box-shadow: 0 0 0 2px var(--wd-a35);
}

.wd-day-note-empty {
  margin: 0;
  padding: 0.15rem 0;
  font-size: 0.8125rem;
  color: var(--wd-muted);
  letter-spacing: 0.01em;
}

/* [wd-auth] ——— Auth modal (login / sign up) ——— */
body.modal-open .modal-backdrop {
  background: var(--wd-modal-backdrop);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
}

.wd-auth-modal.modal.fade .modal-dialog {
  transition:
    transform 0.28s var(--wd-ease-out),
    opacity 0.28s var(--wd-ease-out);
  transform: translateY(10px) scale(0.98);
  opacity: 0;
}

.wd-auth-modal.modal.show .modal-dialog {
  transform: translateY(0) scale(1);
  opacity: 1;
}

.wd-auth-dialog {
  width: 420px;
  max-width: min(420px, calc(100vw - 2rem));
  margin-left: auto;
  margin-right: auto;
}

@media (max-width: 575.98px) {
  .wd-auth-dialog {
    width: 100%;
    max-width: none;
    margin: 0;
    min-height: 100%;
  }

  .wd-auth-modal .modal-content.wd-auth-card {
    min-height: 100dvh;
    max-height: none;
    border-radius: 0;
  }
}

.wd-auth-card {
  display: flex;
  flex-direction: column;
  max-height: min(90vh, 640px);
  border-radius: var(--wd-radius-lg);
  background: rgba(14, 16, 22, 0.58);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.45);
  color: var(--wd-text);
  transition: box-shadow 0.35s var(--wd-ease-out);
}

.wd-auth-card--success {
  box-shadow:
    0 24px 64px rgba(0, 0, 0, 0.45),
    0 0 0 1px var(--wd-a45),
    0 0 40px var(--wd-a18);
}

.wd-auth-header {
  flex-shrink: 0;
  padding: 1.35rem 1.5rem 0.35rem;
  align-items: flex-start;
}

.wd-auth-brand {
  flex: 1;
  min-width: 0;
  padding-right: 0.35rem;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.5rem;
}

.wd-auth-product {
  flex-shrink: 0;
}

/* [wd-brand] WilsonDesk logotype: mark + wordmark (Inter), aligns with wd-tokens gold accent */
.wd-brand {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
}

.wd-brand-name {
  font-family: var(--wd-font);
  font-weight: 600;
  letter-spacing: -0.03em;
  color: var(--wd-text);
  font-size: 1.0625rem;
  line-height: 1.2;
}

.wd-brand--compact .wd-brand-mark-svg {
  width: 26px;
  height: 26px;
}

.wd-brand--compact .wd-brand-name {
  font-size: 0.9375rem;
  font-weight: 600;
  letter-spacing: -0.025em;
}

.wd-brand--auth .wd-brand-mark-svg {
  width: 28px;
  height: 28px;
}

.wd-brand--auth .wd-brand-name {
  font-size: 1rem;
}

.wd-brand--icon-only {
  gap: 0;
}

.wd-brand--icon-only .wd-brand-name {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.wd-auth-heading {
  font-size: 1.25rem;
  font-weight: 600;
  letter-spacing: -0.02em;
  margin: 0;
  line-height: 1.25;
}

.wd-auth-sub {
  color: var(--wd-muted);
  font-size: 0.8125rem;
  line-height: 1.45;
  margin-top: 0.125rem;
  max-width: 34rem;
}

.wd-auth-close {
  opacity: 0.65;
  filter: invert(1);
  margin-top: -0.15rem;
}

.wd-auth-close:hover {
  opacity: 1;
}

.wd-auth-body {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-height: 0;
  padding: 0 1.5rem 1.35rem;
}

.wd-auth-seg {
  display: flex;
  flex-shrink: 0;
  padding: 3px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.055);
  border: 1px solid rgba(255, 255, 255, 0.065);
  gap: 3px;
  margin-bottom: 0.85rem;
}

.wd-auth-seg-btn {
  flex: 1;
  border: 0;
  border-radius: 10px;
  padding: 0.45rem 0.65rem;
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--wd-muted);
  background: transparent;
  cursor: pointer;
  transition:
    background var(--wd-dur-fast) var(--wd-ease-out),
    color var(--wd-dur-fast) var(--wd-ease-out),
    transform var(--wd-dur-fast) var(--wd-ease-out);
}

.wd-auth-seg-btn:hover {
  color: var(--wd-text);
}

.wd-auth-seg-btn.is-active {
  color: var(--wd-btn-primary-fg);
  background: var(--wd-btn-primary-bg);
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.12);
}

.wd-auth-seg-btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--wd-a45);
}

.wd-auth-stack {
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

.wd-auth-panes {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 1fr;
  flex: 1 1 auto;
  min-height: 0;
}

.wd-auth-pane {
  grid-area: 1 / 1;
  opacity: 0;
  visibility: hidden;
  transition:
    opacity 0.28s var(--wd-ease-out),
    visibility 0.28s;
  pointer-events: none;
  display: flex;
  flex-direction: column;
  min-height: 0;
  min-width: 0;
}

.wd-auth-pane.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  z-index: 1;
}

.wd-auth-form {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  gap: 0;
}

.wd-auth-scroll {
  flex: 1 1 auto;
  min-height: 0;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  padding-bottom: 0.15rem;
}

.wd-auth-actions {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding-top: 0.65rem;
}

.wd-auth-banner-slot {
  min-height: 0;
  display: flex;
  align-items: flex-start;
}

.wd-auth-banner-slot .wd-auth-banner {
  width: 100%;
}

.wd-auth-footer {
  flex-shrink: 0;
  text-align: center;
  padding-top: 1rem;
  margin-top: 0.35rem;
  border-top: 1px solid rgba(255, 255, 255, 0.065);
}

.wd-auth-inline-btn {
  background: none;
  border: none;
  padding: 0;
  font: inherit;
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--wd-accent);
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: opacity var(--wd-dur-fast) var(--wd-ease-out);
}

.wd-auth-inline-btn:hover {
  opacity: 0.88;
}

.wd-auth-inline-btn:focus-visible {
  outline: none;
  border-radius: 4px;
  box-shadow: 0 0 0 2px var(--wd-a40);
}

.wd-auth-field {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  margin: 0;
}

.wd-auth-label {
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--wd-muted2);
}

.wd-auth-input {
  width: 100%;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.05);
  color: var(--wd-text);
  padding: 0.65rem 0.85rem;
  font-size: 0.9375rem;
  transition:
    border-color var(--wd-dur-fast) var(--wd-ease-out),
    background var(--wd-dur-fast) var(--wd-ease-out),
    box-shadow var(--wd-dur-fast) var(--wd-ease-out);
}

.wd-auth-input::placeholder {
  color: rgba(255, 255, 255, 0.32);
}

.wd-auth-input:hover {
  border-color: rgba(255, 255, 255, 0.16);
  background: rgba(255, 255, 255, 0.07);
}

.wd-auth-input:focus {
  outline: none;
  border-color: var(--wd-a55);
  background: rgba(255, 255, 255, 0.08);
  box-shadow: var(--wd-focus-ring);
}

.wd-auth-field.has-error .wd-auth-input {
  border-color: rgba(232, 120, 120, 0.55);
}

.wd-auth-field-error {
  font-size: 0.75rem;
  color: rgba(232, 160, 160, 0.95);
  min-height: 1em;
}

.wd-auth-input-wrap {
  position: relative;
  display: block;
}

.wd-auth-input-wrap .wd-auth-input.has-toggle {
  padding-right: 2.75rem;
}

.wd-auth-toggle {
  position: absolute;
  right: 6px;
  top: 50%;
  transform: translateY(-50%);
  border: 0;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 8px;
  width: 2.25rem;
  height: 2.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--wd-muted);
  cursor: pointer;
  transition:
    background var(--wd-dur-fast) var(--wd-ease-out),
    color var(--wd-dur-fast) var(--wd-ease-out);
}

.wd-auth-toggle:hover {
  background: rgba(255, 255, 255, 0.1);
  color: var(--wd-text);
}

.wd-auth-toggle:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--wd-a45);
}

.wd-auth-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.wd-auth-row--split {
  justify-content: space-between;
}

.wd-auth-check {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  margin: 0;
  font-size: 0.8125rem;
  color: var(--wd-muted);
  cursor: pointer;
  -webkit-user-select: none;
  user-select: none;
}

.wd-auth-check input {
  width: 1rem;
  height: 1rem;
  accent-color: var(--wd-accent);
}

.wd-auth-link {
  border: 0;
  background: none;
  padding: 0;
  font-size: 0.8125rem;
  color: var(--wd-muted);
  text-decoration: underline;
  text-underline-offset: 2px;
  cursor: pointer;
  transition: color var(--wd-dur-fast) var(--wd-ease-out);
}

.wd-auth-link:hover {
  color: rgba(255, 255, 255, 0.78);
}

.wd-auth-strength {
  font-size: 0.6875rem;
  color: var(--wd-muted2);
  margin: -0.15rem 0 0;
  min-height: 1rem;
  line-height: 1.35;
}

.wd-auth-strength[data-tone='weak'] {
  color: rgba(232, 190, 140, 0.9);
}

.wd-auth-strength[data-tone='fair'] {
  color: rgba(200, 210, 230, 0.85);
}

.wd-auth-strength[data-tone='strong'] {
  color: rgba(160, 210, 180, 0.9);
}

.wd-auth-banner {
  font-size: 0.8125rem;
  padding: 0.5rem 0.65rem;
  border-radius: 10px;
  margin: 0;
}

.wd-auth-banner--error {
  background: rgba(180, 60, 60, 0.12);
  color: rgba(255, 190, 190, 0.95);
  border: 1px solid rgba(220, 100, 100, 0.22);
}

.wd-auth-banner--ok {
  background: rgba(60, 140, 90, 0.12);
  color: rgba(180, 235, 200, 0.95);
  border: 1px solid rgba(100, 180, 120, 0.22);
}

.wd-auth-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  width: 100%;
  border-radius: 12px;
  padding: 0.65rem 1rem;
  font-size: 0.9375rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  border: 0;
  cursor: pointer;
  transition:
    transform var(--wd-ui-dur-sm-tight) var(--wd-ui-ease),
    box-shadow var(--wd-ui-dur-sm-tight) var(--wd-ui-ease),
    opacity var(--wd-ui-dur-sm-tight) var(--wd-ui-ease);
}

.wd-auth-btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.wd-auth-btn--primary {
  color: var(--wd-btn-primary-fg);
  background: var(--wd-btn-primary-bg);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.18);
}

.wd-auth-btn--primary:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.22);
}

.wd-auth-btn--primary:active:not(:disabled) {
  transform: translateY(0);
}

.wd-auth-btn.is-loading .wd-auth-btn-label {
  opacity: 0.65;
}

.wd-auth-btn.is-loading .wd-auth-btn-spinner {
  width: 1.1rem;
  height: 1.1rem;
  border: 2px solid color-mix(in srgb, var(--wd-btn-primary-fg) 25%, transparent);
  border-top-color: var(--wd-btn-primary-fg);
  border-radius: 50%;
  animation: wd-auth-spin 0.65s linear infinite;
}

@keyframes wd-auth-spin {
  to {
    transform: rotate(360deg);
  }
}

.wd-auth-btn--google {
  background: rgba(255, 255, 255, 0.06);
  color: var(--wd-text);
  border: 1px solid rgba(255, 255, 255, 0.12);
  font-weight: 500;
}

.wd-auth-btn--google:hover:not(:disabled) {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.18);
}

.wd-auth-btn--google:disabled {
  opacity: 0.45;
}

.wd-auth-google-icon {
  flex-shrink: 0;
}

.wd-auth-oauth-wrap {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.wd-auth-oauth-hint {
  font-size: 0.75rem;
  color: var(--wd-muted2);
  line-height: 1.4;
  margin: 0 0 0.85rem;
  text-align: center;
}

.wd-auth-dev {
  margin-top: 1.25rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.wd-auth-dev-title {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--wd-muted2);
  margin: 0 0 0.65rem;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.wd-auth-dev-badge {
  font-size: 0.6rem;
  padding: 0.12rem 0.4rem;
  border-radius: 6px;
  background: rgba(255, 180, 100, 0.15);
  color: rgba(255, 200, 150, 0.95);
  letter-spacing: 0.06em;
}

.wd-auth-dev-btns {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.wd-auth-btn--dev {
  flex: 1;
  min-width: 8rem;
  background: rgba(255, 255, 255, 0.05);
  color: var(--wd-muted);
  border: 1px dashed rgba(255, 255, 255, 0.15);
  font-size: 0.8125rem;
  font-weight: 500;
}

.wd-auth-btn--dev:hover {
  color: var(--wd-text);
  background: rgba(255, 255, 255, 0.08);
}

@media (prefers-reduced-motion: reduce) {
  .wd-auth-modal.modal.fade .modal-dialog,
  .wd-auth-pane,
  .wd-auth-btn--primary {
    transition: none;
  }

  .wd-auth-btn.is-loading .wd-auth-btn-spinner {
    animation: none;
  }
}

.wd-offcanvas {
  background: color-mix(in srgb, var(--wd-surface-elevated) 92%, transparent);
  -webkit-backdrop-filter: blur(18px);
  backdrop-filter: blur(18px);
  border-right: 1px solid var(--wd-border);
  color: var(--wd-text);
}

.wd-offcanvas .btn-close {
  filter: none;
  opacity: 0.45;
}

[data-theme='dark'] .wd-offcanvas .btn-close {
  filter: invert(1);
  opacity: 0.55;
}

a.wd-offcanvas-brand {
  display: inline-flex;
  align-items: center;
  margin: 0;
  max-width: 100%;
  padding: 0.2rem 0.35rem 0.2rem 0;
  margin-left: -0.1rem;
  border-radius: var(--wd-radius-sm);
  font-size: inherit;
  font-weight: inherit;
  line-height: 1.2;
  color: var(--wd-text);
}

.wd-offcanvas-nav .nav-link,
.wd-offcanvas-nav .wd-nav-mode {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.55rem 0.35rem;
  border-radius: 12px;
  color: var(--wd-muted);
  font-size: 0.9375rem;
  font-weight: 400;
  letter-spacing: 0.02em;
  transition: background var(--wd-dur-fast) var(--wd-ease-out), color var(--wd-dur-fast) var(--wd-ease-out);
}

.wd-offcanvas-nav .wd-nav-mode {
  cursor: pointer;
}

.wd-offcanvas-nav .nav-link i,
.wd-offcanvas-nav .wd-nav-mode i {
  font-size: 1.15rem;
  opacity: 0.88;
  width: 1.35rem;
  text-align: center;
}

.wd-offcanvas-nav .nav-link:hover,
.wd-offcanvas-nav .nav-link:focus,
.wd-offcanvas-nav .wd-nav-mode:hover,
.wd-offcanvas-nav .wd-nav-mode:focus {
  color: var(--wd-text);
  background: color-mix(in srgb, var(--wd-text) 6%, transparent);
}

.wd-offcanvas-nav .nav-link:focus-visible,
.wd-offcanvas-nav .wd-nav-mode:focus-visible {
  outline: none;
  box-shadow: 0 0 0 1px var(--wd-a45);
}

/*
 * [wd-legal-pages] Desk Ledger — Privacy & Terms
 * Concept: calm “ledger” reading — charcoal field, glass sheet, gold register line,
 * numbered sections (01, 02…), comfortable measure, related docs as paired tiles.
 */
.wd-body.wd-static-doc {
  overflow-x: hidden;
  overflow-y: auto;
  background: var(--wd-bg);
}

.wd-static-doc .wd-bg {
  transform: none;
  background-image: none;
  opacity: 1;
}

.wd-static-doc .wd-overlay {
  opacity: 0.92;
}

.wd-static-doc-topbar {
  position: sticky;
  top: 0;
  z-index: 12;
  padding: calc(var(--wd-safe-top) + 0.35rem) var(--wd-pad-x) 0.65rem;
  margin-bottom: 0;
  border-bottom: 1px solid color-mix(in srgb, var(--wd-border) 80%, transparent);
  background: color-mix(in srgb, var(--wd-surface-elevated) 88%, transparent) !important;
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
}

.wd-static-doc-topbar-inner {
  max-width: 48rem;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--wd-space-4);
}

.wd-static-doc-back {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.4rem 0.55rem 0.4rem 0.2rem;
  margin-left: -0.2rem;
  border-radius: var(--wd-radius-sm);
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--wd-muted);
  text-decoration: none;
  transition:
    color var(--wd-dur-fast) var(--wd-ease-out),
    background var(--wd-dur-fast) var(--wd-ease-out);
}

.wd-static-doc-back:hover,
.wd-static-doc-back:focus {
  color: var(--wd-text);
  background: color-mix(in srgb, var(--wd-text) 6%, transparent);
}

.wd-static-doc-back:focus-visible {
  outline: none;
  box-shadow: 0 0 0 1px var(--wd-a45);
}

.wd-static-doc-wordmark {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.25rem 0.35rem;
  margin-right: -0.15rem;
  border-radius: var(--wd-radius-sm);
  text-decoration: none;
  color: var(--wd-text);
}

.wd-static-doc-main {
  position: relative;
  z-index: 2;
  max-width: 48rem;
  margin: 0 auto;
  padding: clamp(1rem, 3vw, 1.75rem) var(--wd-pad-x) calc(var(--wd-safe-bottom) + 3rem);
}

.wd-reset-sheet-narrow {
  max-width: 26rem;
}

.wd-reset-phase {
  margin-top: 0.35rem;
}

.wd-reset-form {
  margin-top: 0.5rem;
}

.wd-static-doc-sheet {
  position: relative;
  counter-reset: wd-legal-section;
  max-width: 42rem;
  margin: 0 auto;
  padding: clamp(1.35rem, 4vw, 2.25rem) clamp(1rem, 3.5vw, 2rem);
  border-radius: var(--wd-radius-xl);
  box-shadow: var(--wd-shadow-soft), 0 0 0 1px color-mix(in srgb, var(--wd-border) 65%, transparent);
}

.wd-static-doc-sheet::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  border-radius: var(--wd-radius-xl) var(--wd-radius-xl) 0 0;
  background: linear-gradient(
    90deg,
    transparent 0%,
    color-mix(in srgb, var(--wd-gold) 55%, transparent) 18%,
    var(--wd-gold-bright) 48%,
    color-mix(in srgb, var(--wd-gold) 55%, transparent) 82%,
    transparent 100%
  );
  opacity: 0.85;
  pointer-events: none;
}

.wd-static-doc-header {
  margin-bottom: clamp(1.35rem, 3vw, 2rem);
  padding-bottom: 1.35rem;
  border-bottom: 1px solid color-mix(in srgb, var(--wd-border) 90%, transparent);
}

.wd-static-doc-kicker {
  display: inline-block;
  margin: 0 0 0.65rem;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--wd-accent);
}

.wd-static-doc-hero-line {
  height: 1px;
  margin: 0 0 1rem;
  max-width: 3.5rem;
  background: linear-gradient(90deg, var(--wd-gold-bright), transparent);
  border-radius: 1px;
}

.wd-static-doc-title {
  margin: 0 0 0.5rem;
  font-size: clamp(1.5rem, 4.2vw, 1.85rem);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.15;
  color: var(--wd-text);
}

.wd-static-doc-meta {
  margin: 0 0 1rem;
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--wd-muted2);
}

.wd-static-doc-meta-label {
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.65rem;
  color: var(--wd-muted2);
  margin-right: 0.25rem;
}

.wd-static-doc-meta time {
  color: var(--wd-muted);
}

.wd-static-doc-lead {
  margin: 0;
  font-size: 0.9375rem;
  line-height: 1.65;
  color: var(--wd-muted);
  max-width: 38rem;
}

.wd-static-doc-section {
  margin-top: 1.5rem;
  padding-top: 1.35rem;
  border-top: 1px solid color-mix(in srgb, var(--wd-border) 75%, transparent);
}

.wd-static-doc-section:first-of-type {
  margin-top: 0.25rem;
  padding-top: 0;
  border-top: none;
}

.wd-static-doc-section h2 {
  margin: 0 0 0.65rem;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 0.5rem 0.75rem;
  font-size: 0.9375rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  line-height: 1.35;
  color: var(--wd-text);
}

.wd-static-doc-section h2::before {
  counter-increment: wd-legal-section;
  content: counter(wd-legal-section, decimal-leading-zero);
  flex-shrink: 0;
  margin-top: 0.12em;
  font-size: 0.7rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.08em;
  color: var(--wd-accent);
  opacity: 0.92;
}

.wd-static-doc-section p,
.wd-static-doc-section li {
  margin: 0;
  font-size: 0.875rem;
  line-height: 1.65;
  color: var(--wd-muted);
}

.wd-static-doc-section p + p {
  margin-top: 0.75rem;
}

.wd-static-doc-section ul {
  margin: 0.5rem 0 0;
  padding: 0;
  list-style: none;
}

.wd-static-doc-section li {
  position: relative;
  padding-left: 1.1rem;
}

.wd-static-doc-section li + li {
  margin-top: 0.55rem;
}

.wd-static-doc-section li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--wd-accent) 55%, var(--wd-muted2));
  opacity: 0.85;
}

.wd-static-doc-section strong {
  font-weight: 600;
  color: color-mix(in srgb, var(--wd-text) 78%, var(--wd-muted));
}

.wd-static-doc-related {
  max-width: 42rem;
  margin: 2rem auto 0;
  padding-top: 0.25rem;
}

.wd-static-doc-related-heading {
  margin: 0 0 0.85rem;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--wd-muted2);
}

.wd-legal-tiles {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.65rem;
  width: 100%;
}

.wd-legal-tiles--static {
  gap: 0.75rem;
}

.wd-legal-tile {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0.6rem;
  min-height: 4rem;
  padding: 0.75rem 0.65rem;
  border-radius: var(--wd-radius);
  border: 1px solid var(--wd-border);
  background: color-mix(in srgb, var(--wd-surface) 50%, transparent);
  text-decoration: none;
  color: var(--wd-text);
  transition:
    border-color var(--wd-dur-fast) var(--wd-ease-out),
    background var(--wd-dur-fast) var(--wd-ease-out),
    box-shadow var(--wd-dur-fast) var(--wd-ease-out);
}

a.wd-legal-tile:hover {
  border-color: color-mix(in srgb, var(--wd-accent) 32%, var(--wd-border));
  background: color-mix(in srgb, var(--wd-surface-elevated) 65%, transparent);
  box-shadow: 0 8px 28px color-mix(in srgb, #000 35%, transparent);
}

a.wd-legal-tile:focus-visible {
  outline: none;
  box-shadow: 0 0 0 1px var(--wd-a45);
}

.wd-legal-tile-icon-wrap {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.35rem;
  height: 2.35rem;
  border-radius: 11px;
  background: color-mix(in srgb, var(--wd-accent) 14%, transparent);
  color: var(--wd-accent);
  font-size: 1.05rem;
}

.wd-legal-tile-main {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.12rem;
}

.wd-legal-tile-title {
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  line-height: 1.25;
}

.wd-legal-tile-hint {
  font-size: 0.75rem;
  font-weight: 400;
  letter-spacing: 0.02em;
  line-height: 1.35;
  color: var(--wd-muted2);
}

.wd-legal-tile-go {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  color: var(--wd-muted2);
  font-size: 1rem;
  line-height: 1;
  opacity: 0.72;
  transition:
    color var(--wd-dur-fast) var(--wd-ease-out),
    opacity var(--wd-dur-fast) var(--wd-ease-out);
}

a.wd-legal-tile:hover .wd-legal-tile-go {
  color: var(--wd-accent);
  opacity: 1;
}

.wd-legal-tile--current {
  cursor: default;
  border-color: color-mix(in srgb, var(--wd-accent) 28%, var(--wd-border));
  background: color-mix(in srgb, var(--wd-accent) 8%, var(--wd-surface));
}

.wd-legal-tile--current .wd-legal-tile-hint {
  color: var(--wd-muted);
}

.wd-legal-tile-mark {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  color: var(--wd-accent);
  font-size: 1.05rem;
  line-height: 1;
  opacity: 0.95;
}

[data-theme='light'] .wd-static-doc-topbar {
  background: color-mix(in srgb, #fff 86%, transparent) !important;
  border-bottom-color: color-mix(in srgb, var(--wd-border) 100%, transparent);
}

[data-theme='light'] .wd-static-doc-sheet::before {
  opacity: 0.95;
}

[data-theme='light'] .wd-static-doc .wd-overlay {
  opacity: 0.88;
}

@media (max-width: 479.98px) {
  .wd-legal-tiles--static {
    grid-template-columns: 1fr;
  }

  .wd-static-doc-sheet {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .wd-legal-tile,
  a.wd-legal-tile {
    transition-duration: 0.01ms;
  }
}

/* [wd-modals] Modals — calmer motion, lighter chrome */
.wd-modal.modal.fade .modal-dialog {
  transition: transform var(--wd-dur-reveal) var(--wd-ease-out), opacity var(--wd-dur-reveal) var(--wd-ease-out);
}

.wd-modal-sheet {
  box-shadow: var(--wd-shadow);
}

.wd-modal-title {
  font-size: 1.125rem;
  font-weight: 500;
  letter-spacing: 0.02em;
}

.wd-modal-title--sm {
  font-size: 1rem;
}

.wd-modal-lead {
  color: var(--wd-muted);
  font-size: 0.875rem;
  font-weight: 400;
  letter-spacing: 0.02em;
  line-height: 1.45;
  margin: 0;
}

.visually-hidden.focusable:focus {
  position: static;
  width: auto;
  height: auto;
  padding: inherit;
  margin: inherit;
  overflow: visible;
  clip: auto;
  white-space: normal;
}

@media (max-width: 575.98px) {
  :root {
    --wd-bottom-hud-y: calc(max(0.5rem, env(safe-area-inset-bottom, 0px)) + 2.65rem);
  }

  .wd-dashboard-stack {
    right: max(var(--wd-pad-x), env(safe-area-inset-right, 0px));
    gap: 0.55rem;
    max-width: min(20rem, calc(100vw - 1rem));
  }

  .wd-mode--dashboard .wd-hero-wrap {
    transform: translateY(-2vh);
  }

  .wd-mode--dashboard .wd-quote {
    max-width: min(17.5rem, calc(100vw - 1rem));
  }
}

/* [wd-bg-fallback] ——— Background fallback (no image) ——— */
.wd-bg.wd-bg--fallback {
  background-image: none !important;
  background: linear-gradient(
    155deg,
    var(--wd-bg-subtle) 0%,
    var(--wd-bg) 42%,
    var(--wd-surface) 100%
  ) !important;
}

/* [wd-theme-light] ——— Light theme: component tuning ——— */
[data-theme='light'] .wd-mode-dots {
  background: color-mix(in srgb, var(--wd-surface) 75%, transparent);
  border-color: var(--wd-border);
}

[data-theme='light'] .wd-mode-dot {
  background: color-mix(in srgb, var(--wd-text) 18%, transparent);
}

[data-theme='light'] .wd-mode-dot:hover {
  background: color-mix(in srgb, var(--wd-text) 32%, transparent);
}

[data-theme='light'] .wd-mode-dot.is-active {
  background: var(--wd-accent);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--wd-accent) 40%, transparent);
}

[data-theme='light'] .wd-notes-scrim {
  background: color-mix(in srgb, var(--wd-bg) 38%, transparent);
}

[data-theme='light'] .wd-notes-panel {
  background: color-mix(in srgb, var(--wd-surface) 88%, transparent);
  border-color: var(--wd-border);
  box-shadow: var(--wd-shadow-soft), 0 0 0 1px color-mix(in srgb, var(--wd-text) 4%, transparent) inset;
}

[data-theme='light'] .wd-notes-body,
[data-theme='light'] .wd-calendar-body {
  background: color-mix(in srgb, var(--wd-surface) 64%, transparent);
  border-color: color-mix(in srgb, var(--wd-border) 88%, transparent);
}

[data-theme='light'] .wd-notes-meta {
  background: color-mix(in srgb, var(--wd-text) 2.8%, transparent);
  border-color: color-mix(in srgb, var(--wd-border) 82%, transparent);
}

[data-theme='light'] .wd-notes-shell.wd-notes--split .wd-notes-body {
  background: color-mix(in srgb, var(--wd-surface) 68%, transparent);
}

[data-theme='light'] .wd-auth-card {
  background: color-mix(in srgb, var(--wd-surface) 88%, transparent);
  border-color: var(--wd-border);
  box-shadow: var(--wd-shadow);
}

[data-theme='light'] .wd-auth-input {
  background: color-mix(in srgb, var(--wd-text) 4%, transparent);
  border-color: var(--wd-border);
  color: var(--wd-text);
}

[data-theme='light'] .wd-auth-input::placeholder {
  color: var(--wd-muted2);
}

[data-theme='light'] .wd-auth-input:hover {
  border-color: var(--wd-border-strong);
  background: color-mix(in srgb, var(--wd-text) 5%, transparent);
}

[data-theme='light'] .wd-auth-input:focus {
  background: var(--wd-surface);
}

[data-theme='light'] .wd-auth-seg {
  background: color-mix(in srgb, var(--wd-text) 5%, transparent);
  border-color: var(--wd-border);
}

[data-theme='light'] .wd-auth-seg-btn:hover {
  color: var(--wd-text);
}

[data-theme='light'] .wd-auth-close {
  filter: none;
  opacity: 0.4;
}

[data-theme='light'] .wd-auth-btn--google {
  background: color-mix(in srgb, var(--wd-text) 5%, transparent);
  border-color: var(--wd-border);
}

[data-theme='light'] .wd-auth-footer {
  border-top-color: var(--wd-border);
}

[data-theme='light'] .wd-auth-toggle {
  background: color-mix(in srgb, var(--wd-text) 6%, transparent);
  color: var(--wd-muted);
}

[data-theme='light'] .wd-auth-toggle:hover {
  background: color-mix(in srgb, var(--wd-text) 10%, transparent);
  color: var(--wd-text);
}

[data-theme='light'] .wd-input {
  background: color-mix(in srgb, var(--wd-text) 4%, transparent);
  border-color: var(--wd-border);
  color: var(--wd-text);
}

[data-theme='light'] .wd-input:focus {
  background: var(--wd-surface);
  border-color: var(--wd-a45);
}

[data-theme='light'] .wd-input::placeholder {
  color: var(--wd-muted2);
}

[data-theme='light'] .wd-glass {
  background: color-mix(in srgb, var(--wd-surface) 86%, transparent);
  border-color: var(--wd-border);
}

[data-theme='light'] .wd-account-theme-seg {
  background: color-mix(in srgb, var(--wd-surface) 92%, transparent);
  border-color: var(--wd-border);
}

[data-theme='light'] .wd-account-theme-opt:hover {
  background: color-mix(in srgb, var(--wd-text) 6%, transparent);
}

/* [wd-modals] Glass modals: default close control is for dark chrome; use theme-colored control on light */
[data-theme='light'] .wd-modal .btn-close.btn-close-white {
  filter: none;
  opacity: 0.5;
}

[data-theme='light'] .wd-modal .btn-close.btn-close-white:hover {
  opacity: 0.72;
}

[data-theme='light'] .wd-day-link-select {
  background: color-mix(in srgb, var(--wd-text) 4%, transparent) !important;
  border-color: var(--wd-border) !important;
}

[data-theme='light'] .wd-day-panel-scrim {
  background: color-mix(in srgb, var(--wd-bg) 42%, transparent);
}

@media (min-width: 560px) {
  [data-theme='light'] .wd-calendar-day-layer--open .wd-day-panel-scrim {
    background: linear-gradient(
      90deg,
      color-mix(in srgb, var(--wd-bg) 22%, transparent) 0%,
      color-mix(in srgb, var(--wd-bg) 38%, transparent) min(52vw, 42rem),
      color-mix(in srgb, var(--wd-bg) 55%, transparent) 100%
    );
  }
}

[data-theme='light'] .wd-day-panel {
  background: color-mix(in srgb, var(--wd-surface) 88%, transparent);
  border-color: var(--wd-border);
  box-shadow: var(--wd-shadow-soft), 0 0 0 1px color-mix(in srgb, var(--wd-text) 4%, transparent) inset;
}

[data-theme='light'] .wd-day-notes-rail {
  background: color-mix(in srgb, var(--wd-text) 2.25%, transparent);
  border-right-color: var(--wd-border);
}

[data-theme='light'] .wd-day-notes-rail__count-pill {
  background: color-mix(in srgb, var(--wd-accent) 12%, transparent);
  border-color: color-mix(in srgb, var(--wd-accent) 26%, var(--wd-border) 74%);
}

[data-theme='light'] .wd-day-panel__rail-scrim {
  background: color-mix(in srgb, var(--wd-bg) 52%, rgba(0, 0, 0, 0.12));
}

@media (max-width: 559.98px) {
  [data-theme='light'] .wd-day-notes-rail {
    border-bottom-color: var(--wd-border);
  }
}

[data-theme='light'] .wd-day-panel__head {
  border-bottom-color: color-mix(in srgb, var(--wd-border) 90%, transparent);
}
