:root {
  color-scheme: light;
  --bg: #ffffff;
  --panel: #ffffff;
  --text: #171717;
  --muted: #6f7378;
  --border: #e5e7eb;
  --line: #e5e7eb;
  --brand: #000000;
  --accent: #0f766e;
  --danger: #b42318;
  --radius: 0;
}

* { box-sizing: border-box; }
body { margin: 0; font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; color: var(--text); background: var(--bg); font-size: 14px; }
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }
input, textarea, select {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 0;
  background: #fff;
  padding: 8px 12px;
  min-height: 40px;
}
textarea { resize: vertical; line-height: 1.5; }
label span, legend { display: block; font-size: 12px; font-weight: 700; color: #3f454b; margin-bottom: 5px; }
fieldset { border: 1px solid var(--line); border-radius: var(--radius); padding: 10px; margin: 0; }

.admin-app { min-height: 100vh; display: flex; }
.admin-sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  width: 224px;
  background: #fafafa;
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  padding: 16px 12px;
}
.brand-row { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 18px; padding: 0 2px; }
.brand { font-weight: 800; font-size: 16px; letter-spacing: 0; }
.sidebar-toggle { display: inline-flex; align-items: center; justify-content: center; width: 22px; height: 22px; border: 0; background: transparent; color: #6b7280; cursor: pointer; }
.sidebar-toggle svg { width: 14px; height: 14px; }
.admin-sidebar nav { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.nav-item { display: flex; align-items: center; gap: 10px; padding: 7px 2px; border-radius: 0; color: #262a2f; font-size: 14px; line-height: 1.25; }
.nav-icon { display: inline-flex; width: 16px; color: #777; flex: 0 0 16px; }
.nav-icon svg { width: 16px; height: 16px; }
.nav-item:hover, .nav-item.active { background: transparent; color: #000; }
.nav-item.active .nav-icon, .nav-item:hover .nav-icon { color: #000; }
.sidebar-footer { border-top: 1px solid var(--line); padding-top: 14px; margin-top: 14px; }
.sidebar-footer .nav-item { font-size: 14px; margin-bottom: 14px; }
.user-name { padding-left: 0; margin: 0 0 8px; font-size: 12px; }
.logout-button { border: 0; background: transparent; padding: 0; color: #000; text-decoration: underline; cursor: pointer; font-size: 12px; }
.version { margin-top: 28px; color: #9aa0a6; font-size: 10px; }
.admin-sidebar.is-collapsed { width: 64px; padding-left: 14px; padding-right: 14px; }
.admin-sidebar.is-collapsed .brand,
.admin-sidebar.is-collapsed .nav-item span:not(.nav-icon),
.admin-sidebar.is-collapsed .user-name,
.admin-sidebar.is-collapsed .logout-button,
.admin-sidebar.is-collapsed .version { display: none; }
.admin-sidebar.is-collapsed .brand-row { justify-content: center; }
.admin-sidebar.is-collapsed .sidebar-toggle svg { transform: rotate(180deg); }
.admin-sidebar.is-collapsed .nav-item { justify-content: center; }
.admin-main { flex: 1; min-width: 0; padding: 24px; background: #fff; }
.page-head { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin: 24px 0 18px; }
h1 { font-size: 24px; line-height: 1.2; margin: 0; letter-spacing: 0; font-weight: 800; }
h2 { font-size: 20px; margin: 0 0 14px; font-weight: 800; }
p { line-height: 1.55; }
.muted { color: var(--muted); }
.small { font-size: 12px; }
.tiny { font-size: 11px; }

.card {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px;
  margin-bottom: 16px;
  box-shadow: none;
}
.module-form-panel {
  display: grid;
  gap: 12px;
  max-width: 960px;
  margin-bottom: 18px;
  padding: 14px;
  border: 1px solid var(--border);
  background: #fafafa;
}
.module-form-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.module-form-head h2 { margin: 0; font-size: 14px; }
.module-grid { display: grid; gap: 10px; align-items: end; }
.module-grid.two-fields { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.module-grid.three-fields { grid-template-columns: minmax(110px, 160px) minmax(110px, 160px) minmax(120px, 180px); }
.module-team-grid { display: grid; grid-template-columns: 150px minmax(0, 1fr); gap: 18px; align-items: start; }
.module-photo-field > span { display: block; font-size: 12px; font-weight: 700; color: #3f454b; margin-bottom: 5px; }
.module-check { align-self: end; min-height: 40px; margin: 0; }
.module-limit { color: var(--muted); font-size: 12px; }
.module-filter { max-width: 260px; margin: 0 0 12px; }
.module-row-form { display: grid; grid-template-columns: 56px minmax(78px, 1fr) auto; gap: 6px; align-items: center; min-width: 210px; }
.module-row-form input[type="number"] { min-height: 30px; padding: 4px 6px; }
.module-row-form .check { margin: 0; white-space: nowrap; }
.module-badge { display: inline-flex; align-items: center; min-height: 22px; margin: 0 4px 4px 0; padding: 2px 7px; background: #e5e7eb; color: #374151; font-size: 11px; }
.module-badge.outline { background: #fff; border: 1px solid var(--border); }
.module-preview-text { max-width: 360px; color: #4b5563; font-size: 12px; }
.announcement-form { max-width: 680px; }
.code-textarea { font-family: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", monospace; font-size: 12px; }
.form-grid { display: grid; gap: 12px; }
.form-grid.compact { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); align-items: end; }
.inline-form { display: grid; grid-template-columns: minmax(180px, 1fr) minmax(180px, 1fr) auto; gap: 8px; align-items: end; }
.inline-form input { width: 100%; min-width: 0; }
.inline-action { display: inline-flex; gap: 6px; margin-left: 6px; }
.button-row { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.two-col { display: grid; grid-template-columns: 1fr; gap: 32px; align-items: start; max-width: 820px; }
.users-page, .profile-page { max-width: 920px; }
.users-create { margin-bottom: 18px; }
.users-create > summary { width: fit-content; list-style: none; }
.users-create > summary::-webkit-details-marker { display: none; }
.users-create-form { margin-top: 12px; }
.users-table-section { margin-top: 18px; }
.eyebrow-heading { font-size: 12px; text-transform: uppercase; color: #6f7378; margin-bottom: 8px; }
.user-edit-row td { background: #fafafa; padding: 14px 16px; }
.user-edit-form { display: grid; gap: 12px; }
.user-delete-row { margin-top: 8px; }
.profile-page .card { max-width: 680px; }
.profile-form { display: grid; gap: 8px; margin-top: 12px; }
.profile-form h3 { margin: 0 0 2px; font-size: 14px; }
.profile-form-split { border-top: 1px solid var(--line); padding-top: 14px; margin-top: 18px; }
.profile-app-form { display: grid; grid-template-columns: minmax(180px, 1fr) auto; gap: 8px; align-items: end; margin-bottom: 12px; }
.marketing-page { max-width: 1180px; }
.marketing-page .page-head { margin-top: 24px; }
.marketing-metrics { margin: 0 0 16px; max-width: 720px; }
.marketing-add-form,
.marketing-import-form,
.marketing-filter-form { max-width: 920px; }
.marketing-filter-form { background: #fff; }
.marketing-campaign-create { margin: 0 0 18px; }
.marketing-campaign-create > summary { width: fit-content; list-style: none; margin-bottom: 12px; }
.marketing-campaign-create > summary::-webkit-details-marker { display: none; }
.marketing-campaign-form,
.marketing-template-form { max-width: 920px; background: #fff; }
.marketing-rich-editor .editor-surface { min-height: 320px; }
.campaign-editor-grid { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 24px; align-items: start; }
.campaign-side { position: sticky; top: 24px; }
.campaign-side fieldset { display: grid; gap: 10px; }
.campaign-schedule-form { display: inline-grid; grid-template-columns: 148px auto; gap: 6px; align-items: center; margin-left: 6px; vertical-align: middle; }
.campaign-schedule-form input { min-height: 30px; padding: 4px 7px; font-size: 12px; }
.notice { margin: 0 0 12px; padding: 9px 10px; border: 1px solid var(--border); font-size: 13px; }
.notice.ok { background: #f0fdf4; border-color: #bbf7d0; color: #166534; }
.notice.danger { background: #fef2f2; border-color: #fecaca; color: #991b1b; }
.secret { display: block; width: 100%; padding: 10px 12px; border: 1px solid var(--border); background: #fff7ed; font-family: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", monospace; font-size: 14px; }
.select-all { user-select: all; }
.settings-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; align-items: start; }
.settings-page { max-width: 920px; }
.settings-form {
  display: grid;
  gap: 12px;
  max-width: 760px;
  padding: 0;
  background: #fff;
}
.settings-form fieldset { display: grid; gap: 10px; }
.settings-actions { border-top: 1px solid var(--line); padding-top: 12px; margin-top: 4px; }
.settings-test-form {
  display: grid;
  gap: 10px;
  max-width: 760px;
  margin-top: 16px;
  padding: 14px;
  border: 1px solid var(--border);
  background: #fafafa;
}
.settings-test-form h2 { font-size: 14px; margin: 0; }
.settings-diagnostic { max-width: 760px; }
.redirects-create-form { max-width: 920px; grid-template-columns: minmax(0, 1fr) auto; align-items: end; }
.redirects-create-form .module-grid { grid-template-columns: minmax(180px, 1fr) minmax(220px, 1fr) 90px; }
.redirects-table input, .redirects-table select { min-height: 32px; padding: 4px 7px; font-size: 12px; }
.redirects-table .check { min-height: 32px; margin: 0; }
.backup-settings-form { max-width: 820px; }
.editor-grid { display: grid; grid-template-columns: minmax(0, 1fr) 380px; gap: 24px; align-items: start; }
.wide { grid-column: 1 / -1; }
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  border: 1px solid var(--border);
  border-radius: 0;
  padding: 7px 14px;
  background: #fff;
  color: #111;
  cursor: pointer;
}
.button.primary { background: var(--brand); border-color: var(--brand); color: #fff; }
.button.danger { background: var(--danger); border-color: var(--danger); color: #fff; }
.button.small { min-height: 30px; padding: 5px 9px; font-size: 12px; }
.button.disabled { color: #9ca3af; background: #fff; pointer-events: none; }
.link-button { border: 0; background: transparent; padding: 4px 0; color: #4a5056; text-decoration: underline; cursor: pointer; }
.danger-text { color: var(--danger); }
.check { display: flex; align-items: center; gap: 8px; font-size: 13px; margin: 4px 0; }
.check input { width: auto; min-height: 0; accent-color: #a855f7; }
.section-tabs {
  display: flex;
  align-items: center;
  gap: 1px;
  overflow-x: auto;
  border-bottom: 1px solid var(--line);
  margin: 0;
}
.section-tab {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 40px;
  border-bottom: 2px solid transparent;
  padding: 0 16px 8px;
  color: #5f6368;
  font-size: 14px;
  line-height: 1;
  white-space: nowrap;
}
.section-tab:first-child { padding-left: 16px; }
.section-tab.active { border-bottom-color: #000; color: #000; font-weight: 700; }
.section-tab:not(.disabled):hover { color: #000; border-bottom-color: #9ca3af; }
.section-tab.disabled { cursor: default; opacity: .9; }
.tab-icon { display: inline-flex; color: currentColor; }
.tab-icon svg { width: 16px; height: 16px; }
.status-tabs { display: flex; gap: 10px; border-bottom: 1px solid var(--line); margin: 0 0 18px; }
.status-tab {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 0 12px 8px;
  border-bottom: 2px solid transparent;
  color: #6b7280;
  font-size: 14px;
}
.status-tab.active { color: #000; border-bottom-color: #000; font-weight: 700; }
.status-tab span { color: #9ca3af; font-weight: 600; }
.actions-cell { white-space: nowrap; }

.table-panel { border: 1px solid var(--border); background: #fff; }
.data-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.data-table th, .data-table td { border-bottom: 1px solid var(--line); padding: 10px 12px; text-align: left; vertical-align: middle; }
.data-table th { background: #f5f5f5; font-size: 12px; text-transform: uppercase; color: #737373; letter-spacing: 0; font-weight: 700; }
.data-table tr:last-child td { border-bottom: 0; }
.avatar { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; vertical-align: middle; }
.avatar.placeholder { display: inline-block; background: #e5e7eb; }
.badge { display: inline-flex; align-items: center; min-height: 24px; padding: 3px 8px; margin-right: 4px; font-size: 11px; font-weight: 700; }
.badge.default { background: #fef3c7; color: #92400e; }
.badge.draft { background: #e5e7eb; color: #374151; }
.badge.danger { background: #fee2e2; color: #991b1b; }
.media-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 14px; }
.media-card { background: #fff; border: 1px solid var(--border); border-radius: var(--radius); padding: 10px; display: grid; gap: 7px; }
.media-card img, .file-tile { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; border-radius: 6px; background: #eef1f3; display: grid; place-items: center; color: var(--muted); }
.is-hidden { display: none !important; }
.media-upload { margin-bottom: 24px; }
.media-upload fieldset { display: grid; gap: 12px; padding: 14px; }
.media-drop-zone {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  min-height: 92px;
  border: 1px dashed var(--border);
  background: #fff;
  padding: 16px;
}
.media-drop-zone.is-dragging { border-color: #000; background: #f7f7f7; }
.media-drop-zone input[type="file"] { display: none; }
.media-drop-zone p { margin: 4px 0 0; }
.media-workbench { display: grid; gap: 14px; }
.media-upload-modal .media-modal-panel { width: min(1040px, calc(100vw - 48px)); }
.media-upload-modal .media-workbench {
  grid-template-columns: 220px minmax(0, 1fr);
  align-items: start;
}
.media-bulk-list {
  display: grid;
  gap: 10px;
  border-right: 1px solid var(--line);
  padding-right: 12px;
}
.media-bulk-list [data-media-queue] { display: grid; gap: 6px; }
.media-queue-item {
  display: grid;
  gap: 3px;
  width: 100%;
  min-height: 44px;
  border: 1px solid var(--border);
  background: #fff;
  padding: 7px 8px;
  text-align: left;
  cursor: pointer;
}
.media-queue-item.is-active { border-color: #000; background: #f7f7f7; }
.media-queue-item span,
.media-queue-item small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.media-queue-item small { color: var(--muted); font-size: 11px; }
.media-bulk-editor { display: grid; gap: 14px; min-width: 0; }
.media-preview-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.media-preview-row figure {
  margin: 0;
  border: 1px solid var(--border);
  padding: 10px;
  background: #fff;
}
.media-preview-row figcaption { font-size: 12px; font-weight: 800; text-transform: uppercase; color: #737373; margin-bottom: 8px; }
.media-preview-row img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: contain;
  background: #f7f7f7;
  border: 1px solid var(--line);
}
.media-preview-row p {
  margin: 8px 0 0;
}
.media-info-chip {
  display: inline-grid;
  gap: 2px;
  min-width: 108px;
  margin: 0 6px 6px 0;
  padding: 6px 8px;
  border: 1px solid var(--border);
  background: #fff;
  vertical-align: top;
}
.media-info-chip b {
  font-size: 10px;
  line-height: 1.2;
  text-transform: uppercase;
  color: #737373;
}
.media-info-chip strong {
  font-size: 13px;
  line-height: 1.25;
  color: #111;
}
.media-info-chip.weight strong {
  font-size: 15px;
}
.media-info-chip.gain {
  border-color: #a7d7c5;
  background: #f2fbf7;
}
.media-info-chip.gain strong {
  color: #047857;
}
.media-form-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.media-optimizer-controls {
  display: grid;
  grid-template-columns: 74px 74px minmax(140px, 1fr) minmax(130px, 1fr) 128px;
  gap: 10px;
  align-items: end;
  border-top: 1px solid var(--line);
  padding-top: 12px;
}
.media-optimizer-controls .check { min-height: 40px; align-items: center; margin: 0; }
.media-optimizer-controls > label:nth-child(6) { grid-column: span 2; }
.media-target-size {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 6px;
}
.media-target-size span {
  min-width: 26px;
  color: var(--muted);
  font-size: 14px;
}
.media-apply-all { border-top: 1px solid var(--line); padding-top: 10px; }
.media-modal {
  position: fixed;
  inset: 0;
  z-index: 50;
  display: grid;
  place-items: center;
  padding: 24px;
}
.media-modal.is-hidden { display: none; }
.media-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, .35);
}
.media-modal-panel {
  position: relative;
  width: min(760px, 100%);
  max-height: calc(100vh - 48px);
  overflow: auto;
  background: #fff;
  border: 1px solid var(--border);
  padding: 16px;
  box-shadow: 0 18px 54px rgba(0, 0, 0, .18);
}
.media-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}
.media-modal-head h2 { margin: 0; font-size: 18px; }
.media-picker-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 6px; max-height: 220px; overflow: auto; }
.media-picker-grid.is-hidden { display: none; }
.media-modal .media-picker-grid { grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: 10px; max-height: none; overflow: visible; }
.media-modal .media-picker-grid > .muted { grid-column: 1 / -1; margin: 0; }
.media-pick { position: relative; border: 1px solid var(--border); background: #fff; border-radius: 6px; padding: 4px; cursor: pointer; display: grid; gap: 4px; text-align: left; }
.media-pick img { width: 100%; aspect-ratio: 1; object-fit: cover; border-radius: 4px; }
.media-pick span { font-size: 10px; color: var(--muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.media-pick.is-selected { outline: 2px solid var(--accent); border-color: var(--accent); }
.media-pick.is-selected::after {
  content: "✓";
  position: absolute;
  top: 6px;
  right: 6px;
  width: 22px;
  height: 22px;
  display: grid;
  place-items: center;
  background: #000;
  color: #fff;
  border: 1px solid #fff;
  font-size: 13px;
  font-weight: 800;
  line-height: 1;
}
.media-pick.is-pending::after { content: "1"; background: #374151; }
.unsaved-modal {
  position: fixed;
  inset: 0;
  z-index: 70;
  display: grid;
  place-items: center;
  padding: 24px;
}
.unsaved-modal.is-hidden { display: none; }
.unsaved-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, .35);
}
.unsaved-modal-panel {
  position: relative;
  width: min(440px, 100%);
  background: #fff;
  border: 1px solid var(--border);
  padding: 18px;
  box-shadow: 0 18px 54px rgba(0, 0, 0, .18);
}
.unsaved-modal-panel h2 {
  margin: 0 0 10px;
  font-size: 20px;
}
.unsaved-modal-panel p {
  margin: 0 0 16px;
  color: #4b5563;
}
.hidden-select { display: none; }
.featured-preview { width: 100%; border: 0; background: transparent; padding: 0; text-align: left; }
.featured-preview.empty {
  min-height: 48px;
  border: 1px dashed var(--border);
  display: grid;
  place-items: center;
  color: #737373;
  font-size: 14px;
  cursor: pointer;
}
.featured-preview.has-media {
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 12px;
  align-items: center;
}
.featured-preview.has-media img { width: 72px; height: 72px; object-fit: cover; background: #111; }
.featured-preview.has-media p { margin: 0 0 4px; line-height: 1.35; }
.featured-preview .link-button { margin-right: 10px; }
.mini-create { display: grid; grid-template-columns: minmax(0, 1fr) 32px; gap: 6px; margin-top: 8px; }
.mini-create .button { padding: 0; min-width: 32px; }
.taxonomy-layout { max-width: 780px; }
.taxonomy-block h2 { margin-bottom: 14px; }
.term-list-admin { margin-top: 12px; border: 1px solid var(--border); }
.term-row-admin { min-height: 38px; display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 8px 12px; border-bottom: 1px solid var(--line); }
.term-row-admin:last-child { border-bottom: 0; }
.term-chip-admin {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  border: 1px solid var(--border);
  padding: 4px 8px;
  margin: 0 4px 8px 0;
  background: #fff;
  color: #374151;
  font-size: 13px;
  cursor: pointer;
}
.term-chip-admin input { display: none; }
.term-chip-admin:has(input:checked) {
  border-color: #d1d5db;
  background: #f9fafb;
  color: #000;
}
[data-term-list] {
  border-bottom: 1px solid var(--line);
  margin-bottom: 12px;
  padding-bottom: 10px;
}
[data-term-list] .muted { margin: 0 0 8px; }
.editor-head { margin-bottom: 18px; }
.editor-main { min-width: 0; }
.editor-main > input[name="title"] { min-height: 42px; font-size: 18px; }
.editor-main > input[name="slug"] { min-height: 40px; }
.slug-row { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 10px; align-items: center; }
.field-title { font-size: 14px; font-weight: 700; color: #000; margin: 8px 0 -4px; }
.editor-sidebar { align-content: start; gap: 16px; }
.editor-sidebar fieldset, .seo-panel {
  border: 1px solid var(--border);
  padding: 14px;
  background: #fff;
}
.editor-sidebar legend, .seo-panel legend {
  color: #737373;
  text-transform: uppercase;
  font-size: 12px;
  font-weight: 800;
  padding: 0 4px;
}
.seo-panel { display: grid; gap: 12px; margin-top: 12px; }
.editor-subpanel { border-top: 1px solid var(--line); padding-top: 14px; display: grid; gap: 12px; }
.rich-editor { display: grid; gap: 8px; }
.editor-toolbar { display: flex; flex-wrap: wrap; gap: 4px; padding: 6px; border: 1px solid var(--border); border-radius: 0; background: #fff; }
.editor-toolbar button { border: 1px solid var(--border); background: #fff; border-radius: 0; min-width: 30px; min-height: 30px; padding: 4px 8px; cursor: pointer; }
.editor-toolbar button:hover { background: #f5f5f5; }
.editor-toolbar button.is-active { background: #000; border-color: #000; color: #fff; }
.editor-surface { min-height: 360px; border: 1px solid var(--border); border-top: 0; border-radius: 0; padding: 14px; background: #fff; line-height: 1.65; overflow: auto; }
.rich-editor textarea { display: none; font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; }
.rich-editor.is-code .editor-surface { white-space: pre-wrap; font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; }
.project-field-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.required-mark { color: var(--danger); }
.project-field-grid small,
.editor-sidebar label small {
  display: block;
  margin-top: 4px;
  color: #737373;
  font-size: 11px;
  line-height: 1.35;
}
.project-service-form {
  display: grid;
  grid-template-columns: minmax(160px, 1fr) minmax(140px, .75fr) minmax(180px, 1fr) auto;
  gap: 8px;
  align-items: end;
  border: 1px solid var(--border);
  padding: 10px;
}
.project-service-table { margin-top: 16px; }
.project-gallery-panel { display: grid; gap: 12px; }
.project-gallery-list { display: grid; gap: 8px; }
.project-gallery-row {
  display: grid;
  grid-template-columns: auto auto 56px minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  border: 1px solid var(--border);
  padding: 8px;
  background: #fff;
}
.project-pair-row { grid-template-columns: 56px auto 56px minmax(0, 1fr) auto; }
.project-row-handle {
  width: 24px;
  min-height: 28px;
  border: 1px solid var(--border);
  background: #fff;
  cursor: pointer;
}
.project-thumb {
  width: 56px;
  height: 56px;
  object-fit: cover;
  background: #f3f4f6;
}
.project-thumb.placeholder {
  display: grid;
  place-items: center;
  border: 1px solid var(--border);
  color: #737373;
  font-size: 10px;
  text-align: center;
}
.project-remove-button { color: var(--danger); }
.project-details {
  border: 1px solid var(--border);
  background: #fff;
}
.project-details summary {
  cursor: pointer;
  padding: 10px 12px;
  font-weight: 700;
}
.project-details-body {
  border-top: 1px solid var(--line);
  padding: 12px;
  display: grid;
  gap: 12px;
}
.google-preview { border: 1px solid #d9e2ef; border-radius: 6px; padding: 12px; background: #fbfdff; display: grid; gap: 3px; }
.google-preview strong { color: #1a0dab; font-size: 17px; font-weight: 500; }
.google-preview span { color: #0b8043; font-size: 13px; }
.google-preview p { margin: 0; color: #4d5156; font-size: 13px; }
.metric-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; margin-bottom: 16px; }
.metric { background: #fff; border: 1px solid var(--border); border-radius: var(--radius); padding: 14px; }
.metric span { display: block; color: var(--muted); font-size: 12px; margin-bottom: 7px; }
.metric strong { font-size: 26px; }
.stats-page { display: grid; gap: 18px; }
.stats-period-form select { min-width: 138px; }
.stats-metrics { grid-template-columns: repeat(5, minmax(0, 1fr)); margin-bottom: 0; }
.stats-state {
  border: 1px solid var(--border);
  background: #fff;
  padding: 22px 24px;
  max-width: 760px;
}
.stats-state h2 { margin: 0 0 8px; font-size: 22px; }
.stats-state p { margin: 0 0 14px; color: var(--muted); }
.stats-settings-panel {
  border: 1px solid var(--border);
  background: #fff;
  padding: 14px 16px;
}
.stats-settings-panel form { margin: 0; }
.stats-settings-panel fieldset { display: grid; gap: 12px; padding: 0; border: 0; }
.stats-settings-panel textarea { max-width: 560px; }
.stats-reset-form { margin-top: 10px !important; border-top: 1px solid var(--line); padding-top: 10px; }
.stats-settings-panel.gsc-settings-panel summary {
  cursor: pointer;
  display: grid;
  gap: 4px;
  list-style: none;
  padding: 2px 0;
}
.stats-settings-panel.gsc-settings-panel summary::-webkit-details-marker { display: none; }
.stats-settings-panel.gsc-settings-panel summary span { font-weight: 700; }
.stats-settings-panel.gsc-settings-panel summary span::before { content: "▸ "; color: var(--muted); }
.stats-settings-panel.gsc-settings-panel[open] summary span::before { content: "▾ "; }
.stats-settings-panel.gsc-settings-panel summary small { color: var(--muted); font-size: 12px; font-weight: 400; }
.stats-settings-panel.gsc-settings-panel[open] summary { border-bottom: 1px solid var(--line); margin-bottom: 14px; padding-bottom: 10px; }
.gsc-settings-panel textarea { max-width: none; font-family: ui-monospace, SFMono-Regular, Consolas, monospace; font-size: 12px; }
.gsc-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin: 10px 0 14px;
}
.gsc-summary-grid > div {
  border: 1px solid var(--line);
  padding: 9px 10px;
  min-width: 0;
}
.gsc-summary-grid strong {
  display: block;
  margin-top: 4px;
  font-size: 13px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.gsc-settings-form { display: grid; gap: 12px; }
.stats-chart-panel {
  border: 1px solid var(--border);
  background: #fff;
  padding: 14px 16px 10px;
}
.stats-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 12px;
}
.stats-panel-head h2 { margin: 0; font-size: 18px; }
.stats-chart-controls { display: flex; gap: 8px; }
.stats-chart-controls select { min-width: 130px; min-height: 34px; font-size: 13px; }
.stats-chart-stage { min-height: 260px; }
.stats-chart-stage svg { width: 100%; min-height: 260px; display: block; }
.stats-chart-grid { stroke: #e5e7eb; stroke-width: 1; }
.stats-chart-line { fill: none; stroke-width: 2.4; stroke-linecap: round; stroke-linejoin: round; }
.stats-chart-line.primary { stroke: #000; }
.stats-chart-line.secondary { stroke: #6b7280; stroke-dasharray: 4 4; }
.stats-chart-labels text,
.stats-chart-legend text { fill: #6b7280; font-size: 12px; }
.primary-dot { fill: #000; }
.secondary-dot { fill: #6b7280; }
.stats-grid-two { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; align-items: start; }
.stats-table-panel { overflow: auto; }
.stats-table-wide { grid-column: 1 / -1; }
.stats-table-panel .stats-panel-head { padding: 12px 12px 0; margin-bottom: 8px; }
.stats-sortable th[data-sort-key] { cursor: pointer; user-select: none; }
.stats-sortable th[data-current-dir]::after { content: " ↓"; color: #111; }
.stats-sortable th[data-current-dir="asc"]::after { content: " ↑"; }
.stats-key { max-width: 420px; word-break: break-word; }
.diag { display: grid; grid-template-columns: 150px 1fr; gap: 8px; margin: 0; font-size: 13px; }
.diag dt { color: var(--muted); }
.diag dd { margin: 0; }
.secret { background: #111827; color: #e5e7eb; padding: 14px; border-radius: 6px; overflow: auto; }
.field-label { display: block; font-size: 12px; font-weight: 700; color: #3f454b; margin-bottom: 5px; }
.notice { border: 1px solid var(--border); padding: 10px 12px; margin-bottom: 12px; font-size: 13px; }
.notice span { display: block; margin-top: 3px; }
.notice.ok { border-color: #bbf7d0; background: #f0fdf4; color: #166534; }
.notice.warn { border-color: #fcd34d; background: #fffbeb; color: #92400e; }
.notice.danger { border-color: #fecaca; background: #fef2f2; color: #991b1b; }
.ok-text { color: #166534; }
.info-text { color: #0e7490; }
.booking-manager { display: grid; grid-template-columns: minmax(0, 1fr) 340px; gap: 24px; align-items: start; margin-bottom: 18px; }
.booking-calendar-panel,
.booking-create-panel,
.booking-config-panel,
.booking-connection-form,
.booking-settings-form,
.booking-type-row {
  border: 1px solid var(--border);
  background: #fff;
}
.booking-create-panel,
.booking-connection-form,
.booking-settings-form,
.booking-type-row { display: grid; gap: 12px; padding: 14px; }
.booking-toolbar,
.booking-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid var(--line);
  background: #fafafa;
  padding: 10px 12px;
}
.booking-toolbar h2,
.booking-panel-head h2 { margin: 0; font-size: 15px; text-transform: none; }
.booking-view-switch { display: inline-flex; border: 1px solid var(--border); }
.booking-view-switch button { border: 0; background: #fff; min-height: 30px; padding: 5px 10px; cursor: pointer; }
.booking-view-switch button.is-active { background: #000; color: #fff; }
.booking-calendar {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  border-top: 0;
}
.booking-calendar-day { grid-template-columns: 1fr; }
.booking-calendar-week { grid-template-columns: repeat(7, minmax(0, 1fr)); }
.booking-day-head {
  padding: 8px;
  border-bottom: 1px solid var(--line);
  border-right: 1px solid var(--line);
  background: #fafafa;
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
  text-align: center;
}
.booking-day {
  min-height: 108px;
  border: 0;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: #fff;
  padding: 8px;
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 4px;
  cursor: pointer;
}
.booking-calendar-day .booking-day { min-height: 320px; }
.booking-day.is-selected { outline: 2px solid #000; outline-offset: -2px; background: #fafafa; }
.booking-day.is-muted { color: #9ca3af; }
.booking-day strong { align-self: flex-end; font-size: 13px; }
.booking-event {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  border: 1px solid var(--border);
  padding: 2px 5px;
  font-size: 11px;
}
.booking-event.ok,
.booking-status.ok { background: #dcfce7; border-color: #bbf7d0; color: #166534; }
.booking-event.warn,
.booking-status.warn { background: #fef3c7; border-color: #fde68a; color: #92400e; }
.booking-event.error,
.booking-status.error { background: #fee2e2; border-color: #fecaca; color: #991b1b; }
.booking-event.neutral,
.booking-status.neutral { background: #f3f4f6; border-color: #e5e7eb; color: #4b5563; }
.booking-event.busy { background: #ecfeff; border-color: #cffafe; color: #0e7490; }
.booking-free { border: 1px dashed var(--border); color: var(--muted); padding: 14px; text-align: center; font-size: 12px; }
.booking-slots { display: flex; flex-wrap: wrap; gap: 6px; min-height: 36px; }
.booking-slot.is-selected { background: #000; border-color: #000; color: #fff; }
.booking-busy-list { min-height: 36px; border: 1px solid var(--border); background: #fafafa; padding: 8px; font-size: 12px; color: #4b5563; }
.booking-message { max-width: 240px; margin-top: 4px; }
.booking-attachments-list { margin: 6px 0 0; padding-left: 16px; }
.booking-attachments-list li { margin: 2px 0; }
.booking-status { display: inline-flex; align-items: center; min-height: 22px; border: 1px solid var(--border); padding: 2px 7px; font-size: 11px; font-weight: 700; }
.booking-table-panel { margin-top: 18px; }
.booking-type-add { background: #fff; max-width: none; }
.booking-type-list { display: grid; gap: 12px; max-width: 1120px; }
.booking-type-grid { grid-template-columns: minmax(0, 1fr) minmax(170px, 240px) 110px 110px; }
.booking-type-grid.bottom { grid-template-columns: 120px 150px minmax(180px, 1fr) minmax(180px, 1fr) 90px; }
.booking-availability-form { display: grid; gap: 16px; max-width: 1120px; }
.booking-rule-list { display: grid; gap: 0; }
.booking-rule-row {
  display: grid;
  grid-template-columns: 180px 120px 120px minmax(110px, 1fr) auto;
  gap: 8px;
  align-items: end;
  border-bottom: 1px solid var(--line);
  padding: 10px 12px;
}
.booking-override-row { grid-template-columns: 130px 150px 105px 105px minmax(160px, 1fr) auto; }
.booking-empty-row { padding: 14px; }
.booking-settings-grid { grid-template-columns: minmax(220px, 1fr) 140px 140px 150px; }
.booking-security-grid { grid-template-columns: 120px 160px 140px 160px; }
.diagnostic-list { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; margin: 10px 0 0; }
.diagnostic-list div { border: 1px solid var(--border); padding: 8px; }
.diagnostic-list dt { font-size: 11px; color: var(--muted); text-transform: uppercase; font-weight: 700; }
.diagnostic-list dd { margin: 2px 0 0; font-size: 13px; }
.booking-email-form { margin-top: 16px; max-width: 900px; }
.booking-email-rich-editor .editor-surface { min-height: 300px; }
.booking-email-rich-editor .placeholder-picker { margin: 12px 0; }

.public-body { background: #fff; }
.site-header { display: flex; justify-content: space-between; align-items: center; padding: 18px 24px; border-bottom: 1px solid var(--line); }
.site-logo { font-weight: 800; }
.site-header nav { display: flex; gap: 16px; color: var(--muted); }
.site-footer { border-top: 1px solid var(--line); margin-top: 48px; padding: 24px; color: var(--muted); }
.public-page { max-width: 920px; margin: 0 auto; padding: 56px 24px; }
.public-page.centered { min-height: 55vh; display: grid; place-content: center; text-align: center; }
.post-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 16px; margin-top: 24px; }
.post-card { border: 1px solid var(--border); border-radius: var(--radius); padding: 16px; }
.post-card h2 { font-size: 18px; }
.article { max-width: 760px; }
.hero-img { width: 100%; max-height: 420px; object-fit: cover; border-radius: var(--radius); margin-bottom: 24px; }
.prose { line-height: 1.7; }
.prose img { max-width: 100%; height: auto; }
.term-row { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; }
.term-chip { display: inline-flex; align-items: center; min-height: 24px; border: 1px solid #c8d8d4; border-radius: 999px; padding: 3px 9px; color: #0f766e; font-size: 12px; background: #f2fbf8; }
.article-hero h1 { font-size: 48px; line-height: 1.05; margin-bottom: 12px; }
.article-summary, .article-toc, .author-bio, .article-cta { border: 1px solid var(--border); border-radius: var(--radius); padding: 16px; margin: 24px 0; background: #fbfbfc; }
.article-toc ol { margin: 0; padding-left: 20px; }
.toc-level-3 { margin-left: 18px; }
.author-bio { display: grid; grid-template-columns: 72px 1fr; gap: 14px; align-items: start; }
.author-bio img { width: 72px; height: 72px; border-radius: 50%; object-fit: cover; }
.author-links { display: flex; flex-wrap: wrap; gap: 10px; }
.article-cta { background: #111827; color: #fff; }
.article-cta .eyebrow { color: #9dd7cc; font-size: 12px; text-transform: uppercase; font-weight: 800; }
.article-cta .button { color: #111; }
.article-cta .button.primary { background: #0f766e; border-color: #0f766e; color: #fff; }
.project-public-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin: 18px 0;
}
.project-public-meta div { border: 1px solid var(--border); padding: 10px; }
.project-public-meta dt { color: var(--muted); font-size: 12px; }
.project-public-meta dd { margin: 2px 0 0; font-weight: 700; }
.project-public-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px;
  margin: 12px 0 24px;
}
.project-public-gallery figure { margin: 0; }
.project-public-gallery img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; }
.project-public-gallery figcaption { color: var(--muted); font-size: 12px; margin-top: 5px; }
.project-before-after { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 4px; }
.status-badge { display: inline-flex; padding: 5px 9px; border: 1px solid #f6c453; border-radius: 999px; background: #fff8dc; color: #7a4b00; font-size: 12px; }
.legal-page { max-width: 780px; }
.install-wrap, .login-wrap { width: min(460px, calc(100% - 32px)); margin: 10vh auto; background: #fff; border: 1px solid var(--border); border-radius: var(--radius); padding: 24px; }
.pressai-announcement {
  position: fixed;
  inset: 0;
  z-index: 9200;
  display: grid;
  place-items: center;
  padding: 16px;
  background: rgba(0, 0, 0, .55);
}
.pressai-announcement-panel {
  width: min(520px, 100%);
  max-height: 90vh;
  overflow: auto;
  background: #fff;
  color: #111;
  border: 1px solid var(--border);
  padding: 28px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, .25);
}
.pressai-announcement-panel h2 { font-size: 24px; margin: 0 0 12px; }
.pressai-announcement-content { line-height: 1.65; }
.pressai-announcement-actions { display: flex; justify-content: flex-end; margin-top: 20px; }
.booking-widget { border: 1px solid var(--border); padding: 22px; margin: 24px 0; background: #fff; }
.booking-widget__form { display: grid; gap: 14px; }
.booking-widget__form h2 { margin: 0; }
.booking-widget__form label { display: grid; gap: 5px; }
.booking-widget__grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.booking-widget__slots { display: flex; flex-wrap: wrap; gap: 8px; min-height: 38px; }
.booking-widget__slots button,
.booking-widget__form > button { border: 1px solid var(--border); background: #fff; min-height: 36px; padding: 8px 12px; cursor: pointer; }
.booking-widget__slots button.is-selected,
.booking-widget__form > button { background: #000; border-color: #000; color: #fff; }
.booking-widget__form > button:disabled { opacity: .45; cursor: default; }
.booking-widget__hint,
.booking-widget__success { color: var(--muted); margin: 0; }
.booking-widget__error { color: var(--danger); margin: 0; }
.booking-widget__attachments small { color: var(--muted); font-size: 12px; }
.booking-widget__consent { display: flex !important; grid-template-columns: auto 1fr; align-items: start; }
.booking-widget__consent input { width: auto; min-height: 0; margin-top: 4px; }

.legal-entity-form,
.legal-page-form,
.legal-consent-form {
  max-width: 980px;
  display: grid;
  gap: 18px;
}
.legal-entity-form fieldset,
.legal-page-form fieldset,
.legal-consent-form fieldset,
.legal-cookie-page-link {
  border: 1px solid var(--border);
  background: #fff;
  padding: 14px;
}
.legal-entity-form legend,
.legal-page-form legend,
.legal-consent-form legend {
  padding: 0 6px;
  color: #737373;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}
.four-fields { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.legal-locale-bar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin: 14px 0 20px;
}
.legal-rich-editor .editor-surface { min-height: 390px; }
.placeholder-picker {
  border: 1px solid var(--border);
  padding: 8px 10px;
  background: #fff;
}
.placeholder-picker summary {
  cursor: pointer;
  font-size: 13px;
  font-weight: 700;
}
.placeholder-picker div {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding-top: 8px;
}
.placeholder-picker button {
  border: 1px solid var(--border);
  background: #fff;
  padding: 5px 8px;
  font-size: 12px;
  cursor: pointer;
}
.legal-category-row,
.consent-script-row {
  border: 1px solid var(--border);
  background: #fff;
  padding: 12px;
  margin-bottom: 10px;
}
.consent-script-row.is-system { background: #eff6ff; border-color: #bfdbfe; }
.consent-add-script { margin-top: 10px; }
.code-textarea { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; font-size: 12px; }
.manage-cookies-link {
  margin-left: 12px;
  border: 0;
  background: transparent;
  color: inherit;
  text-decoration: underline;
  cursor: pointer;
}
.pressai-cookie-banner {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 9000;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 20px;
  align-items: center;
  padding: 16px 22px;
  background: rgba(17, 17, 17, .96);
  color: #fff;
  box-shadow: 0 -10px 30px rgba(0,0,0,.25);
}
.pressai-cookie-copy strong { display: block; margin-bottom: 4px; }
.pressai-cookie-copy p { margin: 0; color: rgba(255,255,255,.72); font-size: 13px; line-height: 1.5; }
.pressai-cookie-actions { display: flex; gap: 8px; justify-content: flex-end; flex-wrap: wrap; }
.pressai-cookie-actions button,
.pressai-cookie-dialog button {
  min-height: 34px;
  border: 1px solid rgba(255,255,255,.35);
  background: transparent;
  color: inherit;
  padding: 7px 12px;
  cursor: pointer;
}
.pressai-cookie-actions button:last-child,
.pressai-cookie-dialog [data-consent-save] {
  background: #fff;
  border-color: #fff;
  color: #000;
}
.pressai-cookie-modal {
  position: fixed;
  inset: 0;
  z-index: 9100;
  display: grid;
  place-items: center;
  padding: 20px;
  background: rgba(0,0,0,.62);
}
.pressai-cookie-dialog {
  width: min(640px, 100%);
  max-height: 90vh;
  overflow: auto;
  background: #111;
  color: #fff;
  padding: 22px;
}
.pressai-cookie-dialog header { display: flex; justify-content: space-between; gap: 16px; align-items: start; }
.pressai-cookie-dialog h2 { margin: 0; font-size: 22px; }
.pressai-cookie-choice {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  border: 1px solid rgba(255,255,255,.16);
  padding: 12px;
  margin: 10px 0;
}
.pressai-cookie-choice small { display: block; color: rgba(255,255,255,.7); line-height: 1.45; margin-top: 4px; }
@media (max-width: 760px) {
  .four-fields { grid-template-columns: 1fr 1fr; }
  .pressai-cookie-banner { grid-template-columns: 1fr; }
  .pressai-cookie-actions { justify-content: stretch; }
  .pressai-cookie-actions button { flex: 1 1 auto; }
}
@media (max-width: 560px) {
  .four-fields { grid-template-columns: 1fr; }
}
.booking-widget__hp { position: absolute; left: -9999px; width: 1px; height: 1px; opacity: 0; }

@media (max-width: 860px) {
  .admin-app { display: block; }
  .admin-sidebar { position: static; width: auto; height: auto; padding: 18px; }
  .brand-row { margin-bottom: 12px; }
  .admin-sidebar nav { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
  .nav-item, .sidebar-footer .nav-item { font-size: 16px; gap: 10px; }
  .nav-icon svg { width: 18px; height: 18px; }
  .admin-main { padding: 16px; }
  .media-modal { padding: 12px; }
  .media-upload-modal .media-modal-panel { width: calc(100vw - 24px); }
  .two-col, .settings-grid, .editor-grid, .metric-grid, .stats-grid-two, .gsc-summary-grid, .module-grid.two-fields, .module-grid.three-fields, .module-team-grid, .profile-app-form, .campaign-editor-grid, .campaign-schedule-form { grid-template-columns: 1fr; }
  .stats-table-wide { grid-column: auto; }
  .stats-panel-head, .stats-chart-controls { align-items: flex-start; flex-direction: column; }
  .campaign-side { position: static; }
  .media-form-grid, .media-optimizer-controls, .media-preview-row, .media-drop-zone, .media-upload-modal .media-workbench { grid-template-columns: 1fr; }
  .media-optimizer-controls > label:nth-child(6) { grid-column: auto; }
  .module-row-form { grid-template-columns: 1fr; }
  .media-bulk-list { border-right: 0; border-bottom: 1px solid var(--line); padding-right: 0; padding-bottom: 12px; }
  .project-service-form, .project-field-grid, .slug-row, .project-public-meta { grid-template-columns: 1fr; }
  .project-gallery-row, .project-pair-row { grid-template-columns: 56px minmax(0, 1fr); }
  .project-gallery-row .link-button { grid-column: 1 / -1; justify-self: start; }
  .booking-manager,
  .booking-type-grid,
  .booking-type-grid.bottom,
  .booking-settings-grid,
  .booking-security-grid,
  .diagnostic-list,
  .booking-rule-row,
  .booking-override-row { grid-template-columns: 1fr; }
  .booking-calendar,
  .booking-calendar-week,
  .booking-widget__grid { grid-template-columns: 1fr; }
  .booking-day-head { display: none; }
  .booking-toolbar,
  .booking-panel-head { align-items: flex-start; flex-direction: column; }
  .page-head { display: block; }
  .section-tab { font-size: 16px; padding-inline: 10px; }
  .status-tab { font-size: 16px; padding-inline: 8px; }
  .data-table { font-size: 15px; }
  .data-table th, .data-table td { padding: 10px; }
  .article-hero h1 { font-size: 34px; }
  .author-bio { grid-template-columns: 1fr; }
}
