:root {
    --bg: #ececea;
    --sidebar-bg: #f0f0ec;
    --panel: #fafaf8;
    --panel-soft: #f1f1ed;
    --active-nav: #e4dfd2;
    --text: #1a1a18;
    --muted: #42423d;
    --faint: #74746c;
    --border: #d3d3cc;
    --border-strong: #b8b8ae;
    --green-bg: #d9e4d9;
    --green-text: #294f29;
    --green-border: #adc5ad;
    --accent: #1a1a18;
    --accent-strong: #1a1a18;
    --accent-soft: #e4dfd2;
    --accent-border: #d3d3cc;
    --nav: #e4dfd2;
    --nav-strong: #1a1a18;
    --nav-soft: #f1eee6;
    --nav-border: #cfc7b6;
    --nav-text: #1a1a18;
    --sage-bg: #e4dfd2;
    --sage-border: #cfc7b6;
    --sage-text: #1a1a18;
    --blue-bg: #d7e3e5;
    --blue-text: #284f58;
    --blue-border: #abc2c7;
    --amber-bg: #e8dfc9;
    --amber-text: #5c5226;
    --amber-border: #ccbf9b;
    --red-bg: #e1d3d3;
    --red-text: #573434;
    --red-border: #c6aaaa;
    --todo-bg: #dededb;
    --todo-text: #464640;
    --paid-text: #17682f;
    --focus: #1a1a18;
    --shadow: 0 16px 40px rgba(26, 26, 24, 0.06);
    --shadow-soft: 0 1px 0 rgba(26, 26, 24, 0.04);
    --shadow-popover: 0 18px 45px rgba(20, 18, 14, 0.16);
    --shadow-modal: 0 24px 70px rgba(20, 18, 14, 0.22);
    --overlay-soft: rgba(18, 18, 18, 0.28);
    --overlay-strong: rgba(18, 18, 18, 0.34);
    --focus-ring: 0 0 0 3px rgba(26, 26, 24, 0.08);
    --surface-translucent: rgba(250, 250, 248, 0.76);
    --surface-translucent-border: rgba(250, 250, 248, 0.72);
    --surface-empty: rgba(250, 250, 248, 0.68);
    --project-bg: #edf4ea;
    --project-bg-hover: #e3ecdf;
    --project-bg-active: #d8e3d5;
    --project-border: #c9d5c8;
    --project-border-hover: #aebfac;
    --project-border-active: #9caf98;
    --project-active-ring: #b9ccb5;
    --cta-bg: #d8e3d5;
    --cta-bg-hover: #cbdac7;
    --cta-border: #aebfac;
    --cta-border-hover: #9caf98;
    --cta-text: #263f28;
    --action-bg: #f0c27a;
    --action-bg-hover: #e8b15d;
    --action-border: #d79a43;
    --action-border-hover: #bf7f25;
    --action-text: #3f2a0b;
    --priority-hue: 62;
    --priority-saturation: 30%;
    --priority-bg-lightness: 90%;
    --priority-border-lightness: 78%;
    --priority-text-lightness: 27%;
    --priority-bg-color: hsl(var(--priority-hue) var(--priority-saturation) var(--priority-bg-lightness));
    --priority-border-color: hsl(var(--priority-hue) var(--priority-saturation) var(--priority-border-lightness));
    --priority-text-color: hsl(var(--priority-hue) var(--priority-saturation) var(--priority-text-lightness));
    --font-family-sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    --font-xs: 11px;
    --font-sm: 13px;
    --font-md: 14px;
    --font-lg: 16px;
    --font-xl: 18px;
    --font-title: 22px;
    --weight-regular: 400;
    --weight-medium: 500;
    --weight-semibold: 600;
    --line-tight: 1.15;
    --line-compact: 1.25;
    --line-normal: 1.4;
    --letter-label: 0.09em;
    --radius-action: 5px;
    --radius-control: 6px;
    --radius-card: 8px;
    --radius-round: 999px;
    --action-height: 24px;
    --control-height: 30px;
    --control-height-compact: 32px;
    --project-height: 42px;
    --nav-height: 46px;
    --sort-direction-width: 74px;
    --settings-browser-min-height: 562px;
    --settings-menu-offset: 132px;
    --textarea-min-height: 118px;
    --auth-status-height: 20px;
    --auth-control-width: 312px;
    --teaser-blur: 3px;
    --pill-height: var(--control-height);
    --pill-radius: var(--radius-control);
    --pill-font-size: var(--font-md);
    --pill-padding: 0 10px;
  }

  * {
    box-sizing: border-box;
  }

  html {
    overflow-y: scroll;
    scrollbar-gutter: stable;
  }

  body {
    margin: 0;
    min-height: 100vh;
    background: var(--bg);
    color: var(--text);
    font-family: var(--font-family-sans);
    font-size: var(--font-md);
    font-weight: var(--weight-regular);
    line-height: var(--line-normal);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
  }

  button,
  input,
  textarea {
    font: inherit;
  }

  button {
    cursor: pointer;
  }

  .app {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 300px minmax(0, 1fr);
    gap: 0;
    padding: 0;
    align-items: start;
    max-width: none;
    margin: 0;
  }

  .sidebar {
    background: var(--sidebar-bg);
    border: 0;
    border-right: 1px solid var(--border);
    border-radius: 0;
    height: 100vh;
    max-height: 100vh;
    padding: 24px 20px;
    display: flex;
    flex-direction: column;
    gap: 30px;
    box-shadow: none;
    position: sticky;
    top: 0;
    left: 0;
    overflow-y: auto;
  }

  .brand {
    display: grid;
    gap: 8px;
    margin-bottom: 6px;
  }

  .brand-lockup {
    display: grid;
    align-items: start;
    gap: 18px;
  }

  .brand-logo {
    display: inline-flex;
    width: 86px;
    height: 86px;
    color: var(--green-dark);
    flex: 0 0 auto;
  }

  .brand-logo svg {
    display: block;
    width: 100%;
    height: 100%;
  }

  h1 {
    margin: 0;
    font-size: var(--font-title);
    line-height: var(--line-tight);
    font-weight: var(--weight-semibold);
    letter-spacing: 0;
  }

  .hint {
    margin: 0;
    color: var(--muted);
    font-size: var(--font-md);
    line-height: var(--line-normal);
  }

  .menu-block {
    display: grid;
    gap: 12px;
  }

  .menu-label {
    color: var(--muted);
    font-size: var(--font-xs);
    font-weight: var(--weight-medium);
    text-transform: uppercase;
    letter-spacing: var(--letter-label);
  }

  .project-list {
    display: grid;
    gap: 8px;
  }

  .sidebar-add-project {
    width: 100%;
    justify-content: center;
    margin-top: 4px;
  }

  .category-list {
    display: grid;
    grid-template-columns: 1fr;
    gap: 3px;
  }

  .category-button {
    min-height: var(--pill-height);
    border: 1px solid var(--border);
    background: var(--panel);
    color: var(--muted);
    border-radius: var(--pill-radius);
    padding: var(--pill-padding);
    font-size: var(--pill-font-size);
    font-weight: 500;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
  }

  .category-list .category-button {
    min-height: var(--control-height-compact);
    border-color: transparent;
    background: transparent;
    color: var(--text);
    padding: 0 12px;
  }

  .category-button:hover {
    border-color: var(--border-strong);
    color: var(--text);
  }

  .category-list .category-button:hover {
    border-color: var(--border);
    background: var(--panel-soft);
  }

  .category-button.active {
    background: var(--sage-bg);
    border-color: var(--sage-border);
    color: var(--sage-text);
  }

  .category-count {
    font-size: var(--pill-font-size);
    color: inherit;
    opacity: 0.9;
    min-width: 34px;
    text-align: right;
  }

  .filter-stack {
    display: grid;
    gap: 6px;
  }

  .filter-panel {
    display: grid;
    gap: 3px;
  }

  .filter-toggle {
    width: 100%;
  }

  .filter-toggle-label {
    color: var(--muted);
  }

  .filter-toggle-value {
    color: var(--text);
    text-align: right;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .filter-options {
    padding-left: 8px;
  }

  .filter-toggle.active,
  .filter-options .category-button.active {
    background: var(--sage-bg);
    border-color: var(--sage-border);
    color: var(--sage-text);
  }

  .filter-toggle.active .filter-toggle-label,
  .filter-toggle.active .filter-toggle-value {
    color: var(--sage-text);
  }

  .sort-control {
    display: grid;
    grid-template-columns: minmax(0, 1fr) var(--sort-direction-width);
    gap: 6px;
  }

  .sort-control .category-button {
    min-height: var(--control-height-compact);
    justify-content: center;
    padding: 0 12px;
  }

  .sort-control .sort-field-button {
    justify-content: space-between;
  }

  .sort-field-button .category-name {
    width: 100%;
    text-align: left;
  }

  .sort-direction-button {
    color: var(--text);
  }

  .project-button {
    min-height: var(--project-height);
    width: 100%;
    border: 1px solid var(--project-border);
    background: var(--project-bg);
    color: var(--text);
    border-radius: var(--radius-control);
    padding: 8px 14px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    text-align: left;
    box-shadow: var(--shadow-soft);
  }

  .project-button:hover {
    background: var(--project-bg-hover);
    border-color: var(--cta-border);
  }

  .project-button.active {
    background: var(--cta-bg);
    border-color: var(--cta-border-hover);
    box-shadow: none;
  }

  .project-name {
    font-size: var(--font-md);
    font-weight: var(--weight-semibold);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .project-count {
    color: var(--muted);
    font-size: var(--font-sm);
    font-weight: var(--weight-regular);
    flex: 0 0 auto;
  }

  .sidebar-actions {
    display: grid;
    gap: 10px;
    margin-top: 14px;
  }

  .btn {
    min-height: var(--pill-height);
    border: 1px solid var(--border);
    background: var(--panel);
    color: var(--text);
    border-radius: var(--pill-radius);
    padding: var(--pill-padding);
    font-size: var(--pill-font-size);
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    white-space: nowrap;
  }

  .btn:hover {
    border-color: var(--border-strong);
    background: var(--active-nav);
  }

  .btn.primary {
    background: var(--action-bg);
    border-color: var(--action-border);
    color: var(--action-text);
  }

  .btn.primary:hover {
    background: var(--action-bg-hover);
    border-color: var(--action-border-hover);
    color: var(--action-text);
  }

  .btn.nav {
    background: var(--nav);
    border-color: var(--nav-strong);
    color: var(--nav-text);
  }

  .btn.nav:hover {
    background: var(--green-bg);
    border-color: var(--green-border);
    color: var(--green-text);
  }

  .btn.danger {
    color: var(--red-text);
    border-color: var(--red-border);
    background: var(--red-bg);
  }

  .btn:disabled {
    cursor: default;
    opacity: 0.55;
  }

  .btn.full {
    width: 100%;
  }

  .content {
    min-width: 0;
    width: 100%;
    display: grid;
    grid-template-rows: auto 1fr;
    gap: 0;
  }

  .project-bar {
    background: var(--sidebar-bg);
    border: 0;
    border-bottom: 1px solid var(--border);
    border-radius: 0;
    padding: 12px 18px;
    position: sticky;
    top: 0;
    z-index: 10;
  }

  .project-heading {
    min-width: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
  }

  .project-title-block {
    min-width: 0;
    display: grid;
    gap: 4px;
  }

  .project-title-row {
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
  }

  h2 {
    margin: 0;
    font-size: var(--font-title);
    line-height: var(--line-tight);
    font-weight: var(--weight-semibold);
    letter-spacing: 0;
    overflow-wrap: anywhere;
    flex: 0 1 auto;
  }

  .stats {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: center;
  }

  .preview-notice {
    color: var(--muted-strong);
    font-size: var(--font-sm);
    font-weight: 400;
  }

  .project-tools {
    display: flex;
    gap: 8px;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
  }

  .btn.compact {
    min-height: 32px;
    padding: 0 12px;
    min-width: 0;
  }

  .view-toggle {
    border: 1px solid var(--red-border);
    border-radius: var(--pill-radius);
    background: var(--red-bg);
    display: inline-flex;
    overflow: hidden;
    min-height: var(--pill-height);
  }

  .view-button {
    border: 0;
    border-right: 1px solid var(--red-border);
    background: var(--red-bg);
    color: var(--red-text);
    min-height: var(--pill-height);
    padding: var(--pill-padding);
    font-size: var(--pill-font-size);
    font-weight: 500;
  }

  .view-button:last-child {
    border-right: 0;
  }

  .view-button.active {
    background: var(--green-bg);
    color: var(--green-text);
    box-shadow: none;
  }

  .stat {
    border: 1px solid var(--border);
    border-radius: var(--pill-radius);
    color: var(--text);
    font-size: var(--pill-font-size);
    font-weight: 500;
    padding: var(--pill-padding);
    background: var(--active-nav);
    min-height: var(--pill-height);
    display: inline-flex;
    align-items: center;
  }

  .grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(330px, 1fr));
    gap: 24px;
    align-items: stretch;
    align-content: start;
    padding: 24px;
  }

  .card {
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: var(--radius-card);
    overflow: hidden;
    min-width: 0;
    box-shadow: var(--shadow);
    display: grid;
    grid-template-rows: auto 1fr;
    height: 315px;
  }

  .card.teaser-locked {
    position: relative;
    cursor: pointer;
  }

  .card.teaser-locked .card-thumb,
  .card.teaser-locked .card-body,
  .sheet-row.teaser-locked td {
    filter: blur(var(--teaser-blur));
    user-select: none;
  }

  .card.teaser-locked::after {
    content: "Sign in to unlock";
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    color: var(--text);
    font-size: var(--font-sm);
    font-weight: 500;
    background: var(--surface-translucent);
  }

  .sheet-row.teaser-locked {
    position: relative;
    cursor: pointer;
  }

  .sheet-row.teaser-locked td:first-child {
    position: relative;
  }

  .sheet-row.teaser-locked td:first-child::after {
    content: "Sign in to unlock";
    position: absolute;
    inset: 0 auto 0 12px;
    display: inline-flex;
    align-items: center;
    color: var(--text);
    font-size: var(--font-sm);
    font-weight: 500;
    background: var(--surface-translucent);
    padding: 0 10px;
    border-radius: var(--pill-radius);
  }

  .card-thumb {
    height: 92px;
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 18px;
    background: linear-gradient(135deg, var(--thumb-a), var(--thumb-b));
    color: var(--thumb-text);
  }

  .card-site-icon {
    width: 36px;
    height: 36px;
    border-radius: 9px;
    background: rgba(255, 255, 255, 0.6);
    color: var(--text);
    display: grid;
    place-items: center;
    flex: 0 0 auto;
    overflow: hidden;
    position: relative;
    font-size: 13px;
    line-height: 1;
    font-weight: var(--weight-semibold);
  }

  .card-site-icon img {
    display: block;
    grid-area: 1 / 1;
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 4px;
    background: rgba(255, 255, 255, 0.82);
    opacity: 0;
    transition: opacity 0.12s ease;
  }

  .card-initials {
    grid-area: 1 / 1;
  }

  .card-site-icon.has-image {
    background: transparent;
  }

  .card-site-icon.has-image img {
    opacity: 1;
  }

  .card-site-icon.has-image .card-initials {
    display: none;
  }

  .thumb-name {
    font-size: var(--font-lg);
    font-weight: var(--weight-semibold);
    line-height: var(--line-tight);
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow-wrap: break-word;
    flex: 1 1 auto;
  }

  .paid-badge {
    min-width: 0;
    height: auto;
    border-radius: 0;
    background: transparent;
    color: var(--paid-text);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-xl);
    font-weight: 500;
    line-height: 1;
    flex: 0 0 auto;
    padding: 0 1px;
    box-shadow: none;
  }

  .priority-badge {
    min-height: var(--pill-height);
    border-radius: var(--pill-radius);
    border: 1px solid var(--priority-border-color);
    background: var(--priority-bg-color);
    color: var(--priority-text-color);
    padding: var(--pill-padding);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: var(--pill-font-size);
    font-weight: 500;
    line-height: 1;
    flex: 0 0 auto;
  }

  .card-body {
    padding: 16px;
    display: flex;
    flex-direction: column;
  }

  .card-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 10px;
  }

  .site-actions {
    display: flex;
    gap: 10px;
    flex: 0 0 auto;
    padding-top: 1px;
  }

  .icon-btn,
  .sheet-action,
  .settings-site-action {
    min-height: var(--action-height);
    border: 1px solid var(--border);
    border-radius: var(--radius-action);
    background: var(--panel);
    color: var(--text);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 7px;
    font-size: var(--font-md);
    font-weight: var(--weight-medium);
    text-decoration: none;
  }

  .icon-btn {
    min-width: 0;
  }

  .icon-btn:hover {
    color: var(--text);
  }

  .icon-btn[data-action="edit"] {
    border-color: var(--green-border);
    background: transparent;
    color: var(--green-text);
  }

  .icon-btn[data-action="delete"] {
    border-color: var(--red-border);
    background: transparent;
    color: var(--red-text);
  }

  .icon-btn[data-action="edit"]:hover {
    background: var(--green-bg);
    border-color: var(--green-border);
    color: var(--green-text);
  }

  .icon-btn[data-action="delete"]:hover {
    background: var(--red-bg);
    border-color: var(--red-border);
    color: var(--red-text);
  }

  .site-desc {
    margin: 0;
    color: var(--muted);
    font-size: var(--font-md);
    font-weight: var(--weight-regular);
    line-height: var(--line-normal);
    max-height: 38px;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow-wrap: anywhere;
    flex: 1 1 auto;
  }

  .status-stack {
    display: grid;
    gap: 8px;
    margin-top: auto;
  }

  .stage-row {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 7px;
  }

  .chip {
    min-height: var(--pill-height);
    border-radius: var(--pill-radius);
    border: 1px solid var(--border);
    background: var(--panel);
    color: var(--muted);
    padding: 4px 6px;
    font-size: var(--pill-font-size);
    font-weight: 500;
    user-select: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1.1;
    white-space: normal;
    text-align: center;
    min-width: 0;
  }

  .chip::before {
    content: none;
  }

  .chip.todo.active {
    background: var(--todo-bg);
    color: var(--todo-text);
    border-color: var(--border);
  }

  .chip.todo.active::before {
    background: var(--todo-text);
  }

  .chip.pending.active {
    background: var(--amber-bg);
    color: var(--amber-text);
    border-color: var(--amber-border);
  }

  .chip.pending.active::before {
    background: var(--amber-text);
  }

  .chip.approved.active {
    background: var(--green-bg);
    color: var(--green-text);
    border-color: var(--green-border);
  }

  .chip.approved.active::before {
    background: var(--green-text);
  }

  .chip.published.active {
    background: var(--blue-bg);
    color: var(--blue-text);
    border-color: var(--blue-border);
  }

  .chip.published.active::before {
    background: var(--blue-text);
  }

  .chip.rejected.active {
    background: var(--red-bg);
    color: var(--red-text);
    border-color: var(--red-border);
  }

  .chip.rejected.active::before {
    background: var(--red-text);
  }

  .card-footer {
    margin-top: 12px;
    padding-top: 8px;
    border-top: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
  }

  .footer-actions {
    display: inline-flex;
    gap: 7px;
    align-items: center;
    justify-content: flex-end;
    flex: 0 0 auto;
  }

  .last-change {
    color: var(--muted);
    font-size: var(--font-sm);
    font-weight: var(--weight-regular);
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
  }

  .open-link {
    min-height: var(--pill-height);
    border: 1px solid var(--cta-border);
    border-radius: var(--pill-radius);
    padding: 0 11px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--cta-text);
    text-decoration: none;
    font-size: var(--font-md);
    font-weight: var(--weight-medium);
    white-space: nowrap;
    background: var(--cta-bg);
  }

  .open-link:hover {
    border-color: var(--cta-border-hover);
    background: var(--cta-bg-hover);
  }

  .open-link.is-disabled,
  .sheet-action.is-disabled {
    color: var(--muted);
    border-color: var(--border);
    background: var(--surface);
    cursor: default;
  }

  .empty {
    border: 2px dashed var(--border-strong);
    border-radius: var(--radius-card);
    padding: 24px;
    background: var(--surface-empty);
    color: var(--muted);
    text-align: center;
    line-height: 1.5;
    font-size: var(--font-lg);
    font-weight: 500;
  }

  .sheet-view {
    padding: 24px;
    display: grid;
    align-content: start;
  }

  .sheet-table {
    width: 100%;
    border-collapse: collapse;
    table-layout: fixed;
    background: var(--panel);
  }

  .sheet-table th,
  .sheet-table td {
    border-bottom: 1px solid var(--border);
    padding: 14px 12px;
    text-align: left;
    vertical-align: middle;
    transition: background-color 0.12s ease;
  }

  .sheet-table th {
    color: var(--muted);
    font-size: var(--font-xs);
    font-weight: var(--weight-medium);
    text-transform: uppercase;
    letter-spacing: var(--letter-label);
  }

  .sheet-row.active td {
    background: var(--active-nav);
  }

  .sheet-sort {
    border: 0;
    background: transparent;
    color: inherit;
    padding: 0;
    font: inherit;
    text-transform: inherit;
    letter-spacing: inherit;
  }

  .sheet-sort:hover,
  .sheet-sort.active {
    color: var(--text);
  }

  .sheet-title {
    display: flex;
    align-items: center;
    gap: 7px;
    min-width: 0;
  }

  .sheet-platform {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
  }

  .sheet-platform-copy {
    min-width: 0;
  }

  .sheet-icon {
    width: 30px;
    height: 30px;
    border-radius: 8px;
    background: var(--panel-soft);
    color: var(--text);
    display: grid;
    place-items: center;
    flex: 0 0 auto;
    overflow: hidden;
    position: relative;
    font-size: 12px;
    line-height: 1;
    font-weight: var(--weight-semibold);
  }

  .sheet-icon img {
    display: block;
    grid-area: 1 / 1;
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 4px;
    background: var(--panel);
    opacity: 0;
    transition: opacity 0.12s ease;
  }

  .sheet-initials {
    grid-area: 1 / 1;
  }

  .sheet-icon.has-image {
    background: transparent;
  }

  .sheet-icon.has-image img {
    opacity: 1;
  }

  .sheet-icon.has-image .sheet-initials {
    display: none;
  }

  .sheet-name {
    color: var(--text);
    font-size: var(--font-md);
    font-weight: var(--weight-semibold);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .sheet-desc {
    color: var(--muted);
    font-size: var(--font-sm);
    font-weight: var(--weight-regular);
    margin-top: 3px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .sheet-paid {
    min-width: 0;
    height: auto;
    border-radius: 0;
    background: transparent;
    color: var(--paid-text);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    font-size: var(--font-sm);
    font-weight: 500;
    flex: 0 0 auto;
  }

  .sheet-priority {
    min-height: var(--pill-height);
    border-radius: var(--pill-radius);
    border: 1px solid var(--priority-border-color);
    background: var(--priority-bg-color);
    color: var(--priority-text-color);
    padding: var(--pill-padding);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: var(--pill-font-size);
    font-weight: 500;
    white-space: nowrap;
  }

  .sheet-channel,
  .sheet-status {
    min-height: var(--pill-height);
    border-radius: var(--pill-radius);
    font-size: var(--pill-font-size);
    font-weight: 500;
    white-space: nowrap;
  }

  .sheet-date-control {
    min-height: var(--pill-height);
    min-width: 112px;
    display: inline-flex;
    align-items: center;
    border: 0;
    background: transparent;
    padding: 0;
    color: var(--muted);
    font-family: inherit;
    font-size: var(--font-sm);
    font-weight: var(--weight-regular);
    text-align: left;
    cursor: pointer;
  }

  .sheet-date-control:hover,
  .sheet-date-control:focus {
    color: var(--text);
    outline: none;
  }

  .sheet-channel,
  .sheet-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--pill-padding);
  }

  .sheet-channel {
    border: 1px solid var(--border);
    background: var(--panel);
    color: var(--muted);
  }

  .sheet-status {
    appearance: none;
    margin: 0;
    border: 1px solid transparent;
    cursor: pointer;
    font-family: inherit;
    font-size: var(--pill-font-size);
    font-weight: 500;
    line-height: 1;
  }

  .sheet-status.todo {
    background: var(--todo-bg);
    color: var(--todo-text);
    border-color: var(--border);
  }

  .sheet-status.pending {
    background: var(--amber-bg);
    color: var(--amber-text);
    border-color: var(--amber-border);
  }

  .sheet-status.approved {
    background: var(--green-bg);
    color: var(--green-text);
    border-color: var(--green-border);
  }

  .sheet-status.published {
    background: var(--blue-bg);
    color: var(--blue-text);
    border-color: var(--blue-border);
  }

  .sheet-status.rejected {
    background: var(--red-bg);
    color: var(--red-text);
    border-color: var(--red-border);
  }

  .sheet-updated {
    color: inherit;
  }

  .sheet-actions {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
  }

  .sheet-action {
    border-color: transparent;
    background: transparent;
  }

  .sheet-action:hover {
    color: var(--text);
  }

  .sheet-action[data-action="edit"] {
    border-color: var(--green-border);
    background: transparent;
    color: var(--green-text);
  }

  .sheet-action[data-action="delete"] {
    border-color: var(--red-border);
    background: transparent;
    color: var(--red-text);
  }

  .sheet-action[data-action="edit"]:hover {
    background: var(--green-bg);
    border-color: var(--green-border);
    color: var(--green-text);
  }

  .sheet-action[data-action="delete"]:hover {
    background: var(--red-bg);
    border-color: var(--red-border);
    color: var(--red-text);
  }

  .sheet-open {
    min-height: var(--pill-height);
    border: 1px solid var(--cta-border);
    border-radius: var(--pill-radius);
    background: var(--cta-bg);
    color: var(--cta-text);
    padding: 0 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .sheet-open:hover {
    background: var(--cta-bg-hover);
    color: var(--cta-text);
  }

  .sheet-open.is-disabled:hover,
  .open-link.is-disabled:hover {
    color: var(--muted);
    border-color: var(--border);
    background: var(--surface);
  }

  .date-popover {
    position: fixed;
    width: 220px;
    border: 1px solid var(--border);
    border-radius: var(--radius-card);
    background: var(--panel);
    box-shadow: var(--shadow-popover);
    padding: 10px;
    z-index: 55;
  }

  .date-calendar-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 8px;
  }

  .date-month {
    color: var(--text);
    font-size: var(--font-xs);
    font-weight: 500;
  }

  .date-nav {
    display: inline-flex;
    gap: 4px;
  }

  .date-nav button,
  .date-cell {
    border: 1px solid transparent;
    background: transparent;
    color: var(--text);
    border-radius: var(--radius-action);
    font-family: inherit;
    cursor: pointer;
  }

  .date-nav button {
    width: 26px;
    height: 26px;
    padding: 0;
    font-size: var(--font-md);
    line-height: 1;
  }

  .date-nav button:hover,
  .date-cell:hover {
    background: var(--panel-soft);
    border-color: var(--border);
  }

  .date-weekdays,
  .date-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 3px;
  }

  .date-weekdays {
    margin-bottom: 4px;
  }

  .date-weekdays span {
    color: var(--muted);
    font-size: var(--font-xs);
    font-weight: 500;
    text-align: center;
  }

  .date-cell {
    width: 100%;
    height: 25px;
    padding: 0;
    font-size: var(--font-xs);
    font-weight: 500;
  }

  .date-cell.today {
    border-color: var(--border-strong);
  }

  .date-cell.selected {
    background: var(--accent);
    border-color: var(--accent-strong);
    color: var(--panel);
  }

  .date-empty {
    width: 100%;
    height: 25px;
  }

  .drawer-backdrop {
    display: none;
  }

  .drawer {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 300px;
    width: auto;
    height: auto;
    background: var(--panel);
    border: 0;
    border-left: 1px solid var(--border);
    border-radius: 0;
    box-shadow: none;
    transform: none;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.12s ease;
    z-index: 30;
    display: grid;
    grid-template-rows: auto 1fr;
    overflow: hidden;
  }

  body.settings-open {
    overflow: hidden;
  }

  body.settings-open .drawer-backdrop {
    opacity: 1;
    pointer-events: auto;
  }

  body.settings-open .drawer {
    opacity: 1;
    pointer-events: auto;
  }

  .drawer-header {
    padding: 16px 24px;
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 14px;
  }

  .settings-back {
    background: var(--nav);
    border-color: var(--nav-strong);
    color: var(--nav-text);
    min-width: 92px;
  }

  .settings-back:hover {
    background: var(--green-bg);
    border-color: var(--green-border);
    color: var(--green-text);
  }

  .drawer-title {
    display: grid;
    gap: 3px;
  }

  .drawer-title h3 {
    margin: 0;
    font-size: var(--font-title);
    font-weight: var(--weight-semibold);
    line-height: var(--line-tight);
  }

  .drawer-title span {
    color: var(--muted);
    font-size: var(--font-sm);
  }

  .drawer-body {
    overflow: auto;
    padding: 24px;
    display: grid;
    grid-template-columns: 220px minmax(0, 1fr);
    gap: 18px;
    align-content: start;
  }

  .settings-menu {
    display: grid;
    gap: 10px;
    align-content: start;
    margin-top: var(--settings-menu-offset);
  }

  .settings-menu-button {
    min-height: var(--nav-height);
    border: 1px solid var(--border);
    border-radius: var(--radius-control);
    background: var(--panel);
    color: var(--muted);
    padding: 0 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    font-size: var(--font-md);
    font-weight: var(--weight-medium);
    text-align: left;
  }

  .settings-menu-button:hover,
  .settings-menu-button.active {
    background: var(--active-nav);
    border-color: var(--nav-border);
    color: var(--nav-text);
  }

  .settings-panels {
    min-width: 0;
    display: grid;
    align-content: start;
  }

  .settings-section {
    border: 1px solid var(--border);
    border-top-color: var(--accent-border);
    border-radius: var(--radius-card);
    padding: 18px;
    background: var(--panel);
    display: grid;
    gap: 14px;
    max-width: 880px;
  }

  .settings-section:not(.sites-settings) {
    margin-top: var(--settings-menu-offset);
  }

  .sites-settings {
    border: 0;
    border-radius: 0;
    padding: 0;
    background: transparent;
    max-width: 1180px;
  }

  .settings-context {
    border: 1px solid var(--border);
    border-top-color: var(--nav-border);
    border-radius: var(--radius-card);
    background: var(--panel);
    padding: 18px 22px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    box-shadow: inset 0 3px 0 var(--active-nav);
    margin-bottom: 18px;
  }

  .settings-context h4 {
    margin: 6px 0 4px;
    font-size: var(--font-lg);
    font-weight: var(--weight-semibold);
    line-height: var(--line-compact);
  }

  .settings-context-actions {
    display: flex;
    gap: 10px;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
  }

  .sites-settings-layout {
    display: grid;
    grid-template-columns: 320px minmax(0, 1fr);
    gap: 28px;
    align-items: stretch;
  }

  .site-browser,
  .site-editor {
    border: 1px solid var(--border);
    border-top-color: var(--accent-border);
    border-radius: var(--radius-card);
    background: var(--panel);
    padding: 22px;
    display: grid;
    gap: 18px;
    min-width: 0;
    box-shadow: inset 0 3px 0 var(--accent-soft);
  }

  .site-browser {
    height: 100%;
    min-height: var(--settings-browser-min-height);
    max-height: 680px;
    grid-template-rows: auto auto minmax(0, 1fr);
  }

  .site-search-field {
    display: grid;
    gap: 7px;
  }

  .site-browser-title {
    display: grid;
    gap: 3px;
  }

  .site-form {
    gap: 18px;
  }

  .site-search-field label {
    color: var(--muted);
    font-size: var(--font-sm);
    font-weight: var(--weight-medium);
  }

  .settings-site-list {
    display: grid;
    gap: 0;
    overflow: auto;
    padding-right: 24px;
    border-top: 1px solid var(--accent-border);
    scrollbar-gutter: stable;
    scrollbar-color: var(--nav) var(--nav-soft);
    scrollbar-width: thin;
  }

  .settings-site-list::-webkit-scrollbar {
    width: 9px;
  }

  .settings-site-list::-webkit-scrollbar-track {
    background: var(--nav-soft);
    border-radius: var(--radius-round);
  }

  .settings-site-list::-webkit-scrollbar-thumb {
    background: var(--nav);
    border: 2px solid var(--nav-soft);
    border-radius: var(--radius-round);
  }

  .settings-site-item {
    border-bottom: 1px solid var(--border);
    background: transparent;
    padding: 10px 0;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
  }

  .settings-site-item.active {
    background: var(--active-nav);
    box-shadow: none;
  }

  .settings-site-name {
    color: var(--text);
    font-size: var(--font-md);
    font-weight: var(--weight-semibold);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .settings-site-meta {
    color: var(--muted);
    font-size: var(--font-sm);
    font-weight: var(--weight-regular);
    margin-top: 3px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .settings-site-actions {
    display: flex;
    gap: 8px;
  }

  .settings-site-action {
    border-color: transparent;
    background: transparent;
  }

  .settings-site-action:hover {
    color: var(--text);
  }

  .settings-site-action[data-action="edit"] {
    border-color: var(--green-border);
    background: transparent;
    color: var(--green-text);
  }

  .settings-site-action[data-action="delete"] {
    border-color: var(--red-border);
    background: transparent;
    color: var(--red-text);
  }

  .settings-site-action[data-action="edit"]:hover {
    background: var(--green-bg);
    border-color: var(--green-border);
    color: var(--green-text);
  }

  .settings-site-action[data-action="delete"]:hover {
    background: var(--red-bg);
    border-color: var(--red-border);
    color: var(--red-text);
  }

  .settings-section h4 {
    margin: 0;
    font-size: var(--font-lg);
    font-weight: var(--weight-semibold);
    line-height: var(--line-compact);
  }

  .settings-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
  }

  .settings-count {
    color: var(--muted);
    font-size: var(--font-sm);
    font-weight: var(--weight-regular);
  }

  .deleted-list {
    display: grid;
    gap: 8px;
  }

  .deleted-item {
    min-width: 0;
    border: 1px solid var(--border);
    border-radius: var(--radius-control);
    background: var(--panel);
    padding: 10px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
  }

  .deleted-name {
    color: var(--text);
    font-size: var(--font-md);
    font-weight: var(--weight-semibold);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .deleted-meta,
  .deleted-empty {
    color: var(--muted);
    font-size: var(--font-sm);
    font-weight: var(--weight-regular);
  }

  .archived-projects-head {
    margin-top: 14px;
  }

  .project-form,
  .site-form {
    display: grid;
    gap: 14px;
  }

  .project-form .btn.primary {
    justify-self: start;
    min-width: 130px;
  }

  .settings-section[data-settings-panel="projects"] > .button-row,
  .settings-section[data-settings-panel="backup"] > .button-row {
    justify-content: flex-start;
  }

  .field {
    display: grid;
    gap: 7px;
  }

  .field label {
    color: var(--text);
    font-size: var(--font-sm);
    font-weight: var(--weight-medium);
  }

  .check-row {
    min-height: var(--pill-height);
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--text);
    font-size: var(--font-md);
    font-weight: var(--weight-medium);
  }

  .check-row input {
    width: 18px;
    height: 18px;
    accent-color: var(--accent);
  }

  .paid-priority-row {
    display: flex;
    gap: 18px;
    align-items: end;
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  .priority-compact {
    width: 92px;
  }

  .priority-compact .input {
    text-align: center;
    padding-left: 8px;
    padding-right: 8px;
  }

  .input,
  .textarea {
    width: 100%;
    border: 1px solid var(--border);
    background: var(--panel);
    color: var(--text);
    border-radius: var(--radius-control);
    outline: none;
    min-width: 0;
  }

  .input {
    height: var(--pill-height);
    padding: var(--pill-padding);
    font-size: var(--font-md);
    font-weight: var(--weight-regular);
  }

  .textarea {
    min-height: var(--textarea-min-height);
    padding: 10px 12px;
    resize: vertical;
    line-height: var(--line-normal);
    font-size: var(--font-md);
    font-weight: var(--weight-regular);
  }

  .notes-textarea {
    min-height: calc(var(--textarea-min-height) * 0.76);
  }

  .date-fields-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
  }

  .input:focus,
  .textarea:focus {
    border-color: var(--focus);
    background: var(--panel);
    box-shadow: var(--focus-ring);
  }

  .status-picker {
    gap: 10px;
  }

  .status-picker.stage-row {
    display: grid;
  }

  .category-picker {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
  }

  .category-picker .category-button {
    justify-content: center;
  }

  .pricing-picker {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
  }

  .pricing-picker .category-button {
    justify-content: center;
  }

  .form-actions,
  .button-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
  }

  .editing-note {
    color: var(--muted);
    font-size: var(--font-sm);
    font-weight: 500;
  }

  .edit-backdrop {
    position: fixed;
    inset: 0;
    background: var(--overlay-soft);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.16s ease;
    z-index: 80;
  }

  .auth-backdrop {
    position: fixed;
    inset: 0;
    background: var(--overlay-soft);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.16s ease;
    z-index: 100;
  }

  .auth-modal {
    position: fixed;
    top: 50%;
    left: 50%;
    width: min(420px, calc(100vw - 32px));
    border: 1px solid var(--border);
    border-top-color: var(--accent-border);
    border-radius: var(--radius-card);
    background: var(--panel);
    box-shadow: inset 0 3px 0 var(--accent-soft), var(--shadow-modal);
    padding: 22px;
    display: grid;
    gap: 16px;
    opacity: 0;
    pointer-events: none;
    transform: translate(-50%, -48%) scale(0.98);
    transition: opacity 0.16s ease, transform 0.16s ease;
    z-index: 110;
  }

  body.auth-open .auth-backdrop {
    opacity: 1;
    pointer-events: auto;
  }

  body.auth-open .auth-modal {
    opacity: 1;
    pointer-events: auto;
    transform: translate(-50%, -50%) scale(1);
  }

  .auth-title {
    margin: 0;
    font-size: var(--font-lg);
    font-weight: var(--weight-semibold);
    line-height: var(--line-compact);
  }

  .auth-copy,
  .auth-status {
    margin: 0;
    color: var(--muted);
    font-size: var(--font-sm);
    font-weight: var(--weight-regular);
    line-height: var(--line-normal);
  }

  .auth-status {
    min-height: var(--auth-status-height);
  }

  .auth-form {
    display: grid;
    gap: 10px;
  }

  .auth-modal > .btn.full,
  .auth-form,
  .auth-divider {
    width: min(100%, var(--auth-control-width));
    justify-self: center;
  }

  .auth-form .btn.full {
    width: 100%;
  }

  .auth-divider {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--muted);
    font-size: var(--font-xs);
    font-weight: var(--weight-medium);
    text-transform: uppercase;
    letter-spacing: var(--letter-label);
  }

  .auth-divider::before,
  .auth-divider::after {
    content: "";
    height: 1px;
    background: var(--border);
    flex: 1 1 auto;
  }

  .edit-modal {
    position: fixed;
    top: 50%;
    left: 50%;
    width: min(760px, calc(100vw - 36px));
    max-height: calc(100vh - 36px);
    overflow: auto;
    border: 1px solid var(--border);
    border-top-color: var(--accent-border);
    border-radius: var(--radius-card);
    background: var(--panel);
    box-shadow: inset 0 3px 0 var(--accent-soft), var(--shadow-modal);
    padding: 22px;
    display: grid;
    gap: 18px;
    opacity: 0;
    pointer-events: none;
    transform: translate(-50%, -48%) scale(0.98);
    transition: opacity 0.16s ease, transform 0.16s ease;
    z-index: 90;
  }

  body.site-edit-open .edit-backdrop {
    opacity: 1;
    pointer-events: auto;
  }

  body.site-edit-open .edit-modal {
    opacity: 1;
    pointer-events: auto;
    transform: translate(-50%, -50%) scale(1);
  }

  .edit-modal-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
  }

  .edit-modal-title {
    margin: 0;
    font-size: var(--font-lg);
    font-weight: var(--weight-semibold);
    line-height: var(--line-compact);
  }

  .confirm-backdrop {
    position: fixed;
    inset: 0;
    background: var(--overlay-strong);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.16s ease;
    z-index: 60;
  }

  .confirm-modal {
    position: fixed;
    top: 50%;
    left: 50%;
    width: min(360px, calc(100vw - 32px));
    border: 1px solid var(--border);
    border-radius: var(--radius-card);
    background: var(--panel);
    box-shadow: var(--shadow-modal);
    padding: 16px;
    display: grid;
    gap: 16px;
    opacity: 0;
    pointer-events: none;
    transform: translate(-50%, -48%) scale(0.98);
    transition: opacity 0.16s ease, transform 0.16s ease;
    z-index: 70;
  }

  body.delete-open .confirm-backdrop {
    opacity: 1;
    pointer-events: auto;
  }

  body.delete-open .confirm-modal {
    opacity: 1;
    pointer-events: auto;
    transform: translate(-50%, -50%) scale(1);
  }

  .confirm-title {
    margin: 0;
    font-size: var(--font-lg);
    font-weight: var(--weight-semibold);
    line-height: var(--line-compact);
  }

  .confirm-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
  }

  .category-button,
  .project-name,
  .project-count,
  .btn,
  .view-button,
  .stat,
  .priority-badge,
  .icon-btn,
  .site-desc,
  .chip,
  .last-change,
  .open-link,
  .empty,
  .sheet-table th,
  .sheet-desc,
  .sheet-priority,
  .sheet-channel,
  .sheet-status,
  .sheet-date-control,
  .sheet-action,
  .date-month,
  .date-weekdays span,
  .date-cell,
  .settings-menu-button,
  .site-search-field label,
  .settings-site-name,
  .settings-site-meta,
  .settings-site-action,
  .settings-count,
  .deleted-name,
  .deleted-meta,
  .deleted-empty,
  .field label,
  .check-row,
  .input,
  .textarea,
  .editing-note {
    font-weight: var(--weight-regular);
  }

  .menu-label,
  .category-button,
  .btn,
  .view-button,
  .stat,
  .priority-badge,
  .icon-btn,
  .chip,
  .sheet-table th,
  .sheet-priority,
  .sheet-channel,
  .sheet-status,
  .sheet-action,
  .date-month,
  .date-weekdays span,
  .date-cell,
  .settings-menu-button,
  .site-search-field label,
  .settings-site-action,
  .check-row,
  .field label,
  .open-link,
  .sheet-open {
    font-weight: var(--weight-medium);
  }

  h1,
  h2,
  .thumb-name,
  .sheet-name,
  .drawer-title h3,
  .settings-context h4,
  .settings-section h4,
  .edit-modal-title,
  .confirm-title,
  .project-name,
  .project-button.active .project-name,
  .settings-site-name,
  .deleted-name {
    font-weight: var(--weight-semibold);
  }

  .paid-badge,
  .sheet-paid {
    font-weight: var(--weight-semibold);
  }

  .hidden {
    display: none !important;
  }

  [hidden] {
    display: none !important;
  }

  body,
  button,
  input,
  textarea {
    font-weight: var(--weight-regular);
  }

  @media (max-width: 980px) {
    .app {
      grid-template-columns: 1fr;
      padding: 0;
    }

    .sidebar {
      position: static;
      height: auto;
      max-height: none;
      overflow-y: visible;
      min-height: 0;
      border-right: 0;
      border-bottom: 1px solid var(--border);
    }

    .drawer {
      left: 0;
    }

    .drawer-body {
      grid-template-columns: 1fr;
    }

    .settings-menu {
      margin-top: 0;
    }

    .settings-section:not(.sites-settings) {
      margin-top: 0;
    }

    .sites-settings-layout {
      grid-template-columns: 1fr;
    }

    .site-browser {
      max-height: none;
    }

    .project-list {
      grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    }

    .grid {
      grid-template-columns: 1fr;
    }

    .sheet-view {
      overflow-x: auto;
    }

    .sheet-table {
      min-width: 760px;
    }

    .project-heading {
      align-items: flex-start;
      display: grid;
      gap: 8px;
    }

    .stats {
      justify-content: flex-start;
    }
  }

  @media (max-width: 540px) {
    .project-bar {
      display: grid;
    }

    .status-picker,
    .category-picker {
      flex-wrap: wrap;
    }

    .stage-row {
      grid-template-columns: 1fr 1fr;
    }

    .category-picker {
      grid-template-columns: 1fr 1fr;
    }
  }


  /* Controlled UI rebuild: structure only, preserving original card status colors */
  :root {
    --bg: #f6f7f9;
    --sidebar-bg: #ffffff;
    --panel: #ffffff;
    --panel-soft: #f3f4f6;
    --active-nav: #edf7ee;
    --text: #151718;
    --muted: #59616b;
    --faint: #7c858f;
    --border: #dce0e5;
    --border-strong: #c8ced6;
    --green-bg: #e9f6ec;
    --green-text: #215c33;
    --green-border: #afd5ba;
    --accent: #31573a;
    --accent-strong: #24432b;
    --accent-soft: #eef6f0;
    --accent-border: #bfd9c7;
    --nav: #f3f4f6;
    --nav-strong: #c8ced6;
    --nav-soft: #f7f8fa;
    --nav-border: #dce0e5;
    --nav-text: #151718;
    --radius-action: 5px;
    --radius-control: 6px;
    --radius-card: 7px;
    --pill-radius: 6px;
    --shadow: 0 8px 20px rgba(20, 23, 26, 0.06);
    --shadow-soft: 0 1px 2px rgba(20, 23, 26, 0.05);
    --font-md: 14px;
    --font-lg: 16px;
    --font-xl: 18px;
    --font-title: 24px;
    --weight-medium: 500;
    --weight-semibold: 600;
  }

  .app.controlled-ui {
    grid-template-columns: 280px minmax(0, 1fr);
    background: var(--bg);
  }

  .sidebar {
    background: var(--sidebar-bg);
    padding: 26px 22px;
    gap: 24px;
    border-right: 1px solid var(--border);
    box-shadow: none;
  }

  .sidebar .brand + .menu-block {
    margin-top: 34px;
  }

  .brand {
    gap: 6px;
  }

  .brand-lockup {
    align-items: start;
  }

  .brand h1 {
    font-size: 22px;
    font-weight: 600;
    letter-spacing: -0.02em;
  }

  .brand .hint {
    font-size: 14px;
    color: var(--muted);
  }

  .menu-label {
    color: var(--faint);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.08em;
  }

  .project-list {
    gap: 7px;
  }

  .project-button,
  .category-list .category-button,
  .filter-toggle,
  .sort-control .category-button,
  .btn,
  .view-button {
    border-radius: 6px;
    font-size: 14px;
    font-weight: 500;
  }

  .project-button {
    min-height: 42px;
    background: transparent;
    border-color: transparent;
    box-shadow: none;
    padding: 8px 10px;
  }

  .project-button:hover {
    background: var(--panel-soft);
    border-color: transparent;
  }

  .project-button.active {
    background: var(--green-bg);
    border-color: var(--green-border);
    box-shadow: none;
  }

  .project-name {
    font-size: 14px;
    font-weight: 500;
  }

  .project-count,
  .category-count {
    font-size: 12px;
    font-weight: 500;
    border-radius: 5px;
    background: #f0f2f4;
    color: var(--muted);
    padding: 2px 6px;
    min-width: 28px;
  }

  .project-button.active .project-count,
  .category-button.active .category-count {
    background: #dcefe1;
    color: var(--green-text);
  }

  .sidebar-actions {
    margin-top: auto;
  }

  .content {
    background: var(--bg);
  }

  .project-bar {
    position: static;
    background: transparent;
    border: 0;
    padding: 28px 30px 0;
    display: grid;
    gap: 18px;
  }

  .project-heading {
    align-items: center;
  }

  .project-title-block {
    gap: 5px;
  }

  .section-eyebrow {
    color: var(--muted);
    font-size: 13px;
    font-weight: 500;
  }

  h2#currentProjectName {
    font-size: 26px;
    font-weight: 600;
    letter-spacing: -0.025em;
  }

  .project-tools {
    gap: 10px;
    align-items: center;
  }

  .project-tools > .btn,
  .project-tools .view-button {
    min-height: 38px;
    padding: 0 16px;
  }

  .project-tools > .btn {
    min-width: 92px;
  }

  .stats {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 12px;
  }

  .metric-card {
    background: var(--metric-bg, var(--panel));
    border: 1px solid var(--metric-border, var(--border));
    border-radius: 7px;
    box-shadow: var(--shadow-soft);
    padding: 14px 14px 13px;
    min-width: 0;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 5px 10px;
    align-items: start;
  }

  .metric-title {
    color: var(--text);
    font-size: 16px;
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    grid-column: 1;
  }

  .metric-value {
    color: var(--text);
    font-size: 24px;
    line-height: 1.05;
    font-weight: 600;
    grid-column: 1;
  }

  .metric-subtitle {
    color: var(--faint);
    font-size: 12px;
    font-weight: 400;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    grid-column: 1 / -1;
  }

  .metric-icon {
    grid-column: 2;
    grid-row: 1 / span 2;
    width: 40px;
    height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--metric-icon-text, var(--text));
  }

  .metric-card.total { --metric-bg: var(--sidebar-bg); --metric-border: var(--border); --metric-icon-bg: var(--panel-soft); --metric-icon-text: var(--muted); }
  .metric-card.todo { --metric-bg: #f1f1ed; --metric-border: #d3d3cc; }
  .metric-card.pending { --metric-bg: #e8dfc9; --metric-border: #ccbf9b; --metric-icon-bg: #f4ead1; --metric-icon-text: #7b5e14; }
  .metric-card.approved { --metric-bg: #d9e4d9; --metric-border: #adc5ad; --metric-icon-bg: #e9f6ec; --metric-icon-text: #215c33; }
  .metric-card.published { --metric-bg: #d7e3e5; --metric-border: #abc2c7; --metric-icon-bg: #e7f1f3; --metric-icon-text: #245760; }
  .metric-card.rejected { --metric-bg: #e1d3d3; --metric-border: #c6aaaa; --metric-icon-bg: #f1dddd; --metric-icon-text: #7a2d2d; }

  .topbar {
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: 7px;
    box-shadow: var(--shadow-soft);
  }

  .views-topbar {
    padding: 8px;
  }

  .views-topbar .category-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }

  .views-topbar .category-button {
    min-height: 36px;
    border-color: transparent;
    background: transparent;
    color: var(--muted);
    padding: 0 10px;
  }

  .views-topbar .category-button:hover {
    background: var(--panel-soft);
    color: var(--text);
  }

  .views-topbar .category-button.active {
    background: var(--green-bg);
    color: var(--green-text);
    border-color: var(--green-border);
  }

  .filters-topbar {
    padding: 0;
    display: flex;
    gap: 10px;
    align-items: flex-start;
    flex-wrap: wrap;
    width: min(100%, 980px);
    background: transparent;
    border: 0;
    box-shadow: none;
  }

  .search-wrap {
    min-height: 40px;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 10px;
    border: 1px solid var(--border);
    border-radius: 6px;
    background: var(--panel);
    padding: 0 10px;
    flex: 0 0 260px;
  }

  .search-wrap span {
    color: var(--text);
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
  }

  .search-wrap input {
    border: 0;
    background: transparent;
    box-shadow: none;
    height: 38px;
    padding: 0;
  }

  .search-wrap input:focus {
    box-shadow: none;
  }

  .filter-panel {
    position: relative;
    flex: 0 0 144px;
  }

  .filter-toggle {
    min-height: 40px;
    width: 100%;
    background: var(--panel);
    border-color: var(--border);
  }

  .filter-options {
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    z-index: 40;
    min-width: 190px;
    padding: 6px;
    border: 1px solid var(--border);
    border-radius: 7px;
    background: var(--panel);
    box-shadow: var(--shadow-popover);
  }

  .filter-options .category-button {
    min-height: 34px;
    justify-content: space-between;
  }

  .sort-control {
    grid-template-columns: minmax(0, 1fr) 82px;
    gap: 8px;
    flex: 0 0 230px;
  }

  .sort-control .category-button {
    min-height: 40px;
    background: var(--panel);
    border-color: var(--border);
  }

  .category-button.active,
  .filter-toggle.active,
  .sort-field-button.active,
  .filter-options .category-button.active {
    box-shadow: none;
  }

  .view-toggle {
    border-color: var(--border);
    background: var(--panel);
    border-radius: 6px;
  }

  .view-button {
    min-height: 36px;
    background: transparent;
    color: var(--muted);
    border-color: var(--border);
  }

  .view-button.active {
    background: var(--green-bg);
    color: var(--green-text);
    box-shadow: none;
  }

  .grid,
  .sheet-view {
    padding: 22px 30px 30px;
  }

  .sheet-table,
  .card,
  .settings-section,
  .settings-context,
  .site-browser,
  .site-editor,
  .edit-modal,
  .auth-modal,
  .confirm-modal {
    border-radius: 7px;
  }

  @media (max-width: 1180px) {
    .stats { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .filters-topbar { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  }

  @media (max-width: 980px) {
    .app.controlled-ui { grid-template-columns: 1fr; }
    .stats { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .filters-topbar { grid-template-columns: 1fr; }
  }


  /* Final correction: no decorative accent lines anywhere in the controlled UI. */
  .metric-card,
  .project-button.active,
  .category-button.active,
  .filter-toggle.active,
  .sort-field-button.active,
  .settings-site-item.active,
  .settings-context,
  .site-browser,
  .site-editor,
  .edit-modal,
  .auth-modal {
    box-shadow: var(--shadow-soft) !important;
  }

  .project-button.active,
  .category-button.active,
  .filter-toggle.active,
  .sort-field-button.active,
  .settings-site-item.active {
    box-shadow: none !important;
  }

  .metric-card {
    border-top: 1px solid var(--metric-border, var(--border)) !important;
  }

  /* Index baseline polish: keep the dashboard clean and compact without nested toolbar cards. */
  .sidebar .brand + .menu-block {
    margin-top: 34px;
  }

  .metric-card.total {
    --metric-bg: var(--panel);
    --metric-border: var(--border);
    --metric-icon-bg: var(--panel-soft);
    --metric-icon-text: var(--muted);
  }

  .metric-card.todo {
    --metric-bg: var(--todo-bg);
    --metric-border: var(--border);
    --metric-icon-text: var(--todo-text);
  }

  .metric-icon svg {
    width: 32px;
    height: 32px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.7;
    stroke-linecap: round;
    stroke-linejoin: round;
  }

  .filters-topbar.topbar {
    width: 100%;
    max-width: none;
    padding: 0;
    background: transparent;
    border: 0;
    box-shadow: none;
    justify-content: flex-start;
  }

  .filters-topbar.topbar > .canvas-view-toggle {
    margin-left: auto;
  }

  .filters-topbar .search-wrap {
    flex: 0 0 282px;
  }

  .filters-topbar .filter-panel {
    flex: 0 0 148px;
  }

  .filters-topbar .sort-control {
    flex: 0 0 238px;
  }

  .filters-topbar .filter-toggle,
  .filters-topbar .sort-control .category-button,
  .filters-topbar .search-wrap {
    box-shadow: var(--shadow-soft);
  }

  .sheet-view {
    overflow-x: auto;
  }

  .sheet-table {
    min-width: 980px;
  }

  .sheet-table th:last-child,
  .sheet-table td:last-child {
    min-width: 220px;
    padding-right: 16px;
  }

  .sheet-table th:last-child {
    text-align: left;
  }

  .sheet-actions {
    gap: 8px;
  }

  .sheet-action {
    min-width: 40px;
  }

  /* Contrast pass: darker text colors without increasing font weight. */
  :root {
    --text: #101214;
    --muted: #343a40;
    --faint: #4b5563;
    --nav-text: #101214;
    --todo-text: #2f3437;
    --amber-text: #4f3f0b;
    --green-text: #14532d;
    --blue-text: #164e63;
    --red-text: #7f1d1d;
    --paid-text: #047332;
  }

  /* Impeccable pass: clarity, rhythm, and mobile scanability improvements. */
  :root {
    --focus-ring: 0 0 0 3px rgba(16, 18, 20, 0.14);
  }

  button:focus-visible,
  a:focus-visible,
  input:focus-visible,
  textarea:focus-visible {
    outline: none;
    box-shadow: var(--focus-ring);
  }

  .project-bar {
    gap: 14px;
    padding: 24px 28px 0;
  }

  .project-title-row {
    align-items: end;
    gap: 12px;
  }

  .project-title-row .btn.compact {
    min-height: 30px;
    padding: 0 10px;
    border-color: var(--border);
    color: var(--muted);
    background: var(--panel);
  }

  .project-title-row .btn.compact:hover {
    color: var(--text);
    border-color: var(--border-strong);
  }

  .preview-notice {
    max-width: 76ch;
    color: var(--muted);
    font-size: 12px;
  }

  .stats {
    gap: 10px;
  }

  .metric-card {
    padding: 12px 12px 11px;
    gap: 4px 8px;
  }

  .metric-title {
    font-size: 14px;
  }

  .metric-value {
    font-size: 22px;
  }

  .views-topbar {
    padding: 7px;
  }

  .views-topbar .category-button {
    min-height: 34px;
    padding: 0 9px;
  }

  .filters-topbar.topbar {
    row-gap: 8px;
    column-gap: 8px;
    flex-wrap: nowrap;
    align-items: center;
  }

  .filters-topbar .search-wrap {
    flex: 0 0 282px;
    min-width: 282px;
  }

  .filters-topbar .filter-panel {
    flex: 0 0 148px;
    min-width: 148px;
  }

  .filters-topbar .sort-control {
    flex: 0 0 238px;
    min-width: 238px;
  }

  .canvas-view-toggle {
    margin-left: auto;
    display: flex;
    align-items: stretch;
  }

  .canvas-view-toggle .view-toggle {
    height: 40px;
    border-radius: 6px;
  }

  .canvas-view-toggle .view-button {
    min-height: 40px;
    padding: 0 14px;
  }

  .sheet-table th {
    position: sticky;
    top: 0;
    z-index: 2;
    background: var(--panel);
  }

  .sheet-actions {
    flex-wrap: nowrap;
    justify-content: flex-start;
  }

  .sheet-action {
    min-width: 46px;
    white-space: nowrap;
  }

  .sheet-open,
  .sheet-listing {
    white-space: nowrap;
  }

  @media (max-width: 980px) {
    .project-bar {
      padding: 18px 16px 0;
      gap: 12px;
    }

    .grid,
    .sheet-view {
      padding: 16px 16px 22px;
    }

    .stats {
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 8px;
    }

    .metric-card {
      padding: 11px 10px;
    }

    .metric-title {
      font-size: 13px;
    }

    .metric-value {
      font-size: 20px;
    }

    .filters-topbar .search-wrap,
    .filters-topbar .filter-panel,
    .filters-topbar .sort-control,
    .canvas-view-toggle {
      flex: 1 1 100%;
      min-width: 0;
    }

    .filters-topbar.topbar {
      flex-wrap: wrap;
    }

    .canvas-view-toggle {
      margin-left: 0;
      justify-content: flex-end;
    }
  }

  @media (max-width: 640px) {
    .project-heading {
      flex-direction: column;
      align-items: stretch;
      gap: 10px;
    }

    .project-tools {
      justify-content: space-between;
      width: 100%;
    }

    .project-tools > .btn {
      min-width: 0;
      flex: 1 1 auto;
    }

    .project-title-row .btn.compact {
      margin-left: auto;
    }

    .stats {
      grid-template-columns: 1fr;
    }
  }

  /* Production redesign: mock-up aligned shell, preserving existing behavior. */
  :root {
    --bg: oklch(97.8% 0.006 248);
    --sidebar-bg: oklch(99.2% 0.004 248);
    --panel: oklch(99.2% 0.004 248);
    --panel-soft: oklch(95.5% 0.006 248);
    --active-nav: oklch(93.8% 0.011 248);
    --text: oklch(19% 0.008 248);
    --muted: oklch(42% 0.018 248);
    --faint: oklch(54% 0.017 248);
    --border: oklch(86.5% 0.01 248);
    --border-strong: oklch(77% 0.015 248);
    --accent: oklch(19% 0.008 248);
    --accent-strong: oklch(16% 0.008 248);
    --accent-soft: oklch(93.8% 0.011 248);
    --accent-border: oklch(79% 0.015 248);
    --nav: oklch(95.5% 0.006 248);
    --nav-strong: oklch(78% 0.014 248);
    --nav-soft: oklch(97.8% 0.006 248);
    --nav-border: oklch(86.5% 0.01 248);
    --nav-text: oklch(19% 0.008 248);
    --green-bg: oklch(94% 0.035 153);
    --green-text: oklch(34% 0.085 153);
    --green-border: oklch(78% 0.045 153);
    --blue-bg: oklch(94% 0.025 218);
    --blue-text: oklch(36% 0.075 218);
    --blue-border: oklch(78% 0.035 218);
    --amber-bg: oklch(94% 0.042 82);
    --amber-text: oklch(38% 0.07 82);
    --amber-border: oklch(78% 0.055 82);
    --red-bg: oklch(94% 0.026 24);
    --red-text: oklch(38% 0.08 24);
    --red-border: oklch(78% 0.04 24);
    --todo-bg: oklch(90.8% 0.006 248);
    --todo-text: oklch(33% 0.012 248);
    --cta-bg: oklch(19% 0.008 248);
    --cta-bg-hover: oklch(27% 0.01 248);
    --cta-border: oklch(19% 0.008 248);
    --cta-border-hover: oklch(27% 0.01 248);
    --cta-text: oklch(98% 0.004 248);
    --action-bg: oklch(19% 0.008 248);
    --action-bg-hover: oklch(27% 0.01 248);
    --action-border: oklch(19% 0.008 248);
    --action-border-hover: oklch(27% 0.01 248);
    --action-text: oklch(98% 0.004 248);
    --paid-text: oklch(43% 0.12 153);
    --shadow: 0 12px 30px rgba(25, 28, 30, 0.06);
    --shadow-soft: 0 1px 2px rgba(25, 28, 30, 0.06);
    --shadow-popover: 0 18px 45px rgba(25, 28, 30, 0.16);
    --shadow-modal: 0 24px 70px rgba(25, 28, 30, 0.22);
    --radius-action: 4px;
    --radius-control: 6px;
    --radius-card: 8px;
    --pill-radius: 6px;
    --font-family-sans: "Geist", "Segoe UI", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
    --font-family-mono: "JetBrains Mono", "SFMono-Regular", Consolas, monospace;
    --font-title: 24px;
    --control-height: 38px;
    --pill-height: 38px;
    --workspace-max: none;
  }

  body {
    overflow: hidden;
    background: var(--bg);
  }

  .app.controlled-ui {
    grid-template-columns: 240px minmax(0, 1fr);
    height: 100vh;
    min-height: 100vh;
    overflow: hidden;
  }

  .sidebar {
    width: 240px;
    padding: 18px 16px;
    gap: 18px;
    background: var(--sidebar-bg);
  }

  .brand-lockup {
    grid-template-columns: 40px minmax(0, 1fr);
    align-items: center;
    gap: 10px;
  }

  .brand-logo {
    width: 40px;
    height: 40px;
    grid-column: 1;
    grid-row: 1;
    color: var(--cta-text);
    background: var(--accent);
    border-radius: 8px;
    padding: 8px;
  }

  .brand-copy {
    grid-column: 2;
  }

  .brand-logo svg path,
  .brand-logo svg circle {
    fill: none;
    stroke: currentColor;
  }

  .brand-logo svg path:last-child {
    fill: none;
    stroke: currentColor;
  }

  .brand h1 {
    font-size: 18px;
    letter-spacing: -0.01em;
  }

  .brand .hint {
    font-size: 12px;
    color: var(--faint);
  }

  .sidebar .brand + .menu-block {
    margin-top: 16px;
  }

  .menu-label {
    padding: 0 10px;
    font-size: 11px;
    letter-spacing: 0.06em;
  }

  .project-button {
    min-height: 40px;
    padding: 8px 10px;
    border-radius: 6px;
    color: var(--muted);
  }

  .project-button::before {
    content: "";
    width: 20px;
    height: 20px;
    flex: 0 0 auto;
    border-radius: 5px;
    background: var(--panel-soft);
    box-shadow: inset 0 0 0 1px var(--border);
  }

  .project-button.active {
    background: var(--active-nav);
    border-color: var(--border);
    color: var(--text);
  }

  .project-button.active::before {
    display: none;
  }

  .project-name {
    flex: 1 1 auto;
  }

  .project-count,
  .category-count {
    font-family: var(--font-family-mono);
    font-size: 11px;
    background: var(--panel-soft);
  }

  .sidebar-add-project,
  .sidebar-actions .btn {
    min-height: 38px;
  }

  .content {
    min-height: 0;
    overflow: auto;
    background: var(--bg);
  }

  .project-bar,
  .content > div {
    width: 100%;
    max-width: var(--workspace-max);
    margin: 0;
  }

  .project-bar {
    padding: 24px 24px 0;
    gap: 14px;
  }

  .project-heading {
    min-height: 40px;
  }

  .section-eyebrow {
    font-size: 12px;
  }

  h2#currentProjectName {
    font-size: 24px;
    line-height: 32px;
  }

  .project-tools > .btn {
    min-height: 38px;
    border-radius: 6px;
  }

  .btn.primary {
    background: var(--action-bg);
    border-color: var(--action-border);
    color: var(--action-text);
  }

  .btn.nav {
    background: var(--panel);
    border-color: var(--border);
    color: var(--text);
  }

  .stats {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 10px;
  }

  .metric-card {
    min-height: 82px;
    padding: 12px;
    border-radius: 8px;
    box-shadow: var(--shadow-soft) !important;
  }

  .metric-title {
    font-size: 13px;
    font-weight: 600;
  }

  .metric-value {
    font-size: 22px;
  }

  .metric-subtitle {
    font-size: 11px;
  }

  .metric-icon {
    width: 32px;
    height: 32px;
  }

  .metric-icon svg {
    width: 30px;
    height: 30px;
  }

  .metric-card.total {
    --metric-bg: var(--panel);
    --metric-border: var(--border);
  }

  .metric-card.todo {
    --metric-bg: var(--todo-bg);
    --metric-border: var(--border);
  }

  .metric-card.pending {
    --metric-bg: var(--amber-bg);
    --metric-border: var(--amber-border);
  }

  .metric-card.approved {
    --metric-bg: var(--green-bg);
    --metric-border: var(--green-border);
  }

  .metric-card.published {
    --metric-bg: var(--blue-bg);
    --metric-border: var(--blue-border);
  }

  .metric-card.rejected {
    --metric-bg: var(--red-bg);
    --metric-border: var(--red-border);
  }

  .views-topbar {
    padding: 8px;
    border-radius: 8px;
  }

  .views-topbar .category-button {
    min-height: 34px;
    padding: 0 10px;
  }

  .filters-topbar.topbar {
    min-height: 58px;
    padding: 8px;
    background: var(--panel-soft);
    border: 1px solid var(--border);
    border-radius: 8px;
    box-shadow: none;
    gap: 8px;
  }

  .filters-topbar .search-wrap,
  .filters-topbar .filter-toggle,
  .filters-topbar .sort-control .category-button,
  .canvas-view-toggle .view-toggle {
    min-height: 38px;
    background: var(--panel);
    box-shadow: var(--shadow-soft);
  }

  .filters-topbar .search-wrap {
    flex: 1 1 360px;
    min-width: 280px;
    max-width: 560px;
  }

  .filters-topbar .filter-panel {
    flex: 0 0 142px;
    min-width: 142px;
  }

  .filters-topbar .sort-control {
    flex: 0 0 184px;
    min-width: 184px;
    grid-template-columns: minmax(0, 1fr) 76px;
  }

  .filter-toggle-label,
  .search-wrap span {
    color: var(--text);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
  }

  .filter-toggle-value {
    font-weight: 600;
  }

  .canvas-view-toggle {
    margin-left: auto;
  }

  .canvas-view-toggle .view-toggle {
    height: 38px;
    overflow: hidden;
  }

  .canvas-view-toggle .view-button {
    min-height: 38px;
    padding: 0 13px;
  }

  .grid,
  .sheet-view {
    padding: 18px 24px 30px;
  }

  .sheet-view {
    overflow-x: auto;
  }

  .sheet-table {
    min-width: 1120px;
    border: 1px solid var(--border);
    border-radius: 8px;
    overflow: hidden;
    box-shadow: var(--shadow-soft);
  }

  .sheet-table th,
  .sheet-table td {
    padding: 14px 12px;
  }

  .sheet-table th {
    background: var(--panel);
    font-size: 11px;
    letter-spacing: 0.06em;
  }

  .sheet-row:hover td {
    background: var(--panel-soft);
  }

  .sheet-actions {
    opacity: 0;
    transform: translateX(3px);
    transition: opacity 0.14s ease, transform 0.14s ease;
    justify-content: flex-end;
  }

  .sheet-row:hover .sheet-actions,
  .sheet-row:focus-within .sheet-actions,
  .sheet-row.active .sheet-actions {
    opacity: 1;
    transform: translateX(0);
  }

  .sheet-table th:last-child {
    text-align: right;
  }

  .sheet-table td:last-child {
    padding-right: 16px;
  }

  .sheet-action {
    min-height: 28px;
    border-radius: 5px;
    background: var(--panel);
    border-color: var(--border);
  }

  .sheet-open {
    background: var(--green-bg);
    border-color: var(--green-border);
    color: var(--green-text);
  }

  .card {
    height: 300px;
    border-radius: 8px;
    box-shadow: var(--shadow-soft);
  }

  .card-thumb {
    height: 84px;
  }

  .site-actions {
    opacity: 0;
    transition: opacity 0.14s ease;
  }

  .card:hover .site-actions,
  .card:focus-within .site-actions {
    opacity: 1;
  }

  .drawer {
    left: 240px;
    background: var(--bg);
  }

  .drawer-header {
    min-height: 72px;
    background: var(--panel);
  }

  .drawer-body {
    width: 100%;
    max-width: var(--workspace-max);
    margin: 0;
    grid-template-columns: 220px minmax(0, 1fr);
  }

  @media (min-width: 1680px) {
    .project-bar {
      padding-left: 32px;
      padding-right: 32px;
    }

    .grid,
    .sheet-view {
      padding-left: 32px;
      padding-right: 32px;
    }

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

    .sheet-table {
      min-width: 1280px;
    }

    .filters-topbar .search-wrap {
      flex-basis: 460px;
    }
  }

  .settings-section,
  .settings-context,
  .site-browser,
  .site-editor {
    background: var(--panel);
    border-radius: 8px;
    box-shadow: var(--shadow-soft) !important;
  }

  .settings-menu-button {
    min-height: 42px;
    border-radius: 6px;
  }

  .settings-menu-button.active {
    background: var(--active-nav);
    border-color: var(--border);
  }

  .settings-context {
    box-shadow: var(--shadow-soft) !important;
  }

  .input,
  .textarea {
    background: var(--panel);
    border-radius: 6px;
  }

  .edit-modal,
  .auth-modal,
  .confirm-modal {
    border-radius: 8px;
    background: var(--panel);
  }

  .drawer-body,
  .settings-panels,
  .settings-section.sites-settings,
  .settings-section[data-settings-panel="sites"] {
    background: transparent;
    border: 0;
    box-shadow: none !important;
  }

  .settings-section.sites-settings {
    max-width: none;
  }

  .settings-context,
  .site-browser,
  .site-editor {
    background: color-mix(in oklch, var(--bg) 94%, var(--panel) 6%);
  }

  .settings-context {
    align-items: flex-start;
    padding: 16px 22px;
  }

  .settings-context h4 {
    margin: 0;
  }

  .settings-context .menu-label {
    padding: 0;
  }

  .settings-project-summary {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: baseline;
    column-gap: 10px;
    row-gap: 2px;
  }

  .settings-project-summary .settings-count {
    grid-column: 2;
  }

  .project-rename-form {
    display: grid;
    grid-template-columns: minmax(220px, 420px) auto;
    gap: 10px;
    align-items: end;
    margin: 12px 0 20px;
  }

  .project-rename-form .btn {
    min-height: var(--pill-height);
  }

  .priority-compact {
    display: grid;
    justify-items: center;
    text-align: center;
  }

  .priority-compact .input {
    width: 92px;
    padding-left: 0;
    padding-right: 0;
    text-align: center;
  }

  @media (max-width: 1180px) {
    .filters-topbar.topbar {
      flex-wrap: wrap;
    }

    .filters-topbar .search-wrap,
    .filters-topbar .filter-panel,
    .filters-topbar .sort-control {
      flex: 1 1 180px;
      min-width: 0;
    }
  }

  @media (max-width: 980px) {
    body {
      overflow: auto;
    }

    .app.controlled-ui {
      display: block;
      grid-template-columns: none;
      height: auto;
      min-height: 100vh;
      overflow: visible;
    }

    .sidebar {
      width: 100%;
      height: auto;
      max-height: none;
      position: static;
      border-right: 0;
      border-bottom: 1px solid var(--border);
    }

    .content {
      display: block;
      overflow: visible;
    }

    .drawer {
      left: 0;
    }

    .project-bar,
    .content > div {
      width: 100%;
    }

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

    .drawer-body {
      width: 100%;
      grid-template-columns: 1fr;
    }
  }

  @media (max-width: 640px) {
    body {
      overflow-x: hidden;
    }

    .sidebar {
      padding: 16px;
    }

    .project-bar,
    .content > div {
      max-width: none;
      width: 100%;
    }

    .project-bar {
      padding: 22px 16px 0;
      grid-template-columns: minmax(0, 1fr);
    }

    .project-bar > * {
      max-width: 100%;
      min-width: 0;
    }

    .project-header-actions,
    .project-actions {
      width: 100%;
    }

    .project-header-actions .btn,
    .project-actions .btn {
      flex: 1 1 auto;
      justify-content: center;
    }

    .project-rename-form {
      grid-template-columns: 1fr;
    }

    .stats {
      grid-template-columns: 1fr;
    }

    .project-heading {
      display: flex;
      flex-direction: column;
      align-items: stretch;
      min-width: 0;
      width: 100%;
    }

    .views-topbar .category-list {
      display: grid;
      grid-auto-flow: column;
      grid-auto-columns: max-content;
      overflow-x: auto;
      padding-bottom: 2px;
    }

    .filters-topbar.topbar {
      display: grid;
      grid-template-columns: 1fr;
      align-items: stretch;
      padding: 14px 16px;
    }

    .filters-topbar .search-wrap,
    .filters-topbar .filter-panel,
    .filters-topbar .sort-control,
    .canvas-view-toggle {
      flex: 1 1 100%;
      width: 100%;
      min-width: 0;
      max-width: none;
    }

    .canvas-view-toggle {
      margin-left: 0;
    }

    .canvas-view-toggle .view-toggle {
      width: 100%;
    }

    .canvas-view-toggle .view-button {
      flex: 1 1 0;
    }

    .grid,
    .sheet-view {
      padding: 16px;
    }

    .sheet-view {
      overflow: visible;
    }

    .sheet-table,
    .sheet-table tbody,
    .sheet-table tr,
    .sheet-table td {
      display: block;
      width: 100%;
      min-width: 0;
    }

    .sheet-table {
      border: 0;
      border-radius: 0;
      background: transparent;
      box-shadow: none;
      table-layout: auto;
    }

    .sheet-table colgroup,
    .sheet-table thead {
      display: none;
    }

    .sheet-table tbody {
      display: grid;
      gap: 10px;
    }

    .sheet-table tr.sheet-row {
      border: 1px solid var(--border);
      border-radius: 8px;
      background: var(--panel);
      box-shadow: var(--shadow-soft);
      padding: 12px;
    }

    .sheet-table tr.sheet-row:hover td {
      background: transparent;
    }

    .sheet-table td {
      border: 0;
      padding: 7px 0;
    }

    .sheet-table td:first-child {
      padding-top: 0;
    }

    .sheet-table td:last-child {
      padding-right: 0;
      padding-bottom: 0;
    }

    .sheet-table td:not(:first-child)::before {
      color: var(--muted);
      content: "";
      display: block;
      font-size: 10px;
      font-weight: var(--weight-medium);
      letter-spacing: 0.06em;
      margin-bottom: 4px;
      text-transform: uppercase;
    }

    .sheet-table td:nth-child(2)::before {
      content: "Priority";
    }

    .sheet-table td:nth-child(3)::before {
      content: "Channel";
    }

    .sheet-table td:nth-child(4)::before {
      content: "Status";
    }

    .sheet-table td:nth-child(5)::before {
      content: "Updated";
    }

    .sheet-table td:nth-child(6)::before {
      content: "Options";
    }

    .sheet-platform {
      align-items: flex-start;
    }

    .sheet-date-control {
      min-width: 0;
      width: 100%;
    }

    .sheet-actions,
    .site-actions {
      opacity: 1;
      transform: none;
    }

    .sheet-actions {
      justify-content: flex-start;
      flex-wrap: wrap;
    }
  }
