/**
 * DDLA · Mystika 0.9.6
 * Canonical design tokens, component contracts and accessibility states.
 */

:root {
  /* Semantic roles: gold structures the editorial world, blue communicates action. */
  --ddla-role-structure: var(--ddla-gold);
  --ddla-role-structure-soft: var(--ddla-gold-soft);
  --ddla-role-structure-light: var(--ddla-gold-light);
  --ddla-role-action: var(--ddla-blue);
  --ddla-role-action-soft: var(--ddla-blue-soft);
  --ddla-role-action-light: var(--ddla-blue-light);

  /* Component geometry. */
  --ddla-component-cut-xs: 6px;
  --ddla-component-cut-sm: 9px;
  --ddla-component-cut-md: 14px;
  --ddla-component-cut-lg: 18px;
  --ddla-component-border: 1px;
  --ddla-component-border-strong: 1.5px;
  --ddla-component-control-sm: 36px;
  --ddla-component-control-md: 44px;
  --ddla-component-control-lg: 52px;
  --ddla-component-touch: 44px;

  /* Surfaces. */
  --ddla-component-surface: color-mix(in srgb, var(--ddla-bg-deep) 84%, transparent);
  --ddla-component-surface-strong: color-mix(in srgb, var(--ddla-bg-deep) 94%, transparent);
  --ddla-component-surface-raised: linear-gradient(145deg, rgba(var(--ddla-blue-deep-rgb), .10), transparent 52%), rgba(3, 8, 17, .84);
  --ddla-component-border-color: rgba(201, 168, 93, .32);
  --ddla-component-border-hover: rgba(var(--ddla-blue-soft-rgb), .72);
  --ddla-component-shadow: 0 16px 44px rgba(0, 0, 0, .28);
  --ddla-component-shadow-raised: 0 24px 70px rgba(0, 0, 0, .42);
  --ddla-component-glow-gold: 0 0 24px rgba(201, 168, 93, .14);
  --ddla-component-glow-blue: 0 0 26px rgba(var(--ddla-blue-rgb), .22);

  /* Typography and rhythm. */
  --ddla-component-label-size: .68rem;
  --ddla-component-meta-size: .72rem;
  --ddla-component-subtitle-size: clamp(.86rem, .8rem + .25vw, 1rem);
  --ddla-component-title-gap: .35rem;
  --ddla-component-section-gap: clamp(1rem, 1.6vw, 1.5rem);
  --ddla-component-panel-padding: clamp(1rem, 1.8vw, 1.45rem);

  /* Focus and state. */
  --ddla-focus-outline: 2px solid var(--ddla-role-action-soft);
  --ddla-focus-offset: 3px;
  --ddla-focus-shadow: 0 0 0 2px var(--ddla-bg-void), 0 0 0 4px var(--ddla-role-action-soft), 0 0 20px rgba(var(--ddla-blue-rgb), .24);
  --ddla-disabled-opacity: .45;
  --ddla-state-success: #8fd9ab;
  --ddla-state-warning: #f0c876;
  --ddla-state-danger: #ef8f8f;
  --ddla-state-info: var(--ddla-role-action-light);
}

/* -------------------------------------------------------------------------
   Baseline accessibility and input contract
   ---------------------------------------------------------------------- */
html:focus-within {
  scroll-behavior: smooth;
}

:where(a, button, input, select, textarea, summary, [tabindex]):focus {
  outline: none;
}

:where(a, button, input, select, textarea, summary, [tabindex]):focus-visible {
  outline: var(--ddla-focus-outline) !important;
  outline-offset: var(--ddla-focus-offset) !important;
  box-shadow: var(--ddla-focus-shadow) !important;
}

:where(button, input, select, textarea):disabled,
[aria-disabled="true"] {
  opacity: var(--ddla-disabled-opacity);
  cursor: not-allowed !important;
}

:where(button, [role="button"], summary) {
  -webkit-tap-highlight-color: transparent;
}

:where(input, textarea, select) {
  max-width: 100%;
  border: var(--ddla-component-border) solid var(--ddla-component-border-color);
  border-radius: 0;
  color: var(--ddla-text-main);
  background: var(--ddla-component-surface-strong);
  box-shadow: inset 0 0 0 1px transparent;
  accent-color: var(--ddla-role-action);
}

:where(input:not([type="checkbox"]):not([type="radio"]):not([type="range"]), select, textarea) {
  min-height: var(--ddla-component-control-md);
  padding: .65rem .78rem;
}

:where(input, textarea, select):hover:not(:disabled) {
  border-color: color-mix(in srgb, var(--ddla-role-structure) 58%, transparent);
}

:where(input, textarea, select):focus-visible {
  border-color: var(--ddla-component-border-hover) !important;
}

:where(input, textarea)::placeholder {
  color: color-mix(in srgb, var(--ddla-text-muted) 84%, transparent);
  opacity: 1;
}

:where(label) {
  color: var(--ddla-text-soft);
}

/* Browser/autofill normalization. */
:where(input):-webkit-autofill,
:where(input):-webkit-autofill:hover,
:where(input):-webkit-autofill:focus {
  -webkit-text-fill-color: var(--ddla-text-main);
  box-shadow: 0 0 0 1000px var(--ddla-bg-deep) inset;
  caret-color: var(--ddla-text-main);
}

/* -------------------------------------------------------------------------
   Canonical surface contract: panels, cards and elevated shells
   ---------------------------------------------------------------------- */
:where(.ddla-panel, .ddla-card, .ddla-route-card) {
  --ddla-panel-cut: var(--ddla-component-cut-md);
  --ddla-card-cut: var(--ddla-component-cut-md);
  --ddla-route-card-cut: var(--ddla-component-cut-lg);
  isolation: isolate;
}

:where(.ddla-panel__surface, .ddla-card__surface) {
  border-radius: 0;
  background-color: transparent;
}

:where(.ddla-panel__surface) {
  padding: var(--ddla-component-panel-padding);
}

:where(.ddla-panel__border-line, .ddla-card__border-line, .ddla-route-card__border-line) {
  stroke-width: var(--ddla-component-border);
}

:where(.ddla-panel, .ddla-card, .ddla-route-card):focus-within {
  filter: drop-shadow(0 0 14px rgba(var(--ddla-blue-rgb), .15));
}

:where(.ddla-panel--aureo, .ddla-card--aureo) {
  --ddla-component-accent: var(--ddla-role-structure);
  --ddla-component-accent-light: var(--ddla-role-structure-light);
}

:where(.ddla-panel--zafiro, .ddla-card--zafiro) {
  --ddla-component-accent: var(--ddla-role-action);
  --ddla-component-accent-light: var(--ddla-role-action-light);
}

/* -------------------------------------------------------------------------
   Buttons and action families
   ---------------------------------------------------------------------- */
:where(
  .ddla-button,
  .wp-block-button__link,
  .ddla-single-tool,
  .ddla-route-card__actions a,
  .ddla-route-card__actions button,
  .ddla-blog-search-popup__apply,
  .ddla-blog-search-popup__reset,
  .ddla-control-button
) {
  border-radius: 0;
  font-family: var(--ddla-font-nav);
  font-weight: 600;
  text-decoration: none;
}

:where(.ddla-single-tool, .ddla-control-button) {
  min-height: var(--ddla-component-control-md);
  border: var(--ddla-component-border) solid transparent;
  color: var(--ddla-text-soft);
  background: transparent;
}

:where(.ddla-single-tool, .ddla-control-button):hover,
:where(.ddla-single-tool, .ddla-control-button):focus-visible,
:where(.ddla-single-tool, .ddla-control-button).is-active,
:where(.ddla-single-tool, .ddla-control-button)[aria-pressed="true"] {
  border-color: var(--ddla-component-border-hover);
  color: var(--ddla-role-action-light);
  background: rgba(var(--ddla-blue-rgb), .09);
}

:where(.ddla-button, .wp-block-button__link) {
  min-height: var(--ddla-component-control-lg);
}

/* Structural/secondary actions remain gold; active/primary actions are blue. */
:where(.ddla-button--outline, .ddla-button--ghost, .ddla-route-card__open) {
  --ddla-button-accent: var(--ddla-role-structure);
  --ddla-button-accent-soft: var(--ddla-role-structure-soft);
  --ddla-button-accent-light: var(--ddla-role-structure-light);
}

:where(.ddla-button--zafiro, .ddla-button--blue, .ddla-route-card__continue, .ddla-blog-search-popup__apply) {
  --ddla-button-accent: var(--ddla-role-action);
  --ddla-button-accent-soft: var(--ddla-role-action-soft);
  --ddla-button-accent-light: var(--ddla-role-action-light);
}

/* -------------------------------------------------------------------------
   Badges, metadata and subtitles
   ---------------------------------------------------------------------- */
:where(
  .ddla-badge,
  [class$="__badge"],
  [class*="__badge "],
  .ddla-panel__tag
) {
  display: inline-flex;
  align-items: center;
  gap: .34rem;
  min-height: 26px;
  padding: .28rem .52rem;
  border: var(--ddla-component-border) solid rgba(201, 168, 93, .28);
  border-radius: 0;
  color: var(--ddla-role-structure-light);
  background: rgba(3, 8, 16, .58);
  font: 600 var(--ddla-component-label-size)/1.2 var(--ddla-font-nav);
  letter-spacing: .06em;
  text-transform: uppercase;
}

:where([aria-current="page"], [aria-current="true"], .is-active) :where([class$="__badge"], .ddla-badge),
:where([class$="__badge"], .ddla-badge).is-active {
  border-color: rgba(var(--ddla-blue-soft-rgb), .54);
  color: var(--ddla-role-action-light);
}

:where(
  .ddla-card__article-subtitle,
  .ddla-single-hero__article-subtitle,
  .ddla-single-prevnext__subtitle,
  .ddla-single-related__subtitle,
  .ddla-route-card__subtitle,
  .ddla-single-route-index__subtitle
) {
  color: var(--ddla-role-action-light);
  font-family: var(--ddla-font-title);
  font-weight: 400;
  line-height: 1.4;
}

:where(
  .ddla-single-meta,
  .ddla-route-card__meta,
  .ddla-blog-entrycard__meta,
  [class$="__meta"]
) {
  font-size: var(--ddla-component-meta-size);
}

/* -------------------------------------------------------------------------
   Notices and live messages
   ---------------------------------------------------------------------- */
:where(.ddla-notice, [role="status"], [role="alert"]) {
  --ddla-notice-accent: var(--ddla-state-info);
}

:where(.ddla-notice) {
  position: relative;
  padding: .85rem 1rem .85rem 1.15rem;
  border: var(--ddla-component-border) solid color-mix(in srgb, var(--ddla-notice-accent) 42%, transparent);
  border-left-width: 3px;
  border-radius: 0;
  color: var(--ddla-text-soft);
  background: color-mix(in srgb, var(--ddla-component-surface-strong) 92%, transparent);
}

.ddla-notice--success { --ddla-notice-accent: var(--ddla-state-success); }
.ddla-notice--warning { --ddla-notice-accent: var(--ddla-state-warning); }
.ddla-notice--danger,
.ddla-notice--error { --ddla-notice-accent: var(--ddla-state-danger); }

/* -------------------------------------------------------------------------
   Tooltips: visible on hover and keyboard focus; no information by color only
   ---------------------------------------------------------------------- */
[data-ddla-tooltip] {
  position: relative;
}

[data-ddla-tooltip]::after {
  border: var(--ddla-component-border) solid rgba(201, 168, 93, .3) !important;
  border-radius: 0 !important;
  color: var(--ddla-text-main) !important;
  background: rgba(3, 8, 16, .98) !important;
  box-shadow: var(--ddla-component-shadow) !important;
  font: 600 .68rem/1.2 var(--ddla-font-nav) !important;
  letter-spacing: .035em;
}

[data-ddla-tooltip]:focus-visible::after,
[data-ddla-tooltip]:focus-within::after {
  opacity: 1;
  visibility: visible;
}

/* -------------------------------------------------------------------------
   Modals, dialogs and drawers
   ---------------------------------------------------------------------- */
:where(dialog, .ddla-single-modal__dialog, .ddla-mobile-sheet__panel) {
  border-radius: 0;
  color: var(--ddla-text-main);
}

:where(dialog[open], .ddla-single-modal:not([hidden]) .ddla-single-modal__dialog, .ddla-mobile-sheet.is-open .ddla-mobile-sheet__panel) {
  box-shadow: var(--ddla-component-shadow-raised), var(--ddla-component-glow-blue);
}

:where(dialog)::backdrop {
  background: rgba(0, 0, 0, .72);
  backdrop-filter: blur(5px);
}

:where(.ddla-single-modal__close, .ddla-blog-search-popup__close, .ddla-mobile-sheet__close, .ddla-single-drawer-close) {
  min-width: var(--ddla-component-control-md);
  min-height: var(--ddla-component-control-md);
  border-radius: 0;
}

body.ddla-a11y-dialog-open {
  overflow: hidden;
}

/* -------------------------------------------------------------------------
   Navigation
   ---------------------------------------------------------------------- */
:where(.ddla-nav-menu__link, .ddla-side-nav__profile-main, .ddla-side-nav__logout, .ddla-mobile-nav a, .ddla-mobile-nav button) {
  min-height: var(--ddla-component-control-md);
}

:where(.ddla-nav-menu__link)[aria-current="page"],
:where(.ddla-nav-menu__link)[aria-current="true"],
:where(.ddla-nav-menu__item).current-menu-item > .ddla-nav-menu__link,
:where(.ddla-nav-menu__item).current_page_item > .ddla-nav-menu__link {
  color: var(--ddla-role-action-light);
}

:where(.ddla-nav-menu__link)[aria-current="page"]::after,
:where(.ddla-nav-menu__link)[aria-current="true"]::after {
  content: "";
  width: 5px;
  height: 5px;
  margin-left: auto;
  background: currentColor;
  transform: rotate(45deg);
  box-shadow: 0 0 8px currentColor;
}

/* -------------------------------------------------------------------------
   Article tools and local finder inside ddla-panel__surface
   ---------------------------------------------------------------------- */
.ddla-single-tools .ddla-article-find {
  position: sticky;
  top: 0;
  z-index: 5;
  width: 100%;
  margin: var(--ddla-component-section-gap) 0 0;
  padding: var(--ddla-component-section-gap) 0 0;
  border: 0;
  border-top: var(--ddla-component-border) solid rgba(201, 168, 93, .22);
  color: var(--ddla-text-soft);
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  clip-path: none;
}

.ddla-single-tools .ddla-article-find__header {
  gap: .18rem;
  margin-bottom: .62rem;
}

.ddla-single-tools .ddla-article-find__header h3 {
  margin: 0;
  color: var(--ddla-text-main);
  font-size: .95rem;
  font-weight: 500;
}

.ddla-single-tools .ddla-article-find__eyebrow {
  color: var(--ddla-role-structure-light);
}

.ddla-single-tools .ddla-article-find__form {
  grid-template-columns: 34px minmax(0, 1fr) auto repeat(3, 34px);
  min-height: 40px;
  overflow: hidden;
  border: var(--ddla-component-border) solid var(--ddla-component-border-color);
  border-radius: 0;
  background: rgba(1, 5, 12, .7);
  box-shadow: inset 0 0 14px rgba(var(--ddla-blue-rgb), .035);
  clip-path: none;
}

.ddla-single-tools .ddla-article-find__form input[type="search"] {
  min-height: 40px;
  padding-inline: .35rem;
  font-size: .76rem;
}

.ddla-single-tools .ddla-article-find__icon,
.ddla-single-tools .ddla-article-find__form button {
  width: 34px;
}

.ddla-single-tools .ddla-article-find__form button {
  height: 34px;
  min-height: 34px;
  align-self: center;
}

.ddla-single-tools .ddla-article-find__count {
  min-width: 3.65rem;
  padding-inline: .3rem;
  font-size: .61rem;
}

.ddla-single-tools .ddla-article-find__help {
  margin: .42rem 0 0;
  font-size: .57rem;
  text-align: left;
}

/* Route navigation returns to the article flow. */
.ddla-single-center > .ddla-article-route-context {
  margin-top: .75rem;
}

/* -------------------------------------------------------------------------
   Light reading mode and explicit light theme contract
   ---------------------------------------------------------------------- */
html.ddla-reading-light,
[data-ddla-theme="light"] {
  --ddla-component-surface: rgba(255, 252, 242, .84);
  --ddla-component-surface-strong: rgba(255, 252, 242, .96);
  --ddla-component-surface-raised: linear-gradient(145deg, rgba(162, 114, 17, .06), transparent 52%), rgba(255, 252, 242, .98);
  --ddla-component-border-color: rgba(122, 83, 10, .32);
  --ddla-component-border-hover: rgba(32, 83, 190, .72);
  --ddla-component-shadow: 0 14px 36px rgba(77, 54, 10, .12);
  --ddla-component-shadow-raised: 0 22px 60px rgba(77, 54, 10, .18);
  --ddla-focus-shadow: 0 0 0 2px #fffaf0, 0 0 0 4px #225bd6, 0 0 16px rgba(34, 91, 214, .18);
}

html.ddla-reading-light .ddla-single-tools .ddla-article-find__form,
[data-ddla-theme="light"] .ddla-single-tools .ddla-article-find__form {
  background: rgba(255, 252, 242, .96);
}

/* -------------------------------------------------------------------------
   Responsive touch target and compact reading rules
   ---------------------------------------------------------------------- */
@media (max-width: 767px) {
  :where(
    button,
    [role="button"],
    input:not([type="checkbox"]):not([type="radio"]):not([type="range"]),
    select,
    .ddla-nav-menu__link,
    .ddla-mobile-nav a,
    .ddla-mobile-nav button,
    .ddla-article-route-context__nav a,
    .ddla-article-route-context__nav > span,
    .ddla-article-route-context__single-route,
    .ddla-route-card__actions a,
    .ddla-route-card__actions button,
    .ddla-blog-view-switcher button,
    .ddla-blog-search-popup__close
  ) {
    min-height: var(--ddla-component-touch);
  }

  :where(.ddla-single-tool, .ddla-control-button) {
    min-height: var(--ddla-component-touch);
  }

  .ddla-single-tools .ddla-article-find__form {
    grid-template-columns: 36px minmax(0, 1fr) auto repeat(3, 38px);
  }

  .ddla-single-tools .ddla-article-find__form button {
    width: 38px;
    height: 38px;
    min-height: 38px;
  }

  [data-ddla-tooltip]::after {
    display: none !important;
  }
}

/* -------------------------------------------------------------------------
   Reduced motion is a first-class mode, not a cosmetic afterthought
   ---------------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  html,
  html:focus-within {
    scroll-behavior: auto !important;
  }

  *,
  *::before,
  *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: .01ms !important;
    transition-delay: 0ms !important;
  }

  :where(.ddla-panel__border-breath, .ddla-panel__border-beam, .ddla-panel__border-spark,
    .ddla-card__border-breath, .ddla-card__border-beam, .ddla-card__border-spark,
    .ddla-route-card__border-glow) {
    display: none !important;
  }

  :where(.ddla-card, .ddla-route-card, .ddla-button):hover,
  :where(.ddla-card, .ddla-route-card, .ddla-button):focus-within {
    transform: none !important;
  }

  body.ddla-theme--mystika {
    background-attachment: scroll !important;
  }
}

/* Forced-colors support keeps controls understandable in high-contrast mode. */
@media (forced-colors: active) {
  :where(.ddla-panel, .ddla-card, .ddla-route-card, .ddla-button, button, input, select, textarea) {
    forced-color-adjust: auto;
  }

  :where(.ddla-panel__border, .ddla-card__border, .ddla-route-card__border) {
    display: none !important;
  }

  :where(.ddla-panel, .ddla-card, .ddla-route-card) {
    border: 1px solid CanvasText;
  }
}

/* Colour-scheme and higher-contrast user preference. */
:root { color-scheme: dark; }
html.ddla-reading-light,
[data-ddla-theme="light"] { color-scheme: light; }

@media (prefers-contrast: more) {
  :root {
    --ddla-component-border-color: rgba(244, 223, 171, .66);
    --ddla-component-border-hover: var(--ddla-blue-light);
    --ddla-text-muted: #b8ad97;
  }

  :where(.ddla-panel, .ddla-card, .ddla-route-card, input, select, textarea, button) {
    box-shadow: none;
  }

  :where(a, button, input, select, textarea, summary, [tabindex]):focus-visible {
    outline-width: 3px !important;
  }
}

/* ==========================================================================
   Mystika 0.9.4 · Compact toolbox, dual search and discoveries
   ========================================================================== */

/* The first toolbox stays available while the remaining sidebar panels scroll. */
.ddla-single-right__scroll {
  position: relative;
  padding-bottom: 1.25rem;
  scroll-padding-top: .75rem;
}

.ddla-single-right__scroll > .ddla-single-tools {
  position: sticky;
  top: 0;
  z-index: 12;
  margin: 0;
  background: rgba(2, 7, 14, .94);
  box-shadow: 0 12px 28px rgba(0, 0, 0, .34);
}

.ddla-single-tools__heading {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: .75rem;
}

.ddla-single-tools__hint {
  display: none;
}

/* Dense icon matrix: new tools can be added without growing the panel vertically. */
.ddla-single-tool-list {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .42rem;
  margin-top: .7rem;
}

.ddla-single-tool-list .ddla-single-tool {
  position: relative;
  display: grid;
  place-items: center;
  width: 100%;
  min-width: 0;
  min-height: 48px;
  height: 48px;
  padding: 0;
  border: 1px solid rgba(201, 168, 93, .2);
  border-radius: 0;
  color: var(--ddla-text-soft);
  background: rgba(201, 168, 93, .025);
  grid-template-columns: 1fr;
  text-align: center;
}

.ddla-single-tool-list .ddla-single-tool:hover,
.ddla-single-tool-list .ddla-single-tool:focus-visible,
.ddla-single-tool-list .ddla-single-tool.is-active,
.ddla-single-tool-list .ddla-single-tool[aria-pressed="true"] {
  border-color: rgba(var(--ddla-blue-rgb), .72);
  color: var(--ddla-blue-light);
  background: rgba(var(--ddla-blue-rgb), .09);
  box-shadow: inset 0 0 15px rgba(var(--ddla-blue-rgb), .05), 0 0 14px rgba(var(--ddla-blue-rgb), .12);
}

.ddla-single-tool-list .ddla-single-tool .ddla-single-icon {
  margin: 0;
  color: currentColor;
  font-size: 1.28rem;
}

.ddla-single-tool-list .ddla-single-tool__label,
.ddla-single-tool-list .ddla-tool-icon-only > :not(.ddla-single-icon):not(.screen-reader-text) {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

.ddla-single-tool-list [data-ddla-tooltip]::after {
  z-index: 40;
  bottom: calc(100% + .52rem);
  left: 50%;
  max-width: 180px;
  transform: translateX(-50%);
  white-space: nowrap;
}

/* Corpus-wide search remains inside the toolbox. */
.ddla-single-global-search {
  position: relative;
  margin-top: .72rem;
  padding-top: .72rem;
  border-top: 1px solid rgba(201, 168, 93, .16);
}

.ddla-single-global-search__bar {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr) 38px;
  align-items: center;
  min-height: 42px;
  overflow: visible;
  border: 1px solid rgba(201, 168, 93, .25);
  border-radius: 0;
  background: rgba(1, 5, 12, .72);
}

.ddla-single-global-search__bar:focus-within {
  border-color: rgba(var(--ddla-blue-rgb), .72);
  box-shadow: var(--ddla-focus-shadow);
}

.ddla-single-global-search__bar input[type="search"] {
  width: 100%;
  min-width: 0;
  min-height: 40px;
  padding: .3rem .4rem;
  border: 0 !important;
  outline: 0 !important;
  color: var(--ddla-text-main);
  background: transparent !important;
  box-shadow: none !important;
  font-size: .78rem;
}

.ddla-single-global-search__submit,
.ddla-single-global-search__settings {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  min-width: 38px;
  min-height: 38px;
  padding: 0;
  border: 0;
  border-radius: 0;
  color: var(--ddla-gold-light);
  background: transparent;
  cursor: pointer;
}

.ddla-single-global-search__submit:hover,
.ddla-single-global-search__submit:focus-visible,
.ddla-single-global-search__settings:hover,
.ddla-single-global-search__settings:focus-visible,
.ddla-single-global-search__settings[aria-expanded="true"] {
  color: var(--ddla-blue-light);
  background: rgba(var(--ddla-blue-rgb), .08);
}

/* Advanced corpus search modal. */
.ddla-single-search-dialog {
  width: min(760px, calc(100vw - 2rem));
  max-height: min(82vh, 760px);
  padding: 0;
  overflow: auto;
  border: 1px solid rgba(201, 168, 93, .42);
  border-radius: 0;
  color: var(--ddla-text-main);
  background: linear-gradient(145deg, rgba(8, 18, 32, .99), rgba(2, 7, 15, .99));
}

.ddla-single-search-dialog__header {
  position: sticky;
  top: 0;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.1rem 1.2rem;
  border-bottom: 1px solid rgba(201, 168, 93, .2);
  background: rgba(3, 9, 18, .96);
  backdrop-filter: blur(16px);
}

.ddla-single-search-dialog__header h2 {
  margin: .15rem 0 0;
  color: var(--ddla-gold-light);
  font-size: 1.15rem;
}

.ddla-single-search-dialog__kicker {
  margin: 0;
  color: var(--ddla-blue-light);
  font: 600 .64rem/1.2 var(--ddla-font-nav);
  letter-spacing: .12em;
  text-transform: uppercase;
}

.ddla-single-search-dialog__close {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  padding: 0;
  border: 1px solid rgba(201, 168, 93, .22);
  border-radius: 0;
  color: var(--ddla-gold-light);
  background: transparent;
}

.ddla-single-search-dialog__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  padding: 1.2rem;
}

.ddla-single-search-dialog__field {
  display: grid;
  gap: .42rem;
}

.ddla-single-search-dialog__field label {
  color: var(--ddla-text-soft);
  font: 600 .7rem/1.3 var(--ddla-font-nav);
  letter-spacing: .06em;
  text-transform: uppercase;
}

.ddla-single-search-dialog__field input,
.ddla-single-search-dialog__field select {
  width: 100%;
  min-height: 44px;
  border-radius: 0;
}

.ddla-single-search-dialog__footer {
  position: sticky;
  bottom: 0;
  z-index: 3;
  display: flex;
  justify-content: flex-end;
  gap: .7rem;
  padding: 1rem 1.2rem;
  border-top: 1px solid rgba(201, 168, 93, .2);
  background: rgba(3, 9, 18, .96);
  backdrop-filter: blur(16px);
}

/* Local Ctrl+F-like bar: detached from the sidebar and visible at any scroll depth. */
.ddla-article-find[hidden] {
  display: none !important;
}

.ddla-article-find {
  position: fixed !important;
  z-index: 100020 !important;
  top: 14px !important;
  left: 50% !important;
  width: min(720px, calc(100vw - 2rem)) !important;
  margin: 0 !important;
  padding: .52rem !important;
  transform: translateX(-50%) !important;
  border: 1px solid rgba(201, 168, 93, .38) !important;
  border-radius: 0 !important;
  color: var(--ddla-text-main) !important;
  background: rgba(2, 7, 15, .97) !important;
  box-shadow: 0 18px 55px rgba(0, 0, 0, .58), 0 0 20px rgba(var(--ddla-blue-rgb), .1) !important;
  backdrop-filter: blur(18px) !important;
  clip-path: none !important;
}

body.admin-bar .ddla-article-find {
  top: 46px !important;
}

.ddla-article-find__form {
  display: grid !important;
  grid-template-columns: 38px minmax(0, 1fr) auto repeat(4, 38px) !important;
  min-height: 42px !important;
  overflow: hidden !important;
  border: 1px solid rgba(201, 168, 93, .22) !important;
  border-radius: 0 !important;
  background: rgba(1, 5, 12, .76) !important;
  clip-path: none !important;
}

.ddla-article-find__form:focus-within {
  border-color: rgba(var(--ddla-blue-rgb), .72) !important;
  box-shadow: var(--ddla-focus-shadow) !important;
}

.ddla-article-find__form input[type="search"] {
  min-width: 0;
  min-height: 40px;
  border: 0 !important;
  outline: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.ddla-article-find__form button,
.ddla-article-find__icon {
  width: 38px !important;
  height: 38px !important;
  min-width: 38px !important;
  min-height: 38px !important;
  align-self: center;
}

.ddla-article-find__help {
  margin: .38rem .2rem 0 !important;
  color: var(--ddla-text-muted) !important;
  font-size: .61rem !important;
  text-align: right !important;
}

body.ddla-article-find-open {
  scroll-padding-top: 86px;
}

/* Discoveries: three different editorial doors into the corpus. */
.ddla-single-discoveries__list {
  display: grid;
  gap: .25rem;
  margin-top: .72rem;
}

.ddla-single-discovery {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) 20px;
  align-items: center;
  gap: .62rem;
  min-height: 78px;
  padding: .7rem .35rem;
  border-bottom: 1px solid rgba(201, 168, 93, .12);
  color: var(--ddla-text-soft);
  text-decoration: none;
}

.ddla-single-discovery:last-child {
  border-bottom: 0;
}

.ddla-single-discovery:hover,
.ddla-single-discovery:focus-visible {
  color: var(--ddla-text-main);
  background: rgba(var(--ddla-blue-rgb), .055);
}

.ddla-single-discovery__icon {
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border: 1px solid rgba(201, 168, 93, .2);
  color: var(--ddla-gold-light);
}

.ddla-single-discovery--anniversary .ddla-single-discovery__icon {
  color: var(--ddla-blue-light);
  border-color: rgba(var(--ddla-blue-rgb), .3);
}

.ddla-single-discovery__copy {
  display: grid;
  gap: .13rem;
  min-width: 0;
}

.ddla-single-discovery__kind {
  color: var(--ddla-blue-light);
  font: 600 .59rem/1.2 var(--ddla-font-nav);
  letter-spacing: .09em;
  text-transform: uppercase;
}

.ddla-single-discovery__title {
  color: var(--ddla-text-main);
  font-family: var(--ddla-font-title);
  font-size: .82rem;
  line-height: 1.3;
}

.ddla-single-discovery__subtitle {
  color: var(--ddla-text-soft);
  font-size: .7rem;
  line-height: 1.35;
}

.ddla-single-discovery__date {
  color: var(--ddla-text-muted);
  font-size: .6rem;
}

.ddla-single-discovery__arrow {
  color: var(--ddla-gold);
}

@media (max-width: 782px) {
  body.admin-bar .ddla-article-find {
    top: 58px !important;
  }
}

@media (max-width: 767px) {
  .ddla-single-right__scroll > .ddla-single-tools {
    position: relative;
    top: auto;
  }

  .ddla-single-tool-list {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .ddla-article-find {
    top: 8px !important;
    width: calc(100vw - 12px) !important;
    padding: .38rem !important;
  }

  body.admin-bar .ddla-article-find {
    top: 52px !important;
  }

  .ddla-article-find__form {
    grid-template-columns: 34px minmax(0, 1fr) auto repeat(4, 34px) !important;
  }

  .ddla-article-find__form button,
  .ddla-article-find__icon {
    width: 34px !important;
    min-width: 34px !important;
  }

  .ddla-article-find__help {
    display: none;
  }

  .ddla-single-search-dialog__grid {
    grid-template-columns: 1fr;
  }

  .ddla-single-search-dialog__footer {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 420px) {
  .ddla-single-tool-list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .ddla-article-find__count {
    display: none !important;
  }

  .ddla-article-find__form {
    grid-template-columns: 32px minmax(0, 1fr) repeat(4, 32px) !important;
  }
}

html.ddla-reading-light .ddla-single-right__scroll > .ddla-single-tools,
html.ddla-reading-light .ddla-article-find,
html.ddla-reading-light .ddla-single-search-dialog {
  color: #1e1a12 !important;
  background: rgba(255, 252, 242, .98) !important;
}

html.ddla-reading-light .ddla-single-global-search__bar,
html.ddla-reading-light .ddla-article-find__form,
html.ddla-reading-light .ddla-single-search-dialog__header,
html.ddla-reading-light .ddla-single-search-dialog__footer {
  background: rgba(255, 252, 242, .96) !important;
}

/* Tooltips for the compact article toolbox. They stay inside the clipped panel. */
.ddla-single-tool-list [data-ddla-tooltip]::after {
  content: attr(data-ddla-tooltip);
  position: absolute;
  top: calc(100% + .38rem);
  bottom: auto;
  left: 50%;
  z-index: 50;
  width: max-content;
  max-width: 170px;
  padding: .42rem .56rem;
  transform: translateX(-50%) translateY(-3px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  white-space: normal;
  text-align: center;
  transition: opacity 140ms ease, transform 140ms ease, visibility 140ms ease;
}

.ddla-single-tool-list [data-ddla-tooltip]:hover::after,
.ddla-single-tool-list [data-ddla-tooltip]:focus-visible::after {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}

.ddla-single-tool-list [data-ddla-tooltip]:nth-child(4n + 1)::after {
  left: 0;
  transform: translateY(-3px);
}

.ddla-single-tool-list [data-ddla-tooltip]:nth-child(4n + 1):hover::after,
.ddla-single-tool-list [data-ddla-tooltip]:nth-child(4n + 1):focus-visible::after {
  transform: translateY(0);
}

.ddla-single-tool-list [data-ddla-tooltip]:nth-child(4n)::after {
  right: 0;
  left: auto;
  transform: translateY(-3px);
}

.ddla-single-tool-list [data-ddla-tooltip]:nth-child(4n):hover::after,
.ddla-single-tool-list [data-ddla-tooltip]:nth-child(4n):focus-visible::after {
  transform: translateY(0);
}

/* ==========================================================================
   Mystika 0.9.5 · Fluid sidebar, simple search actions and Signals
   ========================================================================== */

/* Desktop: only the compact toolbox remains sticky. The rest of the panels
   follow the document and the browser keeps the only scroll bar. */
@media (min-width: 1021px) {
  .ddla-single-right {
    position: static !important;
    top: auto !important;
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
  }

  .ddla-single-right__content,
  .ddla-single-right__scroll {
    display: grid !important;
    gap: 1rem !important;
    height: auto !important;
    max-height: none !important;
    padding: 0 0 1.25rem !important;
    overflow: visible !important;
    overscroll-behavior: auto !important;
  }

  .ddla-single-tools-sticky {
    position: sticky;
    top: var(--ddla-single-sticky-top, 24px);
    z-index: 18;
    align-self: start;
  }

  .ddla-single-tools-sticky > .ddla-single-tools,
  .ddla-single-right__scroll > .ddla-single-tools {
    position: static !important;
    top: auto !important;
    margin: 0 !important;
  }

  .ddla-single-right__panels {
    display: grid;
    gap: 1rem;
    min-width: 0;
  }
}

/* Mobile/tablet drawer still needs one contained scrolling surface because it
   is a full-screen dialog. There are no nested scrolling panels inside it. */
@media (max-width: 1020px) {
  .ddla-single-right__content {
    display: block !important;
  }

  .ddla-single-tools-sticky {
    position: static !important;
  }

  .ddla-single-right__panels {
    display: grid;
    gap: .75rem;
    margin-top: .75rem;
  }
}

/* Advanced search actions are deliberately sober controls, not hero buttons. */
.ddla-single-search-dialog__action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 176px;
  min-height: 46px;
  padding: .72rem 1.15rem;
  border-width: 1px;
  border-style: solid;
  border-radius: 0;
  clip-path: none !important;
  color: var(--ddla-text-main);
  background: transparent;
  box-shadow: none;
  font: 600 .72rem/1.2 var(--ddla-font-nav);
  letter-spacing: .1em;
  text-transform: uppercase;
  cursor: pointer;
  transition: border-color 160ms ease, color 160ms ease, background-color 160ms ease, box-shadow 160ms ease;
}

.ddla-single-search-dialog__action--reset {
  border-color: rgba(201, 168, 93, .72);
  color: var(--ddla-gold-light);
}

.ddla-single-search-dialog__action--reset:hover,
.ddla-single-search-dialog__action--reset:focus-visible {
  border-color: var(--ddla-gold-light);
  color: #fff3ce;
  background: rgba(201, 168, 93, .08);
  box-shadow: 0 0 0 3px rgba(201, 168, 93, .11);
}

.ddla-single-search-dialog__action--apply {
  border-color: rgba(var(--ddla-blue-rgb), .82);
  color: var(--ddla-blue-light);
}

.ddla-single-search-dialog__action--apply:hover,
.ddla-single-search-dialog__action--apply:focus-visible {
  border-color: var(--ddla-blue-light);
  color: #dff9ff;
  background: rgba(var(--ddla-blue-rgb), .09);
  box-shadow: 0 0 0 3px rgba(var(--ddla-blue-rgb), .12);
}

.ddla-single-search-dialog__action:focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 3px;
}

.ddla-single-discovery--signal .ddla-single-discovery__icon {
  color: var(--ddla-gold-light);
  border-color: rgba(201, 168, 93, .38);
  box-shadow: inset 0 0 14px rgba(201, 168, 93, .06), 0 0 14px rgba(201, 168, 93, .06);
}

@media (max-width: 767px) {
  .ddla-single-search-dialog__footer {
    grid-template-columns: 1fr 1fr;
  }

  .ddla-single-search-dialog__action {
    min-width: 0;
    width: 100%;
  }
}

/* ==========================================================================
   Mystika 0.9.6 · Sticky scrollable sidebar and collapsible panels
   ========================================================================== */

@media (min-width: 1021px) {
  .ddla-single-right {
    position: sticky !important;
    top: var(--ddla-single-sticky-top, 24px) !important;
    align-self: start;
    height: calc(100vh - var(--ddla-single-sticky-top, 24px) - 1rem) !important;
    max-height: calc(100vh - var(--ddla-single-sticky-top, 24px) - 1rem) !important;
    overflow: hidden !important;
  }

  .ddla-single-right__content,
  .ddla-single-right__scroll {
    display: block !important;
    width: 100%;
    height: 100% !important;
    max-height: 100% !important;
    min-height: 0;
    padding: 0 .28rem 1.2rem 0 !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    overscroll-behavior: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
    scroll-padding-block: .5rem 1rem;
  }

  .ddla-single-right__content::-webkit-scrollbar,
  .ddla-single-right__scroll::-webkit-scrollbar {
    display: none;
    width: 0;
    height: 0;
  }

  .ddla-single-tools-sticky,
  .ddla-single-tools-sticky > .ddla-single-tools,
  .ddla-single-right__scroll > .ddla-single-tools {
    position: static !important;
    top: auto !important;
    z-index: auto !important;
    margin: 0 !important;
    box-shadow: none;
  }

  .ddla-single-right__panels {
    display: grid;
    gap: 1rem;
    min-width: 0;
    margin-top: 1rem;
  }
}

.ddla-sidebar-panel__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: .7rem;
  min-width: 0;
}

.ddla-sidebar-panel__header-copy,
.ddla-sidebar-panel__header > div:first-child {
  min-width: 0;
}

.ddla-sidebar-panel__header h2,
.ddla-sidebar-panel__header .ddla-single-side-kicker {
  margin-right: 0;
}

.ddla-sidebar-panel__body {
  min-width: 0;
}

.ddla-sidebar-panel__toggle {
  position: relative;
  flex: 0 0 auto;
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  min-width: 30px;
  min-height: 30px;
  margin: -.18rem -.15rem 0 0;
  padding: 0;
  border: 1px solid rgba(201, 168, 93, .24);
  border-radius: 0;
  color: var(--ddla-gold-light);
  background: rgba(201, 168, 93, .025);
  cursor: pointer;
}

.ddla-sidebar-panel__toggle:hover,
.ddla-sidebar-panel__toggle:focus-visible {
  border-color: rgba(var(--ddla-blue-rgb), .7);
  color: var(--ddla-blue-light);
  background: rgba(var(--ddla-blue-rgb), .08);
  box-shadow: 0 0 14px rgba(var(--ddla-blue-rgb), .14);
}

.ddla-sidebar-panel__toggle-icon,
.ddla-sidebar-panel__toggle-icon::after {
  display: block;
  width: 11px;
  height: 1px;
  background: currentColor;
  content: '';
  transition: transform 160ms ease, opacity 160ms ease;
}

.ddla-sidebar-panel__toggle-icon::after {
  transform: translateY(-1px) rotate(90deg) scaleX(0);
  opacity: 0;
}

.ddla-panel.is-collapsed .ddla-sidebar-panel__toggle-icon::after {
  transform: translateY(-1px) rotate(90deg) scaleX(1);
  opacity: 1;
}

.ddla-panel.is-collapsed .ddla-panel__surface {
  padding-top: .8rem;
  padding-bottom: .8rem;
}

.ddla-panel.is-collapsed .ddla-sidebar-panel__header {
  align-items: center;
}

.ddla-panel.is-collapsed .ddla-single-side-kicker {
  display: none;
}

.ddla-panel.is-collapsed .ddla-sidebar-panel__header h2 {
  margin: 0;
  font-size: clamp(.78rem, .72rem + .12vw, .9rem);
}

@media (prefers-reduced-motion: reduce) {
  .ddla-sidebar-panel__toggle-icon,
  .ddla-sidebar-panel__toggle-icon::after {
    transition: none;
  }
}

@media (min-width: 1021px) {
  .ddla-single-right__panels > .ddla-panel {
    content-visibility: auto;
    contain-intrinsic-size: auto 260px;
  }
}
