body.tenant-admin-page{margin:0;min-height:100vh;background:#f4efe7;color:#171717}.tenant-admin-public-header{background:var(--tenant-topbar-bg,#f7f2e8)!important;color:var(--tenant-topbar-text,#111)!important}.tenant-admin-shell{display:grid;grid-template-columns:270px minmax(0,1fr);min-height:calc(100vh - 150px)}.tenant-admin-sidebar{padding:24px 18px;background:#111;color:#fff;border-right:1px solid rgba(255,255,255,.08)}.tenant-admin-sidebar-title{display:grid;gap:4px;margin-bottom:22px}.tenant-admin-sidebar-title strong{font-size:1.5rem;letter-spacing:-.04em}.tenant-admin-sidebar-title span{color:rgba(255,255,255,.68);font-size:.92rem}.tenant-admin-sidebar nav{display:grid;gap:7px}.tenant-admin-sidebar a{display:block;padding:10px 12px;border-radius:11px;color:#fff;text-decoration:none}.tenant-admin-sidebar a:hover,.tenant-admin-sidebar a.active{background:rgba(255,255,255,.14)}.tenant-admin-main{min-width:0;padding:28px}.tenant-admin-main-header{display:flex;justify-content:space-between;gap:16px;max-width:1200px;margin:0 auto 18px}.tenant-admin-panel{max-width:1200px;margin:0 auto;padding:32px;border:1px solid rgba(0,0,0,.10);border-radius:24px;background:rgba(255,255,255,.92);box-shadow:0 24px 70px rgba(0,0,0,.06);overflow-x:auto}.tenant-admin-panel h1{margin:0 0 24px;font-size:clamp(2rem,5vw,4rem);line-height:.92;letter-spacing:-.08em}.dashboard-grid,.admin-card-grid{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))!important;gap:18px!important}.dashboard-card,.admin-card{display:block!important;position:static!important;min-height:124px!important;padding:22px!important;border:1px solid rgba(0,0,0,.10)!important;border-radius:18px!important;background:#fff!important;color:#171717!important;text-decoration:none!important;box-shadow:0 10px 28px rgba(0,0,0,.06)!important}.dashboard-card h3,.dashboard-card p,.admin-card h3,.admin-card p{position:static!important;margin-left:0!important}.admin-toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:end;margin:0 0 18px;padding:16px;border-radius:16px;background:#fff;border:1px solid rgba(0,0,0,.08)}.admin-form,.tenant-admin-panel form{display:grid;gap:18px}.admin-form-grid{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))!important;gap:18px!important}.admin-form-grid.three{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))!important}.admin-panel,fieldset{min-width:0!important;padding:20px!important;border:1px solid rgba(0,0,0,.12)!important;border-radius:18px!important;background:#fff!important}.admin-panel-wide{grid-column:1 / -1!important}.admin-form label,.admin-panel label,fieldset label,.admin-toolbar label{display:grid!important;gap:8px!important;font-weight:800!important}.admin-form input,.admin-form select,.admin-form textarea,.admin-panel input,.admin-panel select,.admin-panel textarea,fieldset input,fieldset select,fieldset textarea,.admin-toolbar input,.admin-toolbar select{width:100%!important;max-width:100%!important;box-sizing:border-box!important;padding:12px!important;border:1px solid #cfc7ba!important;border-radius:12px!important;background:#fff!important;font:inherit!important}.admin-form textarea,.admin-panel textarea,fieldset textarea{min-height:150px!important;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace!important}.admin-form button,.admin-panel button,fieldset button,.tenant-admin-panel button,.admin-toolbar button{padding:12px 18px!important;border:0!important;border-radius:999px!important;background:#111!important;color:#fff!important;font-weight:900!important;cursor:pointer!important}.admin-notice,.notice{padding:12px 16px!important;border-radius:12px!important;background:#eef8ee!important;border:1px solid #99c999!important}.admin-error,.error{padding:12px 16px!important;border-radius:12px!important;background:#fff0f0!important;border:1px solid #d88!important}.admin-table-wrap{width:100%!important;overflow-x:auto!important;border:1px solid rgba(0,0,0,.08)!important;border-radius:16px!important;background:#fff!important}.admin-table,.audit-table,.tenant-admin-panel table{width:100%!important;min-width:860px!important;border-collapse:collapse!important;table-layout:auto!important}.admin-table th,.admin-table td,.audit-table th,.audit-table td,.tenant-admin-panel th,.tenant-admin-panel td{padding:12px!important;border-bottom:1px solid rgba(0,0,0,.08)!important;vertical-align:top!important;text-align:left!important;white-space:normal!important}.admin-table th,.audit-table th,.tenant-admin-panel th{background:#efe9df!important;text-transform:uppercase!important;font-size:.78rem!important;letter-spacing:.08em!important}.tenant-admin-footer{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;border-top:1px solid rgba(0,0,0,.08)}.tenant-admin-footer nav{display:flex;gap:14px;flex-wrap:wrap}@media(max-width:900px){.tenant-admin-shell{grid-template-columns:1fr}.tenant-admin-sidebar{border-right:0}.tenant-admin-main{padding:16px}.tenant-admin-panel{padding:20px}}

/* Inline-admin conversion safety layer. */
.tenant-admin-panel > nav:first-child,
.tenant-admin-panel > p:first-child {
  margin-top: 0;
}

.tenant-admin-panel .admin-shell,
.tenant-admin-panel main.admin-shell {
  display: block !important;
  min-height: auto !important;
  padding: 0 !important;
  background: transparent !important;
}

.tenant-admin-panel header,
.tenant-admin-panel .admin-header {
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
}

.tenant-admin-panel .admin-shell > * {
  max-width: 100% !important;
}

.tenant-admin-panel a[href="/admin"] {
  font-weight: 800;
}

/* End inline-admin conversion safety layer. */

.tenant-admin-main-header:empty{display:none!important}.tenant-admin-main-header{justify-content:flex-end!important}

.admin-billing-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;margin-bottom:1rem}.billing-price{font-size:2rem;font-weight:950;margin:.25rem 0 1rem}.admin-button{display:inline-flex;padding:.75rem 1rem;border-radius:999px;background:#111;color:#fff;text-decoration:none;font-weight:900}

/* Larger admin logos and platform/help shell adjustments. */
.platform-admin-header .platform-admin-logo,
.platform-help-header .platform-help-logo {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
}

.platform-admin-page .tenant-admin-panel,
.platform-help-page .tenant-admin-panel {
  max-width: 1240px;
}

/* End larger admin logos and platform/help shell adjustments. */

/* Route/UI hotfix: admin logo and dashboard cards. */
.tenant-admin-public-header .brand img,
.tenant-admin-public-header .logo-brand img,
.site-header.tenant-admin-public-header img {
    max-height: 72px;
    width: auto;
}

.admin-card-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    margin-top: 1.25rem;
}

.admin-card {
    display: block;
    padding: 1.1rem;
    border: 1px solid rgba(0, 0, 0, 0.12);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.78);
    color: inherit;
    text-decoration: none;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.06);
}

.admin-card:hover,
.admin-card:focus {
    transform: translateY(-1px);
    border-color: rgba(0, 0, 0, 0.24);
}

.admin-card h2 {
    margin-top: 0;
    margin-bottom: 0.4rem;
    font-size: 1.1rem;
}

.admin-card p {
    margin: 0;
}

.inline-form {
    display: inline;
}

.inline-form button {
    font: inherit;
}


/* Tenant visual correction shared with public header. */
.tenant-admin-public-header{isolation:isolate;background-color:var(--topbar-bg-overlay,var(--tenant-topbar-bg,rgba(255,248,236,.86)))!important;background-image:var(--topbar-bg-image);background-position:center;background-size:cover;background-repeat:no-repeat}.tenant-admin-public-header::before{z-index:0;background-color:var(--topbar-bg-overlay,rgba(255,248,236,.86));background-image:none}.tenant-admin-public-header>*{position:relative;z-index:1}.tenant-admin-panel{background-color:var(--content-bg-overlay,rgba(255,250,240,0))!important;box-shadow:0 20px 60px rgba(0,0,0,calc(var(--content-bg-opacity,0) * .10))}
/* End tenant visual correction shared with public header. */



/* Tenant typography preview repair. Keep font previews readable and make live
   changes visible immediately when the select or size field changes. */
.tenant-admin-panel .tenant-typography-grid .font-picker-preview,
.tenant-typography-grid .font-picker-preview {
  display: block !important;
  min-height: 2.25rem !important;
  margin-top: 0.35rem !important;
  padding: 0.55rem 0.7rem !important;
  border: 1px solid rgba(0, 0, 0, 0.18) !important;
  border-radius: 12px !important;
  background: rgba(255, 255, 255, 0.88) !important;
  color: #1f1a14 !important;
  line-height: 1.25 !important;
}

.tenant-admin-panel .tenant-typography-grid .tenant-font-picker,
.tenant-typography-grid .tenant-font-picker {
  width: 100% !important;
}

/* End tenant typography preview repair. */


/* Tenant typography preset buttons mirror color palettes: choose a preset, then tweak individual controls. */
.tenant-admin-panel .tenant-typography-presets,
.tenant-typography-presets {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 0.85rem;
  margin: 1rem 0 1.35rem;
}

.tenant-admin-panel .tenant-typography-preset-button,
.tenant-admin-panel fieldset .tenant-typography-preset-button,
.tenant-admin-panel .admin-panel .tenant-typography-preset-button,
.tenant-typography-preset-button {
  display: grid !important;
  gap: 0.45rem !important;
  min-height: 160px !important;
  padding: 0.95rem !important;
  border: 2px solid color-mix(in srgb, var(--typography-preset-accent, #111) 56%, transparent) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--typography-preset-accent, #111) 16%, transparent), transparent 62%),
    #fffaf4 !important;
  color: #191714 !important;
  cursor: pointer !important;
  text-align: left !important;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08) !important;
}

.tenant-admin-panel .tenant-typography-preset-button:hover,
.tenant-admin-panel .tenant-typography-preset-button:focus,
.tenant-admin-panel .tenant-typography-preset-button[aria-pressed="true"],
.tenant-typography-preset-button:hover,
.tenant-typography-preset-button:focus,
.tenant-typography-preset-button[aria-pressed="true"] {
  border-color: var(--typography-preset-accent, #111) !important;
  outline: 3px solid color-mix(in srgb, var(--typography-preset-accent, #111) 24%, transparent) !important;
  transform: translateY(-1px) !important;
}

.tenant-typography-preset-applied {
  outline: 4px solid var(--typography-preset-accent, #111) !important;
}

.tenant-typography-preset-button .typography-preset-name {
  font-weight: 800;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.tenant-typography-preset-button .typography-preset-tone {
  justify-self: start;
  padding: 0.18rem 0.55rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--typography-preset-accent, #111) 18%, #fff);
  font-size: 0.76rem;
  font-weight: 700;
}

.tenant-typography-preset-button .typography-preset-heading {
  font-family: var(--typography-preset-heading, serif);
  font-size: 1.65rem;
  line-height: 1;
}

.tenant-typography-preset-button .typography-preset-body {
  font-family: var(--typography-preset-body, sans-serif);
  font-size: 0.98rem;
  line-height: 1.35;
}

.tenant-typography-preset-button .typography-preset-description {
  color: rgba(25, 23, 20, 0.72);
  font-size: 0.82rem;
  line-height: 1.35;
}


/* Tenant settings subpages keep the growing settings area navigable without
   hiding save behavior. Each subpage remains a normal form post. */
.tenant-settings-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin: 0 0 1.25rem;
  padding: 0.85rem;
  border: 1px solid rgba(31, 26, 20, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
}

.tenant-settings-subnav-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.4rem;
  padding: 0.52rem 0.9rem;
  border: 1px solid rgba(31, 26, 20, 0.18);
  border-radius: 999px;
  color: #2a241d;
  background: rgba(255, 255, 255, 0.72);
  font-weight: 700;
  text-decoration: none;
}

.tenant-settings-subnav-link:hover,
.tenant-settings-subnav-link:focus {
  border-color: rgba(31, 26, 20, 0.38);
  background: #fffaf0;
  color: #111;
}

.tenant-settings-subnav-link.is-active,
.tenant-settings-subnav-link[aria-current="page"] {
  border-color: #111;
  background: #111;
  color: #fff;
}

@media (max-width: 680px) {
  .tenant-settings-subnav {
    display: grid;
    grid-template-columns: 1fr;
  }

  .tenant-settings-subnav-link {
    justify-content: flex-start;
    width: 100%;
  }
}

/* End of file. */

/* Platform/tenant separation and directory thumbnail picker. */
.platform-admin-page {
    --tenant-topbar-bg: #111827;
    --tenant-topbar-text: #f8efe1;
    background:
        radial-gradient(circle at 12% 8%, rgba(255, 177, 72, 0.22), transparent 34rem),
        linear-gradient(135deg, #111827 0%, #1f2937 34%, #f2eadc 34%, #f7f2e8 100%) !important;
}

.platform-admin-header {
    border-bottom: 4px solid #f0a83a !important;
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.18) !important;
}

.platform-admin-logo img {
    max-height: 54px !important;
    width: auto !important;
}

.platform-admin-context {
    display: grid;
    gap: 0.1rem;
    margin-right: auto;
    color: var(--tenant-topbar-text, #f8efe1);
}

.platform-admin-context strong {
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
}

.platform-admin-context span {
    font-size: 0.85rem;
    opacity: 0.8;
}

.platform-admin-sidebar {
    background: #101827 !important;
    border-right: 5px solid #f0a83a !important;
}

.platform-admin-panel {
    border-top: 6px solid #f0a83a !important;
}

.directory-thumbnail-picker {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 1rem;
}

.directory-thumbnail-option {
    display: grid !important;
    gap: 0.55rem !important;
    align-content: start;
    padding: 0.8rem;
    border: 1px solid rgba(0, 0, 0, 0.14);
    border-radius: 16px;
    background: #fff;
    cursor: pointer;
}

.directory-thumbnail-option input {
    width: auto !important;
}

.directory-thumbnail-option img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    border-radius: 12px;
    border: 1px solid rgba(0, 0, 0, 0.12);
    background: #f6f1e9;
}

.directory-thumbnail-option:has(input:checked) {
    outline: 3px solid #111;
    border-color: #111;
}

.directory-thumbnail-option-none {
    min-height: 130px;
    place-content: center;
    text-align: center;
    background: repeating-linear-gradient(135deg, #fff, #fff 10px, #f6f1e9 10px, #f6f1e9 20px);
}

/* End platform/tenant separation and directory thumbnail picker. */

/* Platform and tenant admin UI enhancements. */
.admin-color-field { display: inline-flex; align-items: center; gap: .5rem; width: 100%; }
.admin-color-field > input:not(.admin-color-picker) { flex: 1 1 auto; }
.admin-color-picker { width: 3rem; min-width: 3rem; height: 2.25rem; padding: 0; border: 1px solid #bbb; border-radius: .35rem; background: #fff; }
.admin-color-swatch { width: 2.25rem; height: 2.25rem; border: 1px solid #999; border-radius: .35rem; box-shadow: inset 0 0 0 1px rgba(255,255,255,.45); }
.admin-bar-chart { display: grid; gap: .5rem; margin: 1rem 0; }
.admin-bar-row { display: grid; grid-template-columns: minmax(5rem, 11rem) 1fr 4rem; gap: .75rem; align-items: center; }
.admin-bar-track { min-height: 1rem; background: rgba(0,0,0,.08); border-radius: 999px; overflow: hidden; }
.admin-bar-fill { display: block; min-height: 1rem; background: currentColor; border-radius: 999px; opacity: .72; }
.admin-section-artwork-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(135px, 1fr)); gap: .75rem; margin: 1rem 0; }
.admin-section-artwork-card { border: 1px solid rgba(0,0,0,.16); border-radius: .5rem; padding: .5rem; background: #fff; }
.admin-section-artwork-card img { width: 100%; height: 110px; object-fit: contain; background: #f5f2ea; display: block; }
.admin-drag-handle { cursor: grab; font-weight: 700; }
.directory-card-thumb img { width: var(--directory-thumb-size, 180px); height: var(--directory-thumb-size, 180px); object-fit: cover; }
.platform-admin-top-link { font-weight: 700; }
.g-recaptcha { margin: 1rem 0; }


/* Tenant visual correction shared with public header. */
.tenant-admin-public-header{isolation:isolate;background-color:var(--topbar-bg-overlay,var(--tenant-topbar-bg,rgba(255,248,236,.86)))!important;background-image:var(--topbar-bg-image);background-position:center;background-size:cover;background-repeat:no-repeat}.tenant-admin-public-header::before{z-index:0;background-color:var(--topbar-bg-overlay,rgba(255,248,236,.86));background-image:none}.tenant-admin-public-header>*{position:relative;z-index:1}.tenant-admin-panel{background-color:var(--content-bg-overlay,rgba(255,250,240,0))!important;box-shadow:0 20px 60px rgba(0,0,0,calc(var(--content-bg-opacity,0) * .10))}
/* End tenant visual correction shared with public header. */


/* Tenant typography preset buttons mirror color palettes: choose a preset, then tweak individual controls. */
.tenant-admin-panel .tenant-typography-presets,
.tenant-typography-presets {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 0.85rem;
  margin: 1rem 0 1.35rem;
}

.tenant-admin-panel .tenant-typography-preset-button,
.tenant-admin-panel fieldset .tenant-typography-preset-button,
.tenant-admin-panel .admin-panel .tenant-typography-preset-button,
.tenant-typography-preset-button {
  display: grid !important;
  gap: 0.45rem !important;
  min-height: 160px !important;
  padding: 0.95rem !important;
  border: 2px solid color-mix(in srgb, var(--typography-preset-accent, #111) 56%, transparent) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--typography-preset-accent, #111) 16%, transparent), transparent 62%),
    #fffaf4 !important;
  color: #191714 !important;
  cursor: pointer !important;
  text-align: left !important;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08) !important;
}

.tenant-admin-panel .tenant-typography-preset-button:hover,
.tenant-admin-panel .tenant-typography-preset-button:focus,
.tenant-admin-panel .tenant-typography-preset-button[aria-pressed="true"],
.tenant-typography-preset-button:hover,
.tenant-typography-preset-button:focus,
.tenant-typography-preset-button[aria-pressed="true"] {
  border-color: var(--typography-preset-accent, #111) !important;
  outline: 3px solid color-mix(in srgb, var(--typography-preset-accent, #111) 24%, transparent) !important;
  transform: translateY(-1px) !important;
}

.tenant-typography-preset-applied {
  outline: 4px solid var(--typography-preset-accent, #111) !important;
}

.tenant-typography-preset-button .typography-preset-name {
  font-weight: 800;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.tenant-typography-preset-button .typography-preset-tone {
  justify-self: start;
  padding: 0.18rem 0.55rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--typography-preset-accent, #111) 18%, #fff);
  font-size: 0.76rem;
  font-weight: 700;
}

.tenant-typography-preset-button .typography-preset-heading {
  font-family: var(--typography-preset-heading, serif);
  font-size: 1.65rem;
  line-height: 1;
}

.tenant-typography-preset-button .typography-preset-body {
  font-family: var(--typography-preset-body, sans-serif);
  font-size: 0.98rem;
  line-height: 1.35;
}

.tenant-typography-preset-button .typography-preset-description {
  color: rgba(25, 23, 20, 0.72);
  font-size: 0.82rem;
  line-height: 1.35;
}


/* Tenant settings subpages keep the growing settings area navigable without
   hiding save behavior. Each subpage remains a normal form post. */
.tenant-settings-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin: 0 0 1.25rem;
  padding: 0.85rem;
  border: 1px solid rgba(31, 26, 20, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
}

.tenant-settings-subnav-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.4rem;
  padding: 0.52rem 0.9rem;
  border: 1px solid rgba(31, 26, 20, 0.18);
  border-radius: 999px;
  color: #2a241d;
  background: rgba(255, 255, 255, 0.72);
  font-weight: 700;
  text-decoration: none;
}

.tenant-settings-subnav-link:hover,
.tenant-settings-subnav-link:focus {
  border-color: rgba(31, 26, 20, 0.38);
  background: #fffaf0;
  color: #111;
}

.tenant-settings-subnav-link.is-active,
.tenant-settings-subnav-link[aria-current="page"] {
  border-color: #111;
  background: #111;
  color: #fff;
}

@media (max-width: 680px) {
  .tenant-settings-subnav {
    display: grid;
    grid-template-columns: 1fr;
  }

  .tenant-settings-subnav-link {
    justify-content: flex-start;
    width: 100%;
  }
}

/* End of file. */

/* Tenant admin readability and site-image picker controls. */
.tenant-admin-brand {
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.8rem !important;
    line-height: 1.05 !important;
    letter-spacing: normal !important;
}

.tenant-admin-brand span {
    display: inline-flex !important;
    align-items: center !important;
    padding: 0.28rem 0.55rem !important;
    border-radius: 999px !important;
    background: rgba(0, 0, 0, 0.12) !important;
    font-size: 0.82rem !important;
    font-weight: 900 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    white-space: nowrap !important;
}

.site-image-picker {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 0.9rem;
    margin: 0.75rem 0 1rem;
}

.site-image-picker-card {
    display: grid !important;
    gap: 0.45rem !important;
    align-content: start;
    padding: 0.75rem;
    border: 1px solid rgba(0, 0, 0, 0.14);
    border-radius: 16px;
    background: #fff;
    cursor: pointer;
}

.site-image-picker-card input {
    width: auto !important;
}

.site-image-picker-card img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    border-radius: 12px;
    border: 1px solid rgba(0, 0, 0, 0.12);
    background: #f6f1e9;
}


/* Tenant visual correction shared with public header. */
.tenant-admin-public-header{isolation:isolate;background-color:var(--topbar-bg-overlay,var(--tenant-topbar-bg,rgba(255,248,236,.86)))!important;background-image:var(--topbar-bg-image);background-position:center;background-size:cover;background-repeat:no-repeat}.tenant-admin-public-header::before{z-index:0;background-color:var(--topbar-bg-overlay,rgba(255,248,236,.86));background-image:none}.tenant-admin-public-header>*{position:relative;z-index:1}.tenant-admin-panel{background-color:var(--content-bg-overlay,rgba(255,250,240,0))!important;box-shadow:0 20px 60px rgba(0,0,0,calc(var(--content-bg-opacity,0) * .10))}
/* End tenant visual correction shared with public header. */


/* Tenant typography preset buttons mirror color palettes: choose a preset, then tweak individual controls. */
.tenant-admin-panel .tenant-typography-presets,
.tenant-typography-presets {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 0.85rem;
  margin: 1rem 0 1.35rem;
}

.tenant-admin-panel .tenant-typography-preset-button,
.tenant-admin-panel fieldset .tenant-typography-preset-button,
.tenant-admin-panel .admin-panel .tenant-typography-preset-button,
.tenant-typography-preset-button {
  display: grid !important;
  gap: 0.45rem !important;
  min-height: 160px !important;
  padding: 0.95rem !important;
  border: 2px solid color-mix(in srgb, var(--typography-preset-accent, #111) 56%, transparent) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--typography-preset-accent, #111) 16%, transparent), transparent 62%),
    #fffaf4 !important;
  color: #191714 !important;
  cursor: pointer !important;
  text-align: left !important;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08) !important;
}

.tenant-admin-panel .tenant-typography-preset-button:hover,
.tenant-admin-panel .tenant-typography-preset-button:focus,
.tenant-admin-panel .tenant-typography-preset-button[aria-pressed="true"],
.tenant-typography-preset-button:hover,
.tenant-typography-preset-button:focus,
.tenant-typography-preset-button[aria-pressed="true"] {
  border-color: var(--typography-preset-accent, #111) !important;
  outline: 3px solid color-mix(in srgb, var(--typography-preset-accent, #111) 24%, transparent) !important;
  transform: translateY(-1px) !important;
}

.tenant-typography-preset-applied {
  outline: 4px solid var(--typography-preset-accent, #111) !important;
}

.tenant-typography-preset-button .typography-preset-name {
  font-weight: 800;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.tenant-typography-preset-button .typography-preset-tone {
  justify-self: start;
  padding: 0.18rem 0.55rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--typography-preset-accent, #111) 18%, #fff);
  font-size: 0.76rem;
  font-weight: 700;
}

.tenant-typography-preset-button .typography-preset-heading {
  font-family: var(--typography-preset-heading, serif);
  font-size: 1.65rem;
  line-height: 1;
}

.tenant-typography-preset-button .typography-preset-body {
  font-family: var(--typography-preset-body, sans-serif);
  font-size: 0.98rem;
  line-height: 1.35;
}

.tenant-typography-preset-button .typography-preset-description {
  color: rgba(25, 23, 20, 0.72);
  font-size: 0.82rem;
  line-height: 1.35;
}


/* Tenant settings subpages keep the growing settings area navigable without
   hiding save behavior. Each subpage remains a normal form post. */
.tenant-settings-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin: 0 0 1.25rem;
  padding: 0.85rem;
  border: 1px solid rgba(31, 26, 20, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
}

.tenant-settings-subnav-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.4rem;
  padding: 0.52rem 0.9rem;
  border: 1px solid rgba(31, 26, 20, 0.18);
  border-radius: 999px;
  color: #2a241d;
  background: rgba(255, 255, 255, 0.72);
  font-weight: 700;
  text-decoration: none;
}

.tenant-settings-subnav-link:hover,
.tenant-settings-subnav-link:focus {
  border-color: rgba(31, 26, 20, 0.38);
  background: #fffaf0;
  color: #111;
}

.tenant-settings-subnav-link.is-active,
.tenant-settings-subnav-link[aria-current="page"] {
  border-color: #111;
  background: #111;
  color: #fff;
}

@media (max-width: 680px) {
  .tenant-settings-subnav {
    display: grid;
    grid-template-columns: 1fr;
  }

  .tenant-settings-subnav-link {
    justify-content: flex-start;
    width: 100%;
  }
}

/* End of file. */


/* Tenant-admin surface variables shared with public tenant pages. */
.tenant-admin-public-header {
    background-color: var(--tenant-topbar-bg, var(--topbar-bg, #f7f2e8)) !important;
    box-shadow: inset 0 0 0 999px rgba(255, 255, 255, calc(1 - var(--topbar-bg-opacity, 0.86))) !important;
}

.tenant-admin-sidebar {
    background-color: var(--menu-bg, #111) !important;
    background-image: var(--menu-bg-image) !important;
    background-position: center !important;
    background-size: cover !important;
    box-shadow: inset 0 0 0 999px rgba(0, 0, 0, calc(1 - var(--menu-bg-opacity, 0.92))) !important;
}

.tenant-admin-main {
    background-color: var(--content-bg, #f4efe7) !important;
    box-shadow: inset 0 0 0 999px rgba(255, 255, 255, calc(1 - var(--content-bg-opacity, 0.72))) !important;
}

.tenant-admin-panel {
    background-color: var(--content-bg, rgba(255, 255, 255, 0.92)) !important;
    box-shadow: inset 0 0 0 999px rgba(255, 255, 255, calc(1 - var(--content-bg-opacity, 0.92))), 0 24px 70px rgba(0,0,0,.06) !important;
}

/* Hide legacy nested admin-shell headings so pages read as one title, not a breadcrumb echo chamber. */
.tenant-admin-panel > h1 + main.admin-shell > h1,
.tenant-admin-panel > h1 + .admin-shell > h1 {
    display: none !important;
}

/* End tenant-admin surface variables. */


/* Tenant typography preset buttons mirror color palettes: choose a preset, then tweak individual controls. */
.tenant-admin-panel .tenant-typography-presets,
.tenant-typography-presets {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 0.85rem;
  margin: 1rem 0 1.35rem;
}

.tenant-admin-panel .tenant-typography-preset-button,
.tenant-admin-panel fieldset .tenant-typography-preset-button,
.tenant-admin-panel .admin-panel .tenant-typography-preset-button,
.tenant-typography-preset-button {
  display: grid !important;
  gap: 0.45rem !important;
  min-height: 160px !important;
  padding: 0.95rem !important;
  border: 2px solid color-mix(in srgb, var(--typography-preset-accent, #111) 56%, transparent) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--typography-preset-accent, #111) 16%, transparent), transparent 62%),
    #fffaf4 !important;
  color: #191714 !important;
  cursor: pointer !important;
  text-align: left !important;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08) !important;
}

.tenant-admin-panel .tenant-typography-preset-button:hover,
.tenant-admin-panel .tenant-typography-preset-button:focus,
.tenant-admin-panel .tenant-typography-preset-button[aria-pressed="true"],
.tenant-typography-preset-button:hover,
.tenant-typography-preset-button:focus,
.tenant-typography-preset-button[aria-pressed="true"] {
  border-color: var(--typography-preset-accent, #111) !important;
  outline: 3px solid color-mix(in srgb, var(--typography-preset-accent, #111) 24%, transparent) !important;
  transform: translateY(-1px) !important;
}

.tenant-typography-preset-applied {
  outline: 4px solid var(--typography-preset-accent, #111) !important;
}

.tenant-typography-preset-button .typography-preset-name {
  font-weight: 800;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.tenant-typography-preset-button .typography-preset-tone {
  justify-self: start;
  padding: 0.18rem 0.55rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--typography-preset-accent, #111) 18%, #fff);
  font-size: 0.76rem;
  font-weight: 700;
}

.tenant-typography-preset-button .typography-preset-heading {
  font-family: var(--typography-preset-heading, serif);
  font-size: 1.65rem;
  line-height: 1;
}

.tenant-typography-preset-button .typography-preset-body {
  font-family: var(--typography-preset-body, sans-serif);
  font-size: 0.98rem;
  line-height: 1.35;
}

.tenant-typography-preset-button .typography-preset-description {
  color: rgba(25, 23, 20, 0.72);
  font-size: 0.82rem;
  line-height: 1.35;
}


/* Tenant settings subpages keep the growing settings area navigable without
   hiding save behavior. Each subpage remains a normal form post. */
.tenant-settings-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin: 0 0 1.25rem;
  padding: 0.85rem;
  border: 1px solid rgba(31, 26, 20, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
}

.tenant-settings-subnav-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.4rem;
  padding: 0.52rem 0.9rem;
  border: 1px solid rgba(31, 26, 20, 0.18);
  border-radius: 999px;
  color: #2a241d;
  background: rgba(255, 255, 255, 0.72);
  font-weight: 700;
  text-decoration: none;
}

.tenant-settings-subnav-link:hover,
.tenant-settings-subnav-link:focus {
  border-color: rgba(31, 26, 20, 0.38);
  background: #fffaf0;
  color: #111;
}

.tenant-settings-subnav-link.is-active,
.tenant-settings-subnav-link[aria-current="page"] {
  border-color: #111;
  background: #111;
  color: #fff;
}

@media (max-width: 680px) {
  .tenant-settings-subnav {
    display: grid;
    grid-template-columns: 1fr;
  }

  .tenant-settings-subnav-link {
    justify-content: flex-start;
    width: 100%;
  }
}

/* End of file. */
/* Tenant admin settings must preview the same page surfaces as the public site. */
body.tenant-admin-page {
  color: var(--text-color, #1f1a14) !important;
  background-color: var(--bg, #f7f2e8) !important;
}

.site-header.tenant-admin-public-header {
  background-color: var(--topbar-bg-overlay, var(--tenant-topbar-bg, rgba(255, 248, 236, 0.86))) !important;
  background-image: var(--topbar-bg-image) !important;
  background-position: center !important;
  background-size: cover !important;
  background-repeat: no-repeat !important;
  box-shadow: var(--tenant-header-shadow, none) !important;
}

.site-header.tenant-admin-public-header nav {
  background-color: var(--menu-bg-overlay, rgba(255, 248, 236, 0.82)) !important;
  background-image: var(--menu-bg-image) !important;
  background-position: center !important;
  background-size: cover !important;
  background-repeat: no-repeat !important;
  border-radius: 999px !important;
  padding: 0.35rem 0.55rem !important;
}

.tenant-admin-main {
  background-color: var(--content-bg-overlay, rgba(255, 250, 240, 0)) !important;
}

.tenant-admin-panel {
  color: var(--text-color, #1f1a14) !important;
  background-color: var(--content-bg-overlay, rgba(255, 250, 240, 0)) !important;
}

.tenant-admin-panel h1,
.tenant-admin-panel h2,
.tenant-admin-panel h3,
.tenant-admin-panel legend {
  color: var(--text-color, #1f1a14) !important;
  background-color: var(--heading-bg-overlay, rgba(255, 248, 236, 0.72)) !important;
  box-shadow: 0.18em 0 0 var(--heading-bg-overlay, rgba(255, 248, 236, 0.72)), -0.18em 0 0 var(--heading-bg-overlay, rgba(255, 248, 236, 0.72)) !important;
}

.tenant-settings-form fieldset,
.tenant-admin-panel .admin-panel,
.tenant-admin-panel .admin-toolbar,
.tenant-admin-panel .admin-table-wrap {
  background-color: var(--text-bg-overlay, rgba(255, 247, 232, 0.72)) !important;
}

/* End tenant admin surface preview. */

/* Tenant admin visual authority repair. */
body.tenant-admin-page {
  color: var(--text-color, #1f1a14) !important;
  background-color: var(--bg, #f7f2e8) !important;
}

.site-header.tenant-admin-public-header {
  background-color: var(--topbar-bg-overlay, var(--tenant-topbar-bg, rgba(255, 248, 236, 0.86))) !important;
  background-image: var(--topbar-bg-image) !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  background-size: cover !important;
  box-shadow: var(--tenant-header-shadow, none) !important;
}

.site-header.tenant-admin-public-header nav {
  background-color: var(--menu-bg-overlay, transparent) !important;
  background-image: var(--menu-bg-image) !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  background-size: cover !important;
  border-radius: var(--menu-panel-radius, 0) !important;
  box-shadow: var(--menu-panel-shadow, none) !important;
  padding: var(--menu-panel-padding, 0) !important;
}

.tenant-admin-main,
.tenant-admin-panel {
  color: var(--text-color, #1f1a14) !important;
  background-color: var(--content-bg-overlay, rgba(255, 250, 240, 0)) !important;
}

.tenant-admin-panel h1,
.tenant-admin-panel h2,
.tenant-admin-panel h3,
.tenant-admin-panel legend {
  color: var(--text-color, #1f1a14) !important;
  background-color: var(--heading-bg-overlay, transparent) !important;
  box-shadow: 0.18em 0 0 var(--heading-bg-overlay, transparent), -0.18em 0 0 var(--heading-bg-overlay, transparent) !important;
}

.tenant-admin-panel label,
.tenant-admin-panel p,
.tenant-admin-panel td,
.tenant-admin-panel th {
  color: var(--text-color, #1f1a14) !important;
}

.tenant-settings-form fieldset,
.tenant-admin-panel .admin-panel,
.tenant-admin-panel .admin-toolbar,
.tenant-admin-panel .admin-table-wrap {
  background-color: var(--text-bg-overlay, rgba(255, 247, 232, 0.72)) !important;
}

/* End tenant admin visual authority repair. */


/* Tenant typography preset buttons mirror color palettes: choose a preset, then tweak individual controls. */
.tenant-admin-panel .tenant-typography-presets,
.tenant-typography-presets {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 0.85rem;
  margin: 1rem 0 1.35rem;
}

.tenant-admin-panel .tenant-typography-preset-button,
.tenant-admin-panel fieldset .tenant-typography-preset-button,
.tenant-admin-panel .admin-panel .tenant-typography-preset-button,
.tenant-typography-preset-button {
  display: grid !important;
  gap: 0.45rem !important;
  min-height: 160px !important;
  padding: 0.95rem !important;
  border: 2px solid color-mix(in srgb, var(--typography-preset-accent, #111) 56%, transparent) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--typography-preset-accent, #111) 16%, transparent), transparent 62%),
    #fffaf4 !important;
  color: #191714 !important;
  cursor: pointer !important;
  text-align: left !important;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08) !important;
}

.tenant-admin-panel .tenant-typography-preset-button:hover,
.tenant-admin-panel .tenant-typography-preset-button:focus,
.tenant-admin-panel .tenant-typography-preset-button[aria-pressed="true"],
.tenant-typography-preset-button:hover,
.tenant-typography-preset-button:focus,
.tenant-typography-preset-button[aria-pressed="true"] {
  border-color: var(--typography-preset-accent, #111) !important;
  outline: 3px solid color-mix(in srgb, var(--typography-preset-accent, #111) 24%, transparent) !important;
  transform: translateY(-1px) !important;
}

.tenant-typography-preset-applied {
  outline: 4px solid var(--typography-preset-accent, #111) !important;
}

.tenant-typography-preset-button .typography-preset-name {
  font-weight: 800;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.tenant-typography-preset-button .typography-preset-tone {
  justify-self: start;
  padding: 0.18rem 0.55rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--typography-preset-accent, #111) 18%, #fff);
  font-size: 0.76rem;
  font-weight: 700;
}

.tenant-typography-preset-button .typography-preset-heading {
  font-family: var(--typography-preset-heading, serif);
  font-size: 1.65rem;
  line-height: 1;
}

.tenant-typography-preset-button .typography-preset-body {
  font-family: var(--typography-preset-body, sans-serif);
  font-size: 0.98rem;
  line-height: 1.35;
}

.tenant-typography-preset-button .typography-preset-description {
  color: rgba(25, 23, 20, 0.72);
  font-size: 0.82rem;
  line-height: 1.35;
}


/* Tenant settings subpages keep the growing settings area navigable without
   hiding save behavior. Each subpage remains a normal form post. */
.tenant-settings-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin: 0 0 1.25rem;
  padding: 0.85rem;
  border: 1px solid rgba(31, 26, 20, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
}

.tenant-settings-subnav-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.4rem;
  padding: 0.52rem 0.9rem;
  border: 1px solid rgba(31, 26, 20, 0.18);
  border-radius: 999px;
  color: #2a241d;
  background: rgba(255, 255, 255, 0.72);
  font-weight: 700;
  text-decoration: none;
}

.tenant-settings-subnav-link:hover,
.tenant-settings-subnav-link:focus {
  border-color: rgba(31, 26, 20, 0.38);
  background: #fffaf0;
  color: #111;
}

.tenant-settings-subnav-link.is-active,
.tenant-settings-subnav-link[aria-current="page"] {
  border-color: #111;
  background: #111;
  color: #fff;
}

@media (max-width: 680px) {
  .tenant-settings-subnav {
    display: grid;
    grid-template-columns: 1fr;
  }

  .tenant-settings-subnav-link {
    justify-content: flex-start;
    width: 100%;
  }
}

/* End of file. */

/* Tenant admin header buttons match link styling. */
.site-header.tenant-admin-public-header nav form {
  display: inline-flex !important;
  align-items: center !important;
  margin: 0 !important;
}

.site-header.tenant-admin-public-header nav .link-button {
  appearance: none !important;
  border: 0 !important;
  background: transparent !important;
  color: inherit !important;
  padding: 0.65rem 1rem !important;
  border-radius: 999px !important;
  font: inherit !important;
  font-weight: 800 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
}


/* Tenant typography preset buttons mirror color palettes: choose a preset, then tweak individual controls. */
.tenant-admin-panel .tenant-typography-presets,
.tenant-typography-presets {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 0.85rem;
  margin: 1rem 0 1.35rem;
}

.tenant-admin-panel .tenant-typography-preset-button,
.tenant-admin-panel fieldset .tenant-typography-preset-button,
.tenant-admin-panel .admin-panel .tenant-typography-preset-button,
.tenant-typography-preset-button {
  display: grid !important;
  gap: 0.45rem !important;
  min-height: 160px !important;
  padding: 0.95rem !important;
  border: 2px solid color-mix(in srgb, var(--typography-preset-accent, #111) 56%, transparent) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--typography-preset-accent, #111) 16%, transparent), transparent 62%),
    #fffaf4 !important;
  color: #191714 !important;
  cursor: pointer !important;
  text-align: left !important;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08) !important;
}

.tenant-admin-panel .tenant-typography-preset-button:hover,
.tenant-admin-panel .tenant-typography-preset-button:focus,
.tenant-admin-panel .tenant-typography-preset-button[aria-pressed="true"],
.tenant-typography-preset-button:hover,
.tenant-typography-preset-button:focus,
.tenant-typography-preset-button[aria-pressed="true"] {
  border-color: var(--typography-preset-accent, #111) !important;
  outline: 3px solid color-mix(in srgb, var(--typography-preset-accent, #111) 24%, transparent) !important;
  transform: translateY(-1px) !important;
}

.tenant-typography-preset-applied {
  outline: 4px solid var(--typography-preset-accent, #111) !important;
}

.tenant-typography-preset-button .typography-preset-name {
  font-weight: 800;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.tenant-typography-preset-button .typography-preset-tone {
  justify-self: start;
  padding: 0.18rem 0.55rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--typography-preset-accent, #111) 18%, #fff);
  font-size: 0.76rem;
  font-weight: 700;
}

.tenant-typography-preset-button .typography-preset-heading {
  font-family: var(--typography-preset-heading, serif);
  font-size: 1.65rem;
  line-height: 1;
}

.tenant-typography-preset-button .typography-preset-body {
  font-family: var(--typography-preset-body, sans-serif);
  font-size: 0.98rem;
  line-height: 1.35;
}

.tenant-typography-preset-button .typography-preset-description {
  color: rgba(25, 23, 20, 0.72);
  font-size: 0.82rem;
  line-height: 1.35;
}


/* Tenant settings subpages keep the growing settings area navigable without
   hiding save behavior. Each subpage remains a normal form post. */
.tenant-settings-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin: 0 0 1.25rem;
  padding: 0.85rem;
  border: 1px solid rgba(31, 26, 20, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
}

.tenant-settings-subnav-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.4rem;
  padding: 0.52rem 0.9rem;
  border: 1px solid rgba(31, 26, 20, 0.18);
  border-radius: 999px;
  color: #2a241d;
  background: rgba(255, 255, 255, 0.72);
  font-weight: 700;
  text-decoration: none;
}

.tenant-settings-subnav-link:hover,
.tenant-settings-subnav-link:focus {
  border-color: rgba(31, 26, 20, 0.38);
  background: #fffaf0;
  color: #111;
}

.tenant-settings-subnav-link.is-active,
.tenant-settings-subnav-link[aria-current="page"] {
  border-color: #111;
  background: #111;
  color: #fff;
}

@media (max-width: 680px) {
  .tenant-settings-subnav {
    display: grid;
    grid-template-columns: 1fr;
  }

  .tenant-settings-subnav-link {
    justify-content: flex-start;
    width: 100%;
  }
}

/* End of file. */

/* Dashboard signal panels shared by platform and tenant admin home pages. */
.dashboard-metric-grid{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(190px,1fr))!important;gap:16px!important;margin:0 0 22px!important}.dashboard-metric-card{display:grid!important;gap:8px!important;min-height:132px!important;padding:20px!important;border:1px solid rgba(0,0,0,.10)!important;border-radius:20px!important;background:linear-gradient(135deg,rgba(255,255,255,.98),rgba(250,245,236,.94))!important;color:#171717!important;text-decoration:none!important;box-shadow:0 14px 34px rgba(0,0,0,.07)!important}.dashboard-metric-card:hover{transform:translateY(-1px);box-shadow:0 18px 42px rgba(0,0,0,.10)!important}.dashboard-metric-card span{font-size:.78rem!important;line-height:1.2!important;text-transform:uppercase!important;letter-spacing:.09em!important;color:#716858!important;font-weight:900!important}.dashboard-metric-card strong{font-size:clamp(1.75rem,4vw,2.9rem)!important;line-height:.95!important;letter-spacing:-.06em!important}.dashboard-metric-card small{font-size:.9rem!important;line-height:1.35!important;color:#5d5549!important}.dashboard-split-grid{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))!important;gap:18px!important;margin:0 0 22px!important}.dashboard-section-head{display:flex!important;justify-content:space-between!important;gap:12px!important;align-items:center!important;margin:0 0 12px!important}.dashboard-section-head h2{margin:0!important;font-size:1.35rem!important;letter-spacing:-.03em!important}.dashboard-section-head a{font-weight:900!important;color:var(--primary,#111)!important}.dashboard-action-grid{grid-template-columns:repeat(auto-fit,minmax(210px,1fr))!important}.dashboard-plan-panel{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))!important;gap:18px!important;margin:0 0 22px!important}.dashboard-plan-panel h2{margin:.15rem 0!important;font-size:clamp(1.35rem,3vw,2.2rem)!important;letter-spacing:-.05em!important}


/* Tenant typography preset buttons mirror color palettes: choose a preset, then tweak individual controls. */
.tenant-admin-panel .tenant-typography-presets,
.tenant-typography-presets {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 0.85rem;
  margin: 1rem 0 1.35rem;
}

.tenant-admin-panel .tenant-typography-preset-button,
.tenant-admin-panel fieldset .tenant-typography-preset-button,
.tenant-admin-panel .admin-panel .tenant-typography-preset-button,
.tenant-typography-preset-button {
  display: grid !important;
  gap: 0.45rem !important;
  min-height: 160px !important;
  padding: 0.95rem !important;
  border: 2px solid color-mix(in srgb, var(--typography-preset-accent, #111) 56%, transparent) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--typography-preset-accent, #111) 16%, transparent), transparent 62%),
    #fffaf4 !important;
  color: #191714 !important;
  cursor: pointer !important;
  text-align: left !important;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08) !important;
}

.tenant-admin-panel .tenant-typography-preset-button:hover,
.tenant-admin-panel .tenant-typography-preset-button:focus,
.tenant-admin-panel .tenant-typography-preset-button[aria-pressed="true"],
.tenant-typography-preset-button:hover,
.tenant-typography-preset-button:focus,
.tenant-typography-preset-button[aria-pressed="true"] {
  border-color: var(--typography-preset-accent, #111) !important;
  outline: 3px solid color-mix(in srgb, var(--typography-preset-accent, #111) 24%, transparent) !important;
  transform: translateY(-1px) !important;
}

.tenant-typography-preset-applied {
  outline: 4px solid var(--typography-preset-accent, #111) !important;
}

.tenant-typography-preset-button .typography-preset-name {
  font-weight: 800;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.tenant-typography-preset-button .typography-preset-tone {
  justify-self: start;
  padding: 0.18rem 0.55rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--typography-preset-accent, #111) 18%, #fff);
  font-size: 0.76rem;
  font-weight: 700;
}

.tenant-typography-preset-button .typography-preset-heading {
  font-family: var(--typography-preset-heading, serif);
  font-size: 1.65rem;
  line-height: 1;
}

.tenant-typography-preset-button .typography-preset-body {
  font-family: var(--typography-preset-body, sans-serif);
  font-size: 0.98rem;
  line-height: 1.35;
}

.tenant-typography-preset-button .typography-preset-description {
  color: rgba(25, 23, 20, 0.72);
  font-size: 0.82rem;
  line-height: 1.35;
}


/* Tenant settings subpages keep the growing settings area navigable without
   hiding save behavior. Each subpage remains a normal form post. */
.tenant-settings-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin: 0 0 1.25rem;
  padding: 0.85rem;
  border: 1px solid rgba(31, 26, 20, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
}

.tenant-settings-subnav-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.4rem;
  padding: 0.52rem 0.9rem;
  border: 1px solid rgba(31, 26, 20, 0.18);
  border-radius: 999px;
  color: #2a241d;
  background: rgba(255, 255, 255, 0.72);
  font-weight: 700;
  text-decoration: none;
}

.tenant-settings-subnav-link:hover,
.tenant-settings-subnav-link:focus {
  border-color: rgba(31, 26, 20, 0.38);
  background: #fffaf0;
  color: #111;
}

.tenant-settings-subnav-link.is-active,
.tenant-settings-subnav-link[aria-current="page"] {
  border-color: #111;
  background: #111;
  color: #fff;
}

@media (max-width: 680px) {
  .tenant-settings-subnav {
    display: grid;
    grid-template-columns: 1fr;
  }

  .tenant-settings-subnav-link {
    justify-content: flex-start;
    width: 100%;
  }
}

/* End of file. */

/* Dashboard and tenant billing override refinements. */
.admin-panel-heading {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.admin-stacked-form {
    display: grid;
    gap: 1rem;
}

.admin-checkbox-card {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 1rem;
    border: 1px solid rgba(120, 95, 60, 0.28);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.68);
}

.admin-checkbox-card input[type="checkbox"] {
    width: 1.2rem;
    height: 1.2rem;
    margin-top: 0.15rem;
    flex: 0 0 auto;
}

.admin-checkbox-card small {
    display: block;
    margin-top: 0.25rem;
    color: var(--af-muted, #665f55);
    line-height: 1.4;
}

.admin-billing-override-panel button {
    min-width: 11rem;
}


/* Tenant typography preset buttons mirror color palettes: choose a preset, then tweak individual controls. */
.tenant-admin-panel .tenant-typography-presets,
.tenant-typography-presets {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 0.85rem;
  margin: 1rem 0 1.35rem;
}

.tenant-admin-panel .tenant-typography-preset-button,
.tenant-admin-panel fieldset .tenant-typography-preset-button,
.tenant-admin-panel .admin-panel .tenant-typography-preset-button,
.tenant-typography-preset-button {
  display: grid !important;
  gap: 0.45rem !important;
  min-height: 160px !important;
  padding: 0.95rem !important;
  border: 2px solid color-mix(in srgb, var(--typography-preset-accent, #111) 56%, transparent) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--typography-preset-accent, #111) 16%, transparent), transparent 62%),
    #fffaf4 !important;
  color: #191714 !important;
  cursor: pointer !important;
  text-align: left !important;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08) !important;
}

.tenant-admin-panel .tenant-typography-preset-button:hover,
.tenant-admin-panel .tenant-typography-preset-button:focus,
.tenant-admin-panel .tenant-typography-preset-button[aria-pressed="true"],
.tenant-typography-preset-button:hover,
.tenant-typography-preset-button:focus,
.tenant-typography-preset-button[aria-pressed="true"] {
  border-color: var(--typography-preset-accent, #111) !important;
  outline: 3px solid color-mix(in srgb, var(--typography-preset-accent, #111) 24%, transparent) !important;
  transform: translateY(-1px) !important;
}

.tenant-typography-preset-applied {
  outline: 4px solid var(--typography-preset-accent, #111) !important;
}

.tenant-typography-preset-button .typography-preset-name {
  font-weight: 800;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.tenant-typography-preset-button .typography-preset-tone {
  justify-self: start;
  padding: 0.18rem 0.55rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--typography-preset-accent, #111) 18%, #fff);
  font-size: 0.76rem;
  font-weight: 700;
}

.tenant-typography-preset-button .typography-preset-heading {
  font-family: var(--typography-preset-heading, serif);
  font-size: 1.65rem;
  line-height: 1;
}

.tenant-typography-preset-button .typography-preset-body {
  font-family: var(--typography-preset-body, sans-serif);
  font-size: 0.98rem;
  line-height: 1.35;
}

.tenant-typography-preset-button .typography-preset-description {
  color: rgba(25, 23, 20, 0.72);
  font-size: 0.82rem;
  line-height: 1.35;
}


/* Tenant settings subpages keep the growing settings area navigable without
   hiding save behavior. Each subpage remains a normal form post. */
.tenant-settings-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin: 0 0 1.25rem;
  padding: 0.85rem;
  border: 1px solid rgba(31, 26, 20, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
}

.tenant-settings-subnav-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.4rem;
  padding: 0.52rem 0.9rem;
  border: 1px solid rgba(31, 26, 20, 0.18);
  border-radius: 999px;
  color: #2a241d;
  background: rgba(255, 255, 255, 0.72);
  font-weight: 700;
  text-decoration: none;
}

.tenant-settings-subnav-link:hover,
.tenant-settings-subnav-link:focus {
  border-color: rgba(31, 26, 20, 0.38);
  background: #fffaf0;
  color: #111;
}

.tenant-settings-subnav-link.is-active,
.tenant-settings-subnav-link[aria-current="page"] {
  border-color: #111;
  background: #111;
  color: #fff;
}

@media (max-width: 680px) {
  .tenant-settings-subnav {
    display: grid;
    grid-template-columns: 1fr;
  }

  .tenant-settings-subnav-link {
    justify-content: flex-start;
    width: 100%;
  }
}

/* End of file. */

/* Tenant admin sidebar readability: default new-site menu text to dark on light menu panels. */
.site-header.tenant-admin-public-header nav {
  color: var(--menu-text-color, var(--text-color, #1f1a14)) !important;
}

.site-header.tenant-admin-public-header nav a,
.site-header.tenant-admin-public-header nav .link-button {
  color: var(--menu-text-color, var(--text-color, #1f1a14)) !important;
  text-shadow: none !important;
}

/* Keep the left tenant-admin application sidebar intentionally dark. */
.tenant-admin-sidebar,
.tenant-admin-sidebar a,
.tenant-admin-brand {
  color: #fff !important;
}


/* Tenant typography preset buttons mirror color palettes: choose a preset, then tweak individual controls. */
.tenant-admin-panel .tenant-typography-presets,
.tenant-typography-presets {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 0.85rem;
  margin: 1rem 0 1.35rem;
}

.tenant-admin-panel .tenant-typography-preset-button,
.tenant-admin-panel fieldset .tenant-typography-preset-button,
.tenant-admin-panel .admin-panel .tenant-typography-preset-button,
.tenant-typography-preset-button {
  display: grid !important;
  gap: 0.45rem !important;
  min-height: 160px !important;
  padding: 0.95rem !important;
  border: 2px solid color-mix(in srgb, var(--typography-preset-accent, #111) 56%, transparent) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--typography-preset-accent, #111) 16%, transparent), transparent 62%),
    #fffaf4 !important;
  color: #191714 !important;
  cursor: pointer !important;
  text-align: left !important;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08) !important;
}

.tenant-admin-panel .tenant-typography-preset-button:hover,
.tenant-admin-panel .tenant-typography-preset-button:focus,
.tenant-admin-panel .tenant-typography-preset-button[aria-pressed="true"],
.tenant-typography-preset-button:hover,
.tenant-typography-preset-button:focus,
.tenant-typography-preset-button[aria-pressed="true"] {
  border-color: var(--typography-preset-accent, #111) !important;
  outline: 3px solid color-mix(in srgb, var(--typography-preset-accent, #111) 24%, transparent) !important;
  transform: translateY(-1px) !important;
}

.tenant-typography-preset-applied {
  outline: 4px solid var(--typography-preset-accent, #111) !important;
}

.tenant-typography-preset-button .typography-preset-name {
  font-weight: 800;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.tenant-typography-preset-button .typography-preset-tone {
  justify-self: start;
  padding: 0.18rem 0.55rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--typography-preset-accent, #111) 18%, #fff);
  font-size: 0.76rem;
  font-weight: 700;
}

.tenant-typography-preset-button .typography-preset-heading {
  font-family: var(--typography-preset-heading, serif);
  font-size: 1.65rem;
  line-height: 1;
}

.tenant-typography-preset-button .typography-preset-body {
  font-family: var(--typography-preset-body, sans-serif);
  font-size: 0.98rem;
  line-height: 1.35;
}

.tenant-typography-preset-button .typography-preset-description {
  color: rgba(25, 23, 20, 0.72);
  font-size: 0.82rem;
  line-height: 1.35;
}


/* Tenant settings subpages keep the growing settings area navigable without
   hiding save behavior. Each subpage remains a normal form post. */
.tenant-settings-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin: 0 0 1.25rem;
  padding: 0.85rem;
  border: 1px solid rgba(31, 26, 20, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
}

.tenant-settings-subnav-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.4rem;
  padding: 0.52rem 0.9rem;
  border: 1px solid rgba(31, 26, 20, 0.18);
  border-radius: 999px;
  color: #2a241d;
  background: rgba(255, 255, 255, 0.72);
  font-weight: 700;
  text-decoration: none;
}

.tenant-settings-subnav-link:hover,
.tenant-settings-subnav-link:focus {
  border-color: rgba(31, 26, 20, 0.38);
  background: #fffaf0;
  color: #111;
}

.tenant-settings-subnav-link.is-active,
.tenant-settings-subnav-link[aria-current="page"] {
  border-color: #111;
  background: #111;
  color: #fff;
}

@media (max-width: 680px) {
  .tenant-settings-subnav {
    display: grid;
    grid-template-columns: 1fr;
  }

  .tenant-settings-subnav-link {
    justify-content: flex-start;
    width: 100%;
  }
}

/* End of file. */

/* Tenant color palette buttons for site settings. */
.tenant-palette-toolbar {
  display: grid !important;
  gap: 0.9rem !important;
  margin: 0 0 1.25rem !important;
  padding: 1rem !important;
  border: 1px solid rgba(0, 0, 0, 0.12) !important;
  border-radius: 18px !important;
  background: rgba(255, 255, 255, 0.74) !important;
}

.tenant-palette-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)) !important;
  gap: 0.85rem !important;
}

.tenant-palette-button {
  display: grid !important;
  gap: 0.5rem !important;
  align-content: start !important;
  min-height: 132px !important;
  padding: 0.9rem !important;
  border: 2px solid color-mix(in srgb, var(--palette-button-accent, #111) 62%, transparent) !important;
  border-radius: 16px !important;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--palette-button-accent, #c9a85f) 22%, transparent), transparent 58%),
    var(--palette-button-bg, #fff) !important;
  color: var(--palette-button-text, #1f1a14) !important;
  cursor: pointer !important;
  text-align: left !important;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08) !important;
  transition: transform 120ms ease, box-shadow 120ms ease, outline-color 120ms ease !important;
}

.tenant-palette-button:hover,
.tenant-palette-button:focus,
.tenant-palette-button[aria-pressed="true"] {
  border-color: var(--palette-button-accent, #111) !important;
  outline: 3px solid color-mix(in srgb, var(--palette-button-accent, #111) 28%, transparent) !important;
  box-shadow: 0 16px 38px rgba(0, 0, 0, 0.14) !important;
  transform: translateY(-1px) !important;
}

.tenant-palette-button-applied {
  outline: 4px solid var(--palette-button-accent, #111) !important;
}

.tenant-palette-button::after {
  content: attr(data-palette-tone) !important;
  display: inline-flex !important;
  justify-self: start !important;
  padding: 0.18rem 0.48rem !important;
  border-radius: 999px !important;
  background: color-mix(in srgb, var(--palette-button-accent, #111) 22%, transparent) !important;
  color: var(--palette-button-text, #1f1a14) !important;
  font-size: 0.72rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.02em !important;
  text-transform: uppercase !important;
}

.tenant-palette-name {
  font-weight: 950 !important;
  letter-spacing: -0.02em !important;
}

.tenant-palette-swatches {
  display: flex !important;
  gap: 0.35rem !important;
  flex-wrap: wrap !important;
}

.tenant-palette-swatch {
  width: 2rem !important;
  height: 2rem !important;
  border-radius: 999px !important;
  border: 1px solid rgba(0, 0, 0, 0.25) !important;
  background: var(--palette-swatch) !important;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.36) !important;
}

.tenant-palette-description {
  color: color-mix(in srgb, var(--palette-button-text, #1f1a14) 72%, transparent) !important;
  font-size: 0.9rem !important;
  line-height: 1.35 !important;
}


/* Tenant typography preset buttons mirror color palettes: choose a preset, then tweak individual controls. */
.tenant-admin-panel .tenant-typography-presets,
.tenant-typography-presets {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 0.85rem;
  margin: 1rem 0 1.35rem;
}

.tenant-admin-panel .tenant-typography-preset-button,
.tenant-admin-panel fieldset .tenant-typography-preset-button,
.tenant-admin-panel .admin-panel .tenant-typography-preset-button,
.tenant-typography-preset-button {
  display: grid !important;
  gap: 0.45rem !important;
  min-height: 160px !important;
  padding: 0.95rem !important;
  border: 2px solid color-mix(in srgb, var(--typography-preset-accent, #111) 56%, transparent) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--typography-preset-accent, #111) 16%, transparent), transparent 62%),
    #fffaf4 !important;
  color: #191714 !important;
  cursor: pointer !important;
  text-align: left !important;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08) !important;
}

.tenant-admin-panel .tenant-typography-preset-button:hover,
.tenant-admin-panel .tenant-typography-preset-button:focus,
.tenant-admin-panel .tenant-typography-preset-button[aria-pressed="true"],
.tenant-typography-preset-button:hover,
.tenant-typography-preset-button:focus,
.tenant-typography-preset-button[aria-pressed="true"] {
  border-color: var(--typography-preset-accent, #111) !important;
  outline: 3px solid color-mix(in srgb, var(--typography-preset-accent, #111) 24%, transparent) !important;
  transform: translateY(-1px) !important;
}

.tenant-typography-preset-applied {
  outline: 4px solid var(--typography-preset-accent, #111) !important;
}

.tenant-typography-preset-button .typography-preset-name {
  font-weight: 800;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.tenant-typography-preset-button .typography-preset-tone {
  justify-self: start;
  padding: 0.18rem 0.55rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--typography-preset-accent, #111) 18%, #fff);
  font-size: 0.76rem;
  font-weight: 700;
}

.tenant-typography-preset-button .typography-preset-heading {
  font-family: var(--typography-preset-heading, serif);
  font-size: 1.65rem;
  line-height: 1;
}

.tenant-typography-preset-button .typography-preset-body {
  font-family: var(--typography-preset-body, sans-serif);
  font-size: 0.98rem;
  line-height: 1.35;
}

.tenant-typography-preset-button .typography-preset-description {
  color: rgba(25, 23, 20, 0.72);
  font-size: 0.82rem;
  line-height: 1.35;
}


/* Tenant settings subpages keep the growing settings area navigable without
   hiding save behavior. Each subpage remains a normal form post. */
.tenant-settings-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin: 0 0 1.25rem;
  padding: 0.85rem;
  border: 1px solid rgba(31, 26, 20, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
}

.tenant-settings-subnav-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.4rem;
  padding: 0.52rem 0.9rem;
  border: 1px solid rgba(31, 26, 20, 0.18);
  border-radius: 999px;
  color: #2a241d;
  background: rgba(255, 255, 255, 0.72);
  font-weight: 700;
  text-decoration: none;
}

.tenant-settings-subnav-link:hover,
.tenant-settings-subnav-link:focus {
  border-color: rgba(31, 26, 20, 0.38);
  background: #fffaf0;
  color: #111;
}

.tenant-settings-subnav-link.is-active,
.tenant-settings-subnav-link[aria-current="page"] {
  border-color: #111;
  background: #111;
  color: #fff;
}

@media (max-width: 680px) {
  .tenant-settings-subnav {
    display: grid;
    grid-template-columns: 1fr;
  }

  .tenant-settings-subnav-link {
    justify-content: flex-start;
    width: 100%;
  }
}

/* End of file. */


/* Settings pages repeat the primary save action below each section so long forms
   can be saved without scrolling back to the bottom. */
.settings-section-actions {
  display: flex;
  justify-content: flex-end;
  margin: -8px 0 8px;
}

/* Tenant palette contrast repair for the public header inside tenant admin. */
.site-header.tenant-admin-public-header,
.site-header.tenant-admin-public-header .brand,
.site-header.tenant-admin-public-header .tenant-admin-brand {
  color: var(--tenant-topbar-text, var(--text-color, #1f1a14)) !important;
}

.site-header.tenant-admin-public-header nav,
.site-header.tenant-admin-public-header nav a,
.site-header.tenant-admin-public-header nav .link-button {
  color: var(--menu-text-color, var(--tenant-topbar-text, var(--text-color, #1f1a14))) !important;
}

.site-header.tenant-admin-public-header nav a:hover,
.site-header.tenant-admin-public-header nav a:focus-visible,
.site-header.tenant-admin-public-header nav .link-button:hover,
.site-header.tenant-admin-public-header nav .link-button:focus-visible {
  background: color-mix(in srgb, currentColor 14%, transparent) !important;
}

.tenant-palette-preview {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  grid-template-rows: auto 1fr !important;
  overflow: hidden !important;
  min-height: 4.5rem !important;
  border-radius: 12px !important;
  border: 1px solid color-mix(in srgb, var(--palette-button-text, #111) 20%, transparent) !important;
  background: var(--palette-button-page, var(--palette-button-bg, #fff)) !important;
}

.tenant-palette-preview-topbar {
  grid-column: 1 / -1 !important;
  display: flex !important;
  align-items: center !important;
  min-height: 1.65rem !important;
  padding: 0.15rem 0.45rem !important;
  background: var(--palette-button-topbar, var(--palette-button-bg, #fff)) !important;
  color: var(--palette-button-topbar-text, var(--palette-button-text, #111)) !important;
  font-weight: 950 !important;
  letter-spacing: -0.04em !important;
}

.tenant-palette-preview-menu {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0.45rem !important;
  border-radius: 999px !important;
  background: var(--palette-button-menu, var(--palette-button-bg, #fff)) !important;
  color: var(--palette-button-menu-text, var(--palette-button-text, #111)) !important;
  font-size: 0.72rem !important;
  font-weight: 900 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
}

.tenant-palette-preview-page {
  margin: 0.45rem 0.45rem 0.45rem 0 !important;
  border-radius: 10px !important;
  background: var(--palette-button-surface, var(--palette-button-page, #fff)) !important;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--palette-button-text, #111) 12%, transparent) !important;
}


/* Tenant typography preset buttons mirror color palettes: choose a preset, then tweak individual controls. */
.tenant-admin-panel .tenant-typography-presets,
.tenant-typography-presets {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 0.85rem;
  margin: 1rem 0 1.35rem;
}

.tenant-admin-panel .tenant-typography-preset-button,
.tenant-admin-panel fieldset .tenant-typography-preset-button,
.tenant-admin-panel .admin-panel .tenant-typography-preset-button,
.tenant-typography-preset-button {
  display: grid !important;
  gap: 0.45rem !important;
  min-height: 160px !important;
  padding: 0.95rem !important;
  border: 2px solid color-mix(in srgb, var(--typography-preset-accent, #111) 56%, transparent) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--typography-preset-accent, #111) 16%, transparent), transparent 62%),
    #fffaf4 !important;
  color: #191714 !important;
  cursor: pointer !important;
  text-align: left !important;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08) !important;
}

.tenant-admin-panel .tenant-typography-preset-button:hover,
.tenant-admin-panel .tenant-typography-preset-button:focus,
.tenant-admin-panel .tenant-typography-preset-button[aria-pressed="true"],
.tenant-typography-preset-button:hover,
.tenant-typography-preset-button:focus,
.tenant-typography-preset-button[aria-pressed="true"] {
  border-color: var(--typography-preset-accent, #111) !important;
  outline: 3px solid color-mix(in srgb, var(--typography-preset-accent, #111) 24%, transparent) !important;
  transform: translateY(-1px) !important;
}

.tenant-typography-preset-applied {
  outline: 4px solid var(--typography-preset-accent, #111) !important;
}

.tenant-typography-preset-button .typography-preset-name {
  font-weight: 800;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.tenant-typography-preset-button .typography-preset-tone {
  justify-self: start;
  padding: 0.18rem 0.55rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--typography-preset-accent, #111) 18%, #fff);
  font-size: 0.76rem;
  font-weight: 700;
}

.tenant-typography-preset-button .typography-preset-heading {
  font-family: var(--typography-preset-heading, serif);
  font-size: 1.65rem;
  line-height: 1;
}

.tenant-typography-preset-button .typography-preset-body {
  font-family: var(--typography-preset-body, sans-serif);
  font-size: 0.98rem;
  line-height: 1.35;
}

.tenant-typography-preset-button .typography-preset-description {
  color: rgba(25, 23, 20, 0.72);
  font-size: 0.82rem;
  line-height: 1.35;
}


/* Tenant settings subpages keep the growing settings area navigable without
   hiding save behavior. Each subpage remains a normal form post. */
.tenant-settings-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin: 0 0 1.25rem;
  padding: 0.85rem;
  border: 1px solid rgba(31, 26, 20, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
}

.tenant-settings-subnav-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.4rem;
  padding: 0.52rem 0.9rem;
  border: 1px solid rgba(31, 26, 20, 0.18);
  border-radius: 999px;
  color: #2a241d;
  background: rgba(255, 255, 255, 0.72);
  font-weight: 700;
  text-decoration: none;
}

.tenant-settings-subnav-link:hover,
.tenant-settings-subnav-link:focus {
  border-color: rgba(31, 26, 20, 0.38);
  background: #fffaf0;
  color: #111;
}

.tenant-settings-subnav-link.is-active,
.tenant-settings-subnav-link[aria-current="page"] {
  border-color: #111;
  background: #111;
  color: #fff;
}

@media (max-width: 680px) {
  .tenant-settings-subnav {
    display: grid;
    grid-template-columns: 1fr;
  }

  .tenant-settings-subnav-link {
    justify-content: flex-start;
    width: 100%;
  }
}

/* End of file. */

/* Tenant palette buttons must beat the generic tenant-admin button rule above.
   The generic rule uses .tenant-admin-panel button with !important, so these
   selectors intentionally carry higher specificity and keep palette buttons
   visually representative of their palette instead of black admin pills. */
.tenant-admin-panel .tenant-palette-button,
.tenant-admin-panel fieldset .tenant-palette-button,
.tenant-admin-panel .admin-panel .tenant-palette-button {
  display: grid !important;
  gap: 0.5rem !important;
  align-content: start !important;
  min-height: 132px !important;
  padding: 0.9rem !important;
  border: 2px solid color-mix(in srgb, var(--palette-button-accent, #111) 62%, transparent) !important;
  border-radius: 16px !important;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--palette-button-accent, #c9a85f) 22%, transparent), transparent 58%),
    var(--palette-button-bg, #fff) !important;
  color: var(--palette-button-text, #1f1a14) !important;
  cursor: pointer !important;
  text-align: left !important;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08) !important;
  transition: transform 120ms ease, box-shadow 120ms ease, outline-color 120ms ease !important;
}

.tenant-admin-panel .tenant-palette-button:hover,
.tenant-admin-panel .tenant-palette-button:focus,
.tenant-admin-panel .tenant-palette-button[aria-pressed="true"] {
  border-color: var(--palette-button-accent, #111) !important;
  outline: 3px solid color-mix(in srgb, var(--palette-button-accent, #111) 28%, transparent) !important;
  box-shadow: 0 16px 38px rgba(0, 0, 0, 0.14) !important;
  transform: translateY(-1px) !important;
}

.tenant-admin-panel .tenant-palette-button-applied {
  outline: 4px solid var(--palette-button-accent, #111) !important;
}

.tenant-admin-panel .tenant-palette-button::after {
  background: color-mix(in srgb, var(--palette-button-accent, #111) 22%, transparent) !important;
  color: var(--palette-button-text, #1f1a14) !important;
}


/* Tenant typography preset buttons mirror color palettes: choose a preset, then tweak individual controls. */
.tenant-admin-panel .tenant-typography-presets,
.tenant-typography-presets {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 0.85rem;
  margin: 1rem 0 1.35rem;
}

.tenant-admin-panel .tenant-typography-preset-button,
.tenant-admin-panel fieldset .tenant-typography-preset-button,
.tenant-admin-panel .admin-panel .tenant-typography-preset-button,
.tenant-typography-preset-button {
  display: grid !important;
  gap: 0.45rem !important;
  min-height: 160px !important;
  padding: 0.95rem !important;
  border: 2px solid color-mix(in srgb, var(--typography-preset-accent, #111) 56%, transparent) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--typography-preset-accent, #111) 16%, transparent), transparent 62%),
    #fffaf4 !important;
  color: #191714 !important;
  cursor: pointer !important;
  text-align: left !important;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08) !important;
}

.tenant-admin-panel .tenant-typography-preset-button:hover,
.tenant-admin-panel .tenant-typography-preset-button:focus,
.tenant-admin-panel .tenant-typography-preset-button[aria-pressed="true"],
.tenant-typography-preset-button:hover,
.tenant-typography-preset-button:focus,
.tenant-typography-preset-button[aria-pressed="true"] {
  border-color: var(--typography-preset-accent, #111) !important;
  outline: 3px solid color-mix(in srgb, var(--typography-preset-accent, #111) 24%, transparent) !important;
  transform: translateY(-1px) !important;
}

.tenant-typography-preset-applied {
  outline: 4px solid var(--typography-preset-accent, #111) !important;
}

.tenant-typography-preset-button .typography-preset-name {
  font-weight: 800;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.tenant-typography-preset-button .typography-preset-tone {
  justify-self: start;
  padding: 0.18rem 0.55rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--typography-preset-accent, #111) 18%, #fff);
  font-size: 0.76rem;
  font-weight: 700;
}

.tenant-typography-preset-button .typography-preset-heading {
  font-family: var(--typography-preset-heading, serif);
  font-size: 1.65rem;
  line-height: 1;
}

.tenant-typography-preset-button .typography-preset-body {
  font-family: var(--typography-preset-body, sans-serif);
  font-size: 0.98rem;
  line-height: 1.35;
}

.tenant-typography-preset-button .typography-preset-description {
  color: rgba(25, 23, 20, 0.72);
  font-size: 0.82rem;
  line-height: 1.35;
}


/* Tenant settings subpages keep the growing settings area navigable without
   hiding save behavior. Each subpage remains a normal form post. */
.tenant-settings-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin: 0 0 1.25rem;
  padding: 0.85rem;
  border: 1px solid rgba(31, 26, 20, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
}

.tenant-settings-subnav-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.4rem;
  padding: 0.52rem 0.9rem;
  border: 1px solid rgba(31, 26, 20, 0.18);
  border-radius: 999px;
  color: #2a241d;
  background: rgba(255, 255, 255, 0.72);
  font-weight: 700;
  text-decoration: none;
}

.tenant-settings-subnav-link:hover,
.tenant-settings-subnav-link:focus {
  border-color: rgba(31, 26, 20, 0.38);
  background: #fffaf0;
  color: #111;
}

.tenant-settings-subnav-link.is-active,
.tenant-settings-subnav-link[aria-current="page"] {
  border-color: #111;
  background: #111;
  color: #fff;
}

@media (max-width: 680px) {
  .tenant-settings-subnav {
    display: grid;
    grid-template-columns: 1fr;
  }

  .tenant-settings-subnav-link {
    justify-content: flex-start;
    width: 100%;
  }
}

/* End of file. */

/* Tenant typography controls. Font pickers use local/system font stacks only and
   show a preview sample beside each select so admins can see the tone before
   saving the full settings form. */
.tenant-typography-grid .tenant-font-picker {
  width: 100% !important;
}

.tenant-typography-grid .font-picker-preview {
  display: block;
  margin-top: 0.35rem;
  padding: 0.5rem 0.65rem;
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.72);
  color: #1f1a14;
}

/* Tenant typography preset buttons mirror color palettes: choose a preset, then tweak individual controls. */
.tenant-admin-panel .tenant-typography-presets,
.tenant-typography-presets {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 0.85rem;
  margin: 1rem 0 1.35rem;
}

.tenant-admin-panel .tenant-typography-preset-button,
.tenant-admin-panel fieldset .tenant-typography-preset-button,
.tenant-admin-panel .admin-panel .tenant-typography-preset-button,
.tenant-typography-preset-button {
  display: grid !important;
  gap: 0.45rem !important;
  min-height: 160px !important;
  padding: 0.95rem !important;
  border: 2px solid color-mix(in srgb, var(--typography-preset-accent, #111) 56%, transparent) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--typography-preset-accent, #111) 16%, transparent), transparent 62%),
    #fffaf4 !important;
  color: #191714 !important;
  cursor: pointer !important;
  text-align: left !important;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08) !important;
}

.tenant-admin-panel .tenant-typography-preset-button:hover,
.tenant-admin-panel .tenant-typography-preset-button:focus,
.tenant-admin-panel .tenant-typography-preset-button[aria-pressed="true"],
.tenant-typography-preset-button:hover,
.tenant-typography-preset-button:focus,
.tenant-typography-preset-button[aria-pressed="true"] {
  border-color: var(--typography-preset-accent, #111) !important;
  outline: 3px solid color-mix(in srgb, var(--typography-preset-accent, #111) 24%, transparent) !important;
  transform: translateY(-1px) !important;
}

.tenant-typography-preset-applied {
  outline: 4px solid var(--typography-preset-accent, #111) !important;
}

.tenant-typography-preset-button .typography-preset-name {
  font-weight: 800;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.tenant-typography-preset-button .typography-preset-tone {
  justify-self: start;
  padding: 0.18rem 0.55rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--typography-preset-accent, #111) 18%, #fff);
  font-size: 0.76rem;
  font-weight: 700;
}

.tenant-typography-preset-button .typography-preset-heading {
  font-family: var(--typography-preset-heading, serif);
  font-size: 1.65rem;
  line-height: 1;
}

.tenant-typography-preset-button .typography-preset-body {
  font-family: var(--typography-preset-body, sans-serif);
  font-size: 0.98rem;
  line-height: 1.35;
}

.tenant-typography-preset-button .typography-preset-description {
  color: rgba(25, 23, 20, 0.72);
  font-size: 0.82rem;
  line-height: 1.35;
}


/* Tenant settings subpages keep the growing settings area navigable without
   hiding save behavior. Each subpage remains a normal form post. */
.tenant-settings-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin: 0 0 1.25rem;
  padding: 0.85rem;
  border: 1px solid rgba(31, 26, 20, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
}

.tenant-settings-subnav-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.4rem;
  padding: 0.52rem 0.9rem;
  border: 1px solid rgba(31, 26, 20, 0.18);
  border-radius: 999px;
  color: #2a241d;
  background: rgba(255, 255, 255, 0.72);
  font-weight: 700;
  text-decoration: none;
}

.tenant-settings-subnav-link:hover,
.tenant-settings-subnav-link:focus {
  border-color: rgba(31, 26, 20, 0.38);
  background: #fffaf0;
  color: #111;
}

.tenant-settings-subnav-link.is-active,
.tenant-settings-subnav-link[aria-current="page"] {
  border-color: #111;
  background: #111;
  color: #fff;
}

@media (max-width: 680px) {
  .tenant-settings-subnav {
    display: grid;
    grid-template-columns: 1fr;
  }

  .tenant-settings-subnav-link {
    justify-content: flex-start;
    width: 100%;
  }
}

/* End of file. */

/* Tenant typography size controls use sliders and numeric fields instead of
   raw CSS text boxes so admins can make visible adjustments without knowing
   clamp(), rem, or other CSS sizing syntax. */
.tenant-admin-panel .tenant-font-size-control {
  display: grid !important;
  gap: 0.45rem !important;
  align-content: start !important;
}

.tenant-admin-panel .tenant-font-size-label {
  font-weight: 700 !important;
}

.tenant-admin-panel .tenant-font-size-row {
  display: grid !important;
  grid-template-columns: minmax(160px, 1fr) 5.25rem auto !important;
  gap: 0.55rem !important;
  align-items: center !important;
}

.tenant-admin-panel input.tenant-font-size-range[type="range"] {
  appearance: auto !important;
  -webkit-appearance: auto !important;
  width: 100% !important;
  height: 2rem !important;
  min-height: 2rem !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  cursor: ew-resize !important;
  pointer-events: auto !important;
}

.tenant-admin-panel input.tenant-font-size-number[type="number"] {
  width: 100% !important;
}

.tenant-admin-panel .tenant-font-size-unit {
  color: #5c5145 !important;
  font-weight: 700 !important;
}

.tenant-admin-panel .tenant-font-size-control .admin-help {
  margin: 0 !important;
}


/* Tenant typography preset buttons mirror color palettes: choose a preset, then tweak individual controls. */
.tenant-admin-panel .tenant-typography-presets,
.tenant-typography-presets {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 0.85rem;
  margin: 1rem 0 1.35rem;
}

.tenant-admin-panel .tenant-typography-preset-button,
.tenant-admin-panel fieldset .tenant-typography-preset-button,
.tenant-admin-panel .admin-panel .tenant-typography-preset-button,
.tenant-typography-preset-button {
  display: grid !important;
  gap: 0.45rem !important;
  min-height: 160px !important;
  padding: 0.95rem !important;
  border: 2px solid color-mix(in srgb, var(--typography-preset-accent, #111) 56%, transparent) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--typography-preset-accent, #111) 16%, transparent), transparent 62%),
    #fffaf4 !important;
  color: #191714 !important;
  cursor: pointer !important;
  text-align: left !important;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08) !important;
}

.tenant-admin-panel .tenant-typography-preset-button:hover,
.tenant-admin-panel .tenant-typography-preset-button:focus,
.tenant-admin-panel .tenant-typography-preset-button[aria-pressed="true"],
.tenant-typography-preset-button:hover,
.tenant-typography-preset-button:focus,
.tenant-typography-preset-button[aria-pressed="true"] {
  border-color: var(--typography-preset-accent, #111) !important;
  outline: 3px solid color-mix(in srgb, var(--typography-preset-accent, #111) 24%, transparent) !important;
  transform: translateY(-1px) !important;
}

.tenant-typography-preset-applied {
  outline: 4px solid var(--typography-preset-accent, #111) !important;
}

.tenant-typography-preset-button .typography-preset-name {
  font-weight: 800;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.tenant-typography-preset-button .typography-preset-tone {
  justify-self: start;
  padding: 0.18rem 0.55rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--typography-preset-accent, #111) 18%, #fff);
  font-size: 0.76rem;
  font-weight: 700;
}

.tenant-typography-preset-button .typography-preset-heading {
  font-family: var(--typography-preset-heading, serif);
  font-size: 1.65rem;
  line-height: 1;
}

.tenant-typography-preset-button .typography-preset-body {
  font-family: var(--typography-preset-body, sans-serif);
  font-size: 0.98rem;
  line-height: 1.35;
}

.tenant-typography-preset-button .typography-preset-description {
  color: rgba(25, 23, 20, 0.72);
  font-size: 0.82rem;
  line-height: 1.35;
}


/* Tenant settings subpages keep the growing settings area navigable without
   hiding save behavior. Each subpage remains a normal form post. */
.tenant-settings-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin: 0 0 1.25rem;
  padding: 0.85rem;
  border: 1px solid rgba(31, 26, 20, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
}

.tenant-settings-subnav-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.4rem;
  padding: 0.52rem 0.9rem;
  border: 1px solid rgba(31, 26, 20, 0.18);
  border-radius: 999px;
  color: #2a241d;
  background: rgba(255, 255, 255, 0.72);
  font-weight: 700;
  text-decoration: none;
}

.tenant-settings-subnav-link:hover,
.tenant-settings-subnav-link:focus {
  border-color: rgba(31, 26, 20, 0.38);
  background: #fffaf0;
  color: #111;
}

.tenant-settings-subnav-link.is-active,
.tenant-settings-subnav-link[aria-current="page"] {
  border-color: #111;
  background: #111;
  color: #fff;
}

@media (max-width: 680px) {
  .tenant-settings-subnav {
    display: grid;
    grid-template-columns: 1fr;
  }

  .tenant-settings-subnav-link {
    justify-content: flex-start;
    width: 100%;
  }
}

/* End of file. */
/* Tenant dashboard actions intentionally match Portfolio Sections action cards. */
.tenant-admin-action-button{display:flex!important;flex-direction:column!important;align-items:flex-start!important;gap:.35rem!important;padding:1rem 1.1rem!important;border-radius:14px!important;text-decoration:none!important;min-height:104px!important}.tenant-admin-action-button strong{font-size:1rem!important}.tenant-admin-action-button span{font-size:.9rem!important;font-weight:500!important;line-height:1.35!important;opacity:.85!important}
/* End of file. */
/* Shared responsive action-card grid for tenant admin workbenches. */
.tenant-admin-action-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin:1.25rem 0 1.5rem}
/* End of file. */

/* Tenant admin sidebar primary action follows the active tenant palette. */
.tenant-admin-sidebar-upload {
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  margin: 0 0 1.1rem;
  padding: 0.85rem 1rem !important;
  border: 2px solid var(--accent, #c9a85f);
  border-radius: 999px !important;
  background: var(--tenant-topbar-bg, var(--primary, #111827)) !important;
  color: var(--tenant-topbar-text, #f8efe1) !important;
  font-weight: 900;
  text-align: center;
  text-decoration: none;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.24);
  transition:
    background-color 140ms ease,
    border-color 140ms ease,
    box-shadow 140ms ease,
    transform 140ms ease;
}

.tenant-admin-sidebar-upload:hover,
.tenant-admin-sidebar-upload:focus-visible {
  background: color-mix(
    in srgb,
    var(--tenant-topbar-bg, var(--primary, #111827)) 86%,
    var(--accent, #c9a85f)
  ) !important;
  border-color: color-mix(in srgb, var(--accent, #c9a85f) 78%, #fff);
  color: var(--tenant-topbar-text, #f8efe1) !important;
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.3);
  transform: translateY(-1px);
}

.tenant-admin-sidebar-upload:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--accent, #c9a85f) 72%, #fff);
  outline-offset: 3px;
}

.tenant-admin-sidebar-upload span {
  font-size: 1.25rem;
  line-height: 1;
}

/* End of file. */

/* Platform logo intrinsic-ratio repair. */
.platform-admin-topbar > .platform-admin-logo {
    display: inline-flex;
    flex: 0 0 auto;
    align-items: center;
    width: auto;
    max-width: min(220px, 34vw);
}

.platform-admin-topbar > .platform-admin-logo img {
    display: block;
    width: auto !important;
    height: auto !important;
    max-width: 100% !important;
    max-height: 54px !important;
    object-fit: contain;
    aspect-ratio: auto;
}

/* End of file. */
