:root {
  color-scheme: light;
  --ink: #171717;
  --muted: #5c5c5c;
  --page-bg: #ffffff;
  --panel-bg: #ffffff;
  --soft-line: #ededed;
  --soft-shadow: #dcdcdc;
  --tile-size: 152px;
  --font-xs: 0.68rem;
  --font-sm: 0.78rem;
  --font-md: 0.9rem;
  --font-lg: 1.05rem;
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --control-py: 8px;
  --control-px: 12px;
  --control-border: 2px solid var(--ink);
  --control-border-soft: 2px solid #d7d7d7;
  --pixel-corner-xs: polygon(2px 0, calc(100% - 2px) 0, calc(100% - 2px) 2px, 100% 2px, 100% calc(100% - 2px), calc(100% - 2px) calc(100% - 2px), calc(100% - 2px) 100%, 2px 100%, 2px calc(100% - 2px), 0 calc(100% - 2px), 0 2px, 2px 2px);
  --pixel-corner-sm: polygon(4px 0, calc(100% - 4px) 0, calc(100% - 4px) 2px, calc(100% - 2px) 2px, calc(100% - 2px) 4px, 100% 4px, 100% calc(100% - 4px), calc(100% - 2px) calc(100% - 4px), calc(100% - 2px) calc(100% - 2px), calc(100% - 4px) calc(100% - 2px), calc(100% - 4px) 100%, 4px 100%, 4px calc(100% - 2px), 2px calc(100% - 2px), 2px calc(100% - 4px), 0 calc(100% - 4px), 0 4px, 2px 4px, 2px 2px, 4px 2px);
  --pixel-corner-md: polygon(6px 0, calc(100% - 6px) 0, calc(100% - 6px) 2px, calc(100% - 4px) 2px, calc(100% - 4px) 4px, calc(100% - 2px) 4px, calc(100% - 2px) 6px, 100% 6px, 100% calc(100% - 6px), calc(100% - 2px) calc(100% - 6px), calc(100% - 2px) calc(100% - 4px), calc(100% - 4px) calc(100% - 4px), calc(100% - 4px) calc(100% - 2px), calc(100% - 6px) calc(100% - 2px), calc(100% - 6px) 100%, 6px 100%, 6px calc(100% - 2px), 4px calc(100% - 2px), 4px calc(100% - 4px), 2px calc(100% - 4px), 2px calc(100% - 6px), 0 calc(100% - 6px), 0 6px, 2px 6px, 2px 4px, 4px 4px, 4px 2px, 6px 2px);
  --pixel-corner-lg: polygon(8px 0, calc(100% - 8px) 0, calc(100% - 8px) 2px, calc(100% - 6px) 2px, calc(100% - 6px) 4px, calc(100% - 4px) 4px, calc(100% - 4px) 6px, calc(100% - 2px) 6px, calc(100% - 2px) 8px, 100% 8px, 100% calc(100% - 8px), calc(100% - 2px) calc(100% - 8px), calc(100% - 2px) calc(100% - 6px), calc(100% - 4px) calc(100% - 6px), calc(100% - 4px) calc(100% - 4px), calc(100% - 6px) calc(100% - 4px), calc(100% - 6px) calc(100% - 2px), calc(100% - 8px) calc(100% - 2px), calc(100% - 8px) 100%, 8px 100%, 8px calc(100% - 2px), 6px calc(100% - 2px), 6px calc(100% - 4px), 4px calc(100% - 4px), 4px calc(100% - 6px), 2px calc(100% - 6px), 2px calc(100% - 8px), 0 calc(100% - 8px), 0 8px, 2px 8px, 2px 6px, 4px 6px, 4px 4px, 6px 4px, 6px 2px, 8px 2px);
  --danger: #e53e3e;
  --danger-dark: #c53030;
  --success: #4a9e4a;
  --action-primary-bg: var(--ink);
  --action-primary-fg: #ffffff;
  --action-secondary-bg: var(--panel-bg);
  --action-secondary-fg: var(--ink);
  --action-danger-bg: var(--danger);
  --action-danger-fg: #ffffff;
  --action-selected-bg: var(--success);
  --action-selected-fg: var(--page-bg);
  --action-selected-muted-bg: #5a5a5a;
  --action-selected-soft-bg: #f2fbf2;
  --action-custom-bg: #fff4d6;
  --action-favorite-bg: #fff7da;
  --action-favorite-border: #e2b23a;
  --action-favorite-fg: #7a5600;
  --action-muted-fg: #767676;
  --action-muted-hover-fg: #3f3f3f;
  --input-bg: #ffffff;
  --input-readonly-bg: #f3f3f3;
  --input-border: 1px solid rgba(23, 23, 23, 0.16);
  --input-border-strong: 2px solid var(--ink);
  --input-radius: 8px;
  --input-focus-border: var(--ink);
  --input-focus-shadow: 0 0 0 2px rgba(23, 23, 23, 0.08);
  --input-mobile-height: 40px;
  --card-remove-size: 22px;
  --card-remove-small-size: 20px;
  --card-remove-line-size: 10px;
  --card-remove-small-line-size: 9px;
  --card-remove-bg: #ffffff;
  --card-remove-hover-bg: #f7f7f7;
  --card-remove-border: 1px solid rgba(23, 23, 23, 0.2);
  --card-remove-hover-border: 1px solid var(--ink);
  --card-remove-line: var(--ink);
  --selection-active-bg: var(--ink);
  --selection-active-fg: #ffffff;
  --selection-active-border: var(--ink);
  --selection-pill-bg: #f7f7f7;
  --selection-pill-fg: var(--ink);
  --selection-pill-border: var(--ink);
  --selection-soft-bg: #f3f3f3;
  --selection-soft-border: var(--ink);
  --selection-muted-border: #d7d7d7;
  --selection-pill-min-height: 29px;
  --selection-option-min-height: 30px;
  --selection-check-bg: var(--success);
  --selection-check-fg: #ffffff;
  --selection-check-border: 2px solid var(--ink);
  --selection-check-size: 20px;
  --selection-check-inline-size: 20px;
  --selection-check-compact-size: 18px;
  --selection-check-compact-border: 1.5px solid var(--ink);
  --selection-check-compact-font-size: 0.72rem;
  --selection-check-font-size: 0.88rem;
  --selection-check-inline-font-size: 0.84rem;
  --selection-check-radius: 1px;
  --food-card-bg: #ffffff;
  --food-card-border: 1px solid rgba(23, 23, 23, 0.08);
  --food-card-border-hover: rgba(23, 23, 23, 0.16);
  --food-card-radius: 6px;
  --food-card-shadow: 0 5px 16px rgba(23, 23, 23, 0.07);
  --food-card-hover-shadow: 0 8px 22px rgba(23, 23, 23, 0.11);
  --food-card-image-bg: #f7f7f7;
  --food-card-image-size: 178px;
  --mobile-card-bg: #ffffff;
  --mobile-card-border: 1px solid rgba(23, 23, 23, 0.1);
  --mobile-card-radius: 8px;
  --mobile-card-shadow: 0 3px 10px rgba(23, 23, 23, 0.06);
  --mobile-card-padding: 8px;
  --mobile-card-grid-gap: 9px;
  --mobile-card-image-bg: #f4f4f4;
  --mobile-card-image-radius: 6px;
  --mobile-card-image-scale: 88%;
  --mobile-card-action-size: 28px;
  --mobile-card-action-selected-size: var(--selection-check-size);
  --mini-card-bg: #ffffff;
  --mini-card-border: 1px solid rgba(23, 23, 23, 0.1);
  --mini-card-radius: 8px;
  --mini-card-padding: 6px;
  --mini-card-gap: 6px;
  --mini-card-shadow: 0 3px 10px rgba(23, 23, 23, 0.06);
  --mobile-action-dock-inset: 8px;
  --mobile-action-dock-padding: 8px;
  --mobile-action-dock-gap: 8px;
  --mobile-action-dock-radius: 10px;
  --mobile-action-dock-border: 1px solid rgba(23, 23, 23, 0.12);
  --mobile-action-dock-bg: #ffffff;
  --mobile-action-dock-shadow: 0 -8px 22px rgba(23, 23, 23, 0.12);
  --mobile-action-btn-height: 40px;
  --mobile-action-btn-padding: 8px 6px 7px;
  --mobile-action-btn-font-size: 0.68rem;
  --mobile-action-btn-line-height: 1.15;
  --mobile-action-btn-border: 2px solid var(--ink);
  --mobile-action-btn-radius: 2px;
  --cursor-default: default;
  --cursor-pointer: pointer;
  --cursor-grab: grab;
  --cursor-grabbing: grabbing;
  --cursor-text: text;
  --cursor-hover: pointer;
  --cursor-click: pointer;
}

@media (max-width: 760px) {
  body.admin-page {
    padding-bottom: env(safe-area-inset-bottom, 0px);
    background: #fafafa;
  }

  body.admin-page .admin-header {
    padding: 6px 10px 0;
    box-shadow: 0 4px 0 rgba(0, 0, 0, 0.18);
  }

  body.admin-page .admin-header-inner {
    width: 100%;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 6px 8px;
  }

  body.admin-page .admin-logo {
    grid-column: 1;
    grid-row: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 0.82rem;
  }

  body.admin-page .admin-header-tools {
    grid-column: 2;
    grid-row: 1;
    min-width: 0;
  }

  body.admin-page .admin-header .admin-search {
    min-height: 32px;
    padding: 6px 8px 5px;
    font-size: 0.66rem;
  }

  body.admin-page .admin-user-menu {
    grid-column: 3;
    grid-row: 1;
    justify-self: end;
    justify-content: end;
    gap: 6px;
    padding-top: 0;
    font-size: 0.68rem;
  }

  body.admin-page .admin-avatar {
    display: inline-grid;
    place-items: center;
    flex: 0 0 auto;
    width: 24px;
    height: 24px;
    border: 1px solid #ffffff;
    border-radius: 50% !important;
    background: #ffffff center / cover no-repeat;
    color: #111111;
    font-size: 0.62rem;
    font-weight: 700;
    line-height: 1;
  }

  body.admin-page .admin-user-name {
    max-width: 64px;
    color: #ffffff;
  }

  body.admin-page .admin-header .admin-tabs {
    grid-column: 1 / -1;
    grid-row: 2;
    display: flex !important;
    justify-content: flex-start;
    gap: 16px;
    width: calc(100% + 20px);
    margin: 0 -10px;
    padding: 8px 10px 7px;
    overflow-x: auto;
    overscroll-behavior-x: contain;
    border-top: 1px solid rgba(255, 255, 255, 0.18);
    background: #111111;
    box-shadow: none;
    scrollbar-width: none;
  }

  body.admin-page .admin-header .admin-tabs::-webkit-scrollbar {
    display: none;
  }

  body.admin-page .admin-header .admin-tab {
    flex: 0 0 auto;
    min-width: max-content;
    min-height: 28px;
    padding: 4px 0 6px;
    border: 0;
    border-bottom: 2px solid transparent;
    background: transparent;
    color: rgba(255, 255, 255, 0.74);
    font-size: 0.68rem;
    font-weight: 500;
    white-space: nowrap;
  }

  body.admin-page .admin-header .admin-tab.is-active {
    border-bottom-color: #ffffff;
    background: transparent;
    color: #ffffff;
  }

  body.admin-page main.admin-shell {
    width: min(100% - 16px, 1280px);
    padding-top: 12px;
    padding-bottom: calc(18px + env(safe-area-inset-bottom, 0px));
  }

  body.admin-page .admin-shell {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  body.admin-page #adminItemsPanel .admin-sidebar {
    position: static;
    max-height: none;
    overflow: visible;
    padding-right: 0;
  }

  body.admin-page .admin-shell:not(.admin-mobile-detail-open) .admin-editor {
    display: none;
  }

  body.admin-page .admin-shell.admin-mobile-detail-open .admin-sidebar {
    display: none;
  }

  body.admin-page .admin-shell.admin-mobile-detail-open .admin-editor {
    display: block;
  }

  body.admin-page .admin-sidebar,
  body.admin-page .admin-editor {
    padding-inline: 0;
  }

  body.admin-page .admin-list-search {
    position: static;
    min-height: 42px;
    margin-bottom: 8px;
    background: #ffffff;
  }

  body.admin-page .admin-list-type-tabs {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
    margin-bottom: 8px;
  }

  body.admin-page .admin-type-tab {
    min-height: 38px;
    padding: 7px 5px 6px;
    font-size: 0.66rem;
  }

  body.admin-page .admin-count {
    margin: 7px 0;
    font-size: 0.68rem;
  }

  body.admin-page .admin-data-health {
    margin-bottom: 8px;
    padding: 8px;
    border-width: 1px;
  }

  body.admin-page .admin-data-health-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.admin-page .admin-list-actions {
    position: static;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 7px;
    margin-bottom: 9px;
    padding: 7px 0;
    background: #fafafa;
  }

  body.admin-page .admin-list-actions .admin-action {
    min-height: 40px;
    padding: 8px 5px 7px;
    font-size: 0.68rem;
  }

  body.admin-page .admin-item-list {
    max-height: none;
    gap: 8px;
    overflow: visible;
    padding-right: 0;
  }

  body.admin-page #adminItemsPanel .admin-item-button {
    grid-template-columns: 50px minmax(0, 1fr) auto;
    gap: 10px;
    min-height: 58px;
    padding: 8px;
    border-width: 1px;
    background: #ffffff;
  }

  body.admin-page .admin-item-button img {
    width: 46px;
    height: 46px;
  }

  body.admin-page .admin-item-button span {
    font-size: 0.78rem;
    line-height: 1.25;
  }

  body.admin-page #adminItemsPanel .card-display-list-status {
    align-self: center;
    min-width: 42px;
    padding: 5px 6px 4px;
    text-align: center;
    font-size: 0.6rem;
    white-space: nowrap;
  }

  body.admin-page .admin-mobile-back {
    position: sticky;
    top: 110px;
    z-index: 24;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 42px;
    margin: 0 0 10px;
    background: #ffffff;
  }

  body.admin-page .admin-editor-head {
    grid-template-columns: 72px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
    margin-bottom: 2px;
  }

  body.admin-page .admin-preview,
  body.admin-page .admin-no-image {
    width: 72px;
    height: 72px;
  }

  body.admin-page .admin-editor h2 {
    font-size: clamp(1.18rem, 6vw, 1.75rem);
    line-height: 1.15;
  }

  body.admin-page .admin-type-label,
  body.admin-page .admin-save-state {
    margin: 4px 0;
    font-size: 0.66rem;
  }

  body.admin-page #adminItemsPanel .admin-form > .admin-actions {
    position: sticky;
    bottom: calc(58px + env(safe-area-inset-bottom, 0px));
    z-index: 30;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 7px;
    margin: 8px -8px 10px;
    padding: 8px;
    border: 1px solid rgba(23, 23, 23, 0.12);
    background: rgba(255, 255, 255, 0.97);
    box-shadow: 0 -6px 18px rgba(23, 23, 23, 0.1);
  }

  body.admin-page #adminItemsPanel .admin-form > .admin-actions .admin-action {
    min-width: 0;
    min-height: 40px;
    padding: 8px 5px 7px;
    font-size: 0.64rem;
    line-height: 1.12;
  }

  body.admin-page #adminItemsPanel .admin-form > .admin-actions .admin-danger {
    grid-column: 1 / -1;
  }

  body.admin-page .admin-name-field {
    max-width: 100%;
  }

  body.admin-page .admin-name-input,
  body.admin-page .admin-field textarea,
  body.admin-page .admin-import-file {
    font-size: 0.76rem;
  }

  body.admin-page .admin-image-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
  }

  body.admin-page .admin-image-slot {
    min-height: 86px;
  }

  body.admin-page .admin-tag-select-grid,
  body.admin-page .admin-ingredient-row,
  body.admin-page .admin-recipe-fields-grid {
    grid-template-columns: 1fr;
    gap: 9px;
  }

  body.admin-page .admin-qty-row {
    grid-template-columns: minmax(0, 1fr) 72px 70px;
    gap: 6px;
  }

  body.admin-page .admin-step-row {
    grid-template-columns: minmax(0, 1fr);
  }

  body.admin-page .admin-step-actions {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  body.admin-page .admin-step-btn {
    width: auto;
  }

  body.admin-page .admin-import-head {
    grid-template-columns: minmax(0, 1fr);
    gap: 0;
  }

  body.admin-page .admin-import-titlebar {
    display: grid;
    gap: 10px;
  }

  body.admin-page .admin-import-steps,
  body.admin-page .admin-import-step {
    gap: 9px;
  }

  body.admin-page .admin-import-step {
    padding: 10px;
    border-width: 1px;
  }

  body.admin-page .admin-import-guide {
    padding: 11px;
  }

  body.admin-page .admin-import-guide ul {
    gap: 7px;
    font-size: 0.72rem;
    line-height: 1.65;
  }

  body.admin-page .admin-import-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@font-face {
  font-family: "Fusion Pixel 12px";
  src: url("/assets/fonts/fusion-pixel-12px-monospaced-latin.ttf") format("truetype");
  font-display: swap;
  font-style: normal;
  font-weight: 400 700;
  unicode-range: U+0000-00FF, U+0100-024F, U+2000-206F, U+20A0-20CF;
}

@font-face {
  font-family: "Fusion Pixel 12px";
  src: url("/assets/fonts/fusion-pixel-12px-monospaced-zh_hans.ttf") format("truetype");
  font-display: swap;
  font-style: normal;
  font-weight: 400 700;
  unicode-range: U+2E80-2EFF, U+3000-303F, U+3400-4DBF, U+4E00-9FFF, U+FF00-FFEF;
}

* {
  box-sizing: border-box;
}

[hidden] {
  display: none !important;
}

body {
  margin: 0;
  min-height: 100vh;
  background: var(--page-bg);
  color: var(--ink);
  font-family: "Fusion Pixel 12px", monospace;
  text-rendering: geometricPrecision;
  cursor: var(--cursor-default);
}

button, a, [role="button"], input[type="button"], input[type="submit"],
.admin-action, .admin-tab, .admin-type-tab, .admin-item-button,
.view-tab, .tag-button, .dish-card, .taxonomy-result-card,
.taxonomy-batch-card, .taxonomy-tag-chip, .admin-type-tab,
.skin-preset-btn {
  cursor: var(--cursor-hover);
}

button:active, a:active, [role="button"]:active,
input[type="button"]:active, input[type="submit"]:active,
.admin-action:active, .admin-tab:active, .admin-type-tab:active,
.admin-item-button:active, .view-tab:active, .tag-button:active,
.dish-card:active, .taxonomy-result-card:active,
.taxonomy-batch-card:active, .taxonomy-tag-chip:active,
.skin-preset-btn:active {
  cursor: var(--cursor-click);
}

[style*="cursor: grab"],
.dish-card[draggable="true"] {
  cursor: var(--cursor-grab);
}

.is-grabbing,
.is-grabbing * {
  cursor: var(--cursor-grabbing) !important;
}

input[type="text"],
input[type="search"],
input:not([type]),
textarea,
[contenteditable="true"] {
  cursor: var(--cursor-text);
}

.site-header {
  position: relative;
  top: 0;
  z-index: 30;
  padding: 28px 20px 22px;
  background:
    linear-gradient(90deg, transparent 0 11px, var(--soft-line) 11px 12px) 0 100% / 12px 2px repeat-x,
    var(--page-bg);
  transform: translateY(0);
  transition:
    background-color 220ms ease,
    box-shadow 220ms ease,
    padding 220ms ease,
    transform 240ms ease;
}

.site-header.is-compact {
  position: sticky;
  top: 0;
  padding: 10px 18px;
  background: #111111;
  box-shadow: 0 4px 0 rgba(0, 0, 0, 0.18);
}

.site-header.is-hidden {
  transform: translateY(-110%);
}

.site-header-inner {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  justify-items: center;
  gap: 14px;
  width: min(1540px, calc(100vw - 32px));
  margin: 0 auto;
}

.site-header.is-compact .site-header-inner {
  grid-template-columns: auto auto minmax(220px, 420px) 1fr;
  align-items: center;
  justify-items: start;
  gap: 12px;
}

.site-admin-link {
  color: var(--muted);
  font-size: 0.78rem;
  text-decoration: none;
}

.site-admin-link:hover {
  color: var(--ink);
}

.site-header.is-compact .site-admin-link,
.site-header.is-compact .site-table-link,
.site-header.is-compact .site-pantry-link,
.site-header.is-compact .site-auth-button,
.site-header.is-compact .site-user-name {
  color: #ffffff;
}

.site-header-actions {
  position: absolute;
  top: -10px;
  right: 0;
  display: flex;
  align-items: center;
  gap: 14px;
}

.site-header.is-compact .site-header-actions {
  position: static;
  justify-self: end;
}

.site-account,
.site-user-menu {
  position: relative;
  display: flex;
  align-items: center;
  gap: 8px;
}

.site-user-trigger {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  max-width: 190px;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  cursor: pointer;
}

.site-avatar,
.profile-avatar {
  display: inline-grid;
  place-items: center;
  flex: 0 0 auto;
  width: 30px;
  height: 30px;
  border: 2px solid var(--ink);
  border-radius: 50%;
  background: #ffffff center / cover no-repeat;
  color: var(--ink);
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1;
}

.site-user-name {
  max-width: 140px;
  color: var(--muted);
  font-size: 0.78rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.site-user-trigger:hover .site-user-name {
  color: var(--ink);
}

.site-user-drawer {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  z-index: 30;
  min-width: 148px;
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 2px solid var(--ink);
  background: var(--panel-bg);
  box-shadow: 4px 4px 0 var(--soft-shadow);
}

.site-user-drawer[hidden] {
  display: none;
}

.site-user-drawer.is-compact-open {
  position: fixed;
  top: calc(env(safe-area-inset-top, 0px) + 52px);
  right: 8px;
  z-index: 280;
}

.site-drawer-action {
  width: 100%;
  display: block;
  padding: 9px 10px;
  border: 2px solid var(--ink);
  background: #ffffff;
  color: var(--ink);
  font: inherit;
  font-size: 0.78rem;
  text-decoration: none;
  text-align: center;
  cursor: pointer;
}

.site-drawer-action:hover {
  transform: translateY(-1px);
}

.site-drawer-danger {
  border-color: #9f1d1d;
  background: #dc2f2f;
  color: #ffffff;
}

.site-drawer-danger:hover {
  background: #bf2424;
}

.site-table-link,
.site-pantry-link,
.site-auth-button {
  color: var(--muted);
  font: inherit;
  font-size: 0.78rem;
  background: none;
  border: 0;
  padding: 0;
  cursor: pointer;
}

.site-table-link:hover,
.site-pantry-link:hover,
.site-auth-button:hover {
  color: var(--ink);
}

.site-table-link,
.site-pantry-link {
  display: none;
}

.site-header.is-compact .site-table-link {
  display: inline;
}

@media (min-width: 641px) {
  .site-header.is-compact .site-pantry-link {
    display: inline;
  }
}

.auth-modal,
.site-confirm-modal,
.table-ingredient-modal {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: grid;
  place-items: center;
  padding: 20px;
  background: rgba(0, 0, 0, 0.42);
}

.avatar-modal {
  position: fixed;
  inset: 0;
  z-index: 90;
  display: grid;
  place-items: center;
  padding: 20px;
  background: rgba(0, 0, 0, 0.42);
}

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

.auth-modal[hidden] {
  display: none;
}

.site-confirm-modal[hidden],
.table-ingredient-modal[hidden] {
  display: none;
}

.auth-modal-card,
.avatar-modal-card,
.site-confirm-card,
.table-ingredient-modal-card {
  position: relative;
  width: min(420px, 100%);
  padding: 26px;
  border: 3px solid var(--ink);
  background: var(--panel-bg);
  box-shadow: 8px 8px 0 var(--soft-shadow);
}

.avatar-modal-card {
  width: min(560px, 100%);
}

.recipe-edit-modal-card {
  width: min(920px, 100%);
  max-height: min(86vh, 820px);
  overflow: auto;
}

#recipeEditTitle {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-right: 34px;
}

.recipe-edit-title-thumb {
  width: 34px;
  height: 34px;
  object-fit: contain;
  image-rendering: pixelated;
  image-rendering: crisp-edges;
}

.auth-modal-card h2,
.avatar-modal-card h2,
.site-confirm-card h2,
.table-ingredient-modal-card h2 {
  margin: 0 0 8px;
  font-size: 1.2rem;
}

.auth-subtitle,
.auth-message,
.site-confirm-message,
.table-ingredient-modal-text {
  margin: 0 0 16px;
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.6;
  white-space: pre-line;
}

.site-confirm-actions,
.table-ingredient-modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.site-confirm-actions .admin-action,
.table-ingredient-modal-actions .admin-action {
  min-height: 36px;
}

.recipe-edit-form,
.recipe-edit-body {
  display: grid;
  gap: 16px;
}

.recipe-edit-section {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid var(--soft-line);
  background: rgba(255, 255, 255, 0.72);
}

.recipe-edit-basic {
  grid-template-columns: 1fr;
}

.recipe-edit-field {
  display: grid;
  gap: 6px;
  color: var(--ink);
  font-size: 0.78rem;
  font-weight: 700;
}

.recipe-edit-field:first-child,
.recipe-edit-field:has(textarea) {
  grid-column: 1 / -1;
}

.recipe-edit-input,
.recipe-edit-ingredient-row input {
  width: 100%;
  min-height: 38px;
  padding: 8px 10px;
  border: var(--input-border);
  border-radius: var(--input-radius);
  background: var(--input-bg);
  color: var(--ink);
  font: inherit;
  font-size: 0.82rem;
}

.recipe-edit-input:focus-visible,
.recipe-edit-ingredient-row input:focus-visible {
  border-color: var(--input-focus-border);
  outline: none;
  box-shadow: var(--input-focus-shadow);
}

.recipe-edit-input:is(textarea) {
  min-height: 96px;
  resize: vertical;
  line-height: 1.5;
}

.recipe-edit-section h3 {
  margin: 0;
  color: var(--ink);
  font-size: 0.95rem;
}

.recipe-edit-select-field {
  min-width: 0;
}

.recipe-edit-multi-select {
  width: 100%;
}

.recipe-edit-multi-select .admin-multi-select-input {
  box-sizing: border-box;
  width: 100%;
}

.recipe-edit-cooking-grid {
  margin: 0;
}

.recipe-edit-section-head {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
}

.recipe-edit-ingredient-rows {
  display: grid;
  gap: 8px;
}

.recipe-edit-ingredient-row {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) 88px 88px auto;
  gap: 8px;
  align-items: stretch;
}

.recipe-edit-ingredient-row .recipe-edit-ingredient-select {
  min-width: 0;
}

.recipe-edit-ingredient-row .admin-multi-select-input {
  min-height: 38px;
}

.recipe-edit-mini-btn {
  min-height: 36px;
  padding: 7px 10px;
  border: 2px solid var(--ink);
  background: var(--page-bg);
  color: var(--ink);
  font: inherit;
  font-size: 0.74rem;
  font-weight: 700;
  cursor: pointer;
}

.recipe-edit-add-btn {
  justify-self: start;
  margin-top: 2px;
}

.recipe-edit-remove-ingredient-btn {
  width: 36px;
  min-width: 36px;
  padding: 0;
  border-color: var(--ink);
  background: var(--danger);
  color: #ffffff;
  font-size: 1rem;
  line-height: 1;
}

.recipe-edit-remove-ingredient-btn:hover {
  background: #d83232;
}

.recipe-edit-tag-groups {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 10px;
}

.recipe-edit-steps-section .admin-action {
  margin: 0;
}

.recipe-edit-steps-list {
  gap: 8px;
}

.recipe-edit-steps-section .admin-step-del {
  border-color: var(--ink);
}

.recipe-edit-dish-select-section > .recipe-edit-dish-select {
  max-width: 100%;
}

.recipe-edit-dish-chip-grid {
  margin-top: 8px;
}

.recipe-edit-actions {
  position: sticky;
  bottom: -26px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  margin: 4px -26px -26px;
  padding: 14px 26px;
  border-top: 1px solid var(--soft-line);
  background: var(--panel-bg);
}

.recipe-edit-action-spacer {
  flex: 1 1 auto;
}

.recipe-edit-restore-btn {
  margin-right: auto;
}

@media (max-width: 640px) {
  .recipe-edit-modal-card {
    width: 100%;
    max-height: 90vh;
    padding: 18px;
  }

  .recipe-edit-basic,
  .recipe-edit-dish-select-section {
    grid-template-columns: 1fr;
  }

  .recipe-edit-ingredient-row {
    grid-template-columns: minmax(116px, 1fr) 54px 44px 30px;
    gap: 5px;
  }

  .recipe-edit-ingredient-row input {
    min-height: 36px;
    padding-inline: 6px;
    font-size: 0.76rem;
  }

  .recipe-edit-ingredient-row .admin-multi-select-input {
    min-height: 36px;
    padding-inline: 7px 22px;
  }

  .recipe-edit-ingredient-row .recipe-edit-ingredient-select.is-open .admin-multi-select-input {
    border-bottom-color: #d7d7d7;
  }

  .recipe-edit-ingredient-select .admin-multi-select-dropdown {
    right: auto;
    width: min(216px, calc(100vw - 72px));
    max-width: calc(100vw - 72px);
  }

  .recipe-edit-ingredient-select .admin-ingredient-search {
    box-sizing: border-box;
    display: block;
    width: calc(100% - 8px);
    max-width: calc(100% - 8px);
  }

  .recipe-edit-ingredient-select .admin-multi-select-option-label {
    overflow: visible;
    text-overflow: clip;
    white-space: normal;
    line-height: 1.18;
  }

  .recipe-edit-ingredient-row .admin-multi-select-chip {
    max-width: 100%;
    padding: 4px 16px 4px 6px;
    font-size: 0.72rem;
    line-height: 1.18;
  }

  .recipe-edit-ingredient-row .admin-multi-select-chip-remove {
    top: -5px;
    right: -5px;
    width: 16px;
    height: 16px;
    font-size: 0.68rem;
  }

  .recipe-edit-remove-ingredient-btn {
    width: 30px;
    min-width: 30px;
    min-height: 36px;
    padding: 0;
  }

  .recipe-edit-add-btn {
    width: 100%;
    justify-content: center;
  }

  .recipe-edit-actions {
    bottom: -18px;
    margin: 4px -18px -18px;
    padding: 12px 18px;
  }
}

.auth-form {
  display: grid;
  gap: 12px;
}

.auth-form label {
  display: grid;
  gap: 6px;
  font-size: 0.78rem;
}

.auth-form input {
  width: 100%;
  padding: 10px 12px;
  border: var(--input-border);
  border-radius: var(--input-radius);
  font: inherit;
  background: var(--input-bg);
}

.auth-form input:focus-visible {
  border-color: var(--input-focus-border);
  outline: none;
  box-shadow: var(--input-focus-shadow);
}

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

.auth-password-wrap input {
  padding-right: 44px;
}

.auth-password-toggle {
  position: absolute;
  top: 50%;
  right: 8px;
  width: 28px;
  height: 28px;
  margin-top: -14px;
  display: grid;
  place-items: center;
  border: 0;
  background: transparent;
  color: var(--ink);
  font: inherit;
  font-size: 0.95rem;
  line-height: 1;
  cursor: pointer;
}

.auth-password-toggle:hover {
  transform: translateY(-1px);
}

.auth-submit,
.auth-switch,
.auth-close {
  border: 2px solid var(--ink);
  background: #ffffff;
  color: var(--ink);
  font: inherit;
  cursor: pointer;
}

.avatar-choice-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(64px, 1fr));
  gap: 12px;
  max-height: min(420px, 56vh);
  overflow: auto;
  padding: 2px;
}

.avatar-choice {
  aspect-ratio: 1;
  border: 2px solid var(--ink);
  border-radius: 50%;
  background: #ffffff center / cover no-repeat;
  color: var(--ink);
  font: inherit;
  font-size: 1.6rem;
  font-weight: 700;
  cursor: pointer;
}

.avatar-choice:hover,
.avatar-choice:focus-visible {
  outline: none;
  transform: translateY(-2px);
  box-shadow: 3px 3px 0 var(--soft-shadow);
}

.avatar-choice-upload {
  background: #ffffff;
}

.profile-view {
  min-height: calc(100vh - 92px);
  padding: 34px var(--page-padding) 72px;
}

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

.profile-shell {
  width: min(820px, 100%);
  margin: 0 auto;
}

.profile-head {
  display: flex;
  align-items: center;
  gap: 18px;
  margin-bottom: 22px;
}

.profile-head h1 {
  margin: 0;
  font-size: clamp(1.5rem, 3vw, 2.4rem);
}

.profile-back {
  padding: 9px 12px;
  border: 2px solid var(--ink);
  background: #ffffff;
  color: var(--ink);
  font: inherit;
  cursor: pointer;
}

.profile-card {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 26px;
  padding: 24px;
  border: 3px solid var(--ink);
  background: var(--panel-bg);
  box-shadow: 8px 8px 0 var(--soft-shadow);
}

.profile-avatar-block {
  display: grid;
  align-content: start;
  justify-items: center;
  gap: 14px;
}

.profile-avatar-button {
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
}

.profile-avatar {
  width: 128px;
  height: 128px;
  font-size: 2.2rem;
}

.profile-fields {
  display: grid;
  gap: 14px;
}

.profile-fields label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 0.82rem;
}

.profile-fields input {
  width: 100%;
  padding: 11px 12px;
  border: var(--input-border);
  border-radius: var(--input-radius);
  background: var(--input-bg);
  color: var(--ink);
  font: inherit;
}

.profile-fields input:focus-visible {
  border-color: var(--input-focus-border);
  outline: none;
  box-shadow: var(--input-focus-shadow);
}

.profile-fields input:read-only,
.profile-fields input:disabled {
  background: var(--input-readonly-bg);
  color: var(--muted);
}

.profile-form-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.profile-view.is-modal {
  position: fixed;
  inset: 0;
  z-index: 320;
  display: grid;
  place-items: center;
  min-height: 100dvh;
  padding: 18px;
  background: rgba(17, 17, 17, 0.42);
}

.profile-view.is-modal[hidden] {
  display: none !important;
}

.profile-view.is-modal .profile-shell {
  width: min(460px, 100%);
  max-height: calc(100dvh - 36px);
  overflow: auto;
  padding: 20px;
  border: 2px solid var(--ink);
  border-radius: 10px;
  background: #ffffff;
  box-shadow: 0 16px 40px rgba(17, 17, 17, 0.22);
}

.profile-view.is-modal .profile-head {
  margin-bottom: 16px;
}

.profile-view.is-modal .profile-card {
  grid-template-columns: 1fr;
  gap: 18px;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.profile-view.is-modal .profile-avatar-block {
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  justify-items: start;
}

.profile-view.is-modal .profile-form-actions {
  justify-content: stretch;
  margin-top: 4px;
}

.profile-view.is-modal .profile-form-actions .auth-submit,
.profile-view.is-modal .profile-form-actions .site-drawer-action {
  flex: 1 1 0;
  justify-content: center;
}

.profile-message {
  min-height: 1.4em;
  margin: 0;
  color: var(--muted);
  font-size: 0.82rem;
}

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

.profile-assets-panel {
  display: grid;
  gap: 16px;
}

.profile-assets-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 5px;
  padding: 18px 20px;
  border: 3px solid var(--ink);
  background: var(--panel-bg);
  box-shadow: 5px 5px 0 var(--soft-shadow);
}

.profile-assets-head h2 {
  margin: 0;
  font-size: 1.18rem;
  line-height: 1.2;
}

.profile-assets-head p,
.profile-assets-status {
  margin: 0;
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.5;
}

.profile-assets-grid {
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
}

.profile-asset-card .dish-card-favorite-btn,
.profile-asset-card .dish-card-add-btn,
.profile-asset-card .dish-card-drag-hint {
  display: none !important;
}

.profile-asset-date {
  display: block;
  margin: 4px 14px 12px;
  color: var(--muted);
  font-size: 0.72rem;
  text-align: left;
}

.profile-image-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 14px;
}

.profile-image-card {
  position: relative;
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 2px solid var(--ink);
  background: #ffffff;
  color: var(--ink);
  font: inherit;
  text-align: left;
  cursor: pointer;
  box-shadow: 4px 4px 0 var(--soft-shadow);
}

.profile-selectable-card,
.profile-image-card {
  position: relative;
}

.profile-selectable-card::after,
.profile-image-card::after {
  content: "✓";
  position: absolute;
  top: 8px;
  right: 8px;
  z-index: 4;
  box-sizing: border-box;
  display: grid;
  place-items: center;
  width: var(--selection-check-size);
  height: var(--selection-check-size);
  border: var(--selection-check-border);
  border-radius: var(--selection-check-radius);
  background: var(--selection-check-bg);
  color: var(--selection-check-fg);
  font-size: var(--selection-check-font-size);
  font-weight: 900;
  line-height: 1;
  opacity: 0;
  pointer-events: none;
  transform: scale(0.86);
  transition:
    opacity 150ms ease,
    transform 150ms ease;
}

.profile-selectable-card.is-selected::after,
.profile-image-card.is-selected::after {
  opacity: 1;
  transform: scale(1);
}

.profile-selectable-card.is-selected,
.profile-image-card.is-selected {
  border-color: var(--ink);
  background: #f4fbf2;
  box-shadow: inset 0 0 0 2px #2f9e44;
}

.profile-asset-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

.profile-asset-actions[hidden] {
  display: none;
}

.profile-image-preview-modal {
  position: fixed;
  inset: 0;
  z-index: 390;
  display: grid;
  place-items: center;
  padding: 18px;
  background: rgba(255, 255, 255, 0.78);
  backdrop-filter: blur(10px);
}

.profile-image-preview-modal[hidden] {
  display: none;
}

.profile-image-preview-card {
  position: relative;
  display: grid;
  gap: 14px;
  width: min(960px, 100%);
  max-height: calc(100dvh - 36px);
  color: var(--ink);
}

.profile-image-preview-card img {
  width: 100%;
  max-height: calc(100dvh - 120px);
  background: #ffffff;
  object-fit: contain;
  touch-action: pan-y;
}

.profile-image-preview-close {
  position: absolute;
  top: 8px;
  right: 8px;
  z-index: 2;
  width: 34px;
  height: 34px;
  border: 2px solid #ffffff;
  background: rgba(0, 0, 0, 0.5);
  color: #ffffff;
  font: inherit;
  font-size: 1.2rem;
  line-height: 1;
}

.profile-image-preview-caption h2,
.profile-image-preview-caption p {
  margin: 0;
}

.profile-image-preview-caption {
  display: grid;
  gap: 7px;
}

.profile-image-preview-caption h2 {
  line-height: 1.15;
}

.profile-image-preview-caption p {
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.45;
}

.profile-image-card img {
  width: 100%;
  aspect-ratio: 1 / 1;
  border: 1px solid rgba(23, 23, 23, 0.12);
  background: #f7f7f7;
  object-fit: cover;
}

.profile-image-card strong {
  overflow: hidden;
  font-size: 0.86rem;
  line-height: 1.25;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.profile-image-card span {
  color: var(--muted);
  font-size: 0.72rem;
}

.profile-empty-state {
  grid-column: 1 / -1;
  padding: 34px 12px;
  color: var(--muted);
  font-size: 0.9rem;
  text-align: center;
}

.auth-submit {
  padding: 11px 14px;
  background: var(--ink);
  color: #ffffff;
}

.auth-switch {
  width: 100%;
  margin-top: 12px;
  padding: 10px 12px;
}

.auth-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 30px;
  height: 30px;
  padding: 0;
  line-height: 1;
}

.site-logo {
  display: inline-block;
  margin: 0;
  font-size: clamp(1.35rem, 3.2vw, 2.35rem);
  line-height: 1;
  letter-spacing: 0;
  text-align: center;
  color: #111111;
  text-decoration: none;
  text-shadow:
    2px 2px 0 #ededed,
    4px 4px 0 #d7d7d7;
  transition:
    color 220ms ease,
    font-size 220ms ease,
    text-shadow 220ms ease;
}

.site-header.is-compact .site-logo {
  color: #ffffff;
  font-size: 1.04rem;
  text-shadow: none;
}

main {
  width: min(1540px, calc(100% - 32px));
  margin: 0 auto;
  padding: 28px 0 56px;
}

body.menu-card-layout main {
  width: min(1540px, calc(100% - 32px));
}

.view-switcher {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin: 0;
  transition: gap 220ms ease;
}

.mobile-header-tabs {
  display: none;
}

.site-header.is-compact .view-switcher {
  justify-content: flex-start;
  gap: 6px;
}

.site-header.is-compact #showTableView {
  display: none;
}

@media (min-width: 641px) {
  .site-header.is-compact #showPantryView {
    display: none;
  }
}

.view-tab {
  appearance: none;
  min-width: 76px;
  padding: 8px 12px 7px;
  border: 2px solid var(--ink);
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font-family: inherit;
  font-size: 0.82rem;
  line-height: 1.2;
  cursor: pointer;
  transition:
    color 180ms ease,
    background-color 180ms ease,
    border-color 180ms ease,
    transform 180ms ease;
}

.view-tab:hover {
  transform: translateY(-1px);
}

.view-tab.is-active {
  background: var(--ink);
  color: #ffffff;
}

.site-header.is-compact .view-tab {
  min-width: 54px;
  padding: 7px 9px 6px;
  border-color: #ffffff;
  background: transparent;
  color: #ffffff;
}

.site-header.is-compact .view-tab.is-active {
  background: #ffffff;
  color: #111111;
}

.site-table-link,
.site-pantry-link {
  position: relative;
}

.site-table-badge {
  position: absolute;
  top: -10px;
  right: -14px;
  display: grid;
  place-items: center;
  min-width: 18px;
  height: 18px;
  padding: 0 4px;
  border: 2px solid currentColor;
  background: var(--danger);
  color: #ffffff;
  font-size: 0.62rem;
  line-height: 1;
}

.header-search-area {
  width: min(560px, 100%);
  transition: width 220ms ease;
}

.site-header.is-compact .header-search-area {
  width: 100%;
}

.search-panel {
  position: relative;
  display: grid;
  gap: 14px;
  width: min(520px, 100%);
  margin: 0 auto;
}

.search-label {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
}

.search-input {
  width: 100%;
  margin: 0 auto;
  padding: 13px 48px 12px 14px;
  border: var(--input-border-strong);
  border-radius: var(--input-radius);
  background: var(--input-bg);
  color: var(--ink);
  font: inherit;
  font-size: 0.95rem;
  line-height: 1.2;
  text-align: center;
  outline: none;
}

.header-search-icon {
  position: absolute;
  top: 7px;
  right: 7px;
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 0;
  background-color: var(--ink);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='19' height='19' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.5-3.5'/%3E%3C/svg%3E");
  background-position: center;
  background-repeat: no-repeat;
  background-size: 19px 19px;
  pointer-events: none;
}

.search-input:focus {
  box-shadow: var(--input-focus-shadow);
}

.search-suggestions {
  position: absolute;
  z-index: 30;
  top: 54px;
  left: 50%;
  display: grid;
  width: min(520px, 100%);
  max-height: min(340px, calc(100vh - 160px));
  overflow: auto;
  transform: translateX(-50%);
  border: 1px solid rgba(23, 23, 23, 0.16);
  background: var(--panel-bg);
  box-shadow: 0 10px 28px rgba(23, 23, 23, 0.12);
}

.search-suggestion-item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  width: 100%;
  min-height: 54px;
  padding: 8px 12px;
  border: 0;
  border-bottom: 1px solid rgba(23, 23, 23, 0.08);
  border-radius: 0;
  background: transparent;
  color: var(--ink);
  font: inherit;
  font-size: 0.82rem;
  line-height: 1.25;
  text-align: left;
  cursor: pointer;
}

.search-suggestion-image {
  width: 38px;
  height: 38px;
  object-fit: contain;
}

.search-suggestion-name {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.search-suggestion-text {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.search-suggestion-meta {
  display: block;
  overflow: hidden;
  color: var(--muted);
  font-size: 0.66rem;
  line-height: 1.2;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.search-suggestion-item:last-child {
  border-bottom: 0;
}

.search-suggestion-item:hover,
.search-suggestion-item:focus-visible {
  background: rgba(23, 23, 23, 0.04);
  outline: none;
}

.site-header.is-compact .search-panel {
  display: block;
}

.site-header.is-compact .search-input {
  width: 100%;
  padding: 8px 10px 7px;
  border: 2px solid #ffffff;
  background: rgba(255, 255, 255, 0.12);
  color: #ffffff;
  text-align: left;
}

.site-header.is-compact .search-input::placeholder {
  color: rgba(255, 255, 255, 0.72);
}

.site-header.is-compact .search-suggestions {
  top: calc(100% + 6px);
  width: 100%;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.16);
}

.site-header.is-compact .active-row {
  display: none;
}

.active-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 28px;
}

.results-count,
.clear-button,
.tag-group-title,
.tag-button,
.category-filter-button,
.quick-filter-button,
.selected-tag {
  font-size: 0.78rem;
  line-height: 1.25;
}

.results-count {
  color: var(--muted);
}

.clear-button,
.tag-button,
.category-filter-button,
.quick-filter-button,
.selected-tag {
  appearance: none;
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font-family: inherit;
  cursor: pointer;
}

.clear-button {
  position: relative;
  min-height: 29px;
  padding: 6px 10px 5px;
  border: 2px solid var(--ink);
  background: #e53e3e;
  color: #fff;
}

.clear-button:hover {
  background: #c53030;
  border-color: var(--ink);
}

.clear-button[hidden] {
  display: none;
}

.primary-filter-strip {
  display: grid;
  gap: 9px;
  margin: 0 0 16px;
}

.primary-quick-strip {
  margin-bottom: 22px;
}

.filter-strip-title {
  margin: 0;
  color: var(--muted);
  font-size: 0.78rem;
  line-height: 1.2;
  text-align: left;
}

.category-filter-list,
.quick-filter-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 7px;
}

.category-filter-button,
.quick-filter-button {
  padding: 6px 9px 5px;
  border: 2px solid #d7d7d7;
}

.layout-shell {
  display: grid;
  grid-template-columns: 0 minmax(0, 1fr);
  gap: 0;
  align-items: start;
  transition: grid-template-columns 180ms ease, gap 180ms ease;
}

body.filters-open .layout-shell {
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 22px;
}

.filter-sidebar {
  position: sticky;
  top: var(--filter-bar-top, 12px);
  max-height: calc(100vh - var(--filter-bar-top, 12px) - 12px);
  overflow: hidden auto;
  opacity: 0;
  pointer-events: none;
  transform: translateX(-10px);
  transition: opacity 140ms ease, transform 140ms ease;
}

body.filters-open .filter-sidebar {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(0);
}

.sidebar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin: 0 0 12px;
}

.sidebar-header h2 {
  margin: 0;
  color: var(--ink);
  font-size: 0.9rem;
  line-height: 1.2;
}

.menu-area {
  position: relative;
  min-width: 0;
}

.floating-filter-bar {
  position: static;
  top: auto;
  z-index: 20;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 8px;
  margin: 0 0 16px;
  padding: 4px 8px;
  width: 100%;
  max-width: 100%;
  background: transparent;
  border: 1px solid transparent;
  box-shadow: none;
  transition: background-color 160ms ease, border-color 160ms ease, box-shadow 160ms ease;
}

body.header-compact .floating-filter-bar {
  position: sticky;
  top: var(--filter-bar-top, 12px);
}

body.filter-bar-raised .floating-filter-bar {
  background: rgba(255, 255, 255, 0.98);
  border-color: rgba(23, 23, 23, 0.08);
  box-shadow: 0 8px 22px rgba(23, 23, 23, 0.08);
  backdrop-filter: blur(8px);
}

.filter-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  min-width: 86px;
  padding: 5px 10px 4px;
  border: 2px solid var(--ink);
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font-family: inherit;
  font-size: 0.78rem;
  line-height: 1.2;
  cursor: pointer;
}

.desktop-facet-bar {
  position: relative;
  flex: 1 1 auto;
  min-width: 0;
}

.ingredient-desktop-facet-bar {
  position: relative;
  display: flex;
  align-items: center;
  flex: 1 1 auto;
  gap: 18px;
  min-width: 0;
}

.ingredient-role-tabs {
  display: inline-flex;
  align-items: center;
  flex: 0 0 auto;
  gap: 7px;
}

.ingredient-role-tab {
  appearance: none;
  min-height: 28px;
  padding: 5px 10px 4px;
  border: 2px solid #d7d7d7;
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font-family: inherit;
  font-size: 0.78rem;
  line-height: 1.2;
  cursor: pointer;
}

.ingredient-role-tab:hover {
  transform: translateY(-1px);
}

.ingredient-role-tab.is-active {
  border-color: var(--ink);
  background: var(--ink);
  color: #ffffff;
}

.ingredient-desktop-facet-scroll {
  display: flex;
  align-items: center;
  flex: 1 1 auto;
  gap: 24px;
  min-width: 0;
  overflow-x: auto;
  padding: 8px 0 1px;
  scrollbar-width: none;
}

.ingredient-desktop-facet-scroll::-webkit-scrollbar {
  display: none;
}

.ingredient-desktop-facet-popover {
  position: absolute;
  z-index: 45;
  top: calc(100% + 8px);
  display: grid;
  gap: 10px;
  width: min(420px, calc(100vw - 32px));
  max-height: min(420px, calc(100vh - var(--filter-bar-top, 12px) - 72px));
  overflow: hidden;
  padding: 12px;
  border: 1px solid rgba(23, 23, 23, 0.14);
  border-radius: 10px;
  background: #ffffff;
  box-shadow: 0 12px 30px rgba(23, 23, 23, 0.14);
}

.ingredient-desktop-facet-popover[hidden] {
  display: none;
}

.desktop-facet-scroll {
  display: flex;
  align-items: center;
  gap: 24px;
  min-width: 0;
  overflow-x: auto;
  padding: 8px 0 1px;
  scrollbar-width: none;
}

.desktop-facet-scroll::-webkit-scrollbar {
  display: none;
}

.desktop-facet-group {
  display: inline-flex;
  align-items: center;
  flex: 0 0 auto;
  gap: 8px;
  min-height: 30px;
}

.desktop-facet-chip {
  appearance: none;
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-height: 24px;
  padding: 4px 2px 3px;
  border: 0;
  border-bottom: 2px solid #d7d7d7;
  border-radius: 0;
  background: transparent;
  color: var(--ink);
  font-family: inherit;
  font-size: 0.76rem;
  line-height: 1.1;
  white-space: nowrap;
  cursor: pointer;
}

.desktop-facet-chip::after {
  content: "";
  width: 0;
  height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid currentColor;
  transform: translateY(1px);
}

.desktop-facet-chip[aria-expanded="true"],
.desktop-facet-chip.is-active {
  border-color: var(--selection-soft-border);
  background: var(--selection-soft-bg);
  color: var(--selection-pill-fg);
}

.desktop-facet-chip[aria-expanded="true"]::after {
  transform: translateY(1px) rotate(180deg);
}

.desktop-facet-selected-tags {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.desktop-facet-selected-tags:empty {
  display: none;
}

.desktop-facet-selected-tag {
  min-height: 25px;
  padding: 4px 20px 3px 7px;
  font-size: 0.72rem;
}

.desktop-facet-popover {
  position: absolute;
  z-index: 45;
  top: calc(100% + 8px);
  display: grid;
  gap: 10px;
  width: min(420px, calc(100vw - 32px));
  max-height: min(420px, calc(100vh - var(--filter-bar-top, 12px) - 72px));
  overflow: hidden;
  padding: 12px;
  border: 1px solid rgba(23, 23, 23, 0.14);
  border-radius: 10px;
  background: #ffffff;
  box-shadow: 0 12px 30px rgba(23, 23, 23, 0.14);
}

.desktop-facet-popover[hidden] {
  display: none;
}

.desktop-facet-popover-title {
  color: var(--muted);
  font-size: 0.72rem;
  line-height: 1.2;
}

.desktop-facet-options {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  max-height: min(280px, calc(100vh - var(--filter-bar-top, 12px) - 190px));
  overflow: auto;
}

.desktop-facet-option {
  appearance: none;
  min-height: var(--selection-option-min-height);
  padding: 5px 8px;
  border: 2px solid var(--selection-muted-border);
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font-family: inherit;
  font-size: 0.78rem;
  line-height: 1.25;
  cursor: pointer;
}

.desktop-facet-option:hover {
  transform: translateY(-1px);
}

.desktop-facet-option.is-active {
  border-color: var(--selection-active-border);
  background: var(--selection-active-bg);
  color: var(--selection-active-fg);
}

.desktop-facet-popover-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  padding-top: 2px;
  border-top: 1px solid rgba(23, 23, 23, 0.08);
}

.desktop-facet-popover-clear,
.desktop-facet-popover-confirm {
  appearance: none;
  min-height: 29px;
  border-radius: 0;
  font-family: inherit;
  font-size: 0.78rem;
  line-height: 1.25;
  cursor: pointer;
}

.desktop-facet-popover-clear {
  border: 2px solid var(--ink);
  background: #e53e3e;
  color: #ffffff;
}

.desktop-facet-popover-clear:hover {
  background: #c53030;
  border-color: var(--ink);
  transform: translateY(-1px);
}

.desktop-facet-popover-confirm {
  border: 2px solid var(--ink);
  background: var(--ink);
  color: #ffffff;
}

.selected-tags {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  flex: 0 1 auto;
  gap: 7px;
  min-height: 29px;
  max-width: 36%;
  overflow: hidden;
}

#menuView .floating-filter-bar > .selected-tags {
  display: none;
}

#ingredientsView .floating-filter-bar > .selected-tags {
  display: none;
}

.selected-tag-group {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 5px;
}

.selected-tag-group:not(:last-child)::after {
  content: "";
  display: inline-block;
  width: 2px;
  height: 18px;
  background: var(--soft-line);
  margin-left: 4px;
}

.selected-tag-group-name {
  font-size: 0.72rem;
  color: var(--muted);
  padding: 4px 2px;
  line-height: 1;
}

.selected-tag {
  position: relative;
  min-height: var(--selection-pill-min-height);
  padding: 6px 22px 5px 8px;
  border: 2px solid var(--selection-pill-border);
  background: var(--selection-pill-bg);
  color: var(--selection-pill-fg);
  font-family: inherit;
  cursor: pointer;
}

.selected-tag-close {
  position: absolute;
  top: -8px;
  right: -8px;
  display: grid;
  place-items: center;
  width: 17px;
  height: 17px;
  border: 2px solid var(--selection-pill-border);
  background: var(--panel-bg);
  color: var(--selection-pill-fg);
  font-size: 0.72rem;
  line-height: 1;
}

body.filters-open .filter-toggle {
  background: var(--ink);
  color: #ffffff;
}

.sidebar-close {
  appearance: none;
  padding: 5px 7px;
  border: 2px solid #d7d7d7;
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font-family: inherit;
  font-size: 0.68rem;
  line-height: 1.2;
  cursor: pointer;
}

.tag-groups {
  display: grid;
  gap: 14px;
}

.tag-group {
  display: grid;
  gap: 7px;
  align-items: start;
}

.tag-group-title {
  margin: 0;
  color: var(--muted);
  font-weight: 700;
  text-align: left;
}

.tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.tag-button {
  padding: 5px 8px;
  border: 2px solid #d7d7d7;
}

.tag-button:hover,
.category-filter-button:hover,
.quick-filter-button:hover,
.selected-tag:hover,
.clear-button:hover,
.filter-toggle:hover,
.sidebar-close:hover {
  transform: translateY(-1px);
}

.tag-button.is-active,
.category-filter-button.is-active,
.quick-filter-button.is-active {
  border-color: var(--selection-active-border);
  background: var(--selection-active-bg);
  color: var(--selection-active-fg);
}

.advanced-filter-panel {
  display: grid;
  gap: 12px;
}

.advanced-filter-panel summary {
  cursor: pointer;
  color: var(--muted);
  font-size: 0.78rem;
  line-height: 1.25;
  list-style-position: inside;
}

.advanced-filter-panel[open] summary {
  margin-bottom: 12px;
}

.menu-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(var(--tile-size), 1fr));
  gap: 16px 10px;
  align-items: start;
}

.catalog-section {
  margin: 0 0 34px;
}

.catalog-section[hidden] {
  display: none;
}

.catalog-title {
  margin: 0 0 18px;
  color: var(--ink);
  font-size: 1.05rem;
  line-height: 1.2;
  text-align: center;
}

.dish-card {
  position: relative;
  appearance: none;
  min-width: 0;
  padding: 7px 5px 5px;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--ink);
  font: inherit;
  cursor: pointer;
}

.dish-card:hover .dish-image {
  transform: translateY(-3px);
}

.dish-card-badge,
.dish-card-tagline,
.dish-card-highlights,
.dish-card-meta {
  display: none;
}

#menuView.menu-style-card .menu-grid {
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  gap: 10px;
}

#favoritesView .menu-grid {
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  gap: 10px;
}

#ingredientsView .ingredient-grid {
  grid-template-columns: repeat(auto-fill, minmax(var(--tile-size), 1fr));
  gap: 16px 10px;
}

body.menu-card-layout #ingredientsView .ingredient-grid {
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  gap: 10px;
}

#myPantryView .pantry-grid {
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  gap: 10px;
}

#menuView.menu-style-card .menu-area {
  min-width: 0;
}

.favorites-layout,
body.filters-open .favorites-layout {
  grid-template-columns: minmax(0, 1fr);
  gap: 0;
}

.favorites-area {
  min-width: 0;
}

#menuView.menu-style-card .dish-card,
#favoritesView .dish-card {
  display: flex;
  flex-direction: column;
  min-height: 370px;
  padding: 14px 12px 12px;
  border: var(--food-card-border);
  border-radius: var(--food-card-radius);
  background: var(--food-card-bg);
  box-shadow: var(--food-card-shadow);
}

#ingredientsView .ingredient-card,
#myPantryView .ingredient-card {
  display: flex;
  flex-direction: column;
  min-height: 260px;
  padding: 14px 12px 12px;
  border: var(--food-card-border);
  border-radius: var(--food-card-radius);
  background: var(--food-card-bg);
  text-align: center;
  box-shadow: var(--food-card-shadow);
}

#menuView.menu-style-card .dish-card:hover,
#favoritesView .dish-card:hover,
#ingredientsView .ingredient-card:hover,
#myPantryView .ingredient-card:hover {
  border-color: var(--food-card-border-hover);
  box-shadow: var(--food-card-hover-shadow);
}

#menuView.menu-style-card .dish-card:focus-visible {
  outline-offset: 3px;
}

#menuView.menu-style-card .dish-image-wrap,
#favoritesView .dish-image-wrap,
#ingredientsView .ingredient-card .dish-image-wrap,
#myPantryView .ingredient-card .dish-image-wrap {
  overflow: hidden;
  min-height: var(--food-card-image-size);
  background: var(--food-card-image-bg);
}

#menuView.menu-style-card .dish-image,
#favoritesView .dish-image,
#ingredientsView .ingredient-card .dish-image,
#myPantryView .ingredient-card .dish-image {
  width: min(var(--food-card-image-size), 100%);
  height: min(var(--food-card-image-size), 100%);
}

#menuView.menu-style-card .dish-name {
  min-height: 24px;
  margin-top: 10px;
  font-size: 0.94rem;
  line-height: 1.28;
  text-align: left;
}

#favoritesView .dish-name {
  min-height: 24px;
  margin-top: 10px;
  font-size: 0.94rem;
  line-height: 1.28;
  text-align: left;
}

#ingredientsView .ingredient-card .dish-name,
#myPantryView .ingredient-card .dish-name {
  min-height: 24px;
  margin-top: 10px;
  font-size: 0.94rem;
  line-height: 1.28;
  text-align: left;
}

#menuView.menu-style-card .dish-card-badge {
  position: absolute;
  top: 8px;
  left: 8px;
  z-index: 1;
  display: inline-grid;
  place-items: center;
  max-width: calc(100% - 54px);
  min-height: 24px;
  padding: 5px 8px 4px;
  color: #fff;
  font-size: 0.64rem;
  line-height: 1;
  text-align: left;
  white-space: nowrap;
}

#favoritesView .dish-card-badge {
  position: absolute;
  top: 8px;
  left: 8px;
  z-index: 1;
  display: inline-grid;
  place-items: center;
  max-width: calc(100% - 54px);
  min-height: 24px;
  padding: 5px 8px 4px;
  color: #fff;
  font-size: 0.64rem;
  line-height: 1;
  text-align: left;
  white-space: nowrap;
}

#menuView.menu-style-card .dish-card-user-recipe-badge {
  background: #171717;
}

#favoritesView .dish-card-user-recipe-badge {
  background: #171717;
}

#menuView.menu-style-card .dish-card-user-recipe-badge + .dish-card-badge:not(.dish-card-user-recipe-badge),
#favoritesView .dish-card-user-recipe-badge + .dish-card-badge:not(.dish-card-user-recipe-badge) {
  top: 36px;
}

#menuView.menu-style-card .dish-card-tagline,
#favoritesView .dish-card-tagline {
  display: -webkit-box;
  min-height: 40px;
  margin: 6px 0 9px;
  overflow: hidden;
  color: var(--muted);
  font-size: 0.74rem;
  line-height: 1.45;
  text-align: left;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

#menuView.menu-style-card .dish-card-highlights,
#favoritesView .dish-card-highlights {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  min-height: 23px;
  margin-bottom: 9px;
}

#menuView.menu-style-card .dish-card-highlights span,
#favoritesView .dish-card-highlights span {
  padding: 4px 6px 3px;
  border: 1px solid #d7d7d7;
  background: #fff;
  color: var(--ink);
  font-size: 0.62rem;
  line-height: 1;
}

#menuView.menu-style-card .dish-card-meta,
#favoritesView .dish-card-meta {
  display: grid;
  gap: 4px;
  margin-top: auto;
  padding-top: 9px;
  border-top: 1px solid #ededed;
  color: var(--muted);
  font-size: 0.68rem;
  line-height: 1.35;
  text-align: left;
}

#menuView.menu-style-card .dish-card-drag-hint,
#favoritesView .dish-card-drag-hint {
  margin-top: 8px;
}

#menuView.menu-style-card .dish-card-add-btn,
#favoritesView .dish-card-add-btn {
  right: 12px;
  bottom: 12px;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

#ingredientsView .ingredient-card .dish-card-add-btn {
  right: 12px;
  bottom: 12px;
}

#menuView.menu-style-card .dish-card-add-btn.is-checked,
#favoritesView .dish-card-add-btn.is-checked {
  background: var(--selection-check-bg);
  color: var(--selection-check-fg);
  border: var(--selection-check-border);
}

.ingredient-card,
.seasoning-card {
  cursor: default;
}

.ingredient-role-line {
  min-height: 18px;
  margin: -4px 0 2px;
  color: var(--muted);
  font-size: 0.62rem;
  line-height: 1.3;
  text-align: center;
}

#ingredientsView .ingredient-role-line {
  margin: 4px 0 0;
  text-align: center;
}

.ingredient-card .dish-image,
.seasoning-card .dish-image {
  clip-path: inset(2px 0 0);
}

.dish-card:focus-visible {
  outline: 2px solid #d7d7d7;
  outline-offset: 4px;
}

.detail-back:focus-visible {
  outline: 2px solid #d7d7d7;
  outline-offset: 3px;
}

.dish-image-wrap {
  position: relative;
  display: grid;
  place-items: center;
  width: 100%;
  min-height: 114px;
}

.dish-image {
  display: block;
  width: min(138px, 100%);
  height: min(138px, 100%);
  object-fit: contain;
  transition: transform 120ms ease;
}

.dish-image,
.detail-image {
  image-rendering: crisp-edges;
  image-rendering: pixelated;
}

.dish-name {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  margin: 2px 0 0;
  padding: 0 4px;
  color: var(--ink);
  font-size: 0.9rem;
  font-weight: 700;
  line-height: 1.45;
  text-align: center;
  overflow-wrap: anywhere;
}

.status {
  margin: 34px 0 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.5;
  text-align: center;
}

.status:empty {
  display: none;
}

.detail-view {
  width: min(1540px, 100%);
  margin: 0 auto;
}

.detail-back {
  appearance: none;
  position: sticky;
  top: var(--filter-bar-top, 12px);
  z-index: 12;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0 0 20px;
  padding: 8px 12px 7px;
  border: 2px solid #d7d7d7;
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font-family: inherit;
  font-size: 0.82rem;
  line-height: 1.2;
  cursor: pointer;
  box-shadow: 2px 2px 0 var(--soft-shadow);
}

.detail-back:hover {
  transform: translateY(-1px);
}

.detail-shell {
  display: grid;
  grid-template-columns: minmax(340px, 38%) minmax(360px, 1fr) minmax(240px, 300px);
  gap: 30px;
  align-items: start;
}

.detail-media {
  position: sticky;
  top: var(--filter-bar-top, 72px);
  display: grid;
  gap: 14px;
  place-items: center;
  min-height: 0;
}

.detail-image-frame {
  display: grid;
  place-items: center;
  width: 100%;
  aspect-ratio: 1 / 1;
  padding: 28px;
  background:
    linear-gradient(90deg, transparent 0 15px, var(--soft-line) 15px 16px) 0 0 / 16px 16px,
    linear-gradient(0deg, transparent 0 15px, var(--soft-line) 15px 16px) 0 0 / 16px 16px,
    var(--page-bg);
}

.detail-image-track {
  display: flex;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.detail-image-slide {
  flex: 0 0 100%;
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
}

.detail-image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.detail-image-dots {
  display: none;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.detail-image-dot {
  appearance: none;
  width: 8px;
  height: 8px;
  min-width: 8px;
  min-height: 8px;
  flex: 0 0 8px;
  padding: 0;
  border: 1.5px solid var(--ink);
  border-radius: 50%;
  background: transparent;
  cursor: pointer;
}

.detail-image-dot.is-active {
  background: var(--ink);
}

.detail-thumb-strip {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 0;
  flex-wrap: wrap;
}

.detail-thumb {
  appearance: none;
  width: 64px;
  height: 64px;
  padding: 3px;
  border: 2px solid #d7d7d7;
  border-radius: 0;
  background: var(--panel-bg);
  cursor: pointer;
  transition: border-color 0.12s;
  display: grid;
  place-items: center;
}

.detail-thumb:hover {
  border-color: var(--ink);
}

.detail-thumb.is-active {
  border-color: var(--ink);
}

.detail-thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  image-rendering: crisp-edges;
  image-rendering: pixelated;
}

.detail-thumb-upload {
  border-style: dashed;
  background:
    linear-gradient(90deg, transparent 0 7px, rgba(23, 23, 23, 0.08) 7px 8px) 0 0 / 8px 8px,
    linear-gradient(0deg, transparent 0 7px, rgba(23, 23, 23, 0.08) 7px 8px) 0 0 / 8px 8px,
    #ffffff;
  color: var(--ink);
  font-size: 1.35rem;
  font-weight: 700;
  line-height: 1;
}

.detail-thumb-upload:disabled {
  cursor: default;
  opacity: 0.55;
}

.detail-content {
  min-width: 0;
  padding-top: 6px;
}

.detail-content h2 {
  margin: 0 0 6px;
  color: var(--ink);
  font-size: clamp(2.2rem, 5vw, 4.4rem);
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: 0;
}

.detail-edited-note {
  margin: -2px 0 12px;
  color: var(--muted);
  font-size: 0.78rem;
  line-height: 1.35;
}

.detail-edited-note[hidden] {
  display: none;
}

.detail-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 12px;
}

.detail-action-row {
  display: grid;
  gap: 10px;
  margin: 0;
}

.detail-action-btn {
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 48px;
  padding: 12px 18px;
  border: 2px solid var(--ink);
  border-radius: 0;
  background: var(--page-bg);
  color: var(--ink);
  font: inherit;
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  cursor: pointer;
  transition: background 150ms ease, color 150ms ease, box-shadow 150ms ease;
}

.action-primary,
[data-action-role="primary"],
.action-danger,
[data-action-role="danger"],
.action-secondary,
[data-action-role="secondary"],
.action-selected,
[data-action-state="selected"] {
  --action-role-bg: var(--action-secondary-bg);
  --action-role-fg: var(--action-secondary-fg);
}

.action-primary,
[data-action-role="primary"] {
  --action-role-bg: var(--action-primary-bg);
  --action-role-fg: var(--action-primary-fg);
}

.action-danger,
[data-action-role="danger"] {
  --action-role-bg: var(--action-danger-bg);
  --action-role-fg: var(--action-danger-fg);
}

.action-selected,
[data-action-state="selected"] {
  --action-role-bg: var(--action-selected-bg);
  --action-role-fg: var(--action-selected-fg);
}

.detail-action-btn:hover {
  box-shadow: 2px 2px 0 var(--ink);
}

.detail-table-btn {
  background: var(--action-primary-bg);
  color: var(--action-primary-fg);
}

.detail-table-btn:hover {
  background: #333;
  border-color: #333;
  color: var(--page-bg);
  box-shadow: 2px 2px 0 #333;
}

.detail-table-btn.is-added {
  background: var(--action-selected-muted-bg);
  border-color: var(--action-selected-muted-bg);
  color: var(--action-primary-fg);
}

.detail-customize-btn {
  background: var(--action-custom-bg);
}

.detail-favorite-btn.is-favorite {
  background: #f6c94f;
}

.detail-bag-btn {
  background: var(--page-bg);
  color: var(--ink);
}

.detail-bag-btn:hover {
  background: #f5f5f5;
}

.detail-tag {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 6px 9px 5px;
  border: 2px solid #d7d7d7;
  color: var(--ink);
  font-size: 0.78rem;
  line-height: 1.2;
}

.detail-summary {
  margin: 0 0 14px;
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.65;
}

.detail-purchase-panel {
  position: sticky;
  top: var(--filter-bar-top, 72px);
  padding: 16px;
  border: 1px solid rgba(23, 23, 23, 0.12);
  background: #ffffff;
  box-shadow: 0 5px 16px rgba(23, 23, 23, 0.07);
}

.detail-purchase-title {
  margin: 0 0 8px;
  color: var(--ink);
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1.25;
}

.detail-purchase-hint {
  margin: 0 0 14px;
  color: var(--muted);
  font-size: 0.74rem;
  line-height: 1.55;
}

.recipe-facts {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin: 0 0 18px;
}

.recipe-fact {
  min-width: 0;
  padding: 10px;
  background: #f7f7f7;
}

.recipe-fact-label {
  display: block;
  margin: 0 0 6px;
  color: var(--muted);
  font-size: 0.72rem;
  line-height: 1.2;
}

.recipe-fact strong {
  display: block;
  color: var(--ink);
  font-size: 0.92rem;
  line-height: 1.25;
}

.recipe-section {
  margin: 0 0 18px;
}

.recipe-section h3,
.ingredient-group h3 {
  margin: 0 0 8px;
  color: var(--ink);
  font-size: 0.95rem;
  line-height: 1.25;
}

.ingredients-section-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  margin: 0 0 8px;
}

.ingredients-section-head h3 {
  margin: 0;
}

.mobile-recipe-edit-link {
  display: none;
}

.recipe-section p,
.recipe-steps li {
  margin: 0;
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.65;
}

.ingredient-item {
  margin: 0;
}

.ingredient-empty {
  margin: 0;
  color: var(--muted);
  font-size: 0.72rem;
  line-height: 1.5;
}

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

.ingredient-group {
  min-width: 0;
  padding: 0;
  background: transparent;
}

.ingredient-items {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(88px, 1fr));
  gap: 8px;
}

.ingredient-item {
  position: relative;
  display: grid;
  gap: 5px;
  min-width: 0;
  overflow: hidden;
  padding: 6px;
  background: #ffffff;
  border: 1px solid var(--soft-line);
}

.ingredient-corner-badge {
  position: absolute;
  top: 9px;
  left: -21px;
  z-index: 2;
  display: grid;
  place-items: center;
  width: 74px;
  height: 17px;
  color: #ffffff;
  font-size: 0.54rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0;
  pointer-events: none;
  transform: rotate(-45deg);
  transform-origin: center;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.75), 0 2px 4px rgba(23, 23, 23, 0.18);
}

.ingredient-corner-badge.is-owned {
  background: #111111;
}

.ingredient-corner-badge.is-bagged {
  background: #1f8f49;
}

.ingredient-item-image-wrap {
  display: grid;
  place-items: center;
  aspect-ratio: 1 / 1;
  background: #f7f7f7;
}

.ingredient-item-image {
  width: 82%;
  height: 82%;
  object-fit: contain;
  image-rendering: crisp-edges;
  image-rendering: pixelated;
}

.ingredient-item-text {
  display: grid;
  gap: 2px;
  min-width: 0;
  text-align: center;
}

.ingredient-item-text strong {
  color: var(--ink);
  font-size: 0.68rem;
  line-height: 1.25;
}

.ingredient-item-text span {
  color: var(--muted);
  font-size: 0.6rem;
  line-height: 1.25;
}

.recipe-steps ol {
  display: grid;
  gap: 7px;
  margin: 0;
  padding-left: 1.35em;
}

.detail-recommendations {
  display: grid;
  gap: 26px;
  margin-top: 34px;
  padding-top: 24px;
  border-top: 1px solid var(--soft-line);
}

.detail-recommendation-section {
  margin: 0;
}

.detail-recommendation-section h3 {
  margin-bottom: 14px;
  font-size: 1rem;
}

.detail-dish-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 12px;
}

.detail-dish-chip {
  appearance: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 12px 10px 10px;
  background: var(--panel-bg);
  border: 1px solid var(--soft-line);
  cursor: pointer;
  font: inherit;
}

.detail-dish-chip:hover {
  background: #f7f7f7;
}

.detail-dish-chip img {
  display: block;
  width: min(104px, 100%);
  height: 104px;
  object-fit: contain;
  image-rendering: crisp-edges;
  image-rendering: pixelated;
}

.detail-dish-chip span {
  font-size: 0.68rem;
  color: var(--ink);
  text-align: center;
  line-height: 1.2;
  word-break: break-all;
}

@media (max-width: 1100px) {
  .detail-shell {
    grid-template-columns: minmax(300px, 42%) minmax(0, 1fr);
  }

  .detail-purchase-panel {
    position: static;
    grid-column: 1 / -1;
  }

  .detail-action-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.admin-page {
  --tile-size: 118px;
}

.table-fab {
  position: fixed;
  right: 20px;
  bottom: 28px;
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  background: var(--panel-bg);
  color: var(--ink);
  border: 2px solid var(--ink);
  border-radius: 0;
  cursor: pointer;
  box-shadow: 4px 4px 0 var(--soft-shadow);
  transition: transform 150ms ease, box-shadow 150ms ease;
}

.table-fab:hover {
  transform: translate(-1px, -1px);
  box-shadow: 5px 5px 0 var(--soft-shadow);
}

.table-fab.is-drop-target {
  transform: translate(-2px, -2px);
  background: var(--ink);
  color: var(--page-bg);
  box-shadow: 5px 5px 0 var(--soft-shadow);
}

.table-fab-badge {
  position: absolute;
  top: -4px;
  right: -4px;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 5px;
  background: var(--page-bg);
  color: var(--ink);
  border: 2px solid var(--ink);
  border-radius: 0;
  font-size: 0.68rem;
  font-weight: 700;
  line-height: 1;
  pointer-events: none;
}

.dish-card.is-dragging {
  opacity: 0.4;
}

.table-header {
  margin: 0 0 28px;
}

.table-header-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.table-header-left {
  display: flex;
  align-items: baseline;
  gap: 12px;
}

.table-header-actions {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
}

.table-records-entry {
  display: flex;
  justify-content: flex-end;
  margin-top: 8px;
}

.table-records-link {
  appearance: none;
  padding: 0 0 2px;
  border: 0;
  border-bottom: 2px solid currentColor;
  border-radius: 0;
  background: transparent;
  color: var(--ink);
  font: inherit;
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1.15;
  cursor: pointer;
}

.table-records-link:hover {
  transform: translateY(-1px);
}

.table-record-detail-tools {
  position: fixed;
  left: max(16px, calc((100vw - 720px) / 2));
  right: max(16px, calc((100vw - 720px) / 2));
  bottom: 18px;
  z-index: 215;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--mobile-action-dock-gap);
  padding: var(--mobile-action-dock-padding);
  border: var(--mobile-action-dock-border);
  border-radius: var(--mobile-action-dock-radius);
  background: var(--mobile-action-dock-bg);
  box-shadow: var(--mobile-action-dock-shadow);
}

.table-record-detail-tools[hidden] {
  display: none;
}

body.table-record-detail-view main {
  padding-bottom: 116px;
}

.table-record-edit-field {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 700;
}

.table-record-edit-field input {
  width: 100%;
  min-height: 38px;
  padding: 9px 10px;
  border: var(--input-border);
  border-radius: var(--input-radius);
  background: var(--input-bg);
  color: var(--ink);
  font: inherit;
  font-size: 0.82rem;
}

.table-record-edit-field input:focus-visible {
  border-color: var(--input-focus-border);
  outline: none;
  box-shadow: var(--input-focus-shadow);
}

.table-record-detail-actions {
  display: flex;
  gap: 8px;
}

.table-record-detail-message {
  min-height: 0;
  margin: 6px 0 0;
  padding: 0;
  color: var(--muted);
  font-size: 0.76rem;
  line-height: 1.45;
}

.table-record-detail-message:empty {
  display: none;
}

.table-record-edit-card {
  display: grid;
  gap: 14px;
}

.table-record-edit-card .table-record-edit-field input {
  min-height: 42px;
}

.table-record-time-editor {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
  margin: 0;
  padding: 0;
  border: 0;
}

.table-record-time-editor legend {
  grid-column: 1 / -1;
  margin: 0 0 2px;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 700;
}

.table-record-time-editor label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 700;
}

.table-record-time-editor input {
  width: 100%;
  min-height: 42px;
  padding: 9px 8px;
  border: var(--input-border);
  border-radius: var(--input-radius);
  background: var(--input-bg);
  color: var(--ink);
  font: inherit;
  font-size: 0.82rem;
  text-align: center;
}

.table-record-time-editor input:focus-visible {
  border-color: var(--input-focus-border);
  outline: none;
  box-shadow: var(--input-focus-shadow);
}

.table-record-edit-message {
  min-height: 1.35em;
  margin: 0;
  color: var(--muted);
  font-size: 0.76rem;
}

.pantry-bag-actions,
.pantry-owned-actions,
.favorites-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  flex: 1 1 auto;
  min-width: min(100%, 360px);
}

.pantry-bag-actions[hidden],
.pantry-owned-actions[hidden],
.favorites-actions[hidden] {
  display: none;
}

.pantry-bag-actions .admin-action,
.pantry-owned-actions .admin-action,
.favorites-actions .admin-action {
  white-space: nowrap;
}

.favorites-select-mode-btn {
  appearance: none;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 34px;
  padding: 7px 10px 6px;
  border: 0;
  background: transparent;
  color: var(--ink);
  font: inherit;
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1.15;
  white-space: nowrap;
  cursor: pointer;
}

.favorites-select-mode-btn::before {
  content: "";
  display: grid;
  place-items: center;
  width: var(--selection-check-inline-size);
  height: var(--selection-check-inline-size);
  border: var(--selection-check-border);
  border-radius: var(--selection-check-radius);
  background: #ffffff;
  color: var(--selection-check-fg);
  font-size: var(--selection-check-inline-font-size);
  font-weight: 900;
  line-height: 1;
}

.favorites-select-mode-btn.is-active::before {
  content: "✓";
  background: var(--selection-check-bg);
  color: var(--selection-check-fg);
}

.admin-action:disabled {
  cursor: default;
  opacity: 0.45;
  transform: none;
}

.table-title {
  margin: 0;
  color: var(--ink);
  font-size: clamp(2rem, 4vw, 3.4rem);
  font-weight: 700;
  line-height: 1.05;
}

.table-count {
  color: var(--muted);
  font-size: 0.82rem;
}

.table-subtitle {
  margin: 8px 0 0;
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.5;
}

.table-tools {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin: 18px 0 10px;
  padding: 0 0 14px;
  border-bottom: 1px solid var(--soft-line);
}

.table-tools-toggle {
  display: none;
}

.table-tools-content {
  display: contents;
}

#tableManagePantryBtn {
  margin-left: auto;
}

.table-hide-owned {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  min-height: 34px;
  color: var(--ink);
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1.2;
  cursor: pointer;
}

.table-hide-owned input {
  appearance: none;
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  margin: 0;
  border: 2px solid #b8b8b8;
  border-radius: 0;
  background: #f5f5f5;
  color: #ffffff;
  cursor: pointer;
  transition: background-color 150ms ease, border-color 150ms ease, box-shadow 150ms ease, transform 150ms ease;
}

.table-hide-owned input::after {
  content: "";
  width: 10px;
  height: 10px;
  background: #b8b8b8;
  transform: scale(0.72);
  transition: background-color 150ms ease, transform 150ms ease;
}

.table-hide-owned input:checked {
  border-color: var(--success);
  background: var(--success);
  box-shadow: 3px 3px 0 rgba(74, 158, 74, 0.18);
}

.table-hide-owned input:checked::after {
  background: #ffffff;
  transform: scale(1);
}

.table-hide-owned input:hover {
  transform: translate(-1px, -1px);
}

.table-hide-owned input:focus-visible {
  outline: 2px solid var(--ink);
  outline-offset: 2px;
}

.table-ingredients {
  color: var(--muted);
  font-size: 0.78rem;
  line-height: 1.5;
}

.table-section-title {
  margin: 20px 0 16px;
  padding: 0 0 6px;
  color: var(--ink);
  font-size: 0.95rem;
  line-height: 1.25;
}

.table-add-checked-btn {
  appearance: none;
  flex: 0 0 auto;
  max-width: min(260px, 100%);
  min-height: 34px;
  padding: 7px 11px 6px;
  border: 2px solid var(--ink);
  border-radius: 0;
  background: #ffffff;
  color: var(--ink);
  font: inherit;
  font-size: 0.7rem;
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
  box-shadow: 3px 3px 0 var(--soft-shadow);
  transition:
    background-color 150ms ease,
    color 150ms ease,
    box-shadow 150ms ease,
    transform 150ms ease;
}

.table-add-checked-btn:hover {
  transform: translate(-1px, -1px);
  box-shadow: 4px 4px 0 var(--soft-shadow);
}

.table-add-checked-btn:disabled {
  cursor: default;
  transform: none;
}

.table-add-checked-btn.is-idle {
  border-color: #d7d7d7;
  background: #f7f7f7;
  color: #7a7a7a;
  box-shadow: none;
}

.table-tools .table-add-checked-btn.is-ready {
  border-color: #171717;
  background: #171717;
  color: #ffffff;
  box-shadow: 3px 3px 0 var(--soft-shadow);
}

.table-tools .table-add-checked-btn.is-complete {
  border-color: var(--success);
  background: #f2fbf2;
  color: var(--success);
  box-shadow: 3px 3px 0 rgba(74, 158, 74, 0.18);
}

.table-ingredients .table-section-title:first-child {
  margin: 0 0 16px;
}

.table-ingredient-items {
  margin-bottom: 8px;
}

.table-ingredient-item {
  position: relative;
  cursor: pointer;
  transition:
    border-color 150ms ease,
    transform 150ms ease,
    box-shadow 150ms ease;
}

.table-ingredient-item:hover,
.table-ingredient-item:focus-visible {
  border-color: #d7d7d7;
  box-shadow: 2px 2px 0 var(--soft-shadow);
}

.table-ingredient-item:focus-visible {
  outline: 2px solid var(--ink);
  outline-offset: 2px;
}

.table-ingredient-item::after {
  content: "✓";
  position: absolute;
  top: 4px;
  right: 4px;
  z-index: 2;
  box-sizing: border-box;
  display: grid;
  place-items: center;
  width: var(--selection-check-compact-size);
  height: var(--selection-check-compact-size);
  border: var(--selection-check-compact-border);
  border-radius: var(--selection-check-radius);
  background: var(--selection-check-bg);
  color: var(--selection-check-fg);
  font-size: var(--selection-check-compact-font-size);
  font-weight: 900;
  line-height: 1;
  opacity: 0;
  transform: scale(0.86);
  transition:
    opacity 150ms ease,
    transform 150ms ease;
}

.table-ingredient-item.is-checked::after {
  opacity: 0.9;
  transform: scale(1);
}

.dish-card-qty {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 0.68rem;
  line-height: 1.3;
  text-align: center;
}

.dish-card-drag-hint {
  display: block;
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 0.55rem;
  text-align: center;
  opacity: 0;
  transition: opacity 200ms ease;
}

.dish-card:hover .dish-card-drag-hint {
  opacity: 0.7;
}

.dish-card-add-btn {
  position: absolute;
  right: 4px;
  bottom: 4px;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  padding: 0;
  background: transparent;
  color: var(--ink);
  border: 0;
  border-radius: 0;
  font: inherit;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  opacity: 0;
  transition: opacity 150ms ease, transform 150ms ease;
}

.dish-card-favorite-btn {
  position: absolute;
  top: 3px;
  right: 3px;
  z-index: 3;
  display: inline-grid;
  place-items: center;
  width: 32px;
  height: 32px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: #ffffff;
  font: inherit;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  appearance: none;
  opacity: 0;
  text-shadow: none;
  transition: opacity 150ms ease, transform 150ms ease, color 150ms ease;
  -webkit-tap-highlight-color: transparent;
}

.favorite-star-icon {
  display: block;
  width: 16px;
  height: 16px;
  overflow: visible;
}

.favorite-star-shape {
  fill: #ffffff;
  stroke: var(--ink);
  stroke-width: 7px;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.dish-card-favorite-btn:focus:not(:focus-visible) {
  outline: none;
}

.dish-card:hover .dish-card-favorite-btn,
.dish-card:focus-within .dish-card-favorite-btn,
.dish-card-favorite-btn.is-favorite {
  opacity: 1;
}

.dish-card-favorite-btn:hover {
  transform: scale(1.12);
}

.dish-card-favorite-btn.is-favorite {
  color: #f6c94f;
}

.dish-card-favorite-btn.is-favorite .favorite-star-shape {
  fill: #f6c94f;
}

@media (hover: none) {
  .dish-card-favorite-btn {
    opacity: 1;
  }
}

.dish-card:hover .dish-card-add-btn,
.dish-card:focus-within .dish-card-add-btn {
  opacity: 1;
}

.dish-card-add-btn:hover {
  transform: scale(1.15);
}

.dish-card-add-btn.is-checked {
  opacity: 0.85;
  background: var(--selection-check-bg);
  color: var(--selection-check-fg);
  border: var(--selection-check-border);
  border-radius: var(--selection-check-radius);
  font-size: var(--selection-check-font-size);
}

@media (hover: none) {
  .dish-card-add-btn {
    width: 28px;
    height: 28px;
    font-size: 1rem;
    opacity: 1;
  }

  .dish-card-add-btn.is-checked {
    opacity: 0.85;
  }
}

.table-remove-btn,
.pantry-remove-btn {
  --card-remove-current-size: var(--card-remove-size);
  --card-remove-current-line-size: var(--card-remove-line-size);
  position: absolute;
  top: 8px;
  right: auto;
  left: 8px;
  z-index: 4;
  display: grid;
  place-items: center;
  width: var(--card-remove-current-size);
  height: var(--card-remove-current-size);
  min-width: var(--card-remove-current-size);
  min-height: var(--card-remove-current-size);
  margin: 0;
  padding: 0;
  border: var(--card-remove-border);
  border-radius: 50%;
  background: var(--card-remove-bg);
  box-shadow: none;
  color: transparent;
  font: inherit;
  font-size: 0;
  line-height: 1;
  cursor: pointer;
  transition:
    background-color 150ms ease,
    box-shadow 150ms ease,
    transform 150ms ease;
}

.pantry-remove-btn {
  --card-remove-current-size: var(--card-remove-small-size);
  --card-remove-current-line-size: var(--card-remove-small-line-size);
}

.table-remove-btn::before,
.table-remove-btn::after,
.pantry-remove-btn::before,
.pantry-remove-btn::after {
  content: "";
  position: absolute;
  width: var(--card-remove-current-line-size);
  height: 2px;
  border-radius: 999px;
  background: var(--card-remove-line);
}

.table-remove-btn::before,
.pantry-remove-btn::before {
  transform: rotate(45deg);
}

.table-remove-btn::after,
.pantry-remove-btn::after {
  transform: rotate(-45deg);
}

.table-remove-btn:hover,
.table-remove-btn:focus-visible,
.pantry-remove-btn:hover,
.pantry-remove-btn:focus-visible {
  border: var(--card-remove-hover-border);
  background: var(--card-remove-hover-bg);
}

.table-remove-btn:focus-visible,
.pantry-remove-btn:focus-visible {
  outline: 2px solid var(--ink);
  outline-offset: 2px;
}

.table-remove-btn:active,
.pantry-remove-btn:active {
  transform: translate(1px, 1px);
}

@media (min-width: 641px) {
  #myTableView {
    position: relative;
    display: grid;
    grid-template-columns: minmax(220px, 0.78fr) minmax(340px, 1.22fr);
    gap: 22px 24px;
    align-items: start;
  }

  #myTableView::after {
    content: "";
    grid-column: 1;
    grid-row: 3 / 8;
    justify-self: end;
    align-self: stretch;
    width: 1px;
    background: var(--soft-line);
    pointer-events: none;
  }

  #myTableView > .detail-back,
  #myTableView > .table-header {
    grid-column: 1 / -1;
  }

  #myTableView > .detail-back {
    justify-self: start;
    margin-bottom: -8px;
  }

  #tableSelectedPanel {
    grid-column: 1;
    grid-row: 3 / span 6;
    min-width: 0;
    padding-right: 18px;
  }

  #tableGrid {
    grid-template-columns: repeat(auto-fill, minmax(118px, 1fr));
  }

  #tableIngredients,
  #tableTools,
  #tableMainIngredients,
  #tableAuxIngredients,
  #tableSeasoningIngredients {
    grid-column: 2;
    min-width: 0;
  }

  #tableTools {
    grid-row: 3;
    justify-content: flex-start;
    margin: 0 0 2px;
  }

  #tableIngredients {
    grid-row: 4;
  }

  #tableMainIngredients {
    grid-row: 5;
  }

  #tableAuxIngredients {
    grid-row: 6;
  }

  #tableSeasoningIngredients {
    grid-row: 7;
  }

  #myTableView .table-section-title {
    margin-top: 0;
  }
}

#myPantryView {
  width: 100%;
  margin: 0;
  padding: 10px 0 88px;
}

.pantry-mode-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

.pantry-mode-tab {
  position: relative;
  min-height: 34px;
  padding: 8px 24px 7px 12px;
  border: 2px solid var(--ink);
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font: inherit;
  font-size: 0.78rem;
  line-height: 1.2;
  cursor: pointer;
}

#myPantryView .pantry-mode-tab {
  padding: 8px 24px 7px 12px;
}

.pantry-mode-tab:hover {
  transform: translateY(-1px);
}

.pantry-mode-tab.is-active {
  background: var(--ink);
  color: #ffffff;
}

.pantry-mode-badge {
  position: absolute;
  top: -8px;
  right: -8px;
  display: grid;
  place-items: center;
  min-width: 20px;
  height: 20px;
  padding: 0 5px;
  border: 2px solid var(--ink);
  border-radius: 999px;
  background: #ffffff;
  color: var(--ink);
  font-size: 0.62rem;
  font-weight: 700;
  line-height: 1;
}

.pantry-mode-tab.is-active .pantry-mode-badge {
  border-color: var(--ink);
  background: var(--success);
  color: #ffffff;
}

.table-records-pane {
  display: grid;
  gap: 12px;
}

.table-records-pane[hidden] {
  display: none;
}

.table-records-list {
  display: grid;
  gap: 12px;
}

.table-record-card {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 2px solid var(--ink);
  border-radius: 4px;
  background: #ffffff;
  cursor: pointer;
}

.table-record-card:hover {
  transform: translateY(-1px);
}

.table-record-card:focus-visible {
  outline: 2px solid var(--ink);
  outline-offset: 3px;
}

.table-record-card-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}

.table-record-card-controls {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  min-width: 0;
}

.table-record-expand-btn {
  appearance: none;
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  flex: 0 0 auto;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--ink);
  font: inherit;
  font-size: 0.86rem;
  font-weight: 900;
  line-height: 1;
  cursor: pointer;
}

.table-record-expand-btn:hover {
  transform: translateY(-1px);
}

.table-record-expand-btn:focus-visible {
  outline: 2px solid var(--ink);
  outline-offset: 2px;
}

.table-record-card h3 {
  min-width: 0;
  flex: 1 1 auto;
  margin: 0;
  overflow: hidden;
  font-size: 1rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.table-record-meta,
.table-record-count {
  color: var(--muted);
  font-size: 0.72rem;
}

.table-record-meta {
  white-space: nowrap;
}

.table-record-count {
  margin: 0;
}

.table-record-dishes {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  min-width: 0;
}

.table-record-card:not(.is-expanded) .table-record-dishes {
  flex-wrap: nowrap;
  overflow: hidden;
  padding-right: 28px;
}

.table-record-card:not(.is-expanded).has-more-dishes .table-record-dishes::after {
  content: "...";
  position: absolute;
  top: 0;
  right: 0;
  display: grid;
  place-items: center;
  width: 34px;
  min-height: 38px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0), #ffffff 32%);
  color: var(--ink);
  font-size: 0.88rem;
  font-weight: 700;
}

.table-record-dish {
  appearance: none;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  max-width: 220px;
  min-height: 38px;
  padding: 5px 9px 5px 5px;
  border: 1px solid var(--soft-line);
  border-radius: 3px;
  background: #ffffff;
  color: var(--ink);
  flex: 0 0 auto;
  font: inherit;
  font-size: 0.76rem;
  line-height: 1.15;
}

button.table-record-dish {
  cursor: pointer;
}

button.table-record-dish:hover {
  border-color: var(--ink);
  transform: translateY(-1px);
}

.dish-card.is-static {
  cursor: default !important;
  pointer-events: none;
}

.dish-card.is-static:hover .dish-image {
  transform: none;
}

.table-ingredient-item.is-static {
  cursor: default !important;
  pointer-events: none;
}

.table-ingredient-item.is-static:hover,
.table-ingredient-item.is-static:focus-visible {
  border-color: var(--soft-line);
  box-shadow: none;
}

.table-ingredient-item.is-static::after {
  content: none;
  display: none;
}

.table-record-dish-image {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  flex: 0 0 auto;
  overflow: hidden;
  border-radius: 3px;
  background: #f3f3f3;
}

.table-record-dish-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.pantry-pane {
  width: 100%;
}

.pantry-add-panel {
  position: relative;
  width: min(520px, 100%);
  margin: 0 0 26px;
}

.pantry-add-panel .search-input {
  width: 100%;
  text-align: left;
}

.pantry-suggestions {
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  width: 100%;
  transform: none;
}

.pantry-section {
  margin: 0 0 30px;
}

.pantry-empty {
  padding: 28px 0;
  text-align: center;
}

.pantry-card {
  cursor: default;
}

.pantry-card.is-selectable {
  position: relative;
  cursor: pointer;
}

.pantry-card.is-selectable::after,
.favorite-selectable-card::after {
  content: "✓";
  position: absolute;
  top: 8px;
  right: 8px;
  z-index: 2;
  box-sizing: border-box;
  display: grid;
  place-items: center;
  width: var(--selection-check-size);
  height: var(--selection-check-size);
  border: var(--selection-check-border);
  border-radius: var(--selection-check-radius);
  background: var(--selection-check-bg);
  color: var(--selection-check-fg);
  font-size: var(--selection-check-font-size);
  font-weight: 900;
  line-height: 1;
  opacity: 0;
  pointer-events: none;
  transform: scale(0.86);
  transition:
    opacity 150ms ease,
    transform 150ms ease;
}

.pantry-card.is-selected,
.favorite-selectable-card.is-selected {
  border-color: var(--ink);
  background: #f4fbf2;
  box-shadow: inset 0 0 0 2px #2f9e44;
}

.pantry-card.is-selected::after,
.favorite-selectable-card.is-selected::after {
  opacity: 1;
  transform: scale(1);
}

.pantry-card.is-selected::before {
  display: none;
}

.pantry-card-fields {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 8px;
  margin-top: auto;
  padding-top: 10px;
  border-top: 1px solid var(--soft-line);
}

.pantry-card-fields label {
  display: grid;
  gap: 5px;
  color: var(--muted);
  font-size: 0.64rem;
  line-height: 1.2;
}

.pantry-card-fields input {
  width: 100%;
  min-width: 0;
  padding: 7px 8px;
  border: var(--input-border);
  border-radius: var(--input-radius);
  background: var(--input-bg);
  color: var(--ink);
  font: inherit;
  font-size: 0.72rem;
}

.pantry-card-fields input:focus-visible {
  border-color: var(--input-focus-border);
  outline: none;
  box-shadow: var(--input-focus-shadow);
}

.pantry-card-quantity {
  display: none;
}

.shopping-bag-card .pantry-card-quantity {
  display: block;
  margin-top: 5px;
  color: var(--muted);
  font-size: 0.72rem;
  line-height: 1.3;
}

.pantry-edit-fields {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 12px 0 16px;
}

.pantry-edit-fields label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 0.78rem;
  line-height: 1.2;
}

.pantry-edit-fields input {
  width: 100%;
  min-width: 0;
  padding: 10px 11px;
  border: var(--input-border);
  border-radius: var(--input-radius);
  background: var(--input-bg);
  color: var(--ink);
  font: inherit;
  font-size: 0.9rem;
}

.pantry-edit-fields input:focus-visible {
  border-color: var(--input-focus-border);
  outline: none;
  box-shadow: var(--input-focus-shadow);
}

.pantry-edit-actions {
  align-items: center;
}

.pantry-edit-remove-btn {
  margin-right: auto;
}

.pantry-bulk-edit-modal-card {
  width: min(520px, calc(100vw - 28px));
}

.pantry-bulk-edit-list {
  display: grid;
  gap: 10px;
  max-height: min(52vh, 460px);
  margin: 12px 0 16px;
  overflow-y: auto;
  padding-right: 2px;
}

.pantry-bulk-edit-row {
  display: grid;
  grid-template-columns: minmax(76px, 0.72fr) minmax(96px, 1fr) minmax(96px, 1fr);
  gap: 8px;
  align-items: end;
  padding: 9px;
  border: 1px solid var(--soft-line);
  background: #ffffff;
}

.pantry-bulk-edit-row strong {
  min-width: 0;
  overflow: hidden;
  color: var(--ink);
  font-size: 0.82rem;
  line-height: 1.25;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.pantry-bulk-edit-row label {
  display: grid;
  gap: 5px;
  color: var(--muted);
  font-size: 0.66rem;
  line-height: 1.2;
}

.pantry-bulk-edit-row input {
  width: 100%;
  min-width: 0;
  padding: 8px 9px;
  border: var(--input-border);
  border-radius: var(--input-radius);
  background: var(--input-bg);
  color: var(--ink);
  font: inherit;
  font-size: 0.78rem;
}

.pantry-bulk-edit-row input:focus-visible {
  border-color: var(--input-focus-border);
  outline: none;
  box-shadow: var(--input-focus-shadow);
}

.admin-header {
  position: sticky;
  top: 0;
  z-index: 30;
  padding: 10px 18px;
  background: #111111;
  box-shadow: 0 4px 0 rgba(0, 0, 0, 0.18);
}

.admin-header-inner {
  display: grid;
  grid-template-columns: auto auto minmax(220px, 360px) auto auto;
  align-items: center;
  gap: 12px;
  width: min(1540px, calc(100vw - 32px));
  margin: 0 auto;
}

.admin-logo {
  display: inline-block;
  margin: 0;
  color: #ffffff;
  font-size: 1.04rem;
  line-height: 1;
  text-decoration: none;
  text-shadow: none;
}

.admin-user-menu {
  position: relative;
  justify-self: end;
  display: block;
  color: #ffffff;
  font-size: 0.78rem;
}

.admin-user-trigger {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 30px;
  padding: 2px 0;
  border: 0;
  background: transparent;
  color: #ffffff;
  font: inherit;
  cursor: pointer;
}

.admin-user-name {
  max-width: 150px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-avatar {
  display: inline-grid;
  place-items: center;
  flex: 0 0 auto;
  width: 26px;
  height: 26px;
  border: 1px solid #ffffff;
  border-radius: 50% !important;
  background: #ffffff center / cover no-repeat;
  color: #111111;
  font-size: 0.62rem;
  font-weight: 700;
  line-height: 1;
}

.admin-user-drawer {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  z-index: 120;
  display: grid;
  gap: 4px;
  width: 144px;
  padding: 6px;
  border: 2px solid var(--ink);
  background: #ffffff;
  box-shadow: 4px 4px 0 var(--soft-shadow);
}

.admin-user-drawer[hidden] {
  display: none;
}

.admin-drawer-action {
  display: flex;
  align-items: center;
  min-height: 34px;
  padding: 8px 9px 7px;
  border: 0;
  background: transparent;
  color: var(--ink);
  font: inherit;
  font-size: 0.72rem;
  line-height: 1.2;
  text-align: left;
  text-decoration: none;
  cursor: pointer;
}

.admin-drawer-action:hover {
  background: var(--ink);
  color: #ffffff;
}

.admin-drawer-danger {
  color: #c92a2a;
}

.admin-header-tools {
  position: relative;
  display: block;
}

.admin-shell {
  display: grid;
  grid-template-columns: 320px minmax(0, 1fr);
  gap: 28px;
  width: min(1540px, calc(100% - 32px));
}

.admin-sidebar,
.admin-editor {
  min-width: 0;
}

#adminItemsPanel .admin-sidebar {
  position: sticky;
  top: 82px;
  align-self: start;
  max-height: calc(100vh - 98px);
  overflow: auto;
  padding-right: 4px;
}

.admin-type-tabs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 12px;
}

.admin-list-type-tabs {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-bottom: 14px;
}

.admin-type-tab,
.admin-item-button,
.admin-action {
  appearance: none;
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font-family: inherit;
  cursor: pointer;
}

.admin-type-tab {
  padding: 8px 9px 7px;
  border: 2px solid var(--ink);
  font-size: 0.78rem;
  line-height: 1.2;
}

.admin-type-tab.is-active,
.admin-item-button.is-active,
.admin-save {
  background: var(--action-primary-bg);
  color: var(--action-primary-fg);
}

.ingredient-entity-summary,
.ingredient-source-list {
  display: grid;
  gap: 10px;
}

.ingredient-entity-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.ingredient-entity-chip {
  border: 2px solid var(--ink);
  padding: 6px 8px 5px;
  background: var(--panel-bg);
  color: var(--ink);
  font-size: 0.74rem;
  line-height: 1;
}

.ingredient-role-editor {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.ingredient-role-option {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: 2px solid var(--line);
  padding: 7px 9px 6px;
  background: #ffffff;
  color: var(--ink);
  font-size: 0.76rem;
  line-height: 1;
  cursor: pointer;
}

.ingredient-role-option:has(input:checked) {
  border-color: var(--ink);
  background: var(--ink);
  color: #ffffff;
}

.ingredient-role-option input {
  accent-color: var(--ink);
}

.ingredient-entity-meta,
.ingredient-source-file {
  margin: 0;
  color: var(--muted);
  font-size: 0.72rem;
  line-height: 1.6;
}

.ingredient-source-card {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  border: 2px solid var(--line);
  padding: 8px;
  background: var(--panel-bg);
}

.ingredient-source-card img {
  width: 56px;
  height: 56px;
  object-fit: contain;
  image-rendering: pixelated;
  image-rendering: crisp-edges;
}

.ingredient-source-label {
  margin: 0 0 3px;
  color: var(--ink);
  font-size: 0.78rem;
  line-height: 1.35;
}

.admin-search {
  width: 100%;
  padding: 11px 10px 10px;
  border: 2px solid var(--ink);
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font: inherit;
  font-size: 0.78rem;
  outline: none;
  margin-bottom: 8px;
}

.admin-header .admin-search {
  margin: 0;
  padding: 8px 10px 7px;
  border-color: #ffffff;
  background: rgba(255, 255, 255, 0.12);
  color: #ffffff;
  text-align: left;
}

.admin-header .admin-search::placeholder {
  color: rgba(255, 255, 255, 0.72);
}

.admin-sidebar > .admin-search {
  margin-bottom: 12px;
}

.admin-list-search {
  margin-bottom: 12px;
}

.admin-setting-search-results {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  z-index: 80;
  display: grid;
  gap: 6px;
  padding: 8px;
  border: 2px solid var(--ink);
  background: #ffffff;
  box-shadow: 4px 4px 0 rgba(0, 0, 0, 0.22);
}

.admin-setting-search-item {
  display: grid;
  gap: 4px;
  width: 100%;
  padding: 8px;
  border: 1px solid #e3e3e3;
  background: #f8f8f8;
  color: var(--ink);
  font: inherit;
  text-align: left;
  cursor: pointer;
}

.admin-setting-search-item:hover,
.admin-setting-search-item:focus-visible {
  border-color: var(--ink);
  background: var(--ink);
  color: #ffffff;
  outline: none;
}

.admin-setting-search-item strong,
.admin-setting-search-item span {
  display: block;
}

.admin-setting-search-item strong {
  font-size: 0.75rem;
  line-height: 1.2;
}

.admin-setting-search-item span,
.admin-setting-search-empty {
  margin: 0;
  color: var(--muted);
  font-size: 0.66rem;
  line-height: 1.35;
}

.admin-setting-search-item:hover span,
.admin-setting-search-item:focus-visible span {
  color: rgba(255, 255, 255, 0.78);
}

.admin-setting-search-empty {
  padding: 8px;
}

.admin-count,
.admin-type-label,
.admin-save-state {
  margin: 10px 0;
  color: var(--muted);
  font-size: 0.76rem;
  line-height: 1.4;
}

.admin-new-item {
  width: 100%;
  margin-bottom: 10px;
  padding: 8px;
  text-align: center;
  font-size: 0.78rem;
}

.admin-data-health {
  display: grid;
  gap: 8px;
  margin-bottom: 10px;
  padding: 10px;
  border: 2px solid #d7d7d7;
  background: #ffffff;
}

.admin-data-health-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  color: var(--muted);
  font-size: 0.72rem;
}

.admin-data-health-head strong {
  color: #2f9e44;
  font-size: 0.72rem;
  white-space: nowrap;
}

.admin-data-health-head strong.is-bad {
  color: #c92a2a;
}

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

.admin-data-health-metric {
  min-width: 0;
  padding: 6px;
  border: 1px solid #e3e3e3;
  background: #f8f8f8;
}

.admin-data-health-metric strong,
.admin-data-health-metric span {
  display: block;
}

.admin-data-health-metric strong {
  color: var(--ink);
  font-size: 0.9rem;
  line-height: 1;
}

.admin-data-health-metric span {
  margin-top: 4px;
  color: var(--muted);
  font-size: 0.62rem;
  line-height: 1.2;
}

.admin-data-health-metric.is-bad strong {
  color: #c92a2a;
}

.admin-data-health-issues {
  display: grid;
  gap: 4px;
}

.admin-data-health-issue {
  margin: 0;
  color: #8f1d1d;
  font-size: 0.66rem;
  line-height: 1.35;
  word-break: break-word;
}

.admin-item-list {
  display: grid;
  gap: 7px;
  max-height: calc(100vh - 260px);
  overflow: auto;
  padding-right: 4px;
}

#adminItemsPanel .admin-item-list {
  max-height: none;
  overflow: visible;
  padding-right: 0;
}

.admin-item-button {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 9px;
  align-items: center;
  width: 100%;
  padding: 6px;
  border: 2px solid #d7d7d7;
  text-align: left;
}

#adminItemsPanel .admin-item-button {
  grid-template-columns: 42px minmax(0, 1fr) auto;
}

#adminCardDisplayPanel .admin-item-button {
  grid-template-columns: 42px minmax(0, 1fr) auto;
}

.admin-item-button.taxonomy-grp-item {
  grid-template-columns: 36px minmax(0, 1fr) 24px;
}

.admin-item-button img {
  width: 36px;
  height: 36px;
  object-fit: contain;
  image-rendering: crisp-edges;
  image-rendering: pixelated;
  flex-shrink: 0;
}

.taxonomy-grp-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 5px;
  background: var(--ink);
  color: #ffffff;
  font-size: 0.8rem;
  font-weight: 700;
  flex-shrink: 0;
}

.admin-item-button.is-active .taxonomy-grp-icon {
  background: #ffffff;
  color: var(--ink);
}

.admin-item-button.is-active .taxonomy-grp-drag {
  color: #ffffff;
}

.taxonomy-grp-drag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 0;
  color: var(--muted);
  font-size: 0.75rem;
  flex-shrink: 0;
  cursor: grab;
  justify-self: end;
}

.admin-item-button span {
  overflow: hidden;
  font-size: 0.78rem;
  line-height: 1.25;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.user-list-group-title {
  margin: 12px 0 2px;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 700;
}

.user-list-group-title:first-child {
  margin-top: 0;
}

.user-list-button {
  grid-template-columns: minmax(0, 1fr);
  gap: 4px;
}

.user-list-button .admin-item-meta {
  color: var(--muted);
  font-size: 0.68rem;
}

.user-list-button.is-active .admin-item-meta {
  color: rgba(255, 255, 255, 0.72);
}

.admin-editor {
  padding-bottom: 40px;
}

.admin-empty {
  display: grid;
  min-height: 320px;
  place-items: center;
  color: var(--muted);
  font-size: 0.9rem;
}

.admin-mobile-back {
  display: none;
}

.admin-form {
  display: grid;
  gap: 12px;
}

.admin-editor-head {
  display: grid;
  grid-template-columns: 108px minmax(0, 1fr);
  gap: 16px;
  align-items: center;
}

.admin-editor-head > div:last-child {
  min-width: 0;
}

.admin-preview {
  width: 108px;
  height: 108px;
  object-fit: contain;
  image-rendering: crisp-edges;
  image-rendering: pixelated;
}

.admin-no-image {
  display: grid;
  place-items: center;
  width: 108px;
  height: 108px;
  background: var(--panel-bg);
  border: 2px dashed #d7d7d7;
  color: var(--muted);
  font-size: 0.8rem;
  flex-shrink: 0;
}

.admin-name-error {
  margin: 6px 0 0;
  color: #e53e3e;
  font-size: 0.72rem;
  font-weight: 600;
}

.admin-editor h2 {
  margin: 0;
  font-size: clamp(1.5rem, 3.5vw, 2.8rem);
  line-height: 1.1;
}

.admin-field {
  display: grid;
  gap: 6px;
  margin-bottom: 6px;
}

.admin-name-field {
  max-width: 50%;
}

.admin-name-input {
  width: 100%;
  padding: 8px 10px;
  border: 2px solid var(--ink);
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font: inherit;
  font-size: 0.82rem;
  line-height: 1.55;
  outline: none;
}

.admin-image-manager {
  margin: 0 0 8px;
}

.admin-image-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(128px, 152px));
  justify-content: start;
  gap: 10px;
  max-width: none;
}

.admin-image-slot {
  position: relative;
  aspect-ratio: 1 / 1;
  border: 2px dashed #d7d7d7;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  cursor: pointer;
  background: var(--panel-bg);
}

.admin-image-slot img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  image-rendering: crisp-edges;
  image-rendering: pixelated;
}

.admin-image-slot:hover {
  border-color: var(--ink);
}

.admin-image-slot.is-cover {
  border-style: solid;
  border-color: var(--ink);
}

.admin-image-slot-add {
  border-style: dashed;
}

.admin-image-plus {
  font-size: 2rem;
  color: var(--ink);
  font-weight: 400;
  line-height: 1;
}

.admin-image-slot-placeholder {
  color: var(--muted);
  font-size: 0.65rem;
  text-align: center;
  line-height: 1.3;
}

.admin-image-badge {
  position: absolute;
  top: 4px;
  left: 4px;
  z-index: 2;
  padding: 3px 5px 2px;
  background: var(--ink);
  color: var(--page-bg);
  font-size: 0.58rem;
  line-height: 1;
}

.admin-image-controls {
  position: absolute;
  right: 4px;
  bottom: 4px;
  left: 4px;
  z-index: 2;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 3px;
}

.admin-image-control {
  appearance: none;
  min-width: 22px;
  min-height: 22px;
  padding: 3px 5px 2px;
  border: 2px solid var(--ink);
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font-family: inherit;
  font-size: 0.58rem;
  cursor: pointer;
  display: grid;
  place-items: center;
  line-height: 1;
}

.admin-image-control:disabled {
  opacity: 0.35;
  cursor: default;
}

.admin-image-delete {
  background: var(--ink);
  color: #ffffff;
}

.admin-image-delete:hover {
  background: #e53e3e;
  border-color: #e53e3e;
}

.admin-image-progress {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.6);
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  font-weight: 600;
  z-index: 3;
}

.admin-field span {
  color: var(--muted);
  font-size: 0.78rem;
  line-height: 1.2;
}

.admin-field textarea {
  width: 100%;
  resize: vertical;
  padding: 10px;
  border: 2px solid var(--ink);
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font: inherit;
  font-size: 0.82rem;
  line-height: 1.55;
  outline: none;
}

.admin-facet-fields {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.admin-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 8px;
}

.admin-action {
  padding: 9px 12px 8px;
  border: 2px solid var(--ink);
  font-size: 0.8rem;
  line-height: 1.2;
}

.admin-action:hover,
.admin-type-tab:hover,
.admin-item-button:hover {
  transform: translateY(-1px);
}

.admin-danger {
  background: var(--action-danger-bg);
  color: var(--action-danger-fg);
}

.admin-shelve {
  background: #f6c94f;
  color: #171717;
}

.admin-restore {
  background: #2f9e44;
  color: #ffffff;
}

.admin-list-actions {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: stretch;
}

.admin-list-actions .admin-action {
  margin: 0;
  min-width: 0;
  white-space: nowrap;
}

.admin-import-panel {
  display: grid;
  gap: 16px;
}

.admin-import-titlebar {
  min-width: 0;
}

.admin-import-back {
  justify-self: start;
  align-self: start;
}

.admin-import-head {
  grid-template-columns: minmax(0, 1fr);
  margin-bottom: 4px;
}

.admin-import-head h2 {
  overflow-wrap: anywhere;
}

.admin-import-steps {
  display: grid;
  gap: 12px;
}

.admin-import-step {
  display: grid;
  gap: 8px;
  padding: 14px;
  border: 2px solid var(--line);
  background: var(--panel-bg);
}

.admin-import-step strong {
  font-size: 0.92rem;
}

.admin-import-step p {
  margin: 0;
  color: var(--muted);
  font-size: 0.78rem;
  line-height: 1.6;
}

.admin-import-guide {
  gap: 12px;
  padding: 16px 18px;
}

.admin-import-guide ul {
  display: grid;
  gap: 9px;
  margin: 0;
  padding-left: 1.25rem;
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.85;
}

.admin-import-guide li {
  padding-left: 2px;
}

.admin-import-file {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  white-space: nowrap;
}

.admin-file-picker {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  margin: 4px 0 2px;
}

.admin-file-picker-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  cursor: pointer;
}

.admin-file-picker-name {
  min-width: 0;
  color: var(--muted);
  font-size: 0.78rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-import-result {
  display: grid;
  gap: 10px;
  min-height: 72px;
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.55;
}

.admin-import-summary {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
}

.admin-import-summary span {
  display: grid;
  gap: 3px;
  padding: 10px;
  border: 2px solid var(--line);
  background: #ffffff;
  color: var(--muted);
  text-align: center;
}

.admin-import-summary strong {
  color: var(--ink);
  font-size: 1.2rem;
  line-height: 1;
}

.admin-import-errors {
  display: grid;
  gap: 6px;
  max-height: 260px;
  overflow: auto;
  padding: 10px;
  border: 2px solid #e53e3e;
  background: #fff7f7;
  color: #9b2c2c;
}

.admin-import-errors p,
.admin-import-ok {
  margin: 0;
}

.admin-import-ok {
  color: #2f855a;
  font-weight: 700;
}

.admin-tabs {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin: 0 0 24px;
}

.admin-header .admin-tabs {
  justify-content: flex-start;
  gap: 6px;
  margin: 0;
}

.admin-tab {
  appearance: none;
  min-width: 88px;
  padding: 8px 20px 7px;
  border: 2px solid var(--ink);
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font-family: inherit;
  font-size: 0.95rem;
  font-weight: 600;
  line-height: 1.2;
  cursor: pointer;
  transition: all 0.15s;
}

.admin-header .admin-tab {
  min-width: 54px;
  padding: 7px 9px 6px;
  border-color: #ffffff;
  background: transparent;
  color: #ffffff;
  font-size: 0.78rem;
  font-weight: 400;
}

.admin-header .admin-tab.is-active {
  background: #ffffff;
  color: #111111;
}

.admin-tab:hover {
  transform: translateY(-1px);
}

.admin-tab.is-active {
  background: var(--ink);
  color: #ffffff;
}

.taxonomy-sidebar-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}

.taxonomy-sidebar-head h2 {
  font-size: 1rem;
  margin: 0;
}

.taxonomy-group-name-row {
  margin: 6px 0 0;
}

.taxonomy-group-name-input {
  width: 100%;
  padding: 7px 10px;
  border: 1px solid #ddd;
  border-radius: 6px;
  font-size: 1rem;
  font-family: inherit;
}

.taxonomy-tags-section {
  margin: 16px 0;
}

.taxonomy-tags-section h3 {
  font-size: 0.95rem;
  margin: 0 0 10px;
  color: #555;
}

.taxonomy-tags-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}

.taxonomy-tag-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px;
  border: 2px solid var(--ink);
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font-size: 0.78rem;
  font-family: inherit;
  cursor: pointer;
  transition: all 0.15s;
}

.taxonomy-tag-chip:hover {
  transform: translateY(-1px);
}

.taxonomy-tag-chip.is-dragging {
  opacity: 0.4;
}

.taxonomy-tag-chip.is-selected {
  background: var(--ink);
  color: #ffffff;
}

.taxonomy-tag-chip .tag-delete {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  border: 2px solid var(--ink);
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font-size: 0.72rem;
  cursor: pointer;
}

.taxonomy-tag-chip.is-selected .tag-delete {
  border-color: #ffffff;
  color: #ffffff;
}

.taxonomy-tag-chip .tag-delete:hover {
  background: var(--ink);
  color: #ffffff;
}

.taxonomy-tag-chip.is-selected .tag-delete:hover {
  background: #ffffff;
  color: var(--ink);
}

.taxonomy-tag-chip.is-drag-before {
  border-left: 3px solid var(--ink);
  padding-left: 7px;
}

.taxonomy-tag-chip.is-drag-over {
  border-right: 3px solid var(--ink);
  padding-right: 7px;
}

.taxonomy-rename-input {
  width: 80px;
  padding: 2px 4px;
  border: 1px solid #999;
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font: inherit;
  font-size: 0.78rem;
  outline: none;
}

.taxonomy-rename-input:focus {
  border-color: var(--ink);
}

.taxonomy-add-tag-row {
  display: flex;
  gap: 8px;
}

.taxonomy-add-tag-input {
  flex: 1;
  padding: 7px 10px;
  border: 1px solid #ddd;
  border-radius: 6px;
  font-size: 0.9rem;
  font-family: inherit;
}

.taxonomy-results {
  margin: 16px 0 0;
}

.taxonomy-results-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 12px 10px;
}

.taxonomy-result-card {
  appearance: none;
  min-width: 0;
  padding: 8px 6px 6px;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--ink);
  font: inherit;
  cursor: pointer;
  text-align: center;
}

.taxonomy-result-card:hover .taxonomy-result-image {
  transform: translateY(-3px);
}

.taxonomy-result-image-wrap {
  display: grid;
  place-items: center;
  width: 100%;
  min-height: 100px;
}

.taxonomy-result-image {
  display: block;
  width: min(120px, 100%);
  height: min(120px, 100%);
  object-fit: contain;
  image-rendering: crisp-edges;
  image-rendering: pixelated;
  transition: transform 120ms ease;
}

.taxonomy-result-name {
  margin: 4px 0 0;
  font-size: 0.78rem;
  line-height: 1.25;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dish-tag-groups {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.dish-tag-group {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.dish-tag-group-label {
  font-size: 0.85rem;
  font-weight: 600;
  color: #555;
}

.dish-tag-group-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.dish-tag-checkbox {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  border: 1px solid #ddd;
  border-radius: 0;
  background: #fff;
  font-size: 0.85rem;
  cursor: pointer;
  transition: all 0.15s;
  user-select: none;
}

.dish-tag-checkbox:hover {
  border-color: var(--ink);
}

.dish-tag-checkbox.is-checked {
  background: var(--ink);
  color: var(--page-bg);
  border-color: var(--ink);
}

.dish-tag-checkbox input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.admin-tag-group {
  margin-bottom: 12px;
}

.admin-tag-group-label {
  font-size: 0.8rem;
  font-weight: 600;
  color: #888;
  margin: 0 0 4px;
}

.admin-tag-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.admin-tag-chip {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border: 1px solid #ddd;
  border-radius: 0;
  background: #fff;
  font-size: 0.8rem;
  cursor: pointer;
  transition: all 0.12s;
  user-select: none;
}

.admin-tag-chip:hover {
  border-color: var(--ink);
}

.admin-tag-chip.is-selected {
  background: var(--ink);
  color: var(--page-bg);
  border-color: var(--ink);
}

.admin-section-title {
  font-size: 0.9rem;
  font-weight: 600;
  color: #555;
  margin: 20px 0 10px;
}

.admin-section {
  margin: 0;
}

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

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

.user-permission-option {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px;
  border: 2px solid var(--ink);
  background: var(--panel-bg);
  font-size: 0.82rem;
}

.user-permission-option input {
  width: 16px;
  height: 16px;
  accent-color: var(--ink);
}

.user-permission-option:has(input:disabled) {
  color: var(--muted);
  background: #f2f2f2;
}

.admin-dish-chip-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
  gap: 10px;
  margin-top: 12px;
}

.admin-dish-chip {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 8px 4px 6px;
  background: var(--panel-bg);
  border: 1px solid var(--soft-line);
}

.admin-dish-chip img {
  display: block;
  width: 56px;
  height: 56px;
  object-fit: contain;
  image-rendering: crisp-edges;
  image-rendering: pixelated;
}

.admin-dish-chip span {
  font-size: 0.7rem;
  color: var(--ink);
  text-align: center;
  line-height: 1.2;
  word-break: break-all;
}

.admin-tag-select-section {
  margin: 0 0 8px;
}

.admin-ingredient-section {
  margin: 0 0 8px;
}

.admin-ingredient-group {
  margin-bottom: 0;
}

.admin-ingredient-search {
  width: calc(100% - 8px);
  margin: 4px;
  padding: 6px 8px;
  border: none;
  border-bottom: 2px solid var(--ink);
  border-radius: 0;
  font-size: 0.8rem;
  font-family: inherit;
  background: var(--panel-bg);
  color: var(--ink);
  outline: none;
}

.admin-ingredient-list {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.admin-ingredient-more {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border: 1px dashed #ccc;
  border-radius: 0;
  background: none;
  color: #888;
  font-size: 0.8rem;
  cursor: pointer;
  font-family: inherit;
  transition: all 0.12s;
}

.admin-ingredient-more:hover {
  border-color: var(--ink);
  color: var(--ink);
}

.admin-recipe-fields {
  margin: 0 0 8px;
}

.admin-recipe-fields-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 8px;
}

.admin-field-inline {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.admin-field-inline span {
  font-size: 0.8rem;
  font-weight: 600;
  color: #888;
}

.admin-field-inline .admin-multi-select {
  width: 100%;
}

.admin-field-inline .admin-multi-select-input {
  box-sizing: border-box;
  width: 100%;
}

.admin-steps-section {
  margin: 0 0 8px;
}

.admin-steps-section textarea {
  width: 100%;
  padding: 10px 12px;
  border: 2px solid var(--ink);
  border-radius: 0;
  background: var(--page-bg);
  color: var(--ink);
  font: inherit;
  font-size: 0.82rem;
  line-height: 1.55;
  resize: vertical;
}

.admin-steps-section .admin-action {
  margin-top: 10px;
  margin-left: 28px;
}

.admin-steps-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.admin-step-row {
  display: flex;
  align-items: flex-start;
  gap: 6px;
}

.admin-step-num {
  width: 22px;
  font-size: 0.85rem;
  color: var(--ink);
  text-align: right;
  flex-shrink: 0;
}

.admin-step-input {
  flex: 1;
  min-height: 48px;
  resize: vertical;
  padding: 10px;
  border: 2px solid var(--ink);
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font: inherit;
  font-size: 0.82rem;
  line-height: 1.55;
  outline: none;
}

.admin-step-input::-webkit-resizer {
  background:
    linear-gradient(135deg, transparent 0 45%, var(--ink) 45% 55%, transparent 55%),
    linear-gradient(135deg, transparent 0 65%, var(--ink) 65% 75%, transparent 75%);
}

.admin-step-actions {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
}

.admin-step-btn {
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: 2px solid var(--ink);
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font-size: 0.78rem;
  font-family: inherit;
  cursor: pointer;
  flex-shrink: 0;
  transition: all 0.12s;
}

.admin-step-btn:hover {
  background: #f5f5f5;
}

.admin-step-del {
  border-color: #d83232;
  background: #e83a3a;
  color: #ffffff;
}

.admin-step-del:hover {
  border-color: #d83232;
  background: #d83232;
  color: #ffffff;
}

.admin-item-button.is-dragging {
  opacity: 0.4;
}

.admin-item-button.is-dragover {
  border-color: var(--ink);
  box-shadow: 3px 3px 0 var(--soft-shadow);
}

.admin-multi-select {
  position: relative;
  cursor: pointer;
  user-select: none;
}

.admin-multi-select-input {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  min-height: 38px;
  padding: 6px 28px 6px 0;
  border: none;
  border-bottom: 2px solid #d7d7d7;
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font: inherit;
  font-size: 0.85rem;
  transition: border-color 0.15s;
}

.admin-multi-select-input:hover {
  border-bottom-color: var(--ink);
}

.admin-multi-select.is-open .admin-multi-select-input {
  border-bottom-color: var(--ink);
  box-shadow: none;
}

.admin-multi-select-arrow {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 6px solid var(--ink);
  pointer-events: none;
  transition: transform 0.15s;
}

.admin-multi-select.is-open .admin-multi-select-arrow {
  transform: translateY(-50%) rotate(180deg);
}

.admin-multi-select-chip {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 6px 24px 5px 8px;
  border: 2px solid var(--ink);
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font-size: 0.78rem;
  line-height: 1.25;
  font-family: inherit;
}

.admin-field-inline .admin-multi-select-chip,
.admin-multi-select-chip {
  border-color: var(--ink);
  background: var(--panel-bg);
  color: var(--ink);
}

.admin-multi-select-chip > span {
  color: inherit;
}

.admin-multi-select-chip-remove {
  position: absolute;
  top: -8px;
  right: -8px;
  display: grid;
  place-items: center;
  width: 17px;
  height: 17px;
  border: 2px solid var(--ink);
  border-radius: 0;
  background: var(--panel-bg);
  font-size: 0.72rem;
  line-height: 1;
  cursor: pointer;
}

.admin-field-inline .admin-multi-select-chip-remove {
  color: var(--ink);
}

.admin-multi-select-chip-remove:hover {
  background: var(--ink);
  color: #ffffff;
}

.admin-multi-select-placeholder {
  color: var(--muted);
  font-size: 0.85rem;
}

.admin-multi-select-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  z-index: 100;
  max-height: 220px;
  overflow-y: auto;
  background: var(--panel-bg);
  border: 2px solid var(--ink);
  border-top: none;
  border-radius: 0;
  box-shadow: none;
}

.admin-multi-select-option {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 36px;
  padding: 6px 10px;
  font-size: 0.85rem;
  cursor: pointer;
  transition: background 0.1s;
}

.admin-multi-select.has-image-options .admin-multi-select-option {
  gap: 9px;
  padding: 5px 10px;
}

.admin-multi-select-option-thumb {
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  flex: 0 0 30px;
}

.admin-multi-select-option-thumb img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  image-rendering: crisp-edges;
  image-rendering: pixelated;
}

.admin-multi-select-option-label {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-multi-select-option:hover {
  background: #f5f5f5;
}

.admin-multi-select-option.is-selected {
  background: #f5f5f5;
  color: var(--ink);
  font-weight: 600;
}

.admin-multi-select-option-check {
  width: 16px;
  height: 16px;
  border: 2px solid var(--ink);
  border-radius: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  flex-shrink: 0;
  transition: all 0.12s;
}

.admin-multi-select-option.is-selected .admin-multi-select-option-check {
  background: var(--ink);
  border-color: var(--ink);
  color: #fff;
}

.admin-tag-select-section {
  margin: 12px 0;
}

.admin-tag-select-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

@media (min-width: 761px) {
  #adminItemsPanel .admin-editor {
    padding: 0 0 56px;
  }

  #adminItemsPanel .admin-form {
    gap: 14px;
  }

  #adminItemsPanel .admin-editor-head {
    grid-template-columns: 96px minmax(0, 1fr);
    gap: 14px;
    padding: 0 0 12px;
    border-bottom: 2px solid var(--ink);
  }

  #adminItemsPanel .admin-preview,
  #adminItemsPanel .admin-no-image {
    width: 96px;
    height: 96px;
  }

  #adminItemsPanel .admin-editor h2 {
    font-size: clamp(1.8rem, 3vw, 2.6rem);
  }

  #adminItemsPanel .admin-form > .admin-actions {
    display: grid;
    grid-template-columns: repeat(3, max-content) 1fr max-content max-content;
    align-items: center;
    gap: 8px;
    margin: -2px 0 2px;
    padding: 10px 0 12px;
    border-bottom: 1px solid #d7d7d7;
  }

  #adminItemsPanel .admin-form > .admin-actions .admin-action {
    min-height: 34px;
    padding: 8px 12px 7px;
  }

  #adminItemsPanel .admin-form > .admin-actions .admin-action:nth-child(4) {
    grid-column: 5;
  }

  #adminItemsPanel .admin-form > .admin-actions .admin-action:nth-child(5) {
    grid-column: 6;
  }

  #adminItemsPanel .admin-name-field {
    max-width: min(560px, 100%);
  }

  #adminItemsPanel .admin-name-field,
  #adminItemsPanel .admin-image-manager,
  #adminItemsPanel #dishEditorFields > .admin-field,
  #adminItemsPanel .admin-tag-select-section,
  #adminItemsPanel .admin-ingredient-section,
  #adminItemsPanel .admin-recipe-fields,
  #adminItemsPanel .admin-steps-section,
  #adminItemsPanel #dishEditorFields > .admin-section {
    margin: 0;
    padding: 12px;
    border: 2px solid #d7d7d7;
    background: #ffffff;
  }

  #adminItemsPanel .admin-section-title,
  #adminItemsPanel .admin-field > span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin: 0 0 10px;
    color: var(--ink);
    font-size: 0.78rem;
    font-weight: 800;
    line-height: 1;
  }

  #adminItemsPanel .admin-section-title::before,
  #adminItemsPanel .admin-field > span::before {
    content: "";
    width: 8px;
    height: 12px;
    background: var(--ink);
  }

  #adminItemsPanel .admin-name-input,
  #adminItemsPanel .admin-field textarea,
  #adminItemsPanel .admin-steps-section textarea,
  #adminItemsPanel .admin-step-input {
    border-width: 2px;
    background: #fcfcfc;
  }

  #adminItemsPanel .admin-image-manager {
    padding-bottom: 14px;
  }

  #adminItemsPanel .admin-image-grid {
    grid-template-columns: repeat(auto-fill, minmax(112px, 132px));
    gap: 9px;
  }

  #adminItemsPanel .admin-image-slot {
    border-width: 2px;
  }

  #adminItemsPanel .admin-tag-select-section {
    background: #ffffff;
  }

  #adminItemsPanel .admin-tag-select-section .admin-section-title {
    margin-bottom: 6px;
  }

  #adminItemsPanel .admin-tag-select-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
  }

  #adminItemsPanel .admin-tag-select-grid > .admin-field-inline,
  #adminItemsPanel .admin-tag-group {
    display: grid;
    grid-template-columns: 92px minmax(0, 1fr);
    align-items: start;
    gap: 12px;
    min-height: 42px;
    margin: 0;
    padding: 8px 0 9px;
    border-top: 1px solid #d7d7d7;
  }

  #adminItemsPanel .admin-tag-select-grid > .admin-field-inline:first-child,
  #adminItemsPanel .admin-tag-group:first-child {
    border-top: 0;
  }

  #adminItemsPanel .admin-tag-select-grid > .admin-field-inline > span,
  #adminItemsPanel .admin-tag-group-label {
    margin: 6px 0 0;
    color: var(--ink);
    font-size: 0.72rem;
    font-weight: 700;
    line-height: 1.35;
  }

  #adminItemsPanel .admin-tag-select-grid .admin-multi-select-input {
    min-height: 30px;
    padding: 0 24px 0 0;
    border-bottom-color: transparent;
    background: transparent;
  }

  #adminItemsPanel .admin-tag-select-grid .admin-multi-select-input:hover,
  #adminItemsPanel .admin-tag-select-grid .admin-multi-select.is-open .admin-multi-select-input {
    border-bottom-color: #d7d7d7;
  }

  #adminItemsPanel .admin-tag-select-grid .admin-multi-select-chip,
  #adminItemsPanel .admin-tag-chips .admin-tag-chip {
    padding: 5px 22px 4px 8px;
    border-width: 2px;
    border-color: #d7d7d7;
    background: #ffffff;
    font-size: 0.72rem;
  }

  #adminItemsPanel .admin-tag-chips .admin-tag-chip {
    padding-right: 8px;
  }

  #adminItemsPanel .admin-tag-select-grid .admin-multi-select-chip-remove {
    top: -6px;
    right: -6px;
    width: 15px;
    height: 15px;
    border-width: 2px;
    font-size: 0.66rem;
  }

  #adminItemsPanel .admin-tag-select-grid .admin-multi-select-arrow {
    right: 4px;
    border-left-width: 4px;
    border-right-width: 4px;
    border-top-width: 5px;
  }

  #adminItemsPanel .admin-tag-select-grid .admin-multi-select-dropdown {
    top: calc(100% + 4px);
    border: 2px solid var(--ink);
    box-shadow: 3px 3px 0 var(--soft-shadow);
  }

  #adminItemsPanel .admin-tag-chips {
    gap: 6px;
  }

  #adminItemsPanel .admin-tag-chips .admin-tag-chip.is-selected {
    border-color: var(--ink);
    background: var(--ink);
    color: #ffffff;
  }

  #adminItemsPanel .admin-ingredient-row,
  #adminItemsPanel .admin-recipe-fields-grid {
    gap: 10px;
  }

  #adminItemsPanel .admin-recipe-fields-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  #adminItemsPanel .admin-steps-section .admin-action {
    margin-top: 8px;
    margin-left: 0;
  }

  #adminItemsPanel .admin-dish-chip-grid {
    gap: 8px;
  }
}

.admin-ingredient-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 10px;
}

.admin-ingredient-qty-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin: 14px 0 0;
}

.admin-qty-group-label {
  margin: 10px 0 4px;
  font-size: 0.75rem;
  font-weight: 600;
  color: #666;
}

.admin-qty-group-label:first-child {
  margin-top: 0;
}

.admin-qty-row {
  display: grid;
  grid-template-columns: 1fr 100px 90px;
  gap: 8px;
  align-items: center;
  padding: 6px 0;
  border-bottom: 1px solid var(--soft-line);
}

.admin-qty-name {
  font-size: 0.82rem;
  color: var(--ink);
  font-weight: 500;
}

.admin-qty-amount {
  padding: 5px 8px;
  border: 1px solid #ccc;
  border-radius: 0;
  background: var(--page-bg);
  color: var(--ink);
  font: inherit;
  font-size: 0.78rem;
  text-align: center;
}

.admin-qty-amount:focus {
  border-color: var(--ink);
  outline: none;
}

.admin-qty-unit {
  padding: 5px 4px;
  border: 1px solid #ccc;
  border-radius: 0;
  background: var(--page-bg);
  color: var(--ink);
  font: inherit;
  font-size: 0.78rem;
}

.admin-qty-unit:focus {
  border-color: var(--ink);
  outline: none;
}

@media (max-width: 860px) {
  .admin-recipe-fields-grid {
    grid-template-columns: 1fr 1fr;
  }

  .admin-tag-select-grid {
    grid-template-columns: 1fr;
  }

  .admin-ingredient-row {
    grid-template-columns: 1fr;
  }

  .admin-image-grid {
    max-width: 100%;
  }

  .admin-name-field {
    max-width: 100%;
  }
}

@media (max-width: 640px) {
  .admin-recipe-fields-grid {
    grid-template-columns: 1fr;
  }

  :root {
    --tile-size: 126px;
  }

  .site-header {
    padding: 30px 16px 20px;
  }

  h1 {
    text-shadow:
      3px 3px 0 #ededed,
      6px 6px 0 #d7d7d7;
  }

  main {
    width: min(100% - 18px, 1540px);
    padding-top: 22px;
  }

  body.menu-card-layout main {
    width: min(100% - 12px, 1540px);
  }

  .view-switcher {
    margin-bottom: 20px;
  }

  .view-tab {
    min-width: 66px;
    padding: 7px 10px 6px;
    font-size: 0.74rem;
  }

  .search-panel {
    gap: 12px;
    margin-bottom: 22px;
  }

  .search-input {
    padding: 11px 10px 10px;
    border-width: 2px;
    font-size: 0.82rem;
  }

  .layout-shell,
  body.filters-open .layout-shell {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .filter-sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    z-index: 10;
    width: min(310px, calc(100vw - 48px));
    max-height: 100vh;
    padding: 18px 12px;
    border-right: 3px solid var(--ink);
    background: var(--panel-bg);
    box-shadow: 8px 0 0 var(--soft-shadow);
  }

  .floating-filter-bar {
    top: 8px;
    margin-bottom: 14px;
    padding: 0;
    box-shadow: none;
  }

  .results-count,
  .clear-button,
  .tag-group-title,
  .tag-button,
  .category-filter-button,
  .quick-filter-button,
  .filter-toggle,
  .selected-tag {
    font-size: 0.7rem;
  }

  .tag-list {
    gap: 6px;
  }

  .tag-button,
  .category-filter-button,
  .quick-filter-button {
    padding: 5px 7px;
  }

  .filter-toggle {
    min-width: 68px;
  }

  .selected-tags {
    gap: 6px;
  }

  .selected-tag {
    min-height: var(--selection-pill-min-height);
    padding: 5px 20px 4px 7px;
  }

  .menu-grid {
    gap: 12px 8px;
  }

  .catalog-section {
    margin-bottom: 28px;
  }

  .catalog-title {
    margin-bottom: 14px;
    font-size: 0.86rem;
  }

  .dish-card {
    padding: 6px 4px 5px;
  }

  #menuView.menu-style-card .menu-grid {
    grid-template-columns: repeat(auto-fill, minmax(158px, 1fr));
    gap: 8px;
  }

  #ingredientsView .ingredient-grid {
    grid-template-columns: repeat(auto-fill, minmax(var(--tile-size), 1fr));
    gap: 12px 8px;
  }

  #menuView.menu-style-card .menu-grid,
  body.menu-card-layout #ingredientsView .ingredient-grid {
    grid-template-columns: repeat(auto-fill, minmax(158px, 1fr));
    gap: 8px;
  }

	  #menuView.menu-style-card .dish-card {
	    min-height: 342px;
	    padding: 10px 8px 9px;
	  }

  #ingredientsView .ingredient-card {
    min-height: 220px;
    padding: 10px 8px 9px;
  }

  #menuView.menu-style-card .dish-image-wrap {
    min-height: 136px;
  }

  #ingredientsView .ingredient-card .dish-image-wrap {
    min-height: 136px;
  }

  #menuView.menu-style-card .dish-image {
    width: min(136px, 100%);
    height: min(136px, 100%);
  }

  #ingredientsView .ingredient-card .dish-image {
    width: min(136px, 100%);
    height: min(136px, 100%);
  }

	  #menuView.menu-style-card .dish-name {
	    min-height: 22px;
	    margin-top: 8px;
	    font-size: 0.78rem;
	  }

  #ingredientsView .ingredient-card .dish-name {
    min-height: 22px;
    margin-top: 8px;
    font-size: 0.78rem;
  }

  #menuView.menu-style-card .dish-card-tagline {
    min-height: 35px;
    font-size: 0.68rem;
  }

  #menuView.menu-style-card .dish-card-highlights {
    gap: 4px;
    min-height: 21px;
  }

  #menuView.menu-style-card .dish-card-highlights span,
  #menuView.menu-style-card .dish-card-meta {
    font-size: 0.6rem;
  }

  .dish-image-wrap {
    min-height: 98px;
  }

  .dish-image {
    width: min(116px, 100%);
    height: min(116px, 100%);
  }

  .dish-name {
    min-height: 38px;
    font-size: 0.78rem;
  }

  .detail-back {
    margin-bottom: 16px;
    font-size: 0.74rem;
  }

  .detail-shell {
    grid-template-columns: 1fr;
    gap: 22px;
  }

  .detail-purchase-panel {
    padding: 12px;
  }

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

  .detail-media {
    position: static;
  }

  .detail-image-frame {
    padding: 18px;
  }

  .detail-content h2 {
    margin-bottom: 12px;
    font-size: clamp(2rem, 12vw, 3.25rem);
  }

  .detail-tags {
    gap: 6px;
    margin-bottom: 18px;
  }

  .detail-tag,
  .detail-summary,
  .recipe-section p,
  .recipe-steps li {
    font-size: 0.74rem;
  }

  .detail-summary {
    margin-bottom: 14px;
  }

  .detail-recommendations {
    gap: 20px;
    margin-top: 24px;
    padding-top: 18px;
  }

  .detail-dish-grid {
    grid-template-columns: repeat(auto-fill, minmax(104px, 1fr));
  }

  .detail-dish-chip img {
    height: 72px;
  }

  .recipe-facts {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin-bottom: 16px;
  }

  .recipe-fact {
    padding: 9px;
  }

  .recipe-fact-label {
    font-size: 0.68rem;
  }

  .recipe-fact strong,
  .recipe-section h3,
  .ingredient-group h3 {
    font-size: 0.82rem;
  }

  .ingredient-columns {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .ingredient-items {
    grid-template-columns: repeat(auto-fill, minmax(78px, 1fr));
    gap: 7px;
  }

  .ingredient-group {
    padding: 0;
  }

  .admin-shell {
    grid-template-columns: 1fr;
    gap: 22px;
  }

  .admin-item-list {
    max-height: 280px;
  }

  .admin-editor-head,
  .admin-facet-fields {
    grid-template-columns: 1fr;
  }

  .admin-preview {
    width: 96px;
    height: 96px;
  }
}

.taxonomy-mode-tabs {
  display: flex;
  gap: 4px;
  margin-bottom: 16px;
  border-bottom: var(--control-border-soft);
}

.taxonomy-mode-tab {
  padding: 8px 16px;
  border: 0;
  border-bottom: 2px solid transparent;
  background: transparent;
  color: var(--muted);
  font-size: var(--font-sm);
  font-family: inherit;
  font-weight: 400;
  cursor: pointer;
  margin-bottom: -2px;
  transition: color 0.15s, border-color 0.15s;
}

.taxonomy-mode-tab.is-active {
  color: var(--ink);
  border-bottom-color: var(--ink);
}

.taxonomy-batch-head {
  margin-bottom: 12px;
}

.taxonomy-batch-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px;
  flex-wrap: wrap;
}

.taxonomy-batch-toolbar .admin-search {
  flex: 1;
  min-width: 160px;
}

.taxonomy-batch-actions {
  display: flex;
  gap: 6px;
}

.taxonomy-batch-card {
  border-radius: 0;
  border: 2px solid transparent;
  padding: 6px 4px 4px;
  transition: border-color 0.15s, background 0.15s;
}

.taxonomy-batch-card.is-batch-active {
  border-color: var(--ink);
  background: #f7f7f7;
}

.taxonomy-batch-card.is-batch-changed {
  border-color: var(--muted);
  background: #f5f5f5;
}

.taxonomy-batch-card.is-batch-active.is-batch-changed {
  border-color: var(--ink);
  background: #f5f5f5;
}

.taxonomy-batch-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 16px;
  padding: 10px 14px;
  background: var(--panel-bg);
  border: var(--control-border-soft);
  border-radius: 0;
  position: sticky;
  bottom: 0;
}

.taxonomy-batch-bar-actions {
  display: flex;
  gap: 8px;
}

.skin-color-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 8px 0 16px;
}

.skin-color-row input[type="color"] {
  width: 48px;
  height: 36px;
  padding: 2px;
  border: 2px solid var(--ink);
  border-radius: 0;
  background: none;
  cursor: pointer;
}

.skin-color-hex {
  flex: 1;
  padding: 6px 10px;
  border: 2px solid var(--ink);
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font-family: inherit;
  font-size: 0.85rem;
}

.skin-preset-grid {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 8px;
  margin: 8px 0 16px;
}

.skin-preset-btn {
  width: 100%;
  aspect-ratio: 1;
  border: 2px solid var(--soft-line);
  border-radius: 0;
  cursor: pointer;
  transition: border-color 0.15s;
}

.skin-preset-btn:hover {
  border-color: var(--ink);
}

.skin-preset-btn.is-active {
  border-color: var(--ink);
  outline: 2px solid var(--ink);
  outline-offset: 1px;
}

.skin-ink-preset-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  font-weight: 700;
  background: #fafafa;
}

.skin-preview-card {
  margin: 8px 0 16px;
  padding: 16px;
  border: 2px solid var(--soft-line);
  background: var(--page-bg);
}

.skin-preview-header {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: 10px;
  color: var(--ink);
}

.skin-preview-body {
  display: flex;
  align-items: center;
  gap: 8px;
}

.skin-preview-tag {
  padding: 2px 8px;
  border: 1px solid var(--ink);
  font-size: 0.72rem;
  color: var(--ink);
}

.skin-preview-text {
  font-size: 0.78rem;
  color: var(--muted);
}

.skin-icon-list {
  display: grid;
  gap: 18px;
}

.skin-icon-manager {
  display: grid;
  gap: 16px;
  margin-bottom: 18px;
  padding: 18px;
  background: var(--panel-bg);
}

.skin-icon-manager h3 {
  margin: 0;
  font-size: 0.92rem;
}

.skin-icon-section {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) 96px minmax(220px, 1.6fr) auto;
  gap: 14px;
  align-items: center;
}

.skin-icon-head {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.skin-icon-label {
  color: var(--ink);
  font-size: 0.85rem;
  font-weight: 600;
}

.skin-icon-desc {
  margin: 0;
  color: var(--muted);
  font-size: 0.7rem;
  line-height: 1.5;
}

.skin-icon-current-preview {
  display: grid;
  justify-items: center;
  gap: 5px;
  color: var(--muted);
  font-size: 0.66rem;
}

.skin-icon-current-preview img {
  width: 82px;
  height: 68px;
  object-fit: contain;
  image-rendering: pixelated;
  image-rendering: crisp-edges;
}

.skin-icon-option-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(86px, 1fr));
  gap: 8px;
}

.skin-icon-option {
  display: grid;
  justify-items: center;
  gap: 5px;
  min-height: 86px;
  padding: 8px;
  border: 2px solid var(--soft-line);
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font: inherit;
  font-size: 0.68rem;
}

.skin-icon-option img {
  width: 68px;
  height: 50px;
  object-fit: contain;
  image-rendering: pixelated;
  image-rendering: crisp-edges;
}

.skin-icon-option.is-active {
  border-color: var(--ink);
  outline: 2px solid var(--ink);
  outline-offset: 1px;
}

.skin-button-preview-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(118px, 1fr));
  gap: 10px;
}

.skin-button-preview-card {
  display: grid;
  gap: 8px;
  align-content: center;
  min-height: 86px;
  padding: 10px;
  border: 2px solid var(--soft-line);
}

.skin-button-preview-card > span {
  color: var(--muted);
  font-size: 0.68rem;
}

.skin-icon-plus-preview,
.skin-icon-checked-preview {
  position: static;
  opacity: 1;
  width: 40px;
  height: 40px;
}

.skin-icon-plus-preview {
  border: 0;
  background: transparent;
  color: var(--ink);
}

.skin-cursor-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.skin-cursor-manager {
  display: grid;
  gap: 16px;
  margin-bottom: 18px;
  padding: 18px;
  background: var(--panel-bg);
}

.skin-cursor-manager h3 {
  margin: 0;
  font-size: 0.92rem;
}

.skin-cursor-mode-control {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.skin-cursor-mode-btn {
  appearance: none;
  min-width: 104px;
  padding: 8px 12px 7px;
  border: 2px solid #d7d7d7;
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font: inherit;
  font-size: 0.78rem;
}

.skin-cursor-mode-btn.is-active {
  border-color: var(--ink);
  background: var(--ink);
  color: var(--page-bg);
}

.skin-cursor-name-row,
.skin-cursor-global-row,
.skin-cursor-slider-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  color: var(--muted);
  font-size: 0.75rem;
}

.skin-cursor-name-row input {
  min-width: min(260px, 100%);
  padding: 7px 8px;
  border: 2px solid #d7d7d7;
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font: inherit;
}

.skin-cursor-global-row input[type="range"],
.skin-cursor-slider-row input[type="range"] {
  width: min(220px, 100%);
  accent-color: var(--ink);
}

.skin-cursor-value {
  min-width: 44px;
  color: var(--ink);
}

.skin-cursor-list.is-disabled {
  opacity: 0.55;
}

.skin-cursor-section {
  background: var(--panel-bg);
  padding: 18px;
}

.skin-cursor-row-v2 {
  display: grid;
  grid-template-columns: minmax(150px, 1.2fr) 76px auto minmax(180px, 1.4fr) minmax(190px, 1.6fr);
  gap: 14px;
  align-items: center;
}

.skin-cursor-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-bottom: 14px;
}

.skin-cursor-label {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--ink);
}

.skin-cursor-desc {
  font-size: 0.7rem;
  color: var(--muted);
}

.skin-cursor-icon-row {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}

.skin-cursor-icon-slot {
  width: clamp(56px, 8vw, 80px);
  flex-direction: column;
  gap: 2px;
}

.skin-cursor-icon-slot.admin-image-slot-add {
  flex-direction: column;
}

.skin-cursor-text {
  font-size: 0.68rem;
  color: var(--ink);
  line-height: 1;
}

.skin-cursor-icon-slot.is-active {
  border-color: var(--ink);
  border-style: solid;
  background: var(--panel-bg);
}

.skin-cursor-icon-slot.is-custom {
  border-style: solid;
  border-color: var(--ink);
}

.skin-cursor-preview-box {
  display: grid;
  place-items: center;
  width: 72px;
  height: 72px;
  border: 2px solid var(--ink);
  background:
    linear-gradient(45deg, #f4f4f4 25%, transparent 25%),
    linear-gradient(-45deg, #f4f4f4 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, #f4f4f4 75%),
    linear-gradient(-45deg, transparent 75%, #f4f4f4 75%);
  background-size: 12px 12px;
  background-position: 0 0, 0 6px, 6px -6px, -6px 0;
}

.skin-cursor-preview {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  image-rendering: pixelated;
  image-rendering: crisp-edges;
}

.skin-cursor-param-row {
  display: flex;
  gap: 8px;
  margin-top: 10px;
  flex-wrap: wrap;
}

.skin-cursor-param {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 0.7rem;
  color: var(--muted);
}

.skin-cursor-param-input {
  width: 48px;
  padding: 3px 5px;
  border: 1px solid var(--soft-line);
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font-family: inherit;
  font-size: 0.72rem;
  text-align: center;
}

.skin-cursor-param-input:focus-visible {
  outline: 2px solid var(--ink);
  outline-offset: 1px;
}

.skin-cursor-hotspot {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 0.75rem;
}

.skin-cursor-hotspot-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(42px, 1fr));
  gap: 4px;
}

.skin-cursor-hotspot-btn {
  appearance: none;
  min-height: 26px;
  padding: 4px 5px;
  border: 1px solid #d7d7d7;
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  font: inherit;
  font-size: 0.64rem;
}

.skin-cursor-hotspot-btn.is-active {
  border-color: var(--ink);
  background: var(--ink);
  color: var(--page-bg);
}

.skin-cursor-hotspot-hint {
  color: var(--muted);
  font-size: 0.68rem;
}

@media (max-width: 980px) {
  .skin-cursor-row-v2 {
    grid-template-columns: 1fr 72px;
  }

  .skin-cursor-row-v2 .admin-action,
  .skin-cursor-slider-row,
  .skin-cursor-hotspot {
    grid-column: 1 / -1;
  }
}

.taxonomy-sidebar-head-heading {
  margin: 0 0 10px;
  font-size: 1rem;
  font-weight: 600;
}

button,
a,
summary,
[role="button"],
input[type="button"],
input[type="submit"],
input[type="color"],
.dish-card,
.detail-thumb,
.detail-dish-chip,
.table-fab,
.table-remove-btn,
.admin-action,
.admin-tab,
.admin-type-tab,
.admin-item-button,
.admin-image-slot,
.taxonomy-grp-item,
.taxonomy-tag-chip,
.taxonomy-result-card,
.taxonomy-batch-card,
.admin-multi-select,
.admin-multi-select-option,
.skin-preset-btn,
.tag-button,
.category-filter-button,
.quick-filter-button,
.selected-tag,
.clear-button,
.view-tab,
.pantry-mode-tab {
  cursor: var(--cursor-hover) !important;
}

button:active,
a:active,
summary:active,
[role="button"]:active,
input[type="button"]:active,
input[type="submit"]:active,
.dish-card:active,
.detail-thumb:active,
.detail-dish-chip:active,
.table-fab:active,
.table-remove-btn:active,
.admin-action:active,
.admin-tab:active,
.admin-type-tab:active,
.admin-item-button:active,
.admin-image-slot:active,
.taxonomy-grp-item:active,
.taxonomy-tag-chip:active,
.taxonomy-result-card:active,
.taxonomy-batch-card:active,
.admin-multi-select:active,
.admin-multi-select-option:active,
.skin-preset-btn:active,
.tag-button:active,
.category-filter-button:active,
.quick-filter-button:active,
.selected-tag:active,
.clear-button:active,
.view-tab:active,
.pantry-mode-tab:active {
  cursor: var(--cursor-click) !important;
}

input[type="text"],
input[type="search"],
input[type="number"],
input:not([type]),
textarea,
[contenteditable="true"] {
  cursor: var(--cursor-text) !important;
}

[style*="cursor: grab"],
.dish-card[draggable="true"],
.step-drag-handle {
  cursor: var(--cursor-grab) !important;
}

.is-grabbing,
.is-grabbing * {
  cursor: var(--cursor-grabbing) !important;
}

.ingredient-card,
.seasoning-card {
  cursor: var(--cursor-default) !important;
}

.view-tab,
.filter-toggle,
.clear-button,
.tag-button,
.category-filter-button,
.quick-filter-button,
.selected-tag,
.pantry-mode-tab,
.admin-tab,
.admin-type-tab,
.admin-action,
.admin-item-button,
.taxonomy-mode-tab,
.taxonomy-tag-chip,
.taxonomy-batch-card,
.skin-cursor-mode-btn,
.skin-cursor-hotspot-btn {
  border-radius: 0 !important;
  font-family: inherit;
  letter-spacing: 0;
}

.view-tab,
.filter-toggle,
.admin-tab,
.admin-type-tab,
.admin-action,
.pantry-mode-tab,
.skin-cursor-mode-btn {
  min-height: 34px;
  padding: var(--control-py) var(--control-px) 7px;
  border: var(--control-border);
  font-size: var(--font-sm);
  line-height: 1.2;
}

.tag-button,
.category-filter-button,
.quick-filter-button,
.selected-tag,
.taxonomy-tag-chip {
  min-height: 28px;
  padding: 6px 9px 5px;
  border: var(--control-border-soft);
  font-size: var(--font-xs);
  line-height: 1.2;
}

.tag-button.is-active,
.category-filter-button.is-active,
.quick-filter-button.is-active,
.selected-tag,
.taxonomy-tag-chip.is-active {
  border-color: var(--selection-pill-border);
}

.search-input,
.admin-search,
.admin-name-field,
.skin-cursor-name-row input,
input[type="text"],
input[type="search"],
input[type="number"],
textarea,
select {
  border-radius: 0 !important;
  font-family: inherit;
  letter-spacing: 0;
}

.search-input {
  border-width: 2px;
}

.table-fab {
  width: 48px;
  height: 48px;
  border: 2px solid var(--ink);
  border-radius: 0;
  background: var(--panel-bg);
  color: var(--ink);
  box-shadow: 4px 4px 0 var(--soft-shadow);
}

.table-fab:hover {
  transform: translate(-1px, -1px);
  box-shadow: 5px 5px 0 var(--soft-shadow);
}

.table-fab.is-drop-target {
  transform: translate(-2px, -2px);
  background: var(--ink);
  color: var(--page-bg);
  box-shadow: 5px 5px 0 var(--soft-shadow);
}

.table-fab-badge {
  top: -8px;
  right: -8px;
  min-width: 20px;
  height: 20px;
  border: 2px solid var(--ink);
  border-radius: 0;
  background: var(--page-bg);
  color: var(--ink);
}

.dish-card-add-btn {
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--ink);
}

.dish-card-add-btn.is-checked {
  background: var(--selection-check-bg);
  color: var(--selection-check-fg);
  border: var(--selection-check-border);
}

.admin-shell {
  gap: 22px;
}

.admin-sidebar {
  align-self: start;
}

.admin-editor {
  padding-bottom: 28px;
}

.admin-type-tabs,
.taxonomy-mode-tabs,
.skin-cursor-mode-control,
.table-header-actions {
  gap: var(--space-2);
}

.admin-item-list {
  gap: 7px;
}

.admin-item-button {
  min-height: 34px;
}

.skin-cursor-manager,
.skin-cursor-section {
  border: 0;
  padding: var(--space-4);
}

.skin-cursor-row-v2 {
  grid-template-columns: minmax(138px, 1.1fr) 72px auto minmax(170px, 1.3fr) minmax(184px, 1.5fr);
  gap: var(--space-3);
}

.skin-cursor-info {
  margin-bottom: 0;
}

.skin-cursor-preview-box {
  width: 68px;
  height: 68px;
}

.skin-cursor-hotspot-grid {
  gap: 3px;
}

.skin-cursor-hotspot-btn {
  min-height: 24px;
  padding: 3px 4px;
}

@media (max-width: 640px) {
  .site-header,
  .admin-header {
    padding-top: 24px;
  }

  h1 {
    font-size: clamp(1.8rem, 11vw, 3rem);
  }

  main {
    padding-top: 18px;
  }

  .view-switcher {
    margin-bottom: 16px;
  }

  .search-panel {
    margin-bottom: 16px;
  }

  .admin-header h1 {
    font-size: clamp(1.75rem, 10vw, 2.8rem);
  }

  .admin-tabs {
    width: 100%;
    justify-content: center;
  }

  .admin-tab {
    flex: 1 1 0;
    min-width: 0;
    padding-inline: 8px;
  }

  .admin-shell {
    gap: 16px;
  }

  .skin-cursor-row-v2 {
    grid-template-columns: minmax(0, 1fr) 68px;
    padding: 14px;
  }

  .skin-cursor-row-v2 .admin-action,
  .skin-cursor-slider-row,
  .skin-cursor-hotspot {
    grid-column: 1 / -1;
  }

  .table-fab {
    right: 14px;
    bottom: 18px;
  }
}

@media (hover: none), (pointer: coarse) {
  button,
  input,
  select,
  textarea,
  .view-tab,
  .filter-toggle,
  .clear-button,
  .tag-button,
  .category-filter-button,
  .quick-filter-button,
  .selected-tag,
  .admin-tab,
  .admin-type-tab,
  .taxonomy-mode-tab,
  .admin-action,
  .admin-item-button,
  .admin-multi-select-input,
  .admin-multi-select-option {
    min-height: 40px;
  }

  .admin-step-btn,
  .table-fab,
  .dish-card-add-btn {
    min-width: 40px;
    min-height: 40px;
  }
}

@media (max-width: 640px) {
  :root {
    --tile-size: 132px;
    --control-py: 9px;
    --control-px: 10px;
  }

  body {
    font-size: 0.9rem;
  }

  .site-header {
    padding: 18px 12px 12px;
  }

  .site-admin-link {
    top: 10px;
    right: 12px;
    font-size: 0.68rem;
  }

  h1 {
    font-size: clamp(1.85rem, 10vw, 2.65rem);
    line-height: 1;
    text-shadow:
      3px 3px 0 #ededed,
      5px 5px 0 #d7d7d7;
  }

  main {
    width: min(100% - 16px, 1540px);
    padding-top: 12px;
    padding-bottom: 72px;
  }

  .view-switcher {
    gap: 6px;
    margin-bottom: 12px;
  }

  .view-tab {
    flex: 1 1 0;
    min-width: 0;
    max-width: 88px;
    padding: 8px 5px 7px;
    font-size: 0.7rem;
    line-height: 1.15;
  }

  .search-panel {
    gap: 8px;
    margin-bottom: 12px;
  }

  .search-input {
    height: 40px;
    padding: 8px 10px 7px;
    font-size: 0.76rem;
  }

  .search-suggestions {
    top: 44px;
    border-width: 1px;
  }

  .search-suggestion-item {
    padding: 10px 12px 9px;
    font-size: 0.74rem;
  }

  .floating-filter-bar {
    top: 6px;
    margin-bottom: 10px;
  }

  .filter-toggle {
    min-width: 72px;
    padding: 8px 9px 7px;
  }

  .active-row {
    min-height: 24px;
    gap: 6px;
  }

  .selected-tags {
    gap: 5px;
  }

  .selected-tag {
    min-height: 30px;
    padding: 6px 22px 5px 7px;
  }

  .filter-sidebar {
    width: min(316px, calc(100vw - 44px));
    padding: 16px 12px;
  }

  .tag-button,
  .category-filter-button,
  .quick-filter-button {
    padding: 7px 8px 6px;
  }

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

  .catalog-section {
    margin-bottom: 24px;
  }

  .catalog-title {
    margin-bottom: 10px;
  }

  .dish-card {
    min-height: 0;
    padding: 5px 3px;
  }

  .dish-image-wrap {
    min-height: 102px;
  }

  .dish-image {
    width: min(118px, 100%);
    height: min(118px, 100%);
  }

  .dish-name {
    min-height: 34px;
    margin-top: 3px;
    font-size: 0.74rem;
    line-height: 1.24;
  }

  .dish-card-add-btn {
    right: 2px;
    bottom: 2px;
    width: 40px;
    height: 40px;
    opacity: 1;
  }

  .dish-card-add-btn.is-checked {
    right: 10px;
    bottom: 10px;
    width: var(--selection-check-size);
    height: var(--selection-check-size);
    min-width: var(--selection-check-size);
    min-height: var(--selection-check-size);
    font-size: var(--selection-check-font-size);
  }

  .table-fab {
    right: 12px;
    bottom: 14px;
    width: 44px;
    height: 44px;
  }

  .detail-back {
    margin-bottom: 12px;
    font-size: 0.72rem;
  }

  .detail-shell {
    gap: 16px;
  }

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

  .detail-image-frame {
    padding: 14px;
  }

  .detail-content {
    padding-top: 0;
  }

  .detail-content h2 {
    margin-bottom: 10px;
    font-size: clamp(1.85rem, 9.5vw, 2.8rem);
  }

  .detail-tags {
    gap: 5px;
    margin-bottom: 14px;
  }

  .detail-tag,
  .detail-summary,
  .recipe-section p,
  .recipe-steps li {
    font-size: 0.72rem;
    line-height: 1.65;
  }

  .detail-summary {
    margin-bottom: 12px;
  }

  .recipe-facts {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
    margin-bottom: 14px;
  }

  .recipe-fact {
    min-height: 56px;
    padding: 8px;
  }

  .recipe-section {
    margin-top: 14px;
  }

  .ingredient-columns {
    gap: 7px;
  }

  .ingredient-items {
    grid-template-columns: repeat(auto-fill, minmax(72px, 1fr));
    gap: 6px;
  }

  .ingredient-group {
    padding: 0;
  }

  .admin-header {
    padding: 18px 10px 12px;
  }

  .admin-header h1 {
    font-size: clamp(1.75rem, 9vw, 2.55rem);
    line-height: 1;
  }

  .admin-tabs,
  .admin-type-tabs,
  .taxonomy-mode-tabs {
    gap: 6px;
  }

  .admin-type-tabs {
    grid-template-columns: repeat(auto-fit, minmax(64px, 1fr));
  }

  .admin-tab,
  .admin-type-tab,
  .taxonomy-mode-tab {
    padding: 8px 6px 7px;
    font-size: 0.7rem;
    line-height: 1.15;
  }

  .admin-shell {
    width: min(100% - 16px, 1280px);
    gap: 14px;
  }

  .admin-sidebar,
  .admin-editor,
  .admin-taxonomy,
  .skin-cursor-manager {
    padding-inline: 0;
  }

  .admin-shell:not(.admin-mobile-detail-open) .admin-editor {
    display: none;
  }

  #adminItemsPanel .admin-sidebar {
    position: static;
    max-height: none;
    overflow: visible;
    padding-right: 0;
  }

  .admin-shell.admin-mobile-detail-open .admin-sidebar {
    display: none;
  }

  .admin-shell.admin-mobile-detail-open .admin-editor {
    display: block;
  }

  .admin-mobile-back {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    margin-bottom: 12px;
  }

  .admin-search {
    min-height: 40px;
    margin-bottom: 7px;
    padding: 8px 10px 7px;
  }

  .admin-item-list {
    max-height: none;
    gap: 6px;
    overflow: visible;
    padding-right: 0;
  }

  .admin-item-button {
    grid-template-columns: 38px minmax(0, 1fr);
    gap: 8px;
    min-height: 46px;
    padding: 5px 7px;
  }

  .admin-item-thumb {
    width: 34px;
    height: 34px;
  }

  .admin-editor-head {
    grid-template-columns: 88px minmax(0, 1fr);
    gap: 12px;
    align-items: center;
  }

  .admin-import-head {
    grid-template-columns: minmax(0, 1fr);
    gap: 0;
  }

  .admin-import-head h2 {
    font-size: clamp(1.2rem, 6.4vw, 1.75rem);
    line-height: 1.08;
  }

  .admin-preview,
  .admin-no-image {
    width: 88px;
    height: 88px;
  }

  .admin-editor h2 {
    font-size: clamp(1.4rem, 7.5vw, 2.1rem);
    line-height: 1.1;
  }

  .admin-image-grid {
    grid-template-columns: repeat(3, minmax(72px, 1fr));
    gap: 8px;
  }

  .admin-image-slot {
    min-height: 72px;
  }

  .admin-field-inline,
  .admin-recipe-fields {
    gap: 5px;
  }

  .admin-multi-select-input {
    min-height: 42px;
    padding: 7px 34px 7px 0;
  }

  .admin-multi-select-dropdown {
    max-height: min(360px, 55vh);
  }

  .admin-multi-select-option {
    min-height: 44px;
    gap: 8px;
    padding-block: 4px;
  }

  .admin-multi-select-option-thumb {
    width: 36px;
    height: 36px;
    flex: 0 0 36px;
  }

  .admin-ingredient-item {
    grid-template-columns: minmax(0, 1fr) 88px 86px;
    gap: 6px;
  }

  .admin-step-row {
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 6px;
    align-items: stretch;
  }

  .admin-step-input {
    min-height: 72px;
    padding: 9px 10px;
  }

  .admin-step-actions {
    flex-direction: column;
    gap: 4px;
  }

  .admin-step-btn {
    width: 40px;
    height: 40px;
  }

  .skin-cursor-manager,
  .skin-icon-manager,
  .skin-cursor-section {
    padding: 12px 0;
  }

  .skin-icon-section {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .skin-icon-current-preview {
    justify-items: start;
  }

  .skin-cursor-row-v2 {
    grid-template-columns: minmax(0, 1fr) 68px;
    gap: 10px;
    padding: 12px 0;
  }

  .skin-cursor-preview-box {
    width: 64px;
    height: 64px;
  }
}

.table-fab {
  width: 76px;
  height: 64px;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.table-fab:hover {
  transform: translateY(-2px);
  box-shadow: none;
}

.table-fab.is-drop-target {
  background: transparent;
  color: var(--ink);
  filter: contrast(1.08) drop-shadow(3px 3px 0 var(--soft-shadow));
  transform: translateY(-3px);
  box-shadow: none;
}

.table-fab-icon {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  image-rendering: pixelated;
  image-rendering: crisp-edges;
  pointer-events: none;
}

.table-fab-badge {
  top: -4px;
  right: -2px;
}

@media (max-width: 640px) {
  .table-fab {
    right: 22px;
    bottom: 22px;
    width: 70px;
    height: 58px;
  }
}

/* ===== 幸运卡片 ===== */
.lucky-drawer-tab {
  position: fixed;
  left: 0;
  right: auto;
  top: 50%;
  transform: translateY(-50%);
  z-index: 100;
  width: 28px;
  padding: 12px 4px;
  border: 2px solid var(--ink);
  border-left: 0;
  background: var(--ink);
  color: #ffffff;
  font-family: inherit;
  font-size: 0.72rem;
  line-height: 1.2;
  cursor: pointer;
  user-select: none;
  touch-action: none;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  letter-spacing: 2px;
  transition: top 0.15s ease, transform 0.15s ease;
}

.lucky-drawer-tab:hover {
  transform: translateY(-50%) translateX(4px);
}

.lucky-drawer-tab.is-right {
  right: 0;
  left: auto;
  border-right: 0;
  border-left: 2px solid var(--ink);
}

.lucky-drawer-tab.is-right:hover {
  transform: translateY(-50%) translateX(-4px);
}

.lucky-drawer-tab.is-dragging,
.lucky-drawer-tab.is-dragging:hover {
  cursor: grabbing;
  transition: none;
  transform: translateY(-50%);
}

.lucky-drawer {
  position: fixed;
  inset: 0 auto 0 0;
  z-index: 101;
  width: min(400px, 100vw);
  height: 100vh;
  overflow: hidden;
  border-right: 3px solid var(--ink);
  background: #f8faf6;
  box-shadow: 8px 0 0 var(--soft-shadow);
  transform: translateX(-100%);
  transition: transform 0.25s ease;
  display: flex;
  flex-direction: column;
}

.lucky-drawer.is-right {
  inset: 0 0 0 auto;
  border-right: 0;
  border-left: 3px solid var(--ink);
  box-shadow: -8px 0 0 var(--soft-shadow);
  transform: translateX(100%);
}

.lucky-drawer.is-open {
  transform: translateX(0);
}

.lucky-drawer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 14px 16px 12px;
  flex-shrink: 0;
}

.lucky-drawer-title {
  margin: 0;
  color: var(--ink);
  font-size: 1rem;
  line-height: 1.2;
}

.lucky-drawer-close {
  appearance: none;
  width: 32px;
  min-width: 32px;
  height: 32px;
  min-height: 32px;
  flex: 0 0 32px;
  aspect-ratio: 1 / 1;
  padding: 0;
  border: 1px solid rgba(23, 23, 23, 0.14);
  border-radius: 50% !important;
  background: rgba(255, 255, 255, 0.88);
  color: var(--ink);
  font-family: inherit;
  font-size: 0.9rem;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 6px 18px rgba(23, 23, 23, 0.08);
}

.lucky-screen {
  display: flex;
  flex-direction: column;
  flex: 1;
  overflow: hidden;
}

#luckyTagSelect {
  padding-bottom: max(18px, env(safe-area-inset-bottom, 0px));
}

.lucky-subtitle {
  margin: 0;
  color: var(--muted);
  font-size: 0.94rem;
  font-weight: 700;
  line-height: 1.25;
  text-align: center;
  padding: 0 8px 2px;
  flex-shrink: 0;
}

.lucky-tag-pool {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 12px;
  width: 100%;
  max-width: 360px;
  margin: 0 auto;
  padding: 16px 18px 12px;
  overflow-y: auto;
  flex: 1;
}

.is-filter-expanded .lucky-tag-pool {
  justify-content: flex-start;
}

.lucky-tag-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.lucky-tag-group-label {
  font-size: 0.78rem;
  color: var(--muted);
  margin: 0;
}

.lucky-tag-options {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 7px;
}

.lucky-tag-option {
  appearance: none;
  min-height: 32px;
  padding: 7px 11px 6px;
  border: 1px solid rgba(23, 23, 23, 0.14);
  border-radius: 8px;
  background: var(--selection-pill-bg);
  color: var(--ink);
  font-family: inherit;
  font-size: 0.72rem;
  line-height: 1.2;
  cursor: pointer;
  transition: background-color 150ms ease, border-color 150ms ease, color 150ms ease, transform 150ms ease;
}

.lucky-tag-option:hover {
  border-color: var(--ink);
  transform: translateY(-1px);
}

.lucky-tag-option.is-selected {
  border-color: var(--selection-active-border);
  background: var(--selection-active-bg);
  color: var(--selection-active-fg);
}

.lucky-advanced-filters {
  display: grid;
  gap: 13px;
  padding-top: 4px;
}

.lucky-tag-group.is-advanced .lucky-tag-options {
  justify-content: flex-start;
}

.lucky-more-filters-btn {
  appearance: none;
  width: min(260px, calc(100% - 48px));
  min-height: 40px;
  align-self: center;
  padding: 10px 16px 9px;
  border: 1px solid rgba(23, 23, 23, 0.16);
  border-radius: var(--action-radius);
  background: rgba(255, 255, 255, 0.72);
  color: var(--ink);
  font-family: inherit;
  font-size: 0.78rem;
  cursor: pointer;
}

.lucky-more-filters-btn[aria-expanded="true"] {
  border-color: var(--ink);
  background: #ffffff;
}

.lucky-skip-tags {
  appearance: none;
  width: min(260px, calc(100% - 48px));
  min-height: 40px;
  padding: 10px 16px 9px;
  border: 1px solid rgba(23, 23, 23, 0.16);
  border-radius: var(--action-radius);
  background: rgba(255, 255, 255, 0.68);
  color: var(--muted);
  font-family: inherit;
  font-size: 0.78rem;
  cursor: pointer;
  align-self: center;
  margin: 4px 0;
  flex-shrink: 0;
}

.lucky-skip-tags:hover {
  border-color: var(--ink);
  color: var(--ink);
}

.lucky-start-btn {
  appearance: none;
  width: min(260px, calc(100% - 48px));
  min-height: 44px;
  padding: 12px 24px 11px;
  border: 2px solid var(--ink);
  border-radius: var(--action-radius);
  background: var(--ink);
  color: #fff;
  font-family: inherit;
  font-size: 0.86rem;
  cursor: pointer;
  align-self: center;
  margin-bottom: 0;
  flex-shrink: 0;
}

.lucky-start-btn:hover {
  transform: translateY(-1px);
}

/* ===== 滑动界面沉浸式布局 ===== */
.lucky-swipe-layout {
  display: flex;
  flex-direction: column;
  height: 100vh;
  padding: 0;
  position: relative;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.88) 0%, rgba(246, 249, 242, 0.94) 42%, #ffffff 100%),
    linear-gradient(90deg, transparent 0 11px, rgba(23, 23, 23, 0.04) 11px 12px) 0 0 / 12px 12px repeat;
}

.lucky-swipe-top {
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr) 40px;
  align-items: center;
  gap: 4px;
  min-height: 58px;
  padding: 10px 14px 8px;
  flex-shrink: 0;
  position: relative;
  border-bottom: 1px solid rgba(23, 23, 23, 0.08);
  background: rgba(255, 255, 255, 0.82);
  backdrop-filter: blur(14px);
}

.lucky-swipe-top .lucky-drawer-title {
  grid-column: 2;
  margin: 0;
  font-size: 0.95rem;
  margin: 0;
  text-align: center;
}

.lucky-counter {
  grid-column: 2;
  font-size: 0.78rem;
  color: var(--muted);
  text-align: center;
}

.lucky-undo-btn {
  appearance: none;
  grid-column: 1;
  grid-row: 1 / span 2;
  width: 36px;
  height: 36px;
  padding: 0;
  border: 1px solid rgba(23, 23, 23, 0.14);
  border-radius: 50% !important;
  background: rgba(255, 255, 255, 0.9);
  color: var(--ink);
  font-family: inherit;
  font-size: 1rem;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 6px 18px rgba(23, 23, 23, 0.08);
}

.lucky-swipe-top .lucky-drawer-close {
  position: static;
  grid-column: 3;
  grid-row: 1 / span 2;
  justify-self: end;
  align-self: center;
  transform: none;
}

.lucky-card-stack {
  position: relative;
  flex: 1;
  display: grid;
  place-items: center;
  min-height: 0;
  padding: 14px 16px 10px;
}

.lucky-card {
  position: absolute;
  width: min(360px, calc(100vw - 36px));
  height: min(540px, calc(100vh - 220px));
  max-height: 100%;
  border: 1px solid rgba(23, 23, 23, 0.14);
  border-radius: 14px;
  background: #ffffff;
  overflow: hidden;
  touch-action: none;
  user-select: none;
  transition: transform 0.1s ease-out;
  will-change: transform;
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 44px rgba(23, 23, 23, 0.14);
}

.lucky-card.is-flying {
  transition: transform 0.35s ease-out, opacity 0.35s ease-out;
}

/* 堆叠效果 */
.lucky-card:nth-last-child(1) {
  z-index: 1;
}

.lucky-card:nth-last-child(2) {
  transform: scale(0.94) translateY(10px);
  opacity: 0.52;
  z-index: -1;
  transition: transform 0.3s ease-out, opacity 0.3s ease-out;
}

.lucky-card:nth-last-child(3) {
  transform: scale(0.88) translateY(20px);
  opacity: 0.26;
  z-index: -2;
  transition: transform 0.3s ease-out, opacity 0.3s ease-out;
}

/* 翻面效果 */
.lucky-card-flipper {
  width: 100%;
  height: 100%;
  position: relative;
  transform-style: preserve-3d;
  transition: transform 0.5s ease;
}

.lucky-card-flipper.is-flipped {
  transform: rotateY(180deg);
}

.lucky-card-front,
.lucky-card-back {
  position: absolute;
  inset: 0;
  backface-visibility: hidden;
  display: flex;
  flex-direction: column;
}

.lucky-card-back {
  transform: rotateY(180deg);
  padding: 18px;
  overflow: hidden;
  background: #ffffff;
}

.lucky-card-image {
  width: 100%;
  aspect-ratio: 1 / 1;
  height: auto;
  max-height: none;
  min-height: 0;
  background:
    linear-gradient(145deg, rgba(247, 250, 244, 0.95), rgba(230, 239, 224, 0.88));
  display: grid;
  place-items: center;
  flex-shrink: 0;
  overflow: hidden;
}

.lucky-card-image img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center center;
  image-rendering: pixelated;
  image-rendering: crisp-edges;
  filter: drop-shadow(0 12px 18px rgba(23, 23, 23, 0.12));
}

.lucky-card-info {
  padding: 15px 16px 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
  overflow-y: auto;
  min-height: 0;
}

.lucky-card-name {
  margin: 0;
  font-size: 1.32rem;
  line-height: 1.2;
  color: var(--ink);
  font-weight: 700;
}

.lucky-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.lucky-card-tag-chip {
  padding: 3px 7px 2px;
  border: 1px solid rgba(23, 23, 23, 0.1);
  border-radius: 999px;
  background: #f6f8f3;
  color: #516149;
  font-size: 0.66rem;
  line-height: 1.25;
}

.lucky-card-desc {
  margin: 0;
  font-size: 0.78rem;
  color: var(--muted);
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.lucky-card-ingredients {
  margin: 0;
  display: grid;
  gap: 3px;
  font-size: 0.72rem;
  color: var(--muted);
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.lucky-card-ingredients-label {
  display: block;
  font-size: 0.68rem;
  color: var(--ink);
  font-weight: 700;
}

.lucky-card-overlay {
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.1s ease;
}

.lucky-card-overlay.is-left {
  background: linear-gradient(90deg, rgba(239, 91, 91, 0.54), transparent 72%);
}

.lucky-card-overlay.is-right {
  background: linear-gradient(-90deg, rgba(58, 167, 107, 0.54), transparent 72%);
}

.lucky-card-overlay.is-up {
  background: linear-gradient(180deg, rgba(73, 144, 226, 0.52), transparent 72%);
}

.lucky-card-label {
  position: absolute;
  top: 28%;
  left: 50%;
  transform: translateX(-50%) rotate(-12deg);
  padding: 8px 16px;
  border: 3px solid #fff;
  background: transparent;
  color: #fff;
  font-size: 1.4rem;
  font-weight: 700;
  text-shadow: 2px 2px 0 rgba(0, 0, 0, 0.3);
  opacity: 0;
  transition: opacity 0.1s ease;
  pointer-events: none;
  white-space: nowrap;
}

.lucky-card-label.is-visible {
  opacity: 1;
}

/* 操作按钮 */
.lucky-actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: center;
  justify-items: center;
  gap: 22px;
  padding: 8px 42px 8px;
  flex-shrink: 0;
}

.lucky-action-btn {
  --lucky-action-mark-bg: currentColor;
  --lucky-action-mark-fg: #ffffff;
  appearance: none;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  min-width: 48px;
  min-height: 48px;
  padding: 0;
  border: 0;
  border-radius: 50%;
  background: transparent;
  color: var(--ink);
  font-family: inherit;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  box-shadow: none;
}

.lucky-action-icon {
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  flex: 0 0 auto;
  border: 0;
  border-radius: 50%;
  background: var(--lucky-action-mark-bg);
  color: var(--lucky-action-mark-fg);
  font-size: 1.05rem;
  transition: transform 0.1s ease, background 0.1s ease, color 0.1s ease;
}

@media (hover: hover) {
  .lucky-action-btn:hover .lucky-action-icon {
    transform: scale(1.08);
  }
}

.lucky-action-btn:active .lucky-action-icon {
  transform: scale(0.92);
}

.lucky-action-btn.lucky-skip {
  --lucky-action-mark-bg: #d94848;
  --lucky-action-mark-fg: #ffffff;
  border-color: rgba(217, 72, 72, 0.24);
  background: transparent;
  color: #a83c3c;
}

.lucky-action-btn.lucky-skip:active {
  background: transparent;
}

.lucky-action-btn.lucky-maybe {
  --lucky-action-mark-bg: #276fbf;
  --lucky-action-mark-fg: #ffffff;
  border-color: rgba(39, 111, 191, 0.24);
  background: transparent;
  color: #276fbf;
}

.lucky-action-btn.lucky-maybe:active {
  background: transparent;
}

.lucky-action-btn.lucky-like {
  --lucky-action-mark-bg: #2f8f4e;
  --lucky-action-mark-fg: #ffffff;
  border-color: #2f8f4e;
  background: transparent;
  color: #ffffff;
}

.lucky-action-btn.lucky-like:active {
  background: transparent;
}

.lucky-action-label {
  display: none;
  min-width: 0;
  font-size: 0.68rem;
  color: currentColor;
  white-space: nowrap;
}

/* 底部导航按钮 */
.lucky-nav-actions {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  padding: 8px 14px max(14px, env(safe-area-inset-bottom, 0px));
  flex-shrink: 0;
  border-top: 1px solid rgba(23, 23, 23, 0.08);
  background: rgba(255, 255, 255, 0.78);
  backdrop-filter: blur(12px);
}

.lucky-nav-btn {
  appearance: none;
  position: relative;
  display: flex;
  flex: 1 1 0;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 2px;
  min-width: 0;
  min-height: 34px;
  padding: 7px 6px;
  border: 0;
  border-radius: 8px;
  background: rgba(23, 23, 23, 0.04);
  color: var(--muted);
  font-family: inherit;
  font-size: 0.68rem;
  line-height: 1.2;
  cursor: pointer;
}

.lucky-nav-badge {
  position: absolute;
  top: -6px;
  right: -3px;
  min-width: 18px;
  height: 18px;
  padding: 0 4px;
  border: 1px solid #ffffff;
  border-radius: 999px;
  background: #ef5b5b;
  color: #fff;
  font-size: 0.62rem;
  line-height: 1;
  display: grid;
  place-items: center;
}

.lucky-card-placeholder {
  text-align: center;
  color: var(--muted);
  font-size: 0.82rem;
}

/* 完成界面 */
.lucky-finished-emoji {
  text-align: center;
  font-size: 3rem;
  line-height: 1;
  margin-top: 40px;
}

.lucky-finished-title {
  text-align: center;
  margin: 0;
  font-size: 1.1rem;
  color: var(--ink);
}

.lucky-finished-stats {
  display: flex;
  flex-direction: column;
  gap: 6px;
  text-align: center;
  font-size: 0.82rem;
  color: var(--muted);
}

.lucky-finished-actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: center;
  padding-bottom: 20px;
}

.lucky-restart-btn {
  appearance: none;
  padding: 10px 20px 9px;
  border: 2px solid var(--ink);
  background: var(--panel-bg);
  color: var(--ink);
  font-family: inherit;
  font-size: 0.82rem;
  cursor: pointer;
}

.lucky-goto-table-btn {
  appearance: none;
  padding: 10px 20px 9px;
  border: 2px solid var(--ink);
  background: var(--ink);
  color: #fff;
  font-family: inherit;
  font-size: 0.82rem;
  cursor: pointer;
}

/* 预览面板 */
.lucky-preview {
  position: fixed;
  inset: 0;
  z-index: 102;
  background: var(--panel-bg);
  display: flex;
  flex-direction: column;
  transform: translateY(100%);
  transition: transform 0.3s ease;
}

.lucky-preview.is-open {
  transform: translateY(0);
}

.lucky-preview-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 14px 16px 12px;
  border-bottom: 2px solid var(--ink);
  flex-shrink: 0;
}

.lucky-preview-title {
  margin: 0;
  font-size: 1rem;
  color: var(--ink);
}

.lucky-preview-close {
  appearance: none;
  width: 32px;
  height: 32px;
  padding: 0;
  border: 2px solid var(--ink);
  background: var(--panel-bg);
  color: var(--ink);
  font-family: inherit;
  font-size: 0.9rem;
  line-height: 1;
  cursor: pointer;
}

.lucky-preview-grid {
  flex: 1;
  overflow-y: auto;
  padding: 12px 16px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: 12px;
  align-content: start;
}

.lucky-preview-item {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 6px;
  text-align: center;
}

.lucky-preview-item img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: contain;
}

.lucky-preview-image-wrap {
  position: relative;
  width: 100%;
  background: #f4f4f4;
}

.lucky-preview-image-wrap img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: contain;
}

.lucky-preview-add-btn {
  position: absolute;
  right: 6px;
  bottom: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  padding: 0;
  border: none;
  background: transparent;
  color: var(--ink);
  font: inherit;
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
}

.lucky-preview-add-btn:hover {
  transform: scale(1.2);
}

.lucky-preview-item span {
  padding: 0 26px 0 2px;
  font-size: 0.82rem;
  font-weight: 700;
  line-height: 1.25;
  color: var(--ink);
}

.lucky-preview-footer {
  padding: 12px 16px 16px;
  border-top: 2px solid var(--soft-line);
  flex-shrink: 0;
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}

.lucky-preview-clear {
  padding: 10px 20px 9px;
  border: 2px solid var(--ink);
  background: #e53e3e;
  color: #fff;
  font-family: inherit;
  font-size: 0.82rem;
  cursor: pointer;
}

.lucky-preview-goto {
  appearance: none;
  padding: 10px 20px 9px;
  border: 2px solid var(--ink);
  background: var(--ink);
  color: #fff;
  font-family: inherit;
  font-size: 0.82rem;
  cursor: pointer;
}

.lucky-drawer-backdrop {
  position: fixed;
  inset: 0;
  z-index: 100;
  background: rgba(0, 0, 0, 0.25);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease;
}

.lucky-drawer-backdrop.is-visible {
  opacity: 1;
  pointer-events: auto;
}

/* 游戏进行时隐藏餐桌 FAB */
body.lucky-game-active .table-fab {
  display: none;
}

@media (max-width: 640px) {
  .lucky-drawer-tab {
    width: 24px;
    padding: 10px 3px;
    font-size: 0.68rem;
  }

  .lucky-drawer {
    width: 100vw;
  }

  .lucky-card {
    width: min(340px, calc(100vw - 32px));
    height: min(520px, calc(100vh - 240px));
  }

  .lucky-action-icon {
    width: 48px;
    height: 48px;
    font-size: 1.05rem;
  }

  .lucky-actions {
    gap: 22px;
    padding-right: 42px;
    padding-left: 42px;
  }

  .lucky-nav-btn {
    min-width: 70px;
    padding: 5px 8px;
    font-size: 0.68rem;
  }
}

/* ===== 组件管理样式 ===== */
.component-section {
  margin-bottom: 24px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--soft-line);
}

.component-section:last-child {
  border-bottom: none;
}

.component-toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 0;
}

.component-switch {
  position: relative;
  display: inline-block;
  width: 48px;
  height: 26px;
}

.component-switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

.component-switch-slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: var(--soft-line);
  transition: 0.3s;
  border-radius: 26px;
}

.component-switch-slider:before {
  position: absolute;
  content: "";
  height: 20px;
  width: 20px;
  left: 3px;
  bottom: 3px;
  background-color: white;
  transition: 0.3s;
  border-radius: 50%;
}

.component-switch input:checked + .component-switch-slider {
  background-color: var(--ink);
}

.component-switch input:checked + .component-switch-slider:before {
  transform: translateX(22px);
}

.component-hint {
  font-size: 0.72rem;
  color: var(--muted);
  margin: 4px 0 0;
}

.component-field-group {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 16px;
}

.component-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.component-field > span {
  font-size: 0.78rem;
  font-weight: 500;
}

.component-field input[type="number"],
.component-field select {
  padding: 8px 12px;
  border: 1px solid var(--soft-line);
  background: var(--panel-bg);
  font-family: inherit;
  font-size: 0.85rem;
}

.component-preview-box {
  margin-top: 16px;
  padding: 16px;
  background: var(--soft-line);
  border-radius: 8px;
}

.component-preview-box h4 {
  margin: 0 0 12px;
  font-size: 0.78rem;
  font-weight: 500;
}

.component-preview-tab {
  writing-mode: vertical-rl;
  text-orientation: mixed;
  padding: 12px 8px;
  border-radius: 4px;
  font-size: 0.78rem;
  text-align: center;
}

.component-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px;
  border: 1px solid var(--soft-line);
  background: var(--panel-bg);
  cursor: pointer;
  transition: background 0.15s;
}

.component-item:hover {
  background: rgba(0, 0, 0, 0.03);
}

.component-item.is-active {
  border-color: var(--ink);
  background: rgba(0, 0, 0, 0.05);
}

.component-item-icon {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--soft-line);
  border-radius: 4px;
  font-size: 1rem;
}

.component-item-name {
  font-size: 0.85rem;
  font-weight: 500;
}

.component-item-status {
  font-size: 0.72rem;
  color: var(--muted);
  margin-left: auto;
}

@media (max-width: 640px) {
  .component-field-group {
    grid-template-columns: 1fr;
  }
}

.component-checkbox-group {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 12px;
}

.component-checkbox {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border: 1px solid var(--soft-line);
  background: var(--panel-bg);
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}

.component-checkbox:hover {
  background: rgba(0, 0, 0, 0.03);
}

.component-checkbox input:checked {
  border-color: var(--ink);
  background: rgba(0, 0, 0, 0.05);
}

.component-checkbox input {
  width: 16px;
  height: 16px;
  accent-color: var(--ink);
}

.component-checkbox span {
  font-size: 0.82rem;
}

.card-display-editor-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
}

.card-display-filter-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 12px;
}

.card-display-filter-row .admin-action {
  min-width: 0;
  width: 100%;
  padding-inline: 8px;
}

.card-display-filter-row .admin-action.is-active {
  background: var(--ink);
  color: #ffffff;
}

.card-display-reset-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: start;
}

.card-display-reset-row textarea {
  min-height: 86px;
}

.card-display-reset-row .admin-action {
  white-space: nowrap;
}

.card-display-list-status {
  margin-left: auto;
  color: var(--muted);
  font-size: 0.68rem;
}

#adminItemsPanel .card-display-list-status {
  justify-self: end;
  white-space: nowrap;
  font-size: 0.7rem;
}

#adminCardDisplayPanel .card-display-list-status {
  justify-self: end;
  white-space: nowrap;
  font-size: 0.7rem;
}

#adminItemsPanel .card-display-list-status.is-published {
  color: #2f9e44;
}

#adminItemsPanel .card-display-list-status.is-draft {
  color: #5c6ac4;
}

#adminCardDisplayPanel .card-display-list-status.is-configured {
  color: #2f9e44;
}

#adminItemsPanel .card-display-list-status.is-archived {
  color: #d69e2e;
}

.admin-assets-shell {
  width: min(1540px, calc(100% - 32px));
  display: grid;
  grid-template-columns: 320px minmax(0, 1fr);
  gap: 28px;
}

.admin-assets-sidebar {
  position: sticky;
  top: 82px;
  align-self: start;
  max-height: calc(100vh - 98px);
  overflow: auto;
  padding-right: 4px;
  display: grid;
  gap: 14px;
}

.admin-assets-content {
  min-width: 0;
  display: grid;
  gap: 12px;
  align-content: start;
}

.asset-filter-group {
  display: grid;
  gap: 8px;
}

.asset-upload-panel {
  display: grid;
  gap: 6px;
  padding: 10px;
  border: 2px solid #d7d7d7;
  background: #ffffff;
}

.asset-upload-panel .admin-action {
  width: 100%;
}

.asset-upload-panel p {
  margin: 0;
  color: var(--muted);
  font-size: 0.66rem;
  line-height: 1.4;
}

.asset-filter-group h2 {
  margin: 0;
  color: var(--muted);
  font-size: 0.72rem;
  line-height: 1.2;
}

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

.asset-filter-row .admin-action {
  min-width: 0;
  width: 100%;
  padding-inline: 8px;
  white-space: normal;
}

.asset-filter-row .admin-action.is-active {
  background: var(--ink);
  color: #ffffff;
}

.asset-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 14px;
}

.asset-card {
  border: 2px solid var(--line);
  background: var(--panel-bg);
  display: grid;
  gap: 10px;
  padding: 10px;
}

.asset-card-image {
  aspect-ratio: 1;
  display: grid;
  place-items: center;
  background: rgba(0, 0, 0, 0.04);
}

.asset-card-image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  image-rendering: pixelated;
  image-rendering: crisp-edges;
}

.asset-card-body {
  display: grid;
  gap: 7px;
}

.asset-bind-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  width: 100%;
  align-items: start;
}

.asset-bind-row .admin-multi-select {
  min-width: 0;
}

.asset-bind-row .admin-multi-select-dropdown {
  width: min(520px, calc(100vw - 48px));
  max-width: none;
  max-height: 260px;
}

.asset-card-body h3 {
  margin: 0;
  overflow: hidden;
  color: var(--ink);
  font-size: 0.85rem;
  line-height: 1.35;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.asset-card-meta,
.asset-card-bindings {
  margin: 0;
  color: var(--muted);
  font-size: 0.68rem;
  line-height: 1.5;
  overflow-wrap: anywhere;
}

.asset-status {
  width: fit-content;
  font-size: 0.7rem;
  line-height: 1;
}

.asset-status.is-active {
  color: #2f9e44;
}

.asset-status.is-orphaned {
  color: #d69e2e;
}

.card-display-badge-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.card-display-badge-list {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

.card-display-badge-row {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) auto auto;
  gap: 10px;
  align-items: center;
}

.card-display-badge-row input[type="color"] {
  width: 42px;
  height: 34px;
  padding: 0;
  border: 1px solid var(--soft-line);
  background: #fff;
}

.card-display-badge-swatch {
  position: static;
  display: inline-grid;
  place-items: center;
  min-height: 24px;
  white-space: nowrap;
}

.card-display-ingredient-preview {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.card-display-preview-card {
  position: relative;
  width: min(280px, 100%);
  padding: 12px;
  border: 1px solid rgba(23, 23, 23, 0.1);
  background: #fff;
  box-shadow: 0 8px 22px rgba(23, 23, 23, 0.1);
}

.card-display-preview-badge {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 1;
  padding: 4px 7px 3px;
  background: #171717;
  color: #fff;
  font-size: 0.62rem;
  line-height: 1;
}

.card-display-preview-image {
  display: grid;
  place-items: center;
  min-height: 170px;
  margin-bottom: 10px;
  background: #f7f7f7;
}

.card-display-preview-image img {
  width: min(170px, 100%);
  height: min(170px, 100%);
  object-fit: contain;
}

.card-display-preview-card h3 {
  margin: 0 0 8px;
  font-size: 1rem;
  line-height: 1.25;
}

.card-display-preview-card p {
  min-height: 38px;
  margin: 0 0 10px;
  color: var(--muted);
  font-size: 0.76rem;
  line-height: 1.55;
}

.card-display-preview-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 10px;
}

.card-display-preview-tags span {
  padding: 4px 6px 3px;
  border: 1px solid #d7d7d7;
  background: #fff;
  font-size: 0.66rem;
  line-height: 1;
}

.card-display-preview-meta {
  margin-top: 5px;
  color: var(--muted);
  font-size: 0.7rem;
  line-height: 1.4;
}

@media (max-width: 640px) {
  .admin-assets-shell {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .admin-assets-sidebar {
    position: static;
    max-height: none;
    padding-right: 0;
  }

  .card-display-reset-row,
  .card-display-badge-row {
    grid-template-columns: 1fr;
  }

  .card-display-badge-head {
    align-items: flex-start;
    flex-direction: column;
  }
}

/* ===== Pixel stepped corners ===== */
.view-tab,
.filter-toggle,
.clear-button,
.tag-button,
.category-filter-button,
.quick-filter-button,
.selected-tag,
.sidebar-close,
.detail-back,
.detail-thumb,
.detail-action-btn,
.detail-tag,
.detail-dish-chip,
.table-fab-badge,
.dish-card-add-btn.is-checked,
.admin-tab,
.admin-type-tab,
.admin-item-button,
.admin-action,
.ingredient-entity-chip,
.ingredient-source-card,
.admin-image-control,
.taxonomy-mode-tab,
.taxonomy-tag-chip,
.taxonomy-rename-input,
.taxonomy-result-card,
.dish-tag-checkbox,
.admin-tag-chip,
.admin-dish-chip,
.admin-ingredient-more,
.admin-step-btn,
.admin-multi-select-chip,
.admin-multi-select-chip-remove,
.admin-multi-select-option-check,
.taxonomy-batch-card,
.taxonomy-batch-bar,
.skin-preset-btn,
.skin-preview-tag,
.skin-icon-option,
.skin-button-preview-card,
.skin-cursor-mode-btn,
.skin-cursor-name-row input,
.skin-cursor-preview-box,
.skin-cursor-param-input,
.skin-cursor-hotspot-btn,
.lucky-drawer-tab,
.lucky-tag-option,
.lucky-skip-tags,
.lucky-start-btn,
.lucky-restart-btn,
.lucky-goto-table-btn,
.lucky-preview-clear,
.lucky-preview-goto,
.component-preview-tab,
.component-item,
.component-item-icon,
.component-checkbox {
  border-radius: 2px !important;
  clip-path: none;
}

.tag-button,
.category-filter-button,
.quick-filter-button,
.selected-tag,
.selected-tag-close,
.detail-tag,
.table-fab-badge,
.dish-card-add-btn.is-checked,
.admin-image-badge,
.admin-image-control,
.taxonomy-tag-chip,
.taxonomy-tag-chip .tag-delete,
.dish-tag-checkbox,
.admin-tag-chip,
.admin-ingredient-more,
.admin-multi-select-chip,
.admin-multi-select-chip-remove,
.admin-multi-select-option-check,
.skin-preview-tag,
.skin-cursor-param-input,
.skin-cursor-hotspot-btn,
.lucky-tag-option,
.lucky-nav-badge,
.component-item-icon {
  border-radius: 1px !important;
  clip-path: none;
}

.dish-card-add-btn,
.dish-card-favorite-btn {
  border-radius: 0 !important;
}

.dish-card-add-btn.is-checked {
  border-radius: var(--selection-check-radius) !important;
}

.dish-card-add-btn:not(.is-checked) {
  border: 0;
}

.search-input,
.admin-search,
.admin-name-input,
.taxonomy-group-name-input,
.taxonomy-add-tag-input,
.admin-field textarea,
.admin-steps-section textarea,
.admin-step-input,
.admin-qty-amount,
.admin-qty-unit,
.skin-color-row input[type="color"],
.skin-color-hex,
.component-field input[type="number"],
.component-field select,
input[type="text"],
input[type="search"],
input[type="number"],
textarea,
select {
  border-radius: var(--input-radius) !important;
  clip-path: none;
}

.recipe-fact,
.ingredient-group,
.admin-no-image,
.admin-image-slot,
.admin-multi-select-dropdown,
.skin-preview-card,
.skin-icon-manager,
.skin-cursor-manager,
.skin-cursor-section,
.component-preview-box {
  border-radius: 3px !important;
  clip-path: none;
}

.component-switch-slider,
.component-switch-slider::before {
  border-radius: 3px !important;
  clip-path: none;
}

.lucky-card {
  border-radius: 18px !important;
  clip-path: none;
}

.lucky-card-image {
  border-radius: 18px 18px 0 0 !important;
  clip-path: none;
}

.lucky-card-label {
  border-radius: 14px !important;
  clip-path: none;
}

.lucky-action-icon {
  border-radius: 50% !important;
  clip-path: none;
}

.lucky-action-icon {
  box-shadow: 0 10px 26px rgba(23, 23, 23, 0.12);
}

.lucky-drawer-close,
.lucky-undo-btn,
.lucky-preview-close {
  border-radius: 50% !important;
  clip-path: none;
}

.lucky-nav-btn,
.lucky-nav-badge {
  border-radius: 999px !important;
  clip-path: none;
}

.view-tab:hover,
.filter-toggle:hover,
.clear-button:hover,
.tag-button:hover,
.category-filter-button:hover,
.quick-filter-button:hover,
.selected-tag:hover,
.sidebar-close:hover,
.detail-back:hover,
.admin-tab:hover,
.admin-type-tab:hover,
.admin-action:hover,
.admin-item-button:hover,
.taxonomy-tag-chip:hover,
.lucky-start-btn:hover,
.lucky-skip-tags:hover,
.lucky-nav-btn:hover,
.lucky-restart-btn:hover,
.lucky-goto-table-btn:hover,
.lucky-preview-clear:hover,
.lucky-preview-goto:hover {
  box-shadow: 2px 2px 0 var(--soft-shadow);
}

@media (max-width: 640px) {
  .site-header {
    position: relative;
    padding: 18px 12px 12px;
    transform: none !important;
  }

  .site-header.is-compact {
    background:
      linear-gradient(90deg, transparent 0 11px, var(--soft-line) 11px 12px) 0 100% / 12px 2px repeat-x,
      var(--page-bg);
    box-shadow: none;
  }

  .site-header-inner,
  body.menu-card-layout .site-header-inner,
  .site-header.is-compact .site-header-inner {
    grid-template-columns: minmax(0, 1fr);
    width: 100%;
    justify-items: center;
    gap: 8px;
  }

  .site-logo,
  .site-header.is-compact .site-logo {
    color: #111111;
    font-size: clamp(1.85rem, 10vw, 2.65rem);
    text-shadow:
      3px 3px 0 #ededed,
      5px 5px 0 #d7d7d7;
  }

  .site-header-actions,
  .site-header.is-compact .site-header-actions {
    position: absolute;
    top: -8px;
    right: 0;
  }

  .site-table-link,
  .site-pantry-link,
  .site-header.is-compact .site-table-link,
  .site-header.is-compact .site-pantry-link {
    display: none;
  }

  .site-header.is-compact .site-admin-link,
  .site-header.is-compact .site-auth-button,
  .site-header.is-compact .site-user-name {
    color: var(--muted);
  }

  .site-header.is-compact .view-switcher {
    justify-content: center;
  }

  .site-header.is-compact #showTableView {
    display: inline-block;
  }

  .site-header.is-compact .view-tab {
    border-color: var(--ink);
    background: var(--panel-bg);
    color: var(--ink);
  }

  .site-header.is-compact .view-tab.is-active {
    background: var(--ink);
    color: #ffffff;
  }

  .site-header.is-compact .search-input {
    border-color: var(--ink);
    background: var(--panel-bg);
    color: var(--ink);
    text-align: center;
  }

  .site-header.is-compact .search-input::placeholder {
    color: var(--muted);
  }
}

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

  .profile-avatar-block {
    justify-items: start;
  }

  .admin-header {
    padding: 10px 12px;
  }

  .admin-header-inner {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
  }

  .admin-logo {
    font-size: 1rem;
  }

  .admin-header .admin-tabs,
  .admin-header-tools {
    grid-column: 1 / -1;
    width: 100%;
  }

  .admin-header .admin-tabs {
    overflow-x: auto;
    justify-content: flex-start;
    padding-bottom: 2px;
  }

  .admin-user-menu {
    grid-column: 1 / -1;
    justify-self: start;
  }

  .user-profile-grid,
  .user-permission-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .admin-header h1.admin-logo,
  .admin-logo {
    font-size: 1rem;
    line-height: 1;
    text-shadow: none;
  }

  .admin-header .admin-tab {
    flex: 0 0 auto;
    min-width: max-content;
    padding: 7px 9px 6px;
  }

}

.site-user-drawer .site-admin-link,
.site-header.is-compact .site-user-drawer .site-admin-link {
  position: static;
  top: auto;
  right: auto;
  color: var(--ink);
  font-size: 0.78rem;
}

.mobile-shop-nav {
  display: none;
}

.mobile-table-mode-tabs,
.mobile-table-mode-tab,
.mobile-my-tabs,
.mobile-table-header-tabs,
.mobile-compact-my-tabs,
.profile-mobile-logout {
  display: none;
}

.mobile-facet-bar,
.mobile-facet-popover {
  display: none;
}

.mobile-full-filter {
  display: none;
}

.mobile-compact-header {
  display: none;
}

#tableSearchPanel {
  display: none;
}

.pantry-add-trigger {
  appearance: none;
  display: none;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 8px 12px 7px;
  border: 2px solid var(--ink);
  border-radius: 0;
  background: #ffffff;
  color: var(--ink);
  font: inherit;
  font-size: 0.78rem;
  font-weight: 700;
}

.pantry-add-trigger[hidden] {
  display: none !important;
}

.ingredient-picker-modal {
  position: fixed;
  inset: 0;
  z-index: 360;
  display: grid;
  place-items: center;
  padding: 18px;
  background: rgba(0, 0, 0, 0.38);
}

.ingredient-picker-modal[hidden] {
  display: none;
}

.ingredient-picker-card {
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr) auto auto;
  gap: 12px;
  width: min(520px, calc(100vw - 28px));
  height: min(720px, calc(100dvh - 28px));
  max-height: min(720px, calc(100dvh - 28px));
  overflow: hidden;
  padding: 18px;
  border: 2px solid var(--ink);
  border-radius: 10px;
  background: #ffffff;
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.24);
}

.ingredient-picker-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
}

.ingredient-picker-head h2 {
  margin: 0;
  font-size: 1.2rem;
}

.ingredient-picker-close {
  width: 34px;
  height: 34px;
  border: 2px solid var(--ink);
  border-radius: 0;
  background: #ffffff;
  color: var(--ink);
  font: inherit;
  font-size: 1rem;
}

.ingredient-picker-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  align-content: start;
  gap: 8px;
  min-height: 120px;
  overflow: auto;
  padding-right: 2px;
}

.ingredient-picker-option {
  position: relative;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  min-height: 58px;
  padding: 7px;
  border: 1px solid var(--soft-line);
  border-radius: 8px;
  background: #ffffff;
  color: var(--ink);
  font: inherit;
  text-align: left;
}

.ingredient-picker-option.is-selected {
  border-color: var(--ink);
  box-shadow: inset 0 0 0 1px var(--ink);
}

.ingredient-picker-option.is-selected::after {
  content: "✓";
  position: absolute;
  top: 4px;
  right: 4px;
  display: grid;
  place-items: center;
  width: 18px;
  height: 18px;
  border: 2px solid var(--ink);
  border-radius: 50%;
  background: var(--success);
  color: #ffffff;
  font-size: 0.72rem;
  font-weight: 700;
}

.ingredient-picker-option img {
  width: 42px;
  height: 42px;
  object-fit: contain;
}

.ingredient-picker-dish-option img {
  border-radius: 6px;
  background: #f4f4f4;
}

.ingredient-picker-option-text {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.ingredient-picker-option-text strong {
  overflow: hidden;
  font-size: 0.78rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ingredient-picker-option-text small,
.ingredient-picker-status {
  color: var(--muted);
  font-size: 0.68rem;
}

.ingredient-picker-actions {
  display: flex;
  justify-content: end;
  gap: 8px;
}

@media (max-width: 640px) {
  :root {
    --mobile-nav-height: 64px;
    --mobile-safe-bottom: env(safe-area-inset-bottom, 0px);
    --mobile-filter-nav-gap: 0px;
    --mobile-visual-bottom: 0px;
  }

  body {
    background: #f7f7f7;
  }

  .site-header,
  .site-header.is-compact {
    position: relative;
    top: 0;
    z-index: 120;
    padding: 10px 10px 9px;
    background: #ffffff;
    box-shadow: 0 1px 0 rgba(23, 23, 23, 0.08), 0 6px 18px rgba(23, 23, 23, 0.06);
    transform: none !important;
  }

  .site-header.is-compact {
    background: #ffffff;
  }

  .site-header-inner,
  body.menu-card-layout .site-header-inner,
  .site-header.is-compact .site-header-inner {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    justify-items: stretch;
    gap: 8px;
    width: 100%;
  }

  .site-logo,
  .site-header.is-compact .site-logo {
    grid-column: 1;
    grid-row: 1;
    align-self: center;
    color: var(--ink);
    font-size: 1.02rem;
    line-height: 1;
    text-align: left;
    text-shadow: 1px 1px 0 #ededed;
    white-space: nowrap;
  }

  .site-header.is-compact .site-logo {
    color: var(--ink);
    font-size: 1.02rem;
    text-shadow: 1px 1px 0 #ededed;
  }

  body.mobile-menu-ingredient-tabs-visible .mobile-header-tabs {
    grid-column: 2;
    grid-row: 1;
    justify-self: stretch;
    align-self: center;
    display: flex !important;
    align-items: center;
    gap: 13px;
    min-width: 0;
    max-width: 100%;
    margin-left: 14px;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 0;
    scrollbar-width: none;
    transform: translateY(1px);
    -webkit-overflow-scrolling: touch;
  }

  body.mobile-my-view .mobile-my-header-tabs {
    grid-column: 2;
    grid-row: 1;
    justify-self: stretch;
    align-self: center;
    display: flex !important;
    align-items: center;
    gap: 13px;
    min-width: 0;
    max-width: 100%;
    margin-left: 14px;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 0;
    scrollbar-width: none;
    transform: translateY(1px);
    -webkit-overflow-scrolling: touch;
  }

  body.mobile-table-tabs-visible .mobile-table-header-tabs {
    grid-column: 2;
    grid-row: 1;
    justify-self: stretch;
    align-self: center;
    display: flex !important;
    align-items: center;
    gap: 16px;
    min-width: 0;
    max-width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 0;
    scrollbar-width: none;
    transform: translateY(1px);
    -webkit-overflow-scrolling: touch;
  }

  body.mobile-menu-ingredient-tabs-visible .mobile-header-tabs::-webkit-scrollbar,
  body.mobile-my-view .mobile-my-header-tabs::-webkit-scrollbar,
  body.mobile-table-tabs-visible .mobile-table-header-tabs::-webkit-scrollbar {
    display: none;
  }

  .mobile-header-tab,
  .mobile-my-header-tabs .pantry-mode-tab {
    appearance: none;
    flex: 0 0 auto;
    min-height: 18px;
    padding: 0 0 2px;
    border: 0;
    border-bottom: 2px solid transparent;
    border-radius: 0;
    background: transparent;
    color: var(--ink);
    font: inherit;
    font-size: 0.82rem;
    font-weight: 700;
    line-height: 1;
    text-shadow: none;
    white-space: nowrap;
  }

  .mobile-table-header-tabs .mobile-header-tab {
    position: relative;
    padding-right: 9px;
  }

  .mobile-table-tab-badge {
    position: absolute;
    top: -8px;
    right: -8px;
    display: grid;
    place-items: center;
    min-width: 16px;
    height: 16px;
    padding: 0 4px;
    border: 1px solid #ffffff;
    border-radius: 999px;
    color: #ffffff;
    font-size: 0.54rem;
    font-weight: 700;
    line-height: 1;
  }

  .mobile-table-tab-badge.is-table {
    background: var(--danger);
  }

  .mobile-table-tab-badge.is-bag {
    background: var(--success);
  }

  .mobile-table-tab-badge.is-owned {
    background: var(--ink);
  }

  .mobile-my-header-tabs .pantry-mode-tab[hidden] {
    display: none;
  }

  .mobile-header-tab.is-active,
  .mobile-my-header-tabs .pantry-mode-tab.is-active {
    border-bottom-color: var(--ink);
  }

  .mobile-admin-shortcut {
    margin-left: auto;
    align-self: center;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 28px;
    padding: 5px 9px 4px;
    border: 1.5px solid var(--ink);
    border-radius: 0;
    background: var(--ink);
    color: #ffffff;
    font-size: 0.72rem;
    font-weight: 700;
    line-height: 1;
    text-decoration: none;
    white-space: nowrap;
  }

  .mobile-admin-shortcut[hidden] {
    display: none;
  }

  .site-header-actions,
  .site-header.is-compact .site-header-actions {
    position: static;
    grid-column: 3;
    grid-row: 1;
    justify-self: end;
    gap: 6px;
  }

  body.mobile-my-view .site-header-actions,
  body.mobile-table-tabs-visible .site-header-actions {
    display: flex;
  }

  .site-auth-button {
    min-height: 30px;
    padding: 6px 8px 5px;
    border: 1px solid #d7d7d7;
    background: #ffffff;
    color: var(--ink);
    font-size: 0.64rem;
  }

  .site-user-trigger {
    max-width: 96px;
  }

  .site-user-name,
  .site-header.is-compact .site-user-name {
    font-size: 0.64rem;
  }

  .site-header.is-compact .site-user-name {
    color: var(--muted);
  }

  .site-table-link,
  .site-pantry-link,
  .site-header.is-compact .site-table-link,
  .site-header.is-compact .site-pantry-link {
    display: none;
  }

  .header-search-area,
  .site-header.is-compact .header-search-area {
    grid-column: 1 / -1;
    grid-row: 2;
    width: 100%;
  }

  body.mobile-my-view .header-search-area {
    display: block;
  }

  body.mobile-my-view .site-header,
  body.mobile-table-tabs-visible .site-header {
    min-height: 122px;
  }

  .site-header.is-compact .header-search-area {
    grid-column: 1 / -1;
    grid-row: 2;
    width: 100%;
  }

  .search-panel,
  .site-header.is-compact .search-panel {
    display: grid;
    gap: 5px;
    margin: 0;
  }

  body.mobile-table-tabs-visible #tableSearchPanel:not([hidden]),
  body.mobile-my-view #tableSearchPanel:not([hidden]) {
    display: grid;
  }

  .search-input,
  .site-header.is-compact .search-input {
    width: 100%;
    height: 42px;
    padding: 10px 44px 9px 13px;
    border: var(--input-border-strong);
    border-radius: var(--input-radius);
    background: var(--input-bg);
    color: var(--ink);
    font-size: 0.78rem;
    text-align: left;
    box-shadow: inset 0 0 0 1px rgba(23, 23, 23, 0.02);
  }

  .site-header.is-compact .search-input {
    height: 42px;
    padding: 10px 44px 9px 13px;
    border-color: var(--ink);
    background: #ffffff;
    color: var(--ink);
    font-size: 0.78rem;
  }

  .header-search-icon {
    top: 5px;
    right: 5px;
    width: 32px;
    height: 32px;
    border-radius: 2px;
    background-size: 17px 17px;
  }

  .search-input::placeholder,
  .site-header.is-compact .search-input::placeholder {
    color: #767676;
  }

  .site-header.is-compact .search-input::placeholder {
    color: #767676;
  }

  .search-suggestions,
  .site-header.is-compact .search-suggestions {
    top: 48px;
    left: 50%;
    width: calc(100vw - 16px);
    max-width: calc(100vw - 16px);
    max-height: min(360px, calc(100vh - 120px));
    transform: translateX(-50%);
    border-radius: 8px;
  }

  .active-row {
    justify-content: flex-start;
    min-height: 18px;
  }

  .results-count {
    font-size: 0.66rem;
  }

  .view-switcher,
  .site-header.is-compact .view-switcher {
    display: none;
  }

  .mobile-facet-bar {
    position: relative;
    grid-column: 1 / -1;
    grid-row: 3;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 8px;
    min-width: 0;
  }

  .mobile-facet-bar[hidden] {
    display: none !important;
  }

  .mobile-facet-scroll {
    display: flex !important;
    gap: 7px;
    min-width: 0;
    overflow-x: auto;
    padding: 1px 0 2px;
    scrollbar-width: none;
  }

  .mobile-facet-scroll::-webkit-scrollbar {
    display: none;
  }

  .mobile-facet-chip,
  .mobile-facet-filter {
    appearance: none;
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    min-height: 28px;
    padding: 5px 4px 4px;
    border: 0;
    border-bottom: 2px solid #d7d7d7;
    border-radius: 0 !important;
    background: transparent;
    color: var(--ink);
    font-family: inherit;
    font-size: 0.72rem;
    line-height: 1.1;
    white-space: nowrap;
  }

  .mobile-facet-chip::after {
    content: "";
    width: 0;
    height: 0;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 5px solid currentColor;
    transform: translateY(1px);
  }

  .mobile-facet-chip[aria-expanded="true"],
  .mobile-facet-chip.is-active,
  .mobile-facet-filter.is-active,
  .mobile-facet-filter[aria-expanded="true"] {
    border-color: var(--selection-soft-border);
    background: var(--selection-soft-bg);
    color: var(--selection-pill-fg);
  }

  .mobile-facet-chip[aria-expanded="true"]::after {
    transform: translateY(1px) rotate(180deg);
  }

  .mobile-facet-filter {
    justify-self: end;
    box-shadow: -8px 0 14px #ffffff;
  }

  .mobile-facet-popover {
    position: absolute;
    z-index: 130;
    top: calc(100% + 7px);
    left: 0;
    right: 0;
    display: grid;
    gap: 10px;
    max-height: min(360px, calc(100dvh - 210px));
    overflow: hidden;
    padding: 12px;
    border: 1px solid rgba(23, 23, 23, 0.14);
    border-radius: 10px;
    background: #ffffff;
    box-shadow: 0 10px 28px rgba(23, 23, 23, 0.14);
  }

  .mobile-facet-popover[hidden] {
    display: none !important;
  }

  .mobile-facet-popover-title {
    color: var(--muted);
    font-size: 0.7rem;
    line-height: 1.2;
  }

  .mobile-facet-options {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    max-height: min(230px, calc(100dvh - 330px));
    overflow: auto;
  }

  .mobile-facet-option {
    appearance: none;
    min-height: var(--selection-option-min-height);
    padding: 5px 8px;
    border: 2px solid var(--selection-muted-border);
    border-radius: 0 !important;
    background: var(--panel-bg);
    color: var(--ink);
    font-family: inherit;
    font-size: 0.78rem;
    line-height: 1.25;
  }

  .mobile-facet-option.is-active {
    border-color: var(--selection-active-border);
    background: var(--selection-active-bg);
    color: var(--selection-active-fg);
  }

  .mobile-compact-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 240;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 8px;
    min-height: 50px;
    padding: 8px 10px;
    background: #111111;
    color: #ffffff;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.2);
    opacity: 0;
    pointer-events: none;
    transform: translateY(-100%);
    transition: transform 160ms ease, opacity 160ms ease;
  }

  .mobile-compact-header[hidden] {
    display: grid !important;
  }

  .mobile-compact-header.is-visible {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
  }

  body.mobile-my-view .mobile-compact-header {
    grid-template-columns: auto minmax(0, 1fr) auto;
    min-height: 50px;
    padding: 8px 10px;
    background: #111111;
    color: #ffffff;
  }

  body.mobile-favorites-view .mobile-compact-header {
    background: #f6c94f;
    color: var(--ink);
    box-shadow: 0 4px 14px rgba(23, 23, 23, 0.18);
  }

  body.mobile-ingredients-view .mobile-compact-header {
    background: var(--success);
    color: #ffffff;
    box-shadow: 0 4px 14px rgba(38, 92, 38, 0.24);
  }

  .mobile-compact-logo {
    color: #ffffff;
    font-size: 0.9rem;
    line-height: 1;
    text-decoration: none;
    white-space: nowrap;
  }

  body.mobile-my-view .mobile-compact-logo,
  body.mobile-my-view .mobile-compact-search {
    display: block !important;
  }

  body.mobile-my-view .mobile-compact-suggestions:not([hidden]) {
    display: block !important;
  }

  body.mobile-my-view .mobile-compact-my-tabs {
    display: none !important;
  }

  body.mobile-my-view .mobile-compact-logo {
    max-width: 5.5em;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  body.mobile-my-view .mobile-compact-my-tabs {
    align-items: center;
    gap: 18px;
    width: auto;
    min-width: 0;
    overflow-x: auto;
    padding: 0;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }

  body.mobile-my-view .mobile-compact-my-tabs::-webkit-scrollbar {
    display: none;
  }

  body.mobile-my-view .mobile-compact-my-tab {
    appearance: none;
    flex: 0 0 auto;
    min-height: 34px;
    padding: 7px 0 6px;
    border: 0;
    border-bottom: 2px solid transparent;
    background: transparent;
    color: rgba(255, 255, 255, 0.68);
    font: inherit;
    font-size: 0.72rem;
    font-weight: 600;
    line-height: 1.1;
    text-decoration: none;
    white-space: nowrap;
  }

  body.mobile-my-view .mobile-compact-my-tab.is-active {
    border-bottom-color: #ffffff;
    color: #ffffff;
  }

  body.mobile-my-view .mobile-compact-my-tab[hidden] {
    display: none;
  }

  body.mobile-my-view .mobile-compact-admin-shortcut {
    margin-left: auto;
    min-height: 30px;
    padding: 6px 10px 5px;
    border: 1.5px solid rgba(255, 255, 255, 0.9);
    color: #ffffff;
  }

  body.mobile-my-view .mobile-compact-admin-shortcut[hidden] {
    display: none;
  }

  body.mobile-favorites-view .mobile-compact-logo {
    color: var(--ink);
  }

  body.mobile-ingredients-view .mobile-compact-logo {
    color: #ffffff;
  }

  .mobile-compact-search {
    min-width: 0;
    width: 100%;
    height: 34px;
    padding: 8px 32px 7px 10px;
    border: 1px solid rgba(255, 255, 255, 0.6);
    border-radius: var(--input-radius);
    background: rgba(255, 255, 255, 0.12);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='17' height='17' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.5-3.5'/%3E%3C/svg%3E");
    background-position: right 9px center;
    background-repeat: no-repeat;
    background-size: 17px 17px;
    color: #ffffff;
    font: inherit;
    font-size: 0.72rem;
    outline: none;
  }

  .mobile-compact-search:focus {
    box-shadow: var(--input-focus-shadow);
  }

  body.mobile-favorites-view .mobile-compact-search {
    border-color: rgba(23, 23, 23, 0.58);
    background-color: rgba(255, 255, 255, 0.42);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='17' height='17' viewBox='0 0 24 24' fill='none' stroke='%23171717' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.5-3.5'/%3E%3C/svg%3E");
    color: var(--ink);
  }

  body.mobile-ingredients-view .mobile-compact-search {
    border-color: rgba(255, 255, 255, 0.68);
    background-color: rgba(255, 255, 255, 0.14);
    color: #ffffff;
  }

  .mobile-compact-search::placeholder {
    color: rgba(255, 255, 255, 0.7);
  }

  body.mobile-favorites-view .mobile-compact-search::placeholder {
    color: rgba(23, 23, 23, 0.62);
  }

  body.mobile-ingredients-view .mobile-compact-search::placeholder {
    color: rgba(255, 255, 255, 0.78);
  }

  .mobile-compact-suggestions {
    grid-column: 1 / -1;
    top: calc(100% + 6px);
    left: 50%;
    width: calc(100vw - 16px);
    max-width: calc(100vw - 16px);
    max-height: min(320px, calc(100dvh - 92px));
    transform: translateX(-50%);
    border-radius: 0;
    background: #ffffff;
    color: var(--ink);
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.18);
  }

	  .mobile-compact-account {
	    display: inline-flex;
	    align-items: center;
	    justify-content: center;
	    gap: 5px;
	    max-width: 82px;
	    min-height: 34px;
	    overflow: hidden;
	    padding: 7px 8px 6px;
	    border: 0;
	    background: transparent;
	    color: #ffffff;
	    font: inherit;
	    font-size: 0.64rem;
	    white-space: nowrap;
	  }

	  body.mobile-favorites-view .mobile-compact-account {
	    color: var(--ink);
	  }

	  body.mobile-ingredients-view .mobile-compact-account {
	    color: #ffffff;
	  }

  .mobile-compact-account.is-signed-in {
    max-width: 104px;
    padding-left: 6px;
  }

  .mobile-compact-avatar {
    display: grid;
    flex: 0 0 22px;
    place-items: center;
    width: 22px;
    height: 22px;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.5);
    border-radius: 50%;
    background-color: rgba(255, 255, 255, 0.16);
    background-position: center;
    background-size: cover;
    color: #ffffff;
    font-size: 0.58rem;
    font-weight: 700;
    line-height: 1;
  }

  body.mobile-favorites-view .mobile-compact-avatar {
    border-color: rgba(23, 23, 23, 0.45);
    background-color: rgba(255, 255, 255, 0.32);
    color: var(--ink);
  }

  body.mobile-ingredients-view .mobile-compact-avatar {
    border-color: rgba(255, 255, 255, 0.56);
    background-color: rgba(255, 255, 255, 0.18);
    color: #ffffff;
  }

  .mobile-compact-avatar[hidden] {
    display: none;
  }

  .mobile-compact-name {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .mobile-facet-popover-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    padding-top: 2px;
    border-top: 1px solid rgba(23, 23, 23, 0.08);
  }

  .mobile-facet-popover-clear,
  .mobile-facet-popover-confirm {
    appearance: none;
    min-height: 32px;
    border-radius: 0;
    font-family: inherit;
    font-size: 0.78rem;
    line-height: 1.25;
  }

  .mobile-facet-popover-clear {
    border: 2px solid var(--ink);
    background: #e53e3e;
    color: #ffffff;
  }

  .mobile-facet-popover-confirm {
    border: 2px solid var(--ink);
    background: var(--ink);
    color: #ffffff;
  }

  main,
  body.menu-card-layout main {
    width: 100%;
    padding: 10px 8px calc(var(--mobile-nav-height) + var(--mobile-safe-bottom) + var(--mobile-visual-bottom) + 22px);
  }

  .floating-filter-bar {
    display: none;
  }

  .filter-toggle {
    flex: 0 0 auto;
    min-width: 66px;
    min-height: 34px;
    padding: 8px 10px 7px;
    border-radius: 999px;
    background: #ffffff;
    font-size: 0.7rem;
  }

  .selected-tags {
    flex: 0 0 auto;
    flex-wrap: nowrap;
    min-height: 32px;
  }

  .selected-tag-group {
    flex-wrap: nowrap;
  }

  .selected-tag {
    min-height: 28px;
    padding: 5px 22px 4px 8px;
    border: 2px solid var(--selection-pill-border);
    border-radius: 0;
    background: var(--selection-pill-bg);
    color: var(--selection-pill-fg);
    white-space: nowrap;
  }

  .clear-button {
    flex: 0 0 auto;
    min-height: 32px;
    border-radius: 999px;
  }

  .filter-sidebar {
    position: fixed;
    inset: auto 0 calc(var(--mobile-nav-height) + var(--mobile-safe-bottom) + var(--mobile-visual-bottom) + var(--mobile-filter-nav-gap));
    z-index: 180;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    width: 100%;
    height: min(78dvh, 640px);
    max-height: calc(100dvh - var(--mobile-nav-height) - var(--mobile-safe-bottom) - var(--mobile-visual-bottom) - var(--mobile-filter-nav-gap) - 48px);
    overflow: hidden;
    overscroll-behavior: contain;
    padding: 0;
    border: 0;
    border-top: 2px solid var(--ink);
    border-radius: 14px 14px 0 0;
    background: #ffffff;
    box-shadow: 0 -12px 28px rgba(23, 23, 23, 0.16);
    opacity: 0;
    pointer-events: none;
    transform: translateY(105%);
  }

  html.filters-open,
  body.filters-open {
    overflow: hidden;
    overscroll-behavior: none;
  }

  body.filters-open .floating-filter-bar {
    visibility: hidden;
  }

  body.filters-open .filter-sidebar {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
  }

  .filter-sidebar > .tag-groups {
    display: none;
  }

  .filter-sidebar .sidebar-header {
    min-height: 52px;
    margin: 0;
    padding: 12px 14px;
    border-bottom: 1px solid rgba(23, 23, 23, 0.08);
    background: #ffffff;
  }

  .filter-sidebar .sidebar-close {
    border: 1px solid #d7d7d7;
    border-radius: 8px;
  }

  .mobile-full-filter {
    display: grid;
    grid-template-columns: 96px minmax(0, 1fr);
    grid-template-rows: minmax(0, 1fr) auto;
    min-height: 0;
    height: auto;
    background: #ffffff;
  }

  .mobile-full-filter[hidden] {
    display: none !important;
  }

  .mobile-full-filter-nav {
    grid-column: 1;
    grid-row: 1;
    display: flex;
    flex-direction: column;
    min-height: 0;
    overflow: auto;
    overscroll-behavior: contain;
    border-right: 1px solid rgba(23, 23, 23, 0.08);
    background: #f5f5f5;
  }

  .mobile-full-filter-nav-item {
    appearance: none;
    width: 100%;
    min-height: 44px;
    padding: 12px 9px;
    border: 0;
    border-left: 3px solid transparent;
    border-bottom: 1px solid rgba(23, 23, 23, 0.06);
    background: transparent;
    color: var(--muted);
    font-family: inherit;
    font-size: 0.72rem;
    line-height: 1.2;
    text-align: left;
  }

  .mobile-full-filter-nav-item.is-active {
    border-left-color: var(--ink);
    background: #ffffff;
    color: var(--ink);
    font-weight: 700;
  }

  .mobile-full-filter-nav-item.has-selection:not(.is-active) {
    border-left-color: var(--selection-soft-border);
    background: var(--selection-soft-bg);
    color: var(--ink);
  }

  .mobile-full-filter-panel {
    grid-column: 2;
    grid-row: 1;
    min-height: 0;
    overflow: auto;
    overscroll-behavior: contain;
    padding: 14px 12px;
  }

  .mobile-full-filter-title {
    margin: 0 0 10px;
    color: var(--muted);
    font-size: 0.72rem;
    line-height: 1.2;
  }

  .mobile-full-filter-options {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-content: flex-start;
  }

  .mobile-full-filter-option {
    appearance: none;
    min-height: var(--selection-option-min-height);
    padding: 5px 8px;
    border: 2px solid var(--selection-muted-border);
    border-radius: 0 !important;
    background: var(--panel-bg);
    color: var(--ink);
    font-family: inherit;
    font-size: 0.78rem;
    line-height: 1.25;
  }

  .mobile-full-filter-option.is-active {
    border-color: var(--selection-active-border);
    background: var(--selection-active-bg);
    color: var(--selection-active-fg);
  }

  .mobile-full-filter-actions {
    grid-column: 1 / -1;
    grid-row: 2;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    padding: 10px 12px 14px;
    border-top: 1px solid rgba(23, 23, 23, 0.12);
    background: rgba(255, 255, 255, 0.98);
    box-shadow: 0 -8px 22px rgba(23, 23, 23, 0.08);
  }

  .mobile-full-filter-clear,
  .mobile-full-filter-confirm {
    appearance: none;
    min-height: 34px;
    border-radius: 0;
    font-family: inherit;
    font-size: 0.78rem;
    line-height: 1.25;
  }

  .mobile-full-filter-clear {
    border: 2px solid var(--ink);
    background: #e53e3e;
    color: #ffffff;
  }

  .mobile-full-filter-confirm {
    border: 2px solid var(--ink);
    background: var(--ink);
    color: #ffffff;
  }

  .tag-groups {
    gap: 16px;
  }

  .tag-list {
    gap: 8px;
  }

  .tag-button,
  .category-filter-button,
  .quick-filter-button {
    min-height: 34px;
    padding: 8px 10px 7px;
    border: 1px solid #d7d7d7;
    border-radius: 999px;
  }

  #menuView.menu-style-card .menu-grid,
  #favoritesView .menu-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--mobile-card-grid-gap);
  }

  #ingredientsView .ingredient-grid,
  body.menu-card-layout #ingredientsView .ingredient-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--mobile-card-grid-gap);
  }

  #tableGrid {
    gap: var(--mobile-card-grid-gap);
  }

  #menuView.menu-style-card .dish-card,
  #favoritesView .dish-card,
  #tableGrid .dish-card {
    min-height: 0;
    padding: var(--mobile-card-padding);
    border: var(--mobile-card-border);
    border-radius: var(--mobile-card-radius);
    background: var(--mobile-card-bg);
    box-shadow: var(--mobile-card-shadow);
  }

  #menuView.menu-style-card .dish-card,
  #favoritesView .dish-card,
  #ingredientsView .ingredient-card {
    display: grid;
    grid-template-columns: 1fr;
    align-items: start;
  }

  #ingredientsView .ingredient-card {
    min-height: 0;
    padding: var(--mobile-card-padding);
    border: var(--mobile-card-border);
    border-radius: var(--mobile-card-radius);
    background: var(--mobile-card-bg);
    align-content: start;
    box-shadow: var(--mobile-card-shadow);
  }

  #menuView.menu-style-card .dish-image-wrap,
  #favoritesView .dish-image-wrap,
  #ingredientsView .ingredient-card .dish-image-wrap,
  #tableGrid .dish-image-wrap {
    aspect-ratio: 1 / 1;
    min-height: 0;
    border-radius: var(--mobile-card-image-radius);
    background: var(--mobile-card-image-bg);
  }

  #menuView.menu-style-card .dish-image-wrap,
  #favoritesView .dish-image-wrap,
  #ingredientsView .ingredient-card .dish-image-wrap {
    grid-column: 1 / -1;
  }

  #menuView.menu-style-card .dish-card .dish-card-favorite-btn,
  #favoritesView .dish-card .dish-card-favorite-btn {
    top: 2px;
    right: 2px;
    width: 32px;
    height: 32px;
    min-width: 0;
    min-height: 0;
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
    color: #ffffff;
    line-height: 1;
    opacity: 1;
    text-shadow: none;
  }

  #menuView.menu-style-card .dish-card .dish-card-favorite-btn.is-favorite,
  #favoritesView .dish-card .dish-card-favorite-btn.is-favorite {
    color: #f6c94f;
  }

  #menuView.menu-style-card .dish-image,
  #favoritesView .dish-image,
  #ingredientsView .ingredient-card .dish-image,
  #tableGrid .dish-image {
    width: var(--mobile-card-image-scale);
    height: var(--mobile-card-image-scale);
    object-fit: contain;
  }

  #menuView.menu-style-card .dish-name,
  #favoritesView .dish-name,
  #ingredientsView .ingredient-card .dish-name,
  #tableGrid .dish-name {
    min-height: 34px;
    margin-top: 8px;
    padding: 0;
    font-size: 0.78rem;
    line-height: 1.28;
  }

  #ingredientsView .ingredient-card .dish-name {
    min-height: 26px;
    margin-top: 6px;
    line-height: 1.2;
  }

  #menuView.menu-style-card .dish-name,
  #favoritesView .dish-name,
  #ingredientsView .ingredient-card .dish-name {
    grid-column: 1;
    grid-row: 2;
    align-items: center;
    justify-content: center;
    text-align: center;
  }

  #menuView.menu-style-card .dish-card-tagline,
  #favoritesView .dish-card-tagline,
  #menuView.menu-style-card .dish-card-drag-hint,
  #favoritesView .dish-card-drag-hint {
    display: none;
  }

  #menuView.menu-style-card .dish-card-highlights,
  #favoritesView .dish-card-highlights {
    grid-column: 1 / -1;
    min-height: 22px;
    margin: 5px 0 7px;
    flex-wrap: nowrap;
    overflow: hidden;
  }

  #menuView.menu-style-card .dish-card-highlights span,
  #favoritesView .dish-card-highlights span {
    flex: 0 0 auto;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    border-radius: 999px;
  }

  #menuView.menu-style-card .dish-card-meta,
  #favoritesView .dish-card-meta {
    grid-column: 1 / -1;
    grid-row: 4;
    gap: 3px;
    padding-right: 38px;
    padding-top: 7px;
    font-size: 0.6rem;
  }

  #menuView.menu-style-card .dish-card-meta span,
  #favoritesView .dish-card-meta span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  #menuView.menu-style-card .dish-card-add-btn,
  #favoritesView .dish-card-add-btn,
  .dish-card-add-btn {
    position: static;
    grid-column: 1;
    grid-row: 4;
    align-self: center;
    justify-self: end;
    z-index: 2;
    width: var(--mobile-card-action-size);
    height: var(--mobile-card-action-size);
    min-width: var(--mobile-card-action-size);
    min-height: var(--mobile-card-action-size);
    border: 0;
    border-radius: 0;
    background: transparent;
    color: var(--ink);
    font-size: 0.92rem;
    opacity: 1;
    box-shadow: none;
  }

  #ingredientsView .ingredient-card .dish-card-add-btn {
    grid-row: 3;
    align-self: center;
    justify-self: end;
    z-index: 2;
    margin: 0;
  }

  #ingredientsView .ingredient-role-line {
    grid-column: 1;
    grid-row: 3;
    align-self: center;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 0;
    min-height: 28px;
    width: 100%;
    margin: 0;
    overflow: hidden;
    color: var(--muted);
    font-size: 0.6rem;
    line-height: 1.2;
    text-align: center;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .dish-card-add-btn.is-checked,
  #menuView.menu-style-card .dish-card-add-btn.is-checked {
    width: var(--mobile-card-action-selected-size);
    height: var(--mobile-card-action-selected-size);
    min-width: var(--mobile-card-action-selected-size);
    min-height: var(--mobile-card-action-selected-size);
    background: var(--selection-check-bg);
    color: var(--selection-check-fg);
    border: var(--selection-check-border);
    border-radius: var(--selection-check-radius);
    font-size: var(--selection-check-font-size);
  }

  .detail-view {
    width: 100%;
    padding-bottom: calc(108px + var(--mobile-safe-bottom));
  }

  body.is-detail-view .site-header,
  body.is-detail-view .mobile-compact-header {
    display: none !important;
  }

  body.is-detail-view main,
  body.is-detail-view.menu-card-layout main {
    padding-top: 8px;
  }

  .detail-back {
    position: sticky;
    top: 8px;
    z-index: 50;
    margin: 0 0 10px;
    border: 1px solid #d7d7d7;
    border-radius: 999px;
    box-shadow: 0 3px 10px rgba(23, 23, 23, 0.08);
  }

  .detail-shell {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .detail-media,
  .detail-content {
    padding: 0 2px;
  }

  .detail-image-frame {
    overflow: hidden;
    padding: 0;
    border-radius: 10px;
    background:
      linear-gradient(90deg, transparent 0 15px, #ececec 15px 16px) 0 0 / 16px 16px,
      linear-gradient(0deg, transparent 0 15px, #ececec 15px 16px) 0 0 / 16px 16px,
      #ffffff;
  }

  .detail-image-track {
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    overscroll-behavior-x: contain;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }

  .detail-image-track::-webkit-scrollbar {
    display: none;
  }

  .detail-image-slide {
    padding: 18px;
    scroll-snap-align: center;
  }

  .detail-image-dots {
    display: flex;
    margin-top: -4px;
  }

  .detail-thumb-strip {
    display: flex;
    justify-content: flex-start;
    flex-wrap: nowrap;
    width: 100%;
    max-width: 100%;
    gap: 7px;
    margin-top: 0;
    overflow-x: auto;
    padding: 0 2px 4px;
    scrollbar-width: none;
  }

  .detail-thumb-strip::-webkit-scrollbar {
    display: none;
  }

  .detail-thumb {
    flex: 0 0 52px;
    width: 52px;
    height: 52px;
  }

  .detail-content h2 {
    margin: 4px 0 8px;
    font-size: clamp(1.7rem, 8vw, 2.4rem);
  }

  .detail-tags {
    flex-wrap: nowrap;
    overflow-x: auto;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    margin-bottom: 12px;
    padding-bottom: 2px;
  }

  .detail-tag {
    flex: 0 0 auto;
    border: 1px solid #d7d7d7;
    border-radius: 999px;
    background: #ffffff;
  }

  .detail-summary,
  .recipe-section p,
  .recipe-steps li {
    font-size: 0.75rem;
  }

  .recipe-facts {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .recipe-fact,
  .ingredient-item,
  .detail-dish-chip {
    border-radius: 8px;
    background: #ffffff;
  }

  .table-ingredient-item::after {
    top: 5px;
    right: 5px;
    width: var(--selection-check-compact-size);
    height: var(--selection-check-compact-size);
    border: var(--selection-check-compact-border);
    font-size: var(--selection-check-compact-font-size);
  }

  .table-tools {
    display: block;
    margin: 10px 0 12px;
    padding: 0;
    overflow: hidden;
    border: 1px solid rgba(23, 23, 23, 0.12);
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 3px 10px rgba(23, 23, 23, 0.05);
  }

  .table-tools-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    min-height: 46px;
    padding: 9px 12px;
    border: 0;
    background: #ffffff;
    color: var(--ink);
    font: inherit;
    text-align: left;
  }

  .table-tools-toggle-text {
    display: grid;
    gap: 2px;
    min-width: 0;
  }

  .table-tools-toggle-text strong {
    font-size: 0.78rem;
    line-height: 1.2;
  }

  .table-tools-toggle-text span {
    overflow: hidden;
    color: var(--muted);
    font-size: 0.62rem;
    line-height: 1.2;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .table-tools-caret {
    display: grid;
    place-items: center;
    width: 24px;
    height: 24px;
    margin-left: 10px;
    color: var(--ink);
    font-size: 0.82rem;
    line-height: 1;
    transition: transform 160ms ease;
  }

  .table-tools.is-open .table-tools-caret {
    transform: rotate(180deg);
  }

  .table-tools-content {
    display: none;
    gap: 8px;
    padding: 0 12px 12px;
    border-top: 1px solid rgba(23, 23, 23, 0.08);
  }

  .table-tools.is-open .table-tools-content {
    display: grid;
  }

  .table-hide-owned {
    gap: 9px;
    justify-content: flex-start;
    width: 100%;
    min-height: 40px;
    padding: 9px 0;
    font-size: 0.75rem;
  }

  .table-tools .table-hide-owned input {
    flex: 0 0 24px;
    width: 24px;
    height: 24px;
    min-width: 24px;
    min-height: 24px;
    max-width: 24px;
    max-height: 24px;
    aspect-ratio: 1 / 1;
    box-sizing: border-box;
  }

  .table-tools .table-hide-owned input::after {
    width: 8px;
    height: 8px;
  }

  .table-tools .table-add-checked-btn,
  #tableManagePantryBtn {
    width: 100%;
    max-width: none;
    min-height: 40px;
    margin: 0;
    border-radius: 6px;
    font-size: 0.72rem;
  }

  .detail-purchase-panel {
    position: fixed;
    top: auto;
    left: 8px;
    right: 8px;
    bottom: calc(var(--mobile-nav-height) + var(--mobile-safe-bottom) + var(--mobile-visual-bottom) + 8px);
    z-index: 210;
    display: grid;
    gap: 8px;
    width: auto;
    min-width: 0;
    padding: 8px;
    border: 1px solid rgba(23, 23, 23, 0.12);
    border-radius: 10px;
    background: #ffffff;
    box-shadow: 0 -8px 22px rgba(23, 23, 23, 0.12);
    backdrop-filter: none;
  }

  .detail-purchase-panel,
  .table-header-actions,
  .table-record-detail-tools,
  .pantry-bag-actions,
  .pantry-owned-actions,
  .favorites-actions {
    border: 1px solid rgba(23, 23, 23, 0.12);
    border-radius: 10px !important;
    background: #ffffff;
    box-shadow: 0 -8px 22px rgba(23, 23, 23, 0.12);
    backdrop-filter: none;
  }

  .detail-purchase-title,
  .detail-purchase-hint {
    display: none;
  }

  .detail-action-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
  }

  .detail-action-row .detail-customize-btn {
    display: none;
  }

  .detail-action-btn {
    min-width: 0;
    min-height: 40px;
    padding: 8px 6px 7px;
    border: 2px solid var(--ink);
    border-radius: 0;
    font-size: 0.68rem;
    font-weight: 400;
    line-height: 1.15;
    letter-spacing: 0;
  }

  .detail-action-btn:hover {
    box-shadow: none;
    transform: translateY(-1px);
  }

  .detail-bag-btn.is-added {
    background: var(--action-selected-soft-bg);
    border-color: var(--success);
    color: var(--success);
  }

  .ingredients-section-head {
    align-items: center;
    margin-bottom: 10px;
  }

  .mobile-recipe-edit-link {
    appearance: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    padding: 2px 0 3px;
    border: 0;
    border-bottom: 2px solid var(--ink);
    border-radius: 0;
    background: transparent;
    color: var(--ink);
    font: inherit;
    font-size: 0.76rem;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: 0;
    cursor: pointer;
  }

  .detail-recommendations {
    padding: 18px 2px 0;
  }

  .detail-recommendation-section {
    min-width: 0;
    max-width: 100%;
    overflow: hidden;
  }

  .detail-dish-grid {
    display: flex;
    gap: 9px;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    overflow-x: auto;
    padding-bottom: 4px;
  }

  .detail-dish-chip {
    flex: 0 0 118px;
  }

  .table-fab,
  .lucky-drawer-tab {
    display: none;
  }

  .mobile-shop-nav {
    position: fixed;
    left: 0;
    right: 0;
    bottom: var(--mobile-visual-bottom);
    z-index: 220;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 0;
    height: calc(var(--mobile-nav-height) + var(--mobile-safe-bottom));
    min-height: 0;
    padding: 6px 6px calc(6px + var(--mobile-safe-bottom));
    border-top: 1px solid rgba(23, 23, 23, 0.12);
    background: #ffffff;
    box-shadow: 0 -8px 22px rgba(23, 23, 23, 0.12);
    backdrop-filter: none;
  }

  .mobile-shop-nav-item {
    position: relative;
    display: grid;
    place-items: center;
    gap: 3px;
    min-width: 0;
    padding: 4px 2px;
    border: 0;
    border-radius: 8px;
    background: transparent;
    color: #5c5c5c;
    font: inherit;
    font-size: 0.62rem;
    line-height: 1.1;
  }

  .mobile-shop-nav-icon {
    display: grid;
    place-items: center;
    width: 24px;
    height: 24px;
    color: currentColor;
    line-height: 1;
  }

  .mobile-shop-nav-svg {
    display: block;
    width: 24px;
    height: 24px;
    object-fit: contain;
    pointer-events: none;
  }

  .mobile-shop-nav-svg-on {
    display: none;
  }

  .mobile-shop-nav-item.is-active .mobile-shop-nav-svg-off {
    display: none;
  }

  .mobile-shop-nav-item.is-active .mobile-shop-nav-svg-on,
  .mobile-shop-nav-lucky .mobile-shop-nav-svg-on {
    display: block;
  }

  .mobile-shop-nav-item.is-active {
    background: #f1f1f1;
    color: var(--ink);
    font-weight: 700;
  }

  .mobile-shop-nav-lucky {
    color: var(--ink);
  }

  .mobile-shop-nav-lucky .mobile-shop-nav-icon {
    width: 36px;
    height: 36px;
    margin-top: -16px;
    color: #ffffff;
  }

  .mobile-shop-nav-lucky .mobile-shop-nav-svg {
    width: 36px;
    height: 36px;
  }

  .mobile-shop-nav-badge {
    position: absolute;
    top: 2px;
    right: 15%;
    display: grid;
    place-items: center;
    min-width: 17px;
    height: 17px;
    padding: 0 4px;
    border: 1px solid #ffffff;
    border-radius: 999px;
    background: var(--danger);
    color: #ffffff;
    font-size: 0.58rem;
    line-height: 1;
  }

  .table-header {
    margin: 0 0 14px;
    padding: 12px 10px;
    border-radius: 10px;
    background: #ffffff;
  }

  #myTableView .table-header-left,
  #myPantryView .table-header-left,
  #myTableView .mobile-table-mode-tabs,
  #myPantryView .pantry-mode-tabs {
    display: none !important;
  }

  #myTableView .mobile-table-mode-tabs,
  #myPantryView .pantry-mode-tabs,
  #profileView .mobile-my-tabs {
    position: sticky;
    top: 0;
    z-index: 180;
    display: flex;
    flex-wrap: nowrap;
    gap: 18px;
    width: 100%;
    max-width: 100%;
    margin: 12px 0 0;
    padding: 8px 0 5px;
    overflow-x: auto;
    border-top: 1px solid rgba(23, 23, 23, 0.08);
    border-bottom: 1px solid rgba(23, 23, 23, 0.12);
    background: #ffffff;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }

  .mobile-table-mode-tabs::-webkit-scrollbar,
  #myPantryView .pantry-mode-tabs::-webkit-scrollbar,
  .mobile-my-tabs::-webkit-scrollbar {
    display: none;
  }

  #myTableView .mobile-table-mode-tabs .pantry-mode-tab,
  #myPantryView .pantry-mode-tabs .pantry-mode-tab,
  #profileView .mobile-my-tabs .pantry-mode-tab {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    min-height: 30px;
    padding: 4px 0 6px;
    border: 0;
    border-bottom: 2px solid transparent;
    background: transparent;
    color: var(--muted);
    font-size: 0.72rem;
    font-weight: 600;
    line-height: 1.2;
    white-space: nowrap;
  }

  #myTableView .mobile-table-mode-tabs .pantry-mode-tab:hover,
  #myPantryView .pantry-mode-tabs .pantry-mode-tab:hover,
  #profileView .mobile-my-tabs .pantry-mode-tab:hover {
    transform: none;
  }

  #myTableView .mobile-table-mode-tabs .pantry-mode-tab.is-active,
  #myPantryView .pantry-mode-tabs .pantry-mode-tab.is-active,
  #profileView .mobile-my-tabs .pantry-mode-tab.is-active {
    border-bottom-color: var(--ink);
    background: transparent;
    color: var(--ink);
  }

  #myPantryView .pantry-mode-tabs .pantry-mode-badge {
    position: static;
    min-width: 17px;
    height: 17px;
    margin-left: 5px;
    padding: 0 5px;
    border: 1px solid currentColor;
    background: transparent;
    color: inherit;
    font-size: 0.58rem;
  }

  .mobile-my-tabs .pantry-mode-tab[hidden] {
    display: none;
  }

  body.mobile-compact-active #myTableView .mobile-table-mode-tabs,
  body.mobile-compact-active #myPantryView .pantry-mode-tabs,
  body.mobile-compact-active #profileView .mobile-my-tabs {
    position: fixed;
    top: 50px;
    left: 0;
    right: 0;
    z-index: 239;
    width: auto;
    max-width: none;
    margin: 0;
    padding: 7px 10px 4px;
    border-top: 1px solid rgba(255, 255, 255, 0.16);
    border-bottom: 0;
    background: #111111;
    box-shadow: 0 5px 12px rgba(0, 0, 0, 0.16);
  }

  body.mobile-compact-active #myTableView .mobile-table-mode-tabs .pantry-mode-tab,
  body.mobile-compact-active #myPantryView .pantry-mode-tabs .pantry-mode-tab,
  body.mobile-compact-active #profileView .mobile-my-tabs .pantry-mode-tab {
    color: rgba(255, 255, 255, 0.7);
  }

  body.mobile-compact-active #myTableView .mobile-table-mode-tabs .pantry-mode-tab.is-active,
  body.mobile-compact-active #myPantryView .pantry-mode-tabs .pantry-mode-tab.is-active,
  body.mobile-compact-active #profileView .mobile-my-tabs .pantry-mode-tab.is-active {
    border-bottom-color: #ffffff;
    color: #ffffff;
  }

  body.mobile-compact-active #myPantryView .pantry-mode-tabs .pantry-mode-badge {
    border-color: rgba(255, 255, 255, 0.7);
    color: inherit;
  }

  .profile-mobile-logout {
    display: inline-flex;
    justify-content: center;
    width: auto;
    margin-top: 0;
  }

  .profile-view {
    padding: 14px 10px calc(var(--mobile-nav-height) + var(--mobile-safe-bottom) + var(--mobile-visual-bottom) + 112px);
  }

  .profile-shell {
    width: 100%;
    max-width: none;
  }

  .profile-head {
    margin: 4px 0 14px;
    padding: 0 2px;
  }

  .profile-view:not(.is-modal) .profile-head {
    display: none;
  }

  .profile-head .eyebrow {
    margin: 0 0 3px;
    color: var(--muted);
    font-size: 0.66rem;
    letter-spacing: 0;
  }

  .profile-head h1 {
    margin: 0;
    font-size: 1.28rem;
    line-height: 1.2;
  }

  .profile-back {
    display: none;
  }

  .profile-card {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
  }

  .profile-avatar-block {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    justify-items: start;
    gap: 12px;
    padding: 12px;
    border: 1px solid rgba(23, 23, 23, 0.1);
    border-radius: 10px;
    background: #ffffff;
  }

  .profile-avatar-button {
    width: 74px;
    height: 74px;
  }

  .profile-avatar-button .profile-avatar {
    width: 74px;
    height: 74px;
    font-size: 1.25rem;
  }

  #profileAvatarChooseButton {
    min-height: 34px;
    padding: 7px 10px 6px;
    border: 1px solid var(--ink);
    background: #ffffff;
    font-size: 0.72rem;
  }

  .profile-fields {
    display: grid;
    gap: 11px;
    padding-bottom: 4px;
  }

  .profile-fields label {
    gap: 5px;
    color: var(--muted);
    font-size: 0.68rem;
  }

  .profile-fields input {
    min-height: var(--input-mobile-height);
    padding: 9px 10px;
    border-radius: var(--input-radius);
    font-size: 0.8rem;
  }

  .profile-fields .auth-submit,
  .profile-mobile-logout {
    min-height: 42px;
    font-size: 0.78rem;
  }

  .profile-form-actions {
    position: fixed;
    left: 8px;
    right: 8px;
    bottom: calc(var(--mobile-nav-height) + var(--mobile-safe-bottom) + var(--mobile-visual-bottom) + 8px);
    z-index: 210;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    width: auto;
    min-width: 0;
    padding: 8px;
    border: 1px solid rgba(23, 23, 23, 0.12);
    border-radius: 10px !important;
    background: #ffffff;
    box-shadow: 0 -8px 22px rgba(23, 23, 23, 0.12);
  }

  .profile-form-actions .auth-submit,
  .profile-form-actions .site-drawer-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-width: 0;
    min-height: 40px;
    padding: 8px 6px 7px;
    font-size: 0.68rem;
    line-height: 1.15;
  }

  .profile-assets-panel {
    gap: 12px;
  }

  .profile-assets-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin: 0 0 10px;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
  }

  .profile-assets-head h2 {
    display: none;
  }

  .profile-assets-head p,
  .profile-assets-status {
    margin: 0;
    color: var(--muted);
    font-size: 0.72rem;
    line-height: 1.45;
  }

  .profile-select-mode-btn {
    flex: 0 0 auto;
  }

  .profile-assets-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 9px;
  }

  .profile-assets-grid .profile-asset-card {
    display: grid;
    grid-template-columns: 1fr;
    align-content: start;
    min-height: 0;
    padding: 8px;
    border: 1px solid rgba(23, 23, 23, 0.1);
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 3px 10px rgba(23, 23, 23, 0.06);
  }

  .profile-assets-grid .dish-card {
    min-height: 0;
  }

  .profile-assets-grid .profile-asset-card .dish-image-wrap {
    grid-column: 1 / -1;
    aspect-ratio: 1 / 1;
    min-height: 0;
    border-radius: 6px;
    background: #f4f4f4;
  }

  .profile-assets-grid .profile-asset-card .dish-image {
    width: 88%;
    height: 88%;
    object-fit: contain;
  }

  .profile-assets-grid .profile-asset-card .dish-name {
    grid-column: 1;
    grid-row: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    margin-top: 8px;
    padding: 0;
    font-size: 0.78rem;
    line-height: 1.28;
    text-align: center;
  }

  .profile-assets-grid .profile-asset-card .dish-card-tagline,
  .profile-assets-grid .profile-asset-card .dish-card-drag-hint {
    display: none;
  }

  .profile-assets-grid .profile-asset-card .dish-card-highlights {
    grid-column: 1 / -1;
    display: flex;
    flex-wrap: nowrap;
    gap: 5px;
    min-height: 22px;
    margin: 5px 0 7px;
    overflow: hidden;
  }

  .profile-assets-grid .profile-asset-card .dish-card-highlights span {
    flex: 0 0 auto;
    max-width: 100%;
    padding: 4px 6px 3px;
    overflow: hidden;
    border: 1px solid #d7d7d7;
    border-radius: 999px;
    background: #ffffff;
    color: var(--ink);
    font-size: 0.62rem;
    line-height: 1;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .profile-assets-grid .profile-asset-card .dish-card-meta {
    grid-column: 1 / -1;
    display: grid;
    gap: 3px;
    padding-top: 7px;
    border-top: 1px solid #ededed;
    color: var(--muted);
    font-size: 0.6rem;
    line-height: 1.35;
    text-align: left;
  }

  .profile-assets-grid .profile-asset-card .dish-card-meta span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .profile-asset-date {
    margin: 7px 0 0;
    padding-top: 6px;
    border-top: 1px solid rgba(23, 23, 23, 0.06);
    font-size: 0.62rem;
  }

  .profile-image-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 9px;
  }

  .profile-image-card {
    gap: 6px;
    padding: 8px;
    border: 1px solid var(--soft-line);
    border-radius: 8px;
    box-shadow: none;
  }

  .profile-image-card strong {
    font-size: 0.72rem;
  }

  .profile-image-card span {
    font-size: 0.62rem;
  }

  .profile-selectable-card::after,
  .profile-image-card::after {
    top: 4px;
    right: 4px;
    width: var(--selection-check-size);
    height: var(--selection-check-size);
    border: var(--selection-check-border);
    border-radius: var(--selection-check-radius);
    background: var(--selection-check-bg);
    color: var(--selection-check-fg);
    font-size: var(--selection-check-font-size);
  }

  .profile-selectable-card.is-selected,
  .profile-image-card.is-selected {
    background: #ffffff;
    box-shadow: none;
  }

  .profile-asset-actions {
    position: fixed;
    left: 8px;
    right: 8px;
    bottom: calc(var(--mobile-nav-height) + var(--mobile-safe-bottom) + var(--mobile-visual-bottom) + 8px);
    z-index: 210;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    width: auto;
    min-width: 0;
    padding: 8px;
    border: 1px solid rgba(23, 23, 23, 0.12);
    border-radius: 10px !important;
    background: #ffffff;
    box-shadow: 0 -8px 22px rgba(23, 23, 23, 0.12);
  }

  .profile-asset-actions[hidden] {
    display: none;
  }

  .profile-asset-actions .admin-action {
    width: 100%;
    min-width: 0;
    min-height: 40px;
    padding: 8px 6px 7px;
    font-size: 0.68rem;
    line-height: 1.15;
  }

  .profile-image-preview-modal {
    padding: 0;
  }

  .profile-image-preview-card {
    width: 100%;
    max-height: 100dvh;
    padding: 12px;
  }

  .profile-image-preview-card img {
    max-height: calc(100dvh - 130px);
  }

  #myPantryView > .detail-back {
    display: none;
  }

  .table-header-row,
  .table-header-left,
  .table-header-actions,
  .table-record-detail-tools,
  .pantry-bag-actions,
  .pantry-owned-actions,
  .favorites-actions,
  .favorites-select-mode-btn {
    align-items: center;
  }

  .table-title {
    font-size: 1.45rem;
  }

  .table-header-actions,
  .table-record-detail-tools,
  .pantry-bag-actions,
  .pantry-owned-actions,
  .favorites-actions {
    position: fixed;
    left: 8px;
    right: 8px;
    bottom: calc(var(--mobile-nav-height) + var(--mobile-safe-bottom) + var(--mobile-visual-bottom) + 8px);
    z-index: 210;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    width: auto;
    min-width: 0;
    padding: 8px;
  }

  .table-header-actions {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .pantry-bag-actions {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .pantry-owned-actions {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .favorites-actions {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .favorites-select-mode-btn {
    margin-left: auto;
    min-height: 30px;
    padding: 4px 0 4px 8px;
    font-size: 0.74rem;
  }

  .favorites-select-mode-btn::before {
    width: var(--selection-check-inline-size);
    height: var(--selection-check-inline-size);
    font-size: var(--selection-check-inline-font-size);
  }

  .table-header-actions[hidden],
  .table-record-detail-tools[hidden],
  .pantry-bag-actions[hidden],
  .pantry-owned-actions[hidden],
  .favorites-actions[hidden] {
    display: none;
  }

  .table-header-actions .admin-action,
  .table-record-detail-tools .admin-action,
  .pantry-bag-actions .admin-action,
  .pantry-owned-actions .admin-action,
  .favorites-actions .admin-action {
    width: 100%;
    min-width: 0;
    min-height: 40px;
    padding: 8px 6px 7px;
    font-size: 0.68rem;
    line-height: 1.15;
  }

  .detail-purchase-panel,
  .table-header-actions,
  .table-record-detail-tools,
  .pantry-bag-actions,
  .pantry-owned-actions,
  .favorites-actions,
  .profile-form-actions,
  .profile-asset-actions {
    position: fixed;
    left: var(--mobile-action-dock-inset);
    right: var(--mobile-action-dock-inset);
    bottom: calc(var(--mobile-nav-height) + var(--mobile-safe-bottom) + var(--mobile-visual-bottom) + var(--mobile-action-dock-inset));
    z-index: 210;
    width: auto;
    min-width: 0;
    padding: var(--mobile-action-dock-padding);
    border: var(--mobile-action-dock-border);
    border-radius: var(--mobile-action-dock-radius) !important;
    background: var(--mobile-action-dock-bg);
    box-shadow: var(--mobile-action-dock-shadow);
    backdrop-filter: none;
  }

  .detail-purchase-panel,
  .table-header-actions,
  .table-record-detail-tools,
  .profile-form-actions,
  .profile-asset-actions {
    display: grid;
    gap: var(--mobile-action-dock-gap);
  }

  .detail-purchase-panel,
  .profile-form-actions,
  .profile-asset-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .table-header-actions {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .table-record-detail-tools {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .detail-action-row {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--mobile-action-dock-gap);
  }

  .pantry-bag-actions,
  .pantry-owned-actions,
  .favorites-actions {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--mobile-action-dock-gap);
  }

  .detail-purchase-panel .detail-action-btn,
  .table-header-actions .admin-action,
  .table-record-detail-tools .admin-action,
  .pantry-bag-actions .admin-action,
  .pantry-owned-actions .admin-action,
  .favorites-actions .admin-action,
  .profile-form-actions .auth-submit,
  .profile-form-actions .site-drawer-action,
  .profile-asset-actions .admin-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-width: 0;
    min-height: var(--mobile-action-btn-height);
    padding: var(--mobile-action-btn-padding);
    border: var(--mobile-action-btn-border);
    border-radius: var(--mobile-action-btn-radius) !important;
    font-size: var(--mobile-action-btn-font-size);
    font-weight: 400;
    line-height: var(--mobile-action-btn-line-height);
    letter-spacing: 0;
  }

  .table-header-actions [data-action-role="primary"],
  .table-record-detail-tools [data-action-role="primary"],
  .pantry-bag-actions [data-action-role="primary"],
  .pantry-owned-actions [data-action-role="primary"],
  .favorites-actions [data-action-role="primary"],
  .profile-form-actions [data-action-role="primary"],
  .profile-asset-actions [data-action-role="primary"] {
    background: var(--action-primary-bg);
    color: var(--action-primary-fg);
  }

  .table-header-actions [data-action-role="secondary"],
  .table-record-detail-tools [data-action-role="secondary"],
  .pantry-bag-actions [data-action-role="secondary"],
  .pantry-owned-actions [data-action-role="secondary"],
  .favorites-actions [data-action-role="secondary"],
  .profile-form-actions [data-action-role="secondary"],
  .profile-asset-actions [data-action-role="secondary"] {
    background: var(--action-secondary-bg);
    color: var(--action-secondary-fg);
  }

  .table-header-actions [data-action-role="danger"],
  .table-record-detail-tools [data-action-role="danger"],
  .pantry-bag-actions [data-action-role="danger"],
  .pantry-owned-actions [data-action-role="danger"],
  .favorites-actions [data-action-role="danger"],
  .profile-form-actions [data-action-role="danger"],
  .profile-asset-actions [data-action-role="danger"] {
    background: var(--action-danger-bg);
    color: var(--action-danger-fg);
  }

  .table-header-actions [data-action-state="selected"],
  .pantry-bag-actions [data-action-state="selected"],
  .pantry-owned-actions [data-action-state="selected"],
  .favorites-actions [data-action-state="selected"],
  .profile-form-actions [data-action-state="selected"],
  .profile-asset-actions [data-action-state="selected"] {
    background: var(--action-selected-soft-bg);
    border-color: var(--success);
    color: var(--success);
  }

  .profile-view.is-modal {
    padding: 12px;
  }

  .profile-view.is-modal .profile-shell {
    max-height: calc(100dvh - 24px);
    padding: 16px;
  }

  .profile-view.is-modal .profile-head {
    margin: 0 0 12px;
    padding: 0;
  }

  .profile-view.is-modal .profile-card {
    gap: 14px;
  }

  .profile-view.is-modal .profile-form-actions {
    position: sticky;
    left: auto;
    right: auto;
    bottom: 0;
    z-index: 1;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-top: 4px;
    padding: 8px 0 0;
    border: 0;
    border-radius: 0 !important;
    background: #ffffff;
    box-shadow: none;
  }

  .detail-purchase-panel .detail-favorite-btn.is-favorite {
    background: #f6c94f;
  }

  .table-records-entry {
    display: none;
  }

  .detail-purchase-panel .detail-bag-btn.is-added {
    background: var(--action-selected-soft-bg);
    border-color: var(--success);
    color: var(--success);
  }

  .detail-purchase-panel .detail-table-btn.is-added {
    background: var(--action-selected-muted-bg);
    border-color: var(--action-selected-muted-bg);
    color: var(--action-primary-fg);
  }

  .detail-action-row .detail-customize-btn {
    display: none;
  }

  .table-subtitle {
    font-size: 0.74rem;
  }

  body.table-records-view #myTableView > .table-header {
    margin: 0 0 10px;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
  }

  .table-record-card {
    padding: 12px;
    border-width: 1px;
  }

  .table-record-card-head {
    align-items: flex-start;
    gap: 8px;
  }

  .table-record-card h3 {
    min-width: 0;
  }

  .table-record-card-controls {
    flex: 0 0 auto;
    gap: 8px;
  }

  .table-record-meta {
    max-width: 112px;
    text-align: right;
  }

  .table-record-dish {
    max-width: 100%;
    font-size: 0.72rem;
  }

  #myTableView .table-subtitle,
  #myPantryView .table-subtitle {
    display: block !important;
    margin: 0 0 12px;
    color: var(--muted);
    font-size: 0.74rem;
    line-height: 1.45;
  }

  .pantry-add-trigger {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    width: 100%;
    min-height: 36px;
    margin: 0 0 12px;
    padding: 8px 10px 7px;
    overflow: hidden;
    border: 1px solid rgba(23, 23, 23, 0.14);
    border-radius: 8px;
    background: #ffffff;
    color: var(--ink);
    font-size: 0.72rem;
    box-shadow: 0 2px 8px rgba(23, 23, 23, 0.04);
  }

  .pantry-add-trigger::before {
    content: attr(data-context-label) " · " attr(data-context-count);
    min-width: 0;
    overflow: hidden;
    color: var(--muted);
    font-weight: 700;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .table-section-title {
    margin: 18px 0 10px;
    padding: 0 2px 6px;
  }

  .table-remove-btn {
    top: 4px;
    left: 4px;
  }

  .table-remove-btn::before,
  .table-remove-btn::after {
    width: var(--card-remove-current-line-size);
  }

  #myTableView,
  #myPantryView {
    padding-bottom: calc(var(--mobile-nav-height) + var(--mobile-safe-bottom) + var(--mobile-visual-bottom) + 92px);
  }

  #myTableView > .detail-back,
  #myPantryView > .detail-back {
    display: none;
  }

  #myPantryView {
    padding-top: 0;
  }

  #myPantryView .pantry-add-panel {
    width: 100%;
    margin-bottom: 16px;
  }

  .ingredient-picker-modal {
    align-items: end;
    padding: 0;
  }

  .ingredient-picker-card {
    width: 100%;
    height: min(82dvh, 720px);
    max-height: min(82dvh, 720px);
    padding: 14px;
    border-right: 0;
    border-bottom: 0;
    border-left: 0;
    border-radius: 14px 14px 0 0;
  }

  .ingredient-picker-grid {
    align-content: start;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    min-height: 0;
    max-height: none;
  }

  .ingredient-picker-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ingredient-picker-actions .admin-action {
    width: 100%;
    min-height: 40px;
  }

  #myPantryView .pantry-grid {
    grid-template-columns: repeat(auto-fill, minmax(88px, 1fr));
    gap: 8px;
  }

  #myPantryView .pantry-card {
    display: grid;
    align-content: start;
    gap: 5px;
    min-height: 0;
    padding: 6px;
    border: 1px solid var(--soft-line);
    border-radius: 8px;
    background: #ffffff;
    box-shadow: none;
    cursor: pointer;
  }

  #myPantryView .pantry-card .dish-image-wrap {
    aspect-ratio: 1 / 1;
    min-height: 0;
    background: #f7f7f7;
  }

  #myPantryView .pantry-card .dish-image {
    width: 82%;
    height: 82%;
    object-fit: contain;
  }

  #myPantryView .pantry-card .dish-name {
    display: -webkit-box;
    min-height: 0;
    margin: 0;
    padding: 0;
    overflow: hidden;
    font-size: 0.68rem;
    line-height: 1.25;
    text-align: center;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
  }

  #myPantryView .ingredient-role-line {
    display: none;
  }

  .pantry-card-fields {
    display: none;
  }

  #myPantryView .pantry-card-quantity {
    display: block;
    min-height: 15px;
    overflow: hidden;
    color: var(--muted);
    font-size: 0.6rem;
    line-height: 1.25;
    text-align: center;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  #myPantryView .pantry-card-quantity[hidden] {
    display: none;
  }

  .pantry-remove-btn {
    top: 4px;
    right: auto;
    left: 4px;
  }

  #myPantryView .pantry-card.is-selectable::after,
  #favoritesView .favorite-selectable-card::after {
    top: 4px;
    right: 4px;
    width: var(--selection-check-size);
    height: var(--selection-check-size);
    border: var(--selection-check-border);
    border-radius: var(--selection-check-radius);
    background: var(--selection-check-bg);
    color: var(--selection-check-fg);
    font-size: var(--selection-check-font-size);
    font-weight: 900;
    line-height: 1;
    opacity: 0;
    transform: scale(0.86);
  }

  #myPantryView .pantry-card.is-selected,
  #favoritesView .favorite-selectable-card.is-selected {
    border-color: var(--soft-line);
    background: #ffffff;
    box-shadow: none;
  }

  #myPantryView .pantry-card.is-selected::after,
  #favoritesView .favorite-selectable-card.is-selected::after {
    opacity: 1;
    transform: scale(1);
  }

  #myPantryView .pantry-card.is-selected::before,
  #favoritesView .favorite-selectable-card.is-selected::before {
    display: none;
  }

  body.mobile-table-tabs-visible #myTableView .table-header-left,
  body.mobile-table-tabs-visible #myPantryView .table-header-left,
  body.mobile-table-tabs-visible #myTableView .mobile-table-mode-tabs,
  body.mobile-table-tabs-visible #myPantryView .pantry-mode-tabs {
    display: none !important;
  }

  body.table-record-detail-view #myTableView .table-header-row {
    display: block;
  }

  body.table-record-detail-view #myTableView .table-header-left {
    display: flex !important;
    align-items: flex-start;
    flex-direction: column;
    gap: 4px;
  }

  body.table-record-detail-view #myTableView .table-title {
    font-size: 1.45rem;
    line-height: 1.18;
  }

  body.table-record-detail-view #myTableView .table-subtitle {
    margin-top: 4px;
  }

  .pantry-edit-modal-card {
    width: min(340px, calc(100vw - 28px));
    padding: 18px;
  }

  .pantry-bulk-edit-modal-card {
    width: min(380px, calc(100vw - 18px));
    padding: 14px;
  }

  .pantry-bulk-edit-row {
    grid-template-columns: minmax(56px, 0.62fr) minmax(0, 1fr) minmax(0, 1fr);
    gap: 8px;
    padding: 8px;
  }

  .pantry-bulk-edit-row strong {
    font-size: 0.76rem;
  }

  .pantry-bulk-edit-row input {
    min-height: 34px;
    padding: 7px 8px;
    font-size: 0.74rem;
  }

  .lucky-drawer {
    inset: 0;
    z-index: 260;
    width: 100%;
    height: 100dvh;
    max-height: none;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    transform: translateY(105%);
    background: #f8faf6;
  }

  .lucky-drawer.is-open {
    transform: translateY(0);
  }

  .lucky-screen {
    min-height: 0;
    overflow: hidden;
  }

  .lucky-drawer-header,
  .lucky-swipe-top {
    min-height: 56px;
    padding: calc(8px + env(safe-area-inset-top, 0px)) 14px 7px;
    background: rgba(255, 255, 255, 0.86);
    border-bottom: 1px solid rgba(23, 23, 23, 0.08);
    backdrop-filter: blur(14px);
  }

  .lucky-drawer-title,
  .lucky-swipe-top .lucky-drawer-title {
    font-size: 0.92rem;
  }

  .lucky-drawer-close,
  .lucky-preview-close {
    width: 32px;
    min-width: 32px;
    height: 32px;
    min-height: 32px;
    flex: 0 0 32px;
    aspect-ratio: 1 / 1;
    border: 1px solid #d7d7d7;
    border-radius: 50% !important;
  }

  .lucky-subtitle {
    padding: 0 8px 2px;
    font-size: 0.94rem;
  }

  .lucky-tag-pool {
    padding: 14px 14px 10px;
    min-height: 0;
  }

  .lucky-skip-tags {
    margin: 4px 0 0;
  }

  .lucky-start-btn {
    width: min(260px, calc(100% - 28px));
    min-height: 44px;
    margin: 8px auto 12px;
    border-radius: 8px;
  }

  .lucky-swipe-layout {
    height: 100%;
    min-height: 0;
    background:
      linear-gradient(180deg, #fbfcf8 0%, #f4f8ef 48%, #ffffff 100%);
  }

  .lucky-swipe-top {
    display: grid;
    grid-template-columns: 40px minmax(0, 1fr) 40px;
    align-items: center;
    gap: 4px;
  }

  .lucky-swipe-top .lucky-drawer-title,
  .lucky-counter {
    grid-column: 2;
    text-align: center;
  }

  .lucky-swipe-top .lucky-drawer-close {
    position: static;
    grid-column: 3;
    grid-row: 1 / span 2;
    justify-self: end;
    transform: none;
  }

  .lucky-card-stack {
    min-height: 0;
    padding: 10px 14px 8px;
  }

  .lucky-card {
    width: min(356px, calc(100vw - 28px));
    height: clamp(376px, calc(100dvh - 204px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px)), 540px);
    min-height: 0;
    border-radius: 18px;
  }

  .lucky-card-image {
    aspect-ratio: 1 / 1;
    height: auto;
    min-height: 0;
    max-height: none;
  }

  .lucky-card-info {
    padding: 12px 14px 14px;
    gap: 6px;
  }

  .lucky-card-name {
    font-size: 1.18rem;
  }

  .lucky-card-desc {
    -webkit-line-clamp: 2;
  }

  .lucky-actions {
    gap: clamp(18px, 8vw, 28px);
    padding: 7px 42px 5px;
    background: rgba(255, 255, 255, 0.9);
  }

  .lucky-action-icon {
    width: 48px;
    height: 48px;
  }

  .lucky-action-label {
    display: none;
    font-size: clamp(0.58rem, 2.7vw, 0.64rem);
    line-height: 1.15;
    white-space: nowrap;
  }

  .lucky-nav-actions {
    gap: 6px;
    padding: 7px 10px calc(9px + env(safe-area-inset-bottom, 0px));
    border-top: 1px solid rgba(23, 23, 23, 0.08);
    background: rgba(255, 255, 255, 0.92);
  }

  .lucky-nav-btn {
    min-width: 0;
    flex: 1 1 0;
    min-height: 32px;
    padding: 6px 4px;
    border: 1px solid rgba(23, 23, 23, 0.1);
    border-radius: 999px;
    font-size: clamp(0.56rem, 2.7vw, 0.62rem);
    white-space: nowrap;
  }

  .lucky-preview {
    inset: 0;
    z-index: 265;
    height: 100dvh;
    border-radius: 0;
  }

  .lucky-preview-grid {
    min-height: 0;
    padding: 12px 14px;
  }

  .lucky-preview-footer {
    padding-bottom: calc(10px + env(safe-area-inset-bottom, 0px));
  }
}

/* Lucky card refresh: keep the swipe game feel while matching the current mobile system. */
.lucky-drawer {
  border-right: 1px solid rgba(23, 23, 23, 0.14);
  background: #f8faf6;
  box-shadow: 8px 0 28px rgba(23, 23, 23, 0.12);
}

.lucky-drawer.is-right {
  border-left: 1px solid rgba(23, 23, 23, 0.14);
  box-shadow: -8px 0 28px rgba(23, 23, 23, 0.12);
}

.lucky-drawer-header,
.lucky-swipe-top,
.lucky-nav-actions,
.lucky-actions {
  border-color: rgba(23, 23, 23, 0.08);
  background: rgba(255, 255, 255, 0.82);
  backdrop-filter: blur(14px);
}

.lucky-drawer-header,
.lucky-swipe-top {
  border-bottom: 1px solid rgba(23, 23, 23, 0.08);
}

.lucky-swipe-layout {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.88) 0%, rgba(246, 249, 242, 0.94) 42%, #ffffff 100%),
    linear-gradient(90deg, transparent 0 11px, rgba(23, 23, 23, 0.04) 11px 12px) 0 0 / 12px 12px repeat;
}

.lucky-card {
  border: 1px solid rgba(23, 23, 23, 0.14);
  border-radius: 14px !important;
  background: #ffffff;
  box-shadow: 0 20px 44px rgba(23, 23, 23, 0.14);
}

.lucky-card:nth-last-child(1) {
  z-index: 3;
}

.lucky-card:nth-last-child(2) {
  z-index: 2;
  transform: scale(0.94) translateY(10px);
  opacity: 0.52;
}

.lucky-card:nth-last-child(3) {
  z-index: 1;
  transform: scale(0.88) translateY(20px);
  opacity: 0.26;
}

.lucky-card-image {
  border-bottom: 1px solid rgba(23, 23, 23, 0.08);
  border-radius: 0 !important;
  background: linear-gradient(145deg, rgba(247, 250, 244, 0.95), rgba(230, 239, 224, 0.88));
}

.lucky-card-image img {
  filter: drop-shadow(0 12px 18px rgba(23, 23, 23, 0.12));
}

.lucky-card-back {
  background: #ffffff;
}

.lucky-back-ingredients {
  display: grid;
  gap: 8px;
  font-size: 0.78rem;
  line-height: 1.4;
}

.lucky-back-ingredient-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.lucky-back-ingredient-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  max-width: 100%;
  min-height: 30px;
  padding: 4px 7px 4px 4px;
  border: 1px solid rgba(23, 23, 23, 0.12);
  border-radius: 8px;
  background: #ffffff;
  box-shadow: none;
  color: var(--ink);
  font-size: 0.7rem;
}

.lucky-back-ingredient-chip img {
  flex: 0 0 22px;
  width: 22px;
  height: 22px;
  object-fit: contain;
  image-rendering: pixelated;
  image-rendering: crisp-edges;
}

.lucky-card-tags {
  color: #516149;
}

.lucky-card-label {
  border: 3px solid #ffffff;
  border-radius: 8px !important;
  background: transparent;
  color: #ffffff;
  text-shadow: 2px 2px 0 rgba(0, 0, 0, 0.3);
  box-shadow: none;
}

.lucky-card-label.is-left {
  background: #d94848;
  color: #ffffff;
}

.lucky-card-label.is-right {
  background: #2f8f4e;
  color: #ffffff;
}

.lucky-card-label.is-up {
  background: #276fbf;
  color: #ffffff;
}

.lucky-action-icon,
.lucky-drawer-close,
.lucky-undo-btn,
.lucky-preview-close {
  border: 1px solid rgba(23, 23, 23, 0.14);
  border-radius: 50% !important;
  background: rgba(255, 255, 255, 0.9);
  color: var(--ink);
  box-shadow: 0 6px 18px rgba(23, 23, 23, 0.08);
}

.lucky-action-icon {
  width: 48px;
  height: 48px;
  border: 0;
  border-radius: 50% !important;
  background: var(--lucky-action-mark-bg);
  color: var(--lucky-action-mark-fg);
  box-shadow: none;
}

.lucky-nav-btn {
  border: 0;
  border-radius: 8px !important;
  background: rgba(23, 23, 23, 0.04);
  box-shadow: none;
}

.lucky-nav-badge {
  border: 1px solid #ffffff;
  border-radius: 999px !important;
  background: var(--danger);
  color: #ffffff;
}

.lucky-actions,
.lucky-nav-actions {
  border-top: 0;
}

.lucky-card-image {
  background: #f4f4f4;
}

.lucky-tag-option,
.lucky-more-filters-btn,
.lucky-skip-tags,
.lucky-start-btn,
.lucky-restart-btn,
.lucky-goto-table-btn,
.lucky-preview-clear,
.lucky-preview-goto {
  border-radius: 8px !important;
  box-shadow: none;
}

.lucky-tag-option {
  border: 1px solid rgba(23, 23, 23, 0.14);
  background: var(--selection-pill-bg);
}

.lucky-tag-option.is-selected {
  border-color: var(--selection-active-border);
  background: var(--selection-active-bg);
  color: var(--selection-active-fg);
}

.lucky-skip-tags,
.lucky-more-filters-btn,
.lucky-restart-btn {
  border: 1px solid rgba(23, 23, 23, 0.16);
  background: rgba(255, 255, 255, 0.68);
  color: var(--muted);
}

.lucky-preview {
  background: var(--page-bg);
}

.lucky-preview-header,
.lucky-preview-footer {
  background: rgba(255, 255, 255, 0.82);
  backdrop-filter: blur(14px);
}

.lucky-preview-header {
  border-bottom: 1px solid rgba(23, 23, 23, 0.08);
}

.lucky-preview-footer {
  border-top: 1px solid rgba(23, 23, 23, 0.08);
}

.lucky-preview-image-wrap {
  overflow: hidden;
  border: 0;
  border-radius: var(--mobile-card-image-radius);
  background: #f4f4f4;
}

.lucky-preview-item {
  gap: var(--mini-card-gap);
  padding: var(--mini-card-padding);
  padding-bottom: calc(var(--mini-card-padding) + 28px);
  border: var(--mini-card-border);
  border-radius: var(--mini-card-radius);
  background: var(--mini-card-bg);
  box-shadow: var(--mini-card-shadow);
}

.lucky-preview-add-btn {
  right: 6px;
  bottom: 6px;
  width: var(--mobile-card-action-size);
  height: var(--mobile-card-action-size);
  border: 1px solid rgba(23, 23, 23, 0.14);
  border-radius: 50%;
  background: #ffffff;
  color: var(--ink);
  box-shadow: 0 6px 14px rgba(23, 23, 23, 0.12);
}

@media (max-width: 640px) {
  .lucky-drawer {
    background: #f8faf6;
  }

  .lucky-drawer-header,
  .lucky-swipe-top {
    background: rgba(255, 255, 255, 0.86);
    border-bottom: 1px solid rgba(23, 23, 23, 0.08);
    backdrop-filter: blur(14px);
  }

  .lucky-swipe-layout {
    background:
      linear-gradient(180deg, rgba(255, 255, 255, 0.88) 0%, rgba(246, 249, 242, 0.94) 42%, #ffffff 100%),
      linear-gradient(90deg, transparent 0 11px, rgba(23, 23, 23, 0.04) 11px 12px) 0 0 / 12px 12px repeat;
  }

  .lucky-card {
    border-radius: 14px !important;
    box-shadow: 0 20px 44px rgba(23, 23, 23, 0.14);
  }

  .lucky-card:nth-last-child(2) {
    transform: scale(0.94) translateY(10px);
  }

  .lucky-card:nth-last-child(3) {
    transform: scale(0.88) translateY(20px);
  }

  .lucky-card-image {
    border-radius: 0 !important;
  }

  .lucky-actions,
  .lucky-nav-actions {
    background: rgba(255, 255, 255, 0.82);
    border-top: 1px solid rgba(23, 23, 23, 0.08);
  }

  .lucky-actions {
    border-top: 0;
  }

  .lucky-action-icon {
    width: 48px;
    height: 48px;
  }

  .lucky-nav-btn {
    border: 0;
    border-radius: 8px !important;
  }
}

/* Mobile shell overrides
   Shared mobile-only behavior for chrome that sits above page content. */
@media (max-width: 640px) {
  .recipe-edit-steps-section .recipe-edit-add-step {
    box-sizing: border-box;
    width: 100%;
    margin: 2px 0 0;
    justify-content: center;
  }

  body.mobile-chrome-suppressed .detail-purchase-panel,
  body.mobile-chrome-suppressed .mobile-shop-nav,
  body.mobile-chrome-suppressed .table-fab {
    display: none;
  }
}

/* Mobile table/my shell corrections kept at the end so legacy mobile rules cannot
   hide the shared header or the new page-level controls. */
@media (max-width: 640px) {
  body.mobile-table-tabs-visible .site-logo {
    display: inline-flex !important;
  }

  body.mobile-table-tabs-visible .mobile-table-header-tabs {
    grid-column: 2;
    justify-self: stretch;
    margin-left: 14px;
    width: auto;
    max-width: 100%;
  }

  body.mobile-table-tabs-visible .mobile-table-header-tabs .mobile-header-tab {
    padding-right: 0;
  }

  body.mobile-table-tabs-visible #myTableView .table-subtitle,
  body.mobile-table-tabs-visible #myPantryView .table-subtitle {
    display: block !important;
    margin: 0 0 8px;
    color: var(--muted);
    font-size: 0.74rem;
    line-height: 1.45;
  }

  body.mobile-table-tabs-visible #myTableView > .table-header,
  body.mobile-table-tabs-visible #myPantryView > .table-header {
    margin: 0;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
  }

  body.mobile-table-tabs-visible .mobile-table-tab-badge {
    display: none !important;
  }

  body.mobile-table-tabs-visible .mobile-table-tab-badge.is-table {
    background: var(--danger);
  }

  body.mobile-table-tabs-visible .mobile-table-tab-badge.is-bag {
    background: var(--success);
  }

  body.mobile-table-tabs-visible .mobile-table-tab-badge.is-owned {
    background: var(--ink);
  }

  body.mobile-table-tabs-visible .pantry-add-trigger {
    display: inline-flex !important;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    width: 100%;
    min-height: 36px;
    margin: 0 0 12px;
    padding: 8px 10px 7px;
    overflow: hidden;
    border: 1px solid rgba(23, 23, 23, 0.14);
    border-radius: 8px;
    background: #ffffff;
    color: var(--ink);
    font-size: 0.72rem;
    box-shadow: 0 2px 8px rgba(23, 23, 23, 0.04);
  }

  body.mobile-table-tabs-visible .pantry-add-trigger[hidden] {
    display: none !important;
  }

  body.mobile-my-view .site-header,
  body.mobile-table-tabs-visible .site-header {
    min-height: 122px;
  }

  body.mobile-my-view .site-header {
    min-height: 122px;
  }

  body.mobile-my-view .mobile-my-header-tabs {
    grid-column: 2;
    justify-self: stretch;
    width: auto;
    max-width: 100%;
  }

  body.mobile-my-view .mobile-my-header-tabs .pantry-mode-tab,
  body.mobile-my-view .mobile-my-header-tabs .mobile-my-admin-tab {
    display: inline-flex !important;
    align-items: center;
    flex: 0 0 auto;
    min-height: 18px;
    padding: 0 0 2px;
    border: 0;
    border-bottom: 2px solid transparent;
    border-radius: 0;
    background: transparent;
    color: var(--ink);
    box-shadow: none;
    font: inherit;
    font-size: 0.82rem;
    font-weight: 700;
    line-height: 1;
    text-decoration: none !important;
    text-underline-offset: auto;
    white-space: nowrap;
  }

  body.mobile-my-view .mobile-my-header-tabs .pantry-mode-tab.is-active {
    border-bottom-color: var(--ink);
  }

  body.mobile-my-view .mobile-compact-my-tabs .mobile-compact-my-tab,
  body.mobile-my-view .mobile-compact-my-tabs .mobile-my-admin-tab {
    display: inline-flex !important;
    align-items: center;
    text-decoration: none !important;
  }

  body.mobile-my-view .site-header-actions,
  body.mobile-table-tabs-visible .site-header-actions {
    display: flex !important;
  }

  body.mobile-menu-ingredient-tabs-visible .mobile-header-tab,
  body.mobile-table-tabs-visible .mobile-table-header-tabs .mobile-header-tab,
  body.mobile-my-view .mobile-my-header-tabs .pantry-mode-tab,
  body.mobile-my-view .mobile-my-header-tabs .mobile-my-admin-tab {
    color: #8a8a8a;
  }

  body.mobile-menu-ingredient-tabs-visible .mobile-header-tab.is-active,
  body.mobile-table-tabs-visible .mobile-table-header-tabs .mobile-header-tab.is-active,
  body.mobile-my-view .mobile-my-header-tabs .pantry-mode-tab.is-active {
    color: var(--ink);
  }
}
