:root {
  --bg: #f4f6ff;
  --bg-soft: #eef2ff;
  --panel: #ffffff;
  --line: #dce3ff;
  --line-strong: #c8d3ff;
  --text: #13182f;
  --muted: #667091;
  --accent: #4d5bff;
  --accent-2: #6f78ff;
  --good: #0c9f6f;
  --warn: #f59f0a;
  --bad: #ef4444;
  --shadow: 0 14px 30px rgba(46, 65, 165, 0.1);
  --workspace-content-max-width: 1380px;
  --workspace-section-gap: 16px;
  --workspace-element-gap: 12px;
  --workspace-panel-padding: 16px;
  --workspace-form-min-col: 180px;
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100%;
}

body {
  font-family: "Space Grotesk", "Manrope", "Avenir Next", sans-serif;
  color: var(--text);
  background: linear-gradient(180deg, #ffffff 0%, var(--bg) 80%);
}

h1,
h2,
h3,
h4 {
  font-family: "Sora", "Space Grotesk", sans-serif;
}

.hidden {
  display: none !important;
}

.aurora {
  position: fixed;
  border-radius: 999px;
  filter: blur(70px);
  opacity: 0.2;
  z-index: -1;
}

.aurora-a {
  width: 300px;
  height: 300px;
  background: #8aa0ff;
  top: -60px;
  right: 5%;
}

.aurora-b {
  width: 360px;
  height: 360px;
  background: #87dbff;
  bottom: -80px;
  left: 4%;
}

.auth-shell {
  max-width: 1240px;
  margin: 0 auto;
  padding: 40px 18px;
  display: grid;
  gap: 18px;
}

.auth-intro {
  background: linear-gradient(135deg, #edf1ff 0%, #ffffff 100%);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 28px;
}

.auth-intro h1 {
  font-size: clamp(32px, 4vw, 52px);
  line-height: 1.08;
  margin: 0 0 12px;
}

.auth-intro p {
  margin: 0;
  font-size: 17px;
  color: var(--muted);
  max-width: 760px;
}

.auth-shell-admin {
  padding-top: 34px;
  padding-bottom: 34px;
  gap: 16px;
}

.admin-auth-intro {
  border-radius: 22px;
  border-color: #cfd9ff;
  background:
    radial-gradient(100% 180% at 100% -12%, rgba(116, 134, 255, 0.22), transparent 45%),
    linear-gradient(135deg, #eef2ff 0%, #ffffff 58%, #f0f4ff 100%);
  padding: 28px;
  display: grid;
  gap: 18px;
}

.admin-auth-intro-main p {
  max-width: 68ch;
}

.admin-auth-intro-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.admin-auth-meta-item {
  border: 1px solid #d4ddff;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.72);
  padding: 10px 12px;
  display: grid;
  gap: 4px;
}

.admin-auth-meta-item strong {
  font-size: 13px;
  color: #22307d;
}

.admin-auth-meta-item span {
  color: #4f5e93;
  font-size: 12px;
  line-height: 1.45;
}

.admin-auth-panels {
  grid-template-columns: minmax(0, 1fr) minmax(360px, 470px);
  align-items: stretch;
  gap: 14px;
}

.admin-auth-info {
  padding: 22px;
  background: linear-gradient(180deg, #ffffff 0%, #f8faff 100%);
  border-color: #d5dfff;
}

.admin-auth-info h2 {
  margin: 0 0 10px;
  font-size: 31px;
  line-height: 1.1;
}

.admin-auth-checklist {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
}

.admin-auth-checklist li {
  position: relative;
  padding-left: 16px;
  color: #344069;
  line-height: 1.5;
  font-weight: 600;
}

.admin-auth-checklist li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.58em;
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);
}

.admin-auth-security {
  margin: 14px 0 0;
  font-size: 13px;
  color: #55638f;
  border-top: 1px dashed #d5dcf8;
  padding-top: 12px;
}

.eyebrow {
  display: inline-block;
  margin-bottom: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  background: #e2e9ff;
  color: var(--accent);
  font-weight: 700;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.marketing-wrap {
  width: min(94vw, 1220px);
  margin: 0 auto;
}

.marketing-page {
  --mk-bg-0: #ffffff;
  --mk-bg-1: var(--bg);
  --mk-bg-2: var(--bg-soft);
  --mk-ink: var(--text);
  --mk-muted: var(--muted);
  --mk-line: var(--line);
  --mk-line-strong: var(--line-strong);
  --mk-accent: var(--accent);
  --mk-accent-2: var(--accent-2);
  --mk-accent-soft: var(--bg-soft);
  --mk-card: var(--panel);
  --mk-shadow: var(--shadow);
  font-family: "Plus Jakarta Sans", "Space Grotesk", "Avenir Next", sans-serif;
  color: var(--mk-ink);
  background:
    radial-gradient(1200px 360px at 14% -18%, rgba(77, 91, 255, 0.15), transparent 58%),
    radial-gradient(1000px 360px at 90% 8%, rgba(111, 120, 255, 0.13), transparent 60%),
    linear-gradient(180deg, var(--mk-bg-0) 0%, var(--mk-bg-1) 52%, #f8faff 100%);
}

.marketing-page .eyebrow {
  background: #e2e9ff;
  color: var(--accent);
  letter-spacing: 0.05em;
}

.mk-bg {
  position: fixed;
  border-radius: 999px;
  filter: blur(68px);
  pointer-events: none;
  z-index: -2;
  opacity: 0.55;
}

.mk-bg-a {
  width: 360px;
  height: 360px;
  top: -120px;
  right: 8%;
  background: rgba(77, 91, 255, 0.24);
}

.mk-bg-b {
  width: 440px;
  height: 440px;
  left: -130px;
  bottom: -200px;
  background: rgba(111, 120, 255, 0.2);
}

.mk-bg-c {
  width: 300px;
  height: 300px;
  right: 24%;
  top: 46%;
  background: rgba(77, 91, 255, 0.15);
  filter: blur(82px);
}

.marketing-page .btn {
  border-color: transparent;
  background: linear-gradient(135deg, var(--mk-accent) 0%, var(--mk-accent-2) 100%);
  box-shadow: 0 10px 20px rgba(15, 122, 199, 0.22);
  color: #fff;
}

.marketing-page .btn-soft {
  background: #fff;
  border-color: var(--mk-line-strong);
  color: var(--mk-accent);
  box-shadow: none;
}

.marketing-page .btn-soft:hover {
  background: var(--mk-accent-soft);
}

.marketing-top {
  position: sticky;
  top: 0;
  z-index: 20;
  border-bottom: 1px solid var(--mk-line);
  background: rgba(247, 252, 255, 0.84);
  backdrop-filter: blur(10px);
}

.mk-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 0;
}

.mk-brand-link {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: inherit;
}

.mk-logo-shell {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  border: 1px solid var(--mk-line-strong);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 8px 20px rgba(27, 80, 130, 0.09);
}

.mk-logo {
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: #fff;
  padding: 6px;
}

.mk-logo-mark {
  font-family: "Space Grotesk", "Plus Jakarta Sans", sans-serif;
  font-size: 14px;
  font-weight: 800;
  color: var(--accent);
}

.marketing-brand {
  font-family: "Space Grotesk", "Plus Jakarta Sans", sans-serif;
  font-size: clamp(21px, 2.2vw, 27px);
  font-weight: 700;
  letter-spacing: 0.01em;
}

.marketing-nav {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}

.marketing-nav a:not(.btn) {
  text-decoration: none;
  font-weight: 600;
  color: #2a355f;
  border-radius: 10px;
  padding: 8px 10px;
}

.marketing-nav a:not(.btn):hover {
  background: #eaf0ff;
}

.mk-hero {
  padding: 40px 0 20px;
}

.mk-hero-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
  align-items: center;
  gap: 24px;
}

.mk-hero-copy {
  animation: mk-rise 600ms ease both;
}

.mk-hero-copy h1 {
  margin: 0 0 12px;
  max-width: 18ch;
  font-size: clamp(34px, 6vw, 62px);
  line-height: 1.02;
}

.mk-hero-copy p {
  margin: 0 0 18px;
  max-width: 58ch;
  color: var(--mk-muted);
  font-size: 18px;
  line-height: 1.6;
}

.mk-stage {
  position: relative;
  border-color: var(--mk-line);
  background:
    linear-gradient(145deg, #f3f6ff 0%, #ffffff 52%, #eef2ff 100%);
  padding: 14px;
  overflow: hidden;
  box-shadow: var(--mk-shadow);
  animation: mk-rise 700ms ease both;
}

.mk-stage::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(rgba(255, 255, 255, 0.4) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.45) 1px, transparent 1px);
  background-size: 24px 24px;
  opacity: 0.6;
  pointer-events: none;
}

.mk-browser {
  position: relative;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fff;
  overflow: hidden;
  z-index: 1;
}

.mk-browser-top {
  height: 34px;
  border-bottom: 1px solid var(--line);
  background: var(--bg-soft);
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 0 12px;
}

.mk-browser-top span {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: #c5d3ff;
}

.mk-browser-body {
  min-height: 250px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  padding: 10px;
}

.mk-browser-col {
  display: grid;
  gap: 10px;
}

.mk-ui-card {
  border-radius: 10px;
  border: 1px solid var(--line);
  background:
    linear-gradient(180deg, #f5f7ff 0%, #ffffff 100%);
  min-height: 80px;
}

.mk-ui-card-highlight {
  background:
    linear-gradient(135deg, rgba(77, 91, 255, 0.18) 0%, rgba(111, 120, 255, 0.06) 100%),
    linear-gradient(180deg, #f5f7ff 0%, #ffffff 100%);
}

.mk-ui-card-wide {
  min-height: 140px;
}

.mk-ui-card-tall {
  min-height: 230px;
}

.mk-stage-floating {
  position: absolute;
  min-width: 178px;
  max-width: 210px;
  border-radius: 12px;
  padding: 10px 12px;
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: 0 18px 30px rgba(39, 54, 129, 0.14);
  z-index: 2;
  animation: mk-float 5s ease-in-out infinite;
}

.mk-stage-floating strong {
  display: block;
  margin-bottom: 4px;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--accent);
}

.mk-stage-floating p {
  margin: 0;
  color: #4a557f;
  font-size: 13px;
}

.mk-stage-note-a {
  top: 18px;
  right: -18px;
}

.mk-stage-note-b {
  bottom: 22px;
  left: -16px;
  animation-delay: 1.2s;
}

.mk-metrics {
  margin-top: 18px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.mk-metric {
  border-color: var(--mk-line);
  background: rgba(255, 255, 255, 0.9);
}

.mk-metric h4 {
  color: #4d6580;
}

.mk-metric strong {
  font-size: clamp(24px, 3vw, 30px);
  color: #173a5a;
}

.mk-section {
  padding: 58px 0 12px;
}

.mk-section-alt {
  margin-top: 22px;
  padding: 42px 0 24px;
  border-top: 1px solid #dde9f7;
  border-bottom: 1px solid #dde9f7;
  background: linear-gradient(180deg, rgba(241, 248, 255, 0.7) 0%, rgba(250, 253, 255, 0.8) 100%);
}

.mk-section-head {
  max-width: 780px;
  margin-bottom: 22px;
}

.mk-section-head h2 {
  margin: 0;
  font-size: clamp(29px, 4.2vw, 45px);
  line-height: 1.1;
}

.mk-process-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.mk-process-card {
  min-height: 210px;
  border-color: #d6e4f3;
  background: var(--mk-card);
  box-shadow: 0 10px 22px rgba(31, 74, 118, 0.08);
}

.mk-step-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 4px 10px;
  margin-bottom: 8px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--accent);
  background: #e2e9ff;
}

.mk-process-card h3 {
  margin: 0 0 8px;
  font-size: 21px;
}

.mk-process-card p {
  margin: 0;
  line-height: 1.6;
  color: var(--mk-muted);
}

.mk-story-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
  gap: 16px;
}

.mk-convo-stack {
  display: grid;
  gap: 10px;
}

.mk-chat-bubble {
  border-radius: 14px;
  border: 1px solid var(--line);
  padding: 12px;
  max-width: 92%;
  box-shadow: 0 10px 22px rgba(39, 54, 129, 0.09);
  background: #fff;
}

.mk-chat-bubble strong {
  display: block;
  margin-bottom: 4px;
  font-size: 12px;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--accent);
}

.mk-chat-bubble p {
  margin: 0;
  color: #4a557f;
  font-size: 14px;
  line-height: 1.6;
}

.mk-chat-left {
  justify-self: start;
}

.mk-chat-right {
  justify-self: end;
  background: #eef2ff;
}

.mk-story-panel {
  border-color: var(--line);
  background:
    radial-gradient(circle at 90% 8%, rgba(77, 91, 255, 0.13) 0%, transparent 40%),
    #fff;
  padding: 18px;
}

.mk-story-panel h3 {
  margin: 0 0 8px;
  font-size: clamp(26px, 3.8vw, 39px);
  line-height: 1.12;
}

.mk-story-panel p {
  margin: 0 0 10px;
  color: var(--mk-muted);
  line-height: 1.7;
}

.mk-mini-checks {
  display: grid;
  gap: 8px;
}

.mk-mini-check {
  border-radius: 10px;
  border: 1px solid var(--line);
  background: #f5f7ff;
  padding: 9px 10px;
  color: #4a557f;
  font-weight: 600;
}

.mk-quote-band {
  padding: 12px 0 4px;
}

.mk-hero-quote {
  margin: 0;
  border-color: var(--line);
  border-radius: 18px;
  padding: 22px;
  text-align: center;
  font-size: clamp(21px, 3.1vw, 33px);
  line-height: 1.4;
  font-weight: 600;
  color: #2a355f;
  background:
    radial-gradient(circle at 0% 100%, rgba(77, 91, 255, 0.1) 0%, transparent 42%),
    radial-gradient(circle at 100% 0%, rgba(111, 120, 255, 0.11) 0%, transparent 44%),
    #fff;
}

.mk-feature-row {
  display: grid;
  grid-template-columns: minmax(0, 1.06fr) minmax(0, 0.94fr);
  gap: 18px;
  align-items: center;
}

.mk-feature-row + .mk-feature-row {
  margin-top: 24px;
}

.mk-feature-row-reverse {
  grid-template-columns: minmax(0, 0.94fr) minmax(0, 1.06fr);
}

.mk-feature-copy h3 {
  margin: 0 0 10px;
  font-size: clamp(28px, 4vw, 40px);
  line-height: 1.1;
}

.mk-feature-copy p {
  margin: 0 0 8px;
  color: var(--mk-muted);
  line-height: 1.65;
}

.mk-feature-visual {
  border-color: var(--mk-line);
  padding: 14px;
  background: #fff;
  box-shadow: 0 12px 26px rgba(39, 54, 129, 0.09);
}

.mk-visual-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: 1fr 1fr;
}

.mk-visual-panel {
  min-height: 100px;
  border-radius: 12px;
  border: 1px solid var(--line);
  background:
    linear-gradient(180deg, #f4f6ff 0%, #ffffff 100%);
}

.mk-visual-panel-wide {
  grid-column: 1 / -1;
  min-height: 138px;
}

.mk-automation-visual {
  position: relative;
  min-height: 280px;
  overflow: hidden;
}

.mk-node {
  position: absolute;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: #fff;
  padding: 9px 10px;
  min-width: 126px;
  text-align: center;
  font-weight: 700;
  color: #394165;
  z-index: 2;
}

.mk-node-a {
  top: 24px;
  left: 18px;
}

.mk-node-b {
  top: 24px;
  right: 20px;
}

.mk-node-c {
  bottom: 24px;
  left: 26px;
}

.mk-node-d {
  bottom: 24px;
  right: 16px;
}

.mk-link {
  position: absolute;
  height: 3px;
  background: linear-gradient(90deg, rgba(111, 120, 255, 0.2) 0%, rgba(77, 91, 255, 0.85) 100%);
  transform-origin: left center;
  z-index: 1;
}

.mk-link-ab {
  top: 56px;
  left: 150px;
  width: calc(100% - 302px);
}

.mk-link-bc {
  top: 126px;
  left: 160px;
  width: calc(100% - 320px);
  transform: rotate(38deg);
}

.mk-link-cd {
  bottom: 55px;
  left: 156px;
  width: calc(100% - 308px);
}

.mk-app-grid {
  margin-top: 18px;
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.mk-app-card {
  border-color: var(--line);
  box-shadow: 0 10px 24px rgba(39, 54, 129, 0.08);
}

.mk-app-thumb {
  height: 120px;
  margin-bottom: 10px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background:
    linear-gradient(145deg, #edf1ff 0%, #ffffff 48%, #f4f6ff 100%);
}

.mk-mobile-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 18px;
  align-items: center;
}

.mk-mobile-row h2 {
  margin: 0 0 10px;
  font-size: clamp(29px, 4.4vw, 46px);
  line-height: 1.1;
}

.mk-lead {
  margin: 0 0 12px;
  color: var(--mk-muted);
  line-height: 1.7;
  font-size: 17px;
}

.mk-device-stack {
  border-color: var(--line);
  min-height: 290px;
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 10% 10%, rgba(77, 91, 255, 0.14) 0%, transparent 45%),
    #fff;
}

.mk-device-phone,
.mk-device-tablet {
  position: absolute;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: linear-gradient(180deg, #f4f6ff 0%, #ffffff 100%);
  box-shadow: 0 12px 26px rgba(39, 54, 129, 0.11);
}

.mk-device-phone {
  width: 170px;
  height: 250px;
  left: 12%;
  bottom: 14px;
}

.mk-device-tablet {
  width: 62%;
  height: 210px;
  right: 9%;
  top: 18px;
}

.mk-map-panel {
  border-color: var(--line);
  overflow: hidden;
}

.mk-map-canvas {
  min-height: 310px;
  position: relative;
  background:
    linear-gradient(rgba(220, 227, 255, 0.62) 1px, transparent 1px),
    linear-gradient(90deg, rgba(220, 227, 255, 0.62) 1px, transparent 1px),
    #f8faff;
  background-size: 32px 32px;
}

.mk-map-node {
  position: absolute;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: #fff;
  padding: 8px 10px;
  color: #394165;
  font-weight: 700;
  box-shadow: 0 10px 20px rgba(39, 54, 129, 0.11);
  z-index: 2;
}

.mk-map-node-1 {
  left: 6%;
  top: 42%;
}

.mk-map-node-2 {
  left: 24%;
  top: 24%;
}

.mk-map-node-3 {
  left: 44%;
  top: 53%;
}

.mk-map-node-4 {
  left: 62%;
  top: 27%;
}

.mk-map-node-5 {
  left: 80%;
  top: 54%;
}

.mk-map-line {
  position: absolute;
  height: 3px;
  background: linear-gradient(90deg, rgba(111, 120, 255, 0.24) 0%, rgba(77, 91, 255, 0.8) 100%);
  transform-origin: left center;
  z-index: 1;
}

.mk-map-line-12 {
  left: 13%;
  top: 45%;
  width: 14%;
  transform: rotate(-30deg);
}

.mk-map-line-23 {
  left: 31%;
  top: 33%;
  width: 16%;
  transform: rotate(28deg);
}

.mk-map-line-34 {
  left: 50%;
  top: 52%;
  width: 15%;
  transform: rotate(-33deg);
}

.mk-map-line-45 {
  left: 70%;
  top: 35%;
  width: 14%;
  transform: rotate(30deg);
}

.mk-workflow-benefits {
  margin-top: 12px;
}

.mk-task-panel {
  margin-top: 12px;
  border-color: var(--line);
  padding: 16px;
}

.mk-task-panel h3 {
  margin: 0 0 8px;
  font-size: clamp(24px, 3.2vw, 35px);
  line-height: 1.14;
}

.mk-results-panel {
  border-color: var(--line);
  padding: 14px;
  margin-bottom: 14px;
}

.mk-results-screen {
  border-radius: 12px;
  border: 1px solid var(--line);
  background: #fff;
  padding: 8px;
  display: grid;
  gap: 8px;
}

.mk-results-row {
  border-radius: 8px;
  border: 1px solid var(--line);
  height: 54px;
  background:
    linear-gradient(145deg, #f4f6ff 0%, #ffffff 100%);
}

.mk-results-pills {
  margin-top: 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.mk-results-pills span {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: #eef2ff;
  color: #4a557f;
  font-size: 12px;
  font-weight: 700;
  padding: 6px 10px;
}

.mk-pricing-core {
  margin-bottom: 14px;
  border-color: #cfd9fb;
  background: linear-gradient(120deg, rgba(80, 100, 255, 0.08) 0%, rgba(255, 255, 255, 0.95) 52%);
}

.mk-pricing-core-label {
  margin: 0 0 4px;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #40539d;
  font-weight: 700;
}

.mk-pricing-core-copy {
  margin: 0;
  font-size: 14px;
  color: #41538b;
}

.mk-pricing-lane + .mk-pricing-lane {
  margin-top: 14px;
}

.mk-pricing-lane-label {
  margin: 0 0 8px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #4b5f9d;
}

.mk-plan-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: stretch;
  gap: 14px;
}

.mk-plan-card {
  border-color: #d1daf8;
  box-shadow: 0 10px 22px rgba(39, 54, 129, 0.08);
  display: flex;
  flex-direction: column;
  gap: 9px;
  min-height: 100%;
  padding: 16px;
}

.mk-plan-card-featured {
  position: relative;
  border-color: #7f92ff;
  background:
    linear-gradient(170deg, rgba(88, 108, 255, 0.1) 0%, rgba(255, 255, 255, 0.96) 30%),
    #fff;
  box-shadow:
    0 16px 30px rgba(41, 58, 140, 0.13),
    0 0 0 1px rgba(104, 126, 255, 0.2) inset;
}

.mk-plan-badge {
  margin: 0;
  width: fit-content;
  border-radius: 999px;
  border: 1px solid #9fb0ff;
  background: #edf1ff;
  color: #334da8;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  padding: 4px 9px;
}

.mk-plan-card h3 {
  font-size: 28px;
  margin: 0;
  line-height: 1.05;
  letter-spacing: -0.01em;
}

.mk-plan-card-price {
  margin: 0;
  font-size: 36px;
  font-weight: 800;
  color: #273a91;
  line-height: 1.02;
}

.mk-plan-card-price span {
  margin-left: 4px;
  font-size: 14px;
  font-weight: 700;
  color: #52629a;
}

.mk-plan-card-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.mk-plan-card-stats span {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid #c7d3fc;
  background: #f5f8ff;
  color: #3d4f89;
  font-size: 11px;
  font-weight: 700;
  padding: 4px 8px;
}

.mk-plan-fit {
  margin: 0;
  font-size: 13px;
  color: #506097;
}

.mk-plan-unique-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 5px;
}

.mk-plan-unique-list li {
  position: relative;
  padding-left: 14px;
  line-height: 1.42;
  font-size: 13px;
  color: #334473;
}

.mk-plan-unique-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 7px;
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: #5f74ff;
}

.mk-enterprise-estimator {
  margin: 2px 0 0;
  padding-top: 8px;
  border-top: 1px dashed #cfd9fb;
}

.mk-enterprise-estimator summary {
  cursor: pointer;
  list-style: none;
  font-size: 12px;
  font-weight: 700;
  color: #5364a1;
}

.mk-enterprise-estimator summary::-webkit-details-marker {
  display: none;
}

.mk-enterprise-estimator summary::after {
  content: "+";
  float: right;
  color: #6a7cbc;
}

.mk-enterprise-estimator[open] summary::after {
  content: "−";
}

.mk-enterprise-slider {
  margin-top: 7px;
  padding: 8px 10px;
  border: 1px solid #dde6ff;
  border-radius: 10px;
  background: #f9fbff;
}

.mk-enterprise-slider label {
  display: block;
  margin-bottom: 3px;
  font-size: 11px;
  font-weight: 700;
  color: #5b6b9c;
}

.mk-enterprise-slider input[type="range"] {
  width: 100%;
  accent-color: #5a6fd7;
  opacity: 0.85;
}

.mk-enterprise-slider-readout {
  margin: 6px 0 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 2px;
}

.mk-enterprise-slider-readout strong {
  font-size: 15px;
  color: #3c519f;
  font-weight: 700;
}

.mk-enterprise-slider-readout span,
.mk-enterprise-slider-readout small {
  font-size: 11px;
  color: #6174af;
}

.mk-plan-choose {
  margin-top: auto;
  width: 100%;
}

body.mk-auth-open {
  overflow: hidden;
}

.mk-auth-modal {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: grid;
  place-items: center;
  padding: 20px;
}

.mk-auth-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(17, 24, 39, 0.58);
}

.mk-auth-modal-card {
  position: relative;
  z-index: 1;
  width: min(560px, 100%);
  padding: 20px;
  border-radius: 14px;
  display: grid;
  gap: 12px;
  box-shadow: 0 24px 56px rgba(21, 33, 71, 0.28);
}

.mk-auth-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.mk-auth-modal-head h3 {
  margin: 0;
  font-size: 29px;
}

.mk-auth-tabs {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.mk-auth-plan {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: #eef2ff;
  color: #33459b;
  font-size: 12px;
  font-weight: 700;
}

.mk-auth-error {
  color: var(--bad);
}

.coming-page {
  --coming-bg-0: #eef3ff;
  --coming-bg-1: #e3ecff;
  --coming-bg-2: #dae7ff;
  --coming-ink: #101b45;
  --coming-muted: #4a5d90;
  --coming-line: rgba(117, 148, 223, 0.38);
  --coming-line-strong: rgba(122, 162, 255, 0.72);
  --coming-accent: #2a66ff;
  --coming-accent-2: #18a8dd;
  --coming-panel: rgba(9, 24, 64, 0.74);
  --coming-panel-2: rgba(16, 39, 96, 0.82);
  position: relative;
  isolation: isolate;
  min-height: 100vh;
  overflow-x: clip;
  font-family: "Plus Jakarta Sans", "Space Grotesk", "Avenir Next", sans-serif;
  color: var(--coming-ink);
  background:
    radial-gradient(980px 440px at 8% -18%, rgba(28, 113, 233, 0.28), transparent 60%),
    radial-gradient(920px 420px at 98% -12%, rgba(30, 189, 222, 0.22), transparent 58%),
    radial-gradient(740px 300px at 46% 98%, rgba(38, 109, 234, 0.12), transparent 65%),
    linear-gradient(180deg, var(--coming-bg-0) 0%, var(--coming-bg-1) 58%, var(--coming-bg-2) 100%);
}

.coming-page .btn {
  border-color: transparent;
  background: linear-gradient(125deg, var(--coming-accent) 0%, var(--coming-accent-2) 100%);
  color: #fff;
  box-shadow: 0 10px 24px rgba(24, 80, 174, 0.25);
}

.coming-page .btn-soft {
  background: #fff;
  color: var(--coming-accent);
  border-color: var(--coming-line-strong);
  box-shadow: none;
}

.coming-page .btn-soft:hover {
  background: #ecf5ff;
}

.coming-wrap {
  width: min(94vw, 1160px);
  margin: 0 auto;
}

.coming-ui-hint {
  position: fixed;
  inset: 84px 0 18px;
  pointer-events: none;
  z-index: 0;
  display: grid;
  place-items: center;
  opacity: 0.16;
}

.coming-ui-frame {
  position: relative;
  width: min(96vw, 1340px);
  height: min(80vh, 820px);
  border-radius: 26px;
  border: 1px solid rgba(92, 129, 208, 0.44);
  background: linear-gradient(150deg, rgba(39, 77, 157, 0.13) 0%, rgba(67, 114, 198, 0.08) 100%);
  box-shadow: inset 0 1px 0 rgba(195, 220, 255, 0.24), 0 20px 44px rgba(24, 63, 134, 0.22);
  overflow: hidden;
}

.coming-ui-header,
.coming-ui-sidebar,
.coming-ui-panel {
  position: absolute;
  border: 1px solid rgba(98, 143, 224, 0.5);
  border-radius: 16px;
  background: linear-gradient(150deg, rgba(106, 155, 240, 0.2) 0%, rgba(95, 151, 242, 0.08) 100%);
}

.coming-ui-header {
  top: 16px;
  left: 16px;
  right: 16px;
  height: 62px;
  border-radius: 14px;
}

.coming-ui-sidebar {
  top: 92px;
  left: 16px;
  bottom: 16px;
  width: 208px;
}

.coming-ui-panel-a {
  top: 92px;
  left: 238px;
  right: 16px;
  height: 184px;
}

.coming-ui-panel-b {
  top: 290px;
  left: 238px;
  width: 38%;
  height: 154px;
}

.coming-ui-panel-c {
  top: 290px;
  right: 16px;
  width: 34%;
  height: 154px;
}

.coming-ui-panel-d {
  top: 458px;
  left: 238px;
  width: 28%;
  bottom: 16px;
}

.coming-ui-panel-e {
  top: 458px;
  left: calc(238px + 30%);
  right: 16px;
  bottom: 16px;
}

.coming-top {
  position: sticky;
  top: 0;
  z-index: 10;
  background: rgba(233, 242, 255, 0.76);
  border-bottom: 1px solid var(--coming-line);
  backdrop-filter: blur(14px);
}

.coming-topbar {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 14px;
  padding: 14px 0;
}

.coming-brand-link {
  text-decoration: none;
  color: inherit;
  display: inline-flex;
  align-items: center;
  gap: 0;
}

.coming-brand-name {
  font-family: "Space Grotesk", "Plus Jakarta Sans", sans-serif;
  font-size: clamp(21px, 2.3vw, 31px);
  font-weight: 700;
  letter-spacing: 0.01em;
  text-transform: capitalize;
}

.coming-nav {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.coming-nav a:not(.btn) {
  text-decoration: none;
  color: #2d385e;
  font-weight: 600;
  border-radius: 10px;
  padding: 8px 10px;
}

.coming-nav a:not(.btn):hover {
  background: #e4edff;
}

.coming-main {
  position: relative;
  z-index: 1;
  padding: 30px 0 52px;
}

.coming-hero {
  padding: 18px 0 20px;
}

.coming-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  gap: 24px;
  align-items: stretch;
}

.coming-copy {
  animation: mk-rise 540ms ease both;
}

.coming-copy h1 {
  margin: 0 0 16px;
  line-height: 1.02;
  max-width: 17ch;
  font-size: clamp(40px, 5.8vw, 68px);
  letter-spacing: -0.018em;
  text-wrap: balance;
}

.coming-copy p {
  margin: 0;
  max-width: 56ch;
  color: var(--coming-muted);
  font-size: 18px;
  line-height: 1.6;
}

.coming-status-card {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(101, 150, 247, 0.5);
  border-radius: 24px;
  padding: 22px 22px;
  color: #f3f7ff;
  background:
    linear-gradient(155deg, var(--coming-panel) 0%, var(--coming-panel-2) 58%, rgba(15, 72, 134, 0.78) 100%);
  box-shadow: 0 22px 44px rgba(16, 42, 104, 0.28);
  backdrop-filter: blur(10px);
}

.coming-status-card::before {
  content: "";
  position: absolute;
  inset: -50% auto auto 52%;
  width: 220px;
  height: 220px;
  background: radial-gradient(circle, rgba(89, 180, 255, 0.28) 0%, rgba(89, 180, 255, 0) 70%);
  pointer-events: none;
}

.coming-status-card h2 {
  margin: 0;
  font-size: 32px;
  color: #f5f8ff;
  letter-spacing: -0.01em;
}

.coming-status-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 12px;
}

.coming-status-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 5px 10px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.02em;
  color: #d0ffe9;
  background: rgba(46, 187, 133, 0.2);
  border: 1px solid rgba(87, 216, 165, 0.62);
  box-shadow: 0 0 0 6px rgba(38, 164, 116, 0.11);
}

.coming-status-note {
  margin: 0 0 14px;
  color: #c0d2f5;
  font-size: 14px;
  line-height: 1.4;
}

.coming-readiness {
  border: 1px solid rgba(127, 171, 255, 0.4);
  border-radius: 14px;
  padding: 12px 12px 10px;
  background: linear-gradient(160deg, rgba(9, 31, 74, 0.4) 0%, rgba(14, 45, 101, 0.42) 100%);
  margin-bottom: 12px;
}

.coming-readiness-meta {
  margin: 0 0 8px;
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  color: #cae0ff;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
}

.coming-readiness-meta strong {
  color: #f6fcff;
  font-size: 18px;
  letter-spacing: -0.01em;
}

.coming-readiness-track {
  position: relative;
  height: 8px;
  border-radius: 999px;
  background: rgba(190, 215, 255, 0.16);
  overflow: hidden;
}

.coming-readiness-fill {
  display: block;
  width: 0%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #35c2ff 0%, #5ce0c5 36%, #8df0bf 100%);
  box-shadow: 0 0 14px rgba(96, 226, 202, 0.5);
  transition: width 420ms ease;
}

.coming-status-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 14px;
}

.coming-status-grid article {
  border: 1px solid rgba(138, 178, 255, 0.34);
  border-radius: 12px;
  background: linear-gradient(150deg, rgba(13, 37, 86, 0.48) 0%, rgba(16, 54, 116, 0.34) 100%);
  padding: 9px 10px;
  display: grid;
  gap: 3px;
}

.coming-status-grid span {
  color: #b8cef5;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.coming-status-grid strong {
  color: #f4f9ff;
  font-size: 15px;
  letter-spacing: -0.01em;
}

.coming-timeline {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}

.coming-timeline li {
  position: relative;
  color: #dce7ff;
  padding: 12px 12px 12px 36px;
  border-radius: 14px;
  border: 1px solid rgba(133, 169, 243, 0.35);
  background: linear-gradient(152deg, rgba(10, 31, 75, 0.5) 0%, rgba(11, 39, 91, 0.4) 100%);
}

.coming-timeline li::before {
  content: "";
  position: absolute;
  left: 14px;
  top: 17px;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: 2px solid rgba(130, 177, 255, 0.88);
  background: rgba(10, 39, 88, 0.9);
  box-shadow: 0 0 0 5px rgba(90, 150, 244, 0.14);
}

.coming-timeline li.is-complete::before {
  border-color: #73f2cb;
  background: #4be3bf;
  box-shadow: 0 0 0 5px rgba(80, 214, 177, 0.18);
}

.coming-timeline li.is-current {
  border-color: rgba(124, 194, 255, 0.64);
  background: linear-gradient(152deg, rgba(12, 38, 86, 0.72) 0%, rgba(12, 54, 112, 0.56) 100%);
}

.coming-timeline li.is-current::before {
  border-color: #95d7ff;
  background: #4fb9ff;
  box-shadow: 0 0 0 5px rgba(95, 194, 255, 0.22);
}

.coming-timeline-kicker {
  margin: 0 0 4px;
  color: #a9c7fb;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.coming-timeline strong {
  display: block;
  margin-bottom: 4px;
  font-size: 22px;
  color: #f8fbff;
  letter-spacing: -0.01em;
}

.coming-timeline span {
  color: #c0d2f3;
  font-size: 14px;
  line-height: 1.45;
}

.coming-section {
  padding: 20px 0 28px;
}

.coming-signup {
  position: relative;
  border: 1px solid rgba(98, 142, 238, 0.44);
  border-radius: 28px;
  padding: 22px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 0.9fr);
  gap: 28px;
  align-items: start;
  background:
    linear-gradient(152deg, rgba(11, 28, 74, 0.86) 0%, rgba(18, 44, 104, 0.84) 56%, rgba(21, 75, 142, 0.8) 100%);
  box-shadow: 0 22px 48px rgba(13, 37, 95, 0.25);
  backdrop-filter: blur(10px);
}

.coming-signup::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 1px solid rgba(173, 210, 255, 0.12);
  pointer-events: none;
}

.coming-signup h2 {
  margin: 0 0 10px;
  font-size: clamp(30px, 4vw, 48px);
  max-width: 20ch;
  color: #f4f8ff;
  letter-spacing: -0.02em;
}

.coming-signup p {
  color: #c4d5fa;
  margin: 0 0 12px;
  font-size: 18px;
}

.coming-capabilities {
  margin: 0 0 14px;
  display: grid;
  gap: 10px;
}

.coming-capabilities-title {
  margin: 0;
  color: #9fc7ff;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.coming-capability-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.coming-capability-tags span {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.03em;
  color: #e9f3ff;
  border: 1px solid rgba(129, 177, 255, 0.48);
  background: linear-gradient(155deg, rgba(16, 52, 113, 0.52) 0%, rgba(22, 83, 150, 0.38) 100%);
}

.coming-checks {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}

.coming-checks li {
  position: relative;
  padding: 10px 12px 10px 34px;
  color: #e4edff;
  font-size: 15px;
  line-height: 1.4;
  border-radius: 12px;
  border: 1px solid rgba(126, 171, 255, 0.3);
  background: linear-gradient(155deg, rgba(13, 36, 89, 0.45) 0%, rgba(16, 52, 118, 0.34) 100%);
}

.coming-checks li::before {
  content: "";
  position: absolute;
  left: 14px;
  top: 16px;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: linear-gradient(135deg, #53a2ff, #2ce0cf);
  box-shadow: 0 0 0 4px rgba(64, 149, 255, 0.17);
}

.coming-form {
  display: grid;
  gap: 0;
  align-self: center;
}

.coming-form-shell {
  border: 1px solid rgba(113, 162, 255, 0.45);
  border-radius: 18px;
  background:
    linear-gradient(160deg, rgba(9, 25, 63, 0.66) 0%, rgba(12, 35, 83, 0.57) 100%);
  box-shadow: 0 18px 34px rgba(9, 31, 80, 0.28);
  padding: 18px;
  display: grid;
  gap: 16px;
}

.coming-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px 14px;
}

.coming-form label {
  display: grid;
  gap: 6px;
  font-size: 11px;
  font-weight: 700;
  color: #cddcff;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

.coming-form label.is-invalid {
  color: #ffd5df;
}

.coming-form input {
  min-height: 50px;
  border: 1px solid rgba(124, 172, 255, 0.56);
  border-radius: 14px;
  padding: 12px 14px;
  font-family: inherit;
  font-size: 16px;
  line-height: 1.35;
  background: linear-gradient(180deg, rgba(7, 17, 45, 0.58) 0%, rgba(10, 24, 60, 0.68) 100%);
  color: #f4f8ff;
  transition: border-color 140ms ease, box-shadow 140ms ease, background 140ms ease;
}

.coming-form input.is-invalid {
  border-color: #ff8aad;
  box-shadow: 0 0 0 3px rgba(255, 120, 165, 0.2);
}

.coming-form input[type="number"] {
  -moz-appearance: textfield;
  appearance: textfield;
}

.coming-form input[type="number"]::-webkit-inner-spin-button,
.coming-form input[type="number"]::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.coming-form input:focus {
  outline: none;
  border-color: #6dc0ff;
  box-shadow: 0 0 0 3px rgba(74, 170, 255, 0.26);
  background: linear-gradient(180deg, rgba(8, 20, 50, 0.68) 0%, rgba(11, 30, 75, 0.74) 100%);
}

.coming-form input.is-invalid:focus {
  border-color: #ff90b0;
  box-shadow: 0 0 0 3px rgba(255, 120, 165, 0.26);
}

.coming-form input::placeholder {
  color: rgba(215, 228, 255, 0.56);
}

.coming-field-full {
  grid-column: 1 / -1;
}

.coming-join-btn {
  width: 100%;
  min-height: 54px;
  font-size: 22px;
  font-weight: 800;
  border-radius: 14px;
  letter-spacing: 0.01em;
  background: linear-gradient(122deg, #2d6dff 0%, #1f86f0 45%, #17bbdc 100%);
  box-shadow: 0 18px 34px rgba(15, 96, 190, 0.34);
}

.coming-join-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 22px 36px rgba(16, 102, 198, 0.36);
}

.coming-join-btn:disabled {
  cursor: wait;
  opacity: 0.88;
  transform: none;
  box-shadow: 0 12px 24px rgba(15, 96, 190, 0.24);
}

.coming-form-note {
  margin: 0;
  color: #a9c1ef;
  font-size: 13px;
  min-height: 20px;
}

.coming-form-note.is-success {
  color: #bcffe4;
}

.coming-form-note.is-error {
  color: #ffd4de;
}

.coming-footer {
  position: relative;
  z-index: 1;
  border-top: 1px solid var(--coming-line);
  padding: 18px 0 28px;
}

.coming-footer-wrap {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 12px;
}

.coming-footer .mk-copyright {
  margin: 0;
  color: #6173a3;
}

.coming-orb {
  position: fixed;
  border-radius: 999px;
  filter: blur(70px);
  pointer-events: none;
  z-index: -2;
  opacity: 0.6;
}

.coming-orb-a {
  width: 360px;
  height: 360px;
  background: rgba(42, 130, 244, 0.34);
  top: -140px;
  left: -80px;
}

.coming-orb-b {
  width: 360px;
  height: 360px;
  background: rgba(33, 188, 222, 0.28);
  top: 8%;
  right: -140px;
}

.coming-orb-c {
  width: 420px;
  height: 420px;
  background: rgba(87, 151, 255, 0.26);
  bottom: -200px;
  left: 26%;
}

@media (max-width: 980px) {
  .coming-main {
    padding: 24px 0 44px;
  }

  .coming-hero {
    padding: 12px 0 18px;
  }

  .coming-ui-hint {
    inset: 72px 0 12px;
    opacity: 0.11;
  }

  .coming-ui-frame {
    width: 98vw;
    height: min(70vh, 700px);
  }

  .coming-ui-sidebar {
    width: 160px;
  }

  .coming-ui-panel-a,
  .coming-ui-panel-b,
  .coming-ui-panel-d,
  .coming-ui-panel-e {
    left: 190px;
  }

  .coming-ui-panel-b,
  .coming-ui-panel-c {
    height: 128px;
  }

  .coming-hero-grid,
  .coming-signup {
    grid-template-columns: minmax(0, 1fr);
  }

  .coming-signup {
    padding: 20px;
    gap: 22px;
  }

  .coming-form {
    align-self: start;
  }

  .coming-form-shell {
    max-width: 700px;
    margin: 0 auto;
  }

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

  .coming-form-grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 720px) {
  .coming-wrap {
    width: min(calc(100vw - 28px), 720px);
  }

  .coming-topbar {
    padding: 12px 0;
  }

  .coming-main {
    padding: 20px 0 38px;
  }

  .coming-hero {
    padding: 8px 0 16px;
  }

  .coming-ui-hint {
    opacity: 0.09;
  }

  .coming-ui-frame {
    border-radius: 20px;
    height: min(62vh, 560px);
  }

  .coming-ui-sidebar {
    width: 118px;
  }

  .coming-ui-panel-a,
  .coming-ui-panel-b,
  .coming-ui-panel-d,
  .coming-ui-panel-e {
    left: 146px;
  }

  .coming-copy h1 {
    font-size: clamp(31px, 9vw, 42px);
    line-height: 1.04;
    margin-bottom: 12px;
    max-width: 16ch;
  }

  .coming-status-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .coming-status-card {
    border-radius: 20px;
    padding: 18px;
  }

  .coming-status-card h2 {
    font-size: 30px;
  }

  .coming-status-grid article {
    padding: 10px 11px;
  }

  .coming-timeline strong {
    font-size: 20px;
  }

  .coming-status-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .coming-copy p {
    font-size: 16px;
    line-height: 1.55;
  }

  .coming-signup {
    border-radius: 22px;
    padding: 18px;
    gap: 18px;
  }

  .coming-signup h2 {
    font-size: clamp(34px, 8vw, 40px);
    margin-bottom: 8px;
  }

  .coming-signup p {
    font-size: 16px;
    line-height: 1.5;
    margin-bottom: 10px;
  }

  .coming-checks li {
    font-size: 14px;
  }

  .coming-form-shell {
    border-radius: 16px;
    padding: 16px;
  }

  .coming-form label {
    font-size: 12px;
  }

  .coming-form input {
    min-height: 48px;
  }

  .coming-join-btn {
    min-height: 52px;
    font-size: 18px;
  }

  .coming-form-note {
    font-size: 14px;
    line-height: 1.4;
  }

  .coming-footer-wrap {
    justify-content: center;
    text-align: center;
  }
}

@media (max-width: 560px) {
  .coming-wrap {
    width: min(calc(100vw - 20px), 520px);
  }

  .coming-ui-hint {
    display: none;
  }

  .coming-orb {
    opacity: 0.44;
    filter: blur(56px);
  }

  .coming-main {
    padding: 16px 0 30px;
  }

  .coming-brand-name {
    font-size: clamp(24px, 7.2vw, 30px);
  }

  .coming-copy h1 {
    font-size: clamp(30px, 10.8vw, 38px);
    max-width: 14ch;
  }

  .coming-status-card {
    border-radius: 18px;
    padding: 16px;
  }

  .coming-status-card h2 {
    font-size: 28px;
  }

  .coming-status-pill {
    font-size: 11px;
    padding: 4px 9px;
    box-shadow: 0 0 0 4px rgba(38, 164, 116, 0.11);
  }

  .coming-readiness {
    padding: 10px 10px 9px;
  }

  .coming-status-grid strong {
    font-size: 16px;
  }

  .coming-timeline {
    gap: 8px;
  }

  .coming-timeline li {
    border-radius: 12px;
    padding: 10px 10px 10px 32px;
  }

  .coming-timeline li::before {
    left: 12px;
    top: 14px;
  }

  .coming-timeline strong {
    font-size: 19px;
    margin-bottom: 3px;
  }

  .coming-timeline span {
    font-size: 13px;
  }

  .coming-signup {
    border-radius: 20px;
    padding: 14px;
    gap: 16px;
  }

  .coming-signup h2 {
    font-size: clamp(32px, 12vw, 38px);
  }

  .coming-signup p {
    font-size: 15px;
  }

  .coming-capabilities-title {
    font-size: 10px;
  }

  .coming-capability-tags {
    gap: 6px;
  }

  .coming-capability-tags span {
    font-size: 10px;
    padding: 6px 9px;
  }

  .coming-checks {
    gap: 8px;
  }

  .coming-checks li {
    border-radius: 10px;
    padding: 9px 10px 9px 30px;
    font-size: 13px;
  }

  .coming-checks li::before {
    left: 12px;
    top: 14px;
    width: 8px;
    height: 8px;
    box-shadow: 0 0 0 3px rgba(64, 149, 255, 0.2);
  }

  .coming-form-shell {
    border-radius: 14px;
    padding: 14px;
    gap: 14px;
  }

  .coming-form-grid {
    gap: 10px;
  }

  .coming-form label {
    font-size: 11px;
    gap: 5px;
  }

  .coming-form input {
    min-height: 46px;
    border-radius: 12px;
  }

  .coming-join-btn {
    min-height: 50px;
    font-size: 17px;
  }

  .coming-form-note {
    min-height: 0;
    font-size: 13px;
  }

  .coming-footer {
    padding: 16px 0 24px;
  }

  .coming-footer .mk-copyright {
    font-size: 12px;
    line-height: 1.4;
  }
}

.mk-flow {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.mk-flow-step {
  border-color: #d5e4f4;
  background: #fff;
  box-shadow: 0 10px 20px rgba(23, 62, 102, 0.08);
  color: #264b6b;
  padding: 14px;
}

.mk-results-grid {
  margin-bottom: 14px;
}

.mk-quote-row {
  display: grid;
  gap: 12px;
  grid-template-columns: 1fr 1fr;
}

.mk-quote-row-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.mk-quote-card {
  border-color: var(--line);
  background: #f8faff;
}

.mk-quote-card p {
  margin: 0 0 10px;
  color: #4a557f;
  line-height: 1.7;
}

.mk-quote-card strong {
  color: #394165;
  font-size: 13px;
}

.mk-final-cta {
  padding-bottom: 36px;
}

.mk-final-card {
  border-color: var(--line);
  padding: 24px;
  text-align: center;
  background:
    radial-gradient(circle at 14% 0%, rgba(77, 91, 255, 0.1) 0%, transparent 45%),
    radial-gradient(circle at 90% 100%, rgba(111, 120, 255, 0.12) 0%, transparent 40%),
    #ffffff;
}

.mk-final-card h2 {
  margin: 0 0 8px;
  font-size: clamp(28px, 4vw, 40px);
}

.mk-final-card p {
  margin: 0 auto 14px;
  max-width: 62ch;
  color: var(--mk-muted);
}

.mk-final-card .row-actions {
  justify-content: center;
}

.marketing-footer {
  border-top: 1px solid var(--mk-line);
  background: rgba(255, 255, 255, 0.86);
}

.mk-footer-wrap {
  padding: 16px 0 22px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.mk-footer-branding {
  display: inline-flex;
  align-items: center;
  gap: 12px;
}

.mk-footer-copy {
  display: grid;
  gap: 2px;
}

.mk-copyright {
  margin: 0;
  font-size: 12px;
  color: var(--muted);
}

.mk-footer-links {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.mk-footer-links a {
  text-decoration: none;
  color: #4a5887;
  font-weight: 600;
  font-size: 13px;
}

.mk-footer-links a:hover {
  color: var(--accent);
}

.marketing-doc .mk-doc-main {
  padding: 24px 0 18px;
}

.marketing-doc .mk-doc-section {
  padding: 22px 0 10px;
}

.marketing-doc .mk-doc-section h1 {
  margin: 0 0 8px;
  font-size: clamp(32px, 5vw, 52px);
  line-height: 1.05;
}

.mk-doc-intro {
  margin: 0 0 14px;
  color: var(--muted);
  max-width: 74ch;
  line-height: 1.7;
  font-size: 16px;
}

.mk-doc-card {
  padding: 20px;
  border-color: var(--line);
  display: grid;
  gap: 10px;
}

.mk-doc-card h2 {
  margin: 10px 0 2px;
  font-size: clamp(21px, 2.7vw, 28px);
}

.mk-doc-card h3 {
  margin: 8px 0 2px;
  font-size: 18px;
}

.mk-doc-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.7;
}

.mk-doc-card a {
  color: var(--accent);
}

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

.marketing-footer p {
  margin: 0;
  color: #4a5887;
  font-weight: 600;
}

@keyframes mk-rise {
  from {
    opacity: 0;
    transform: translateY(14px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes mk-float {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-4px);
  }
}

.auth-panels {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}

.panel {
  border: 1px solid var(--line);
  background: var(--panel);
  border-radius: 16px;
  box-shadow: var(--shadow);
}

.auth-card {
  padding: 18px;
}

.auth-card h2 {
  margin: 0 0 12px;
}

.admin-auth-card {
  padding: 22px;
  border-color: #ccd7ff;
  background: linear-gradient(180deg, #ffffff 0%, #f8faff 100%);
  display: grid;
  gap: 10px;
}

.admin-auth-card-head {
  display: grid;
  gap: 4px;
}

.admin-auth-card-head h2 {
  margin: 0;
  font-size: 35px;
  line-height: 1.04;
}

.admin-auth-card-head p {
  margin: 0;
  color: #5d6892;
  font-size: 14px;
}

.admin-auth-card label {
  margin-bottom: 8px;
  color: #56618b;
  font-size: 12px;
  font-weight: 600;
}

.admin-auth-card input {
  margin-top: 6px;
  border-radius: 12px;
  padding: 12px 13px;
}

.admin-auth-card input::placeholder {
  color: #9ea9ce;
}

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

.admin-auth-actions .btn {
  min-width: 136px;
}

.admin-auth-actions .btn-soft {
  border-color: #d2dcff;
  background: #eef2ff;
}

.admin-auth-note {
  margin-top: 0;
}

label {
  display: block;
  font-size: 12px;
  color: var(--muted);
  margin-bottom: 9px;
}

input,
select,
textarea,
button {
  font: inherit;
}

input,
select,
textarea {
  width: 100%;
  margin-top: 4px;
  border: 1px solid var(--line-strong);
  border-radius: 10px;
  background: #ffffff;
  padding: 10px 12px;
  outline: none;
}

input:focus,
select:focus,
textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(77, 91, 255, 0.16);
}

textarea {
  min-height: 80px;
  resize: vertical;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  border: 1px solid transparent;
  border-radius: 11px;
  padding: 10px 14px;
  cursor: pointer;
  font-weight: 700;
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);
  color: #fff;
  transition: transform 120ms ease, opacity 120ms ease;
}

.btn:hover {
  opacity: 0.95;
}

.btn:active {
  transform: translateY(1px);
}

.btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
  transform: none;
}

.btn-soft {
  background: var(--bg-soft);
  color: var(--accent);
  border-color: var(--line);
}

@media (max-width: 1100px) {
  .admin-auth-panels {
    grid-template-columns: minmax(0, 1fr);
  }

  .admin-auth-card {
    order: -1;
  }

  .admin-auth-intro-meta {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .auth-shell-admin {
    padding: 20px 14px 26px;
  }

  .admin-auth-intro {
    padding: 20px;
    gap: 14px;
  }

  .admin-auth-intro h1 {
    font-size: clamp(32px, 10vw, 44px);
  }

  .admin-auth-intro-meta {
    grid-template-columns: minmax(0, 1fr);
  }

  .admin-auth-info {
    padding: 16px;
  }

  .admin-auth-info h2 {
    font-size: 26px;
  }

  .admin-auth-card {
    padding: 16px;
  }

  .admin-auth-card-head h2 {
    font-size: 29px;
  }

  .admin-auth-actions .btn {
    width: 100%;
    min-width: 0;
  }
}

.app-shell {
  display: grid;
  grid-template-columns: 250px minmax(0, 1fr);
  min-height: 100vh;
  height: 100dvh;
  width: 100%;
  margin: 0;
  border: 1px solid var(--line);
  border-radius: 0;
  overflow: hidden;
  background: #f8faff;
  box-shadow: var(--shadow);
}

.sidebar {
  border-right: 1px solid var(--line);
  background: linear-gradient(180deg, #f9fbff 0%, #f2f5ff 100%);
  padding: 16px;
  position: sticky;
  top: 0;
  align-self: start;
  height: 100dvh;
  max-height: 100vh;
  overflow-y: auto;
  overflow-x: hidden;
}

.brand-block {
  margin-bottom: 14px;
}

.brand {
  font-size: 24px;
  font-weight: 800;
  letter-spacing: 0.02em;
}

.brand-block small {
  color: var(--muted);
}

.quick-actions {
  display: grid;
  gap: 8px;
  margin-bottom: 16px;
}

.menu {
  display: grid;
  gap: 12px;
}

.menu-section {
  display: grid;
  gap: 5px;
}

.menu-row-group {
  display: grid;
  gap: 4px;
}

.menu-heading {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--accent);
  padding: 2px 6px;
}

.menu-item {
  text-align: left;
  border: 1px solid transparent;
  background: transparent;
  color: #394165;
  border-radius: 10px;
  padding: 10px 11px;
  font-weight: 600;
  cursor: pointer;
}

.menu-item:hover {
  background: #e9efff;
}

.menu-item.active {
  background: #dde6ff;
  color: #2332ba;
  border-color: #c5d3ff;
}

.settings-menu-group {
  display: grid;
  gap: 4px;
}

.menu-parent {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.menu-parent::after {
  content: "▸";
  color: var(--muted);
  font-size: 12px;
}

.menu-parent.expanded::after {
  content: "▾";
  color: #2332ba;
}

.menu-submenu {
  display: grid;
  gap: 4px;
  padding-left: 10px;
}

.menu-subitem {
  text-align: left;
  border: 1px solid transparent;
  background: transparent;
  color: #4a557f;
  border-radius: 9px;
  padding: 8px 10px;
  font-weight: 600;
  font-size: 13px;
  cursor: pointer;
}

.menu-subitem:hover {
  background: #e9efff;
}

.menu-subitem.active {
  background: #dde6ff;
  color: #2332ba;
  border-color: #c5d3ff;
}

.menu-subgroup {
  display: grid;
  gap: 4px;
  padding-left: 10px;
}

.menu-subgroup-list {
  display: grid;
  gap: 4px;
}

.menu-subheading {
  color: var(--muted);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 700;
  padding: 4px 8px 2px;
}

.availability-sidebar-menu {
  gap: 6px;
}

.products-sidebar-menu {
  gap: 6px;
}

.menu-sidebar-back {
  margin-bottom: 8px;
  border: 0;
  background: linear-gradient(135deg, #5a54f4 0%, #4f56ff 100%);
  color: #ffffff;
}

.menu-sidebar-back:hover {
  background: linear-gradient(135deg, #5751f0 0%, #4b53fb 100%);
}

.menu-sidebar-overview {
  margin-bottom: 2px;
}

.products-sidebar-item {
  width: 100%;
}

.availability-sidebar-item {
  width: 100%;
}

.workspace {
  display: grid;
  grid-template-rows: auto 1fr;
  min-width: 0;
  min-height: 0;
  overflow-y: auto;
}

.topbar {
  border-bottom: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.88);
  backdrop-filter: blur(6px);
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 520px) minmax(0, 1fr);
  align-items: center;
  column-gap: 12px;
  row-gap: 8px;
  padding: 12px 16px;
  position: sticky;
  top: 0;
  z-index: 8;
}

.search-wrap {
  grid-column: 2;
  max-width: none;
  width: 100%;
}

.top-actions {
  grid-column: 3;
  justify-self: end;
  display: flex;
  gap: 8px;
  align-items: center;
}

.chip {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  background: #edf1ff;
  color: #3443c6;
  padding: 8px 12px;
  font-size: 12px;
  font-weight: 700;
}

.content-area {
  padding: 18px;
  max-width: var(--workspace-content-max-width);
  width: 100%;
  margin: 0 auto;
}

body.workspace-products-wide .content-area {
  max-width: min(96vw, 1640px);
}

#view-container {
  display: grid;
  gap: var(--workspace-section-gap);
  align-content: start;
}

#view-container > * {
  margin-top: 0;
  margin-bottom: 0;
}

.view-head {
  margin-bottom: var(--workspace-section-gap);
}

.view-head h1 {
  margin: 0 0 4px;
  font-size: 36px;
}

.view-head p {
  margin: 0;
  color: var(--muted);
}

.grid {
  display: grid;
  gap: var(--workspace-element-gap);
}

.metrics-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
}

.metric {
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
}

.metric h4 {
  margin: 0 0 8px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.metric strong {
  font-size: 26px;
}

.reports-shell {
  display: grid;
  gap: var(--workspace-section-gap);
}

.reports-tabs {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.reports-tab {
  border: 1px solid var(--line);
  background: #fff;
  color: #4e5a81;
  border-radius: 10px;
  padding: 8px 14px;
  font-weight: 700;
  cursor: pointer;
}

.reports-tab.active {
  background: #eef1ff;
  border-color: #96a7ff;
  color: #3f4cc8;
}

.customer-editor-tabs {
  margin-top: 6px;
}

.customer-editor-tab {
  border-radius: 9px;
}

.customer-editor-metrics {
  margin-top: 12px;
}

.clients-directory-table thead th {
  color: #6c7288;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  white-space: nowrap;
}

.clients-directory-table {
  min-width: 1260px;
}

.clients-directory-table td {
  vertical-align: middle;
}

.clients-sort-arrow {
  color: #8a90a6;
  margin-left: 4px;
}

.clients-directory-name-cell {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 220px;
}

.clients-directory-avatar {
  width: 44px;
  height: 44px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 44px;
  background: linear-gradient(150deg, #9b9fad 0%, #7f8391 100%);
  color: #fff;
  font-weight: 800;
  font-size: 21px;
  overflow: hidden;
}

.clients-directory-avatar-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.clients-directory-avatar-fallback {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

.clients-directory-name-copy {
  display: grid;
  gap: 3px;
}

.clients-directory-name-copy strong {
  font-size: 15px;
  font-weight: 500;
  color: #373b47;
  line-height: 1.25;
}

.clients-directory-name-copy span {
  color: #777e91;
  font-size: 12px;
  line-height: 1.3;
}

.clients-directory-flag {
  font-size: 20px;
}

.customer-directory-row:hover td {
  background: #f5f6fa;
}

.customer-directory-row.is-active td {
  background: #eff2ff;
}

.clients-row-actions {
  display: inline-flex;
  align-items: center;
  gap: 12px;
}

.clients-row-link {
  border: none;
  background: transparent;
  color: #4a52df;
  font-weight: 700;
  cursor: pointer;
  padding: 0;
}

.clients-row-link:hover {
  text-decoration: underline;
}

.clients-row-link-danger {
  color: #dd2f2f;
}

.clients-row-link.is-disabled {
  color: #c4c8d4;
  cursor: not-allowed;
  text-decoration: none;
}

.client-avatar-preview {
  width: 96px;
  height: 96px;
  object-fit: cover;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: #fff;
}

.customer-password-reset-row {
  justify-content: space-between;
}

.customer-password-reset-row .muted-note {
  margin: 0;
  flex: 1 1 280px;
}

.reports-filter-form {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.reports-filter-form label {
  margin-bottom: 0;
}

.reports-mileage-capture-form {
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
}

.reports-filter-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-self: end;
}

.reports-kpi-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.reports-kpi-grid-compact {
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.reports-kpi-card {
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 12px;
  padding: 16px;
  display: grid;
  gap: 10px;
}

.reports-kpi-card span {
  font-size: 12px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  font-weight: 700;
}

.reports-kpi-card strong {
  font-size: 34px;
  color: #4f5c82;
  line-height: 1.1;
}

.reports-kpi-card-primary strong {
  font-size: clamp(38px, 5vw, 56px);
}

.reports-kpi-trend {
  font-size: 13px;
  font-weight: 700;
}

.reports-kpi-trend.positive {
  color: #1f8a4d;
}

.reports-kpi-trend.negative {
  color: #d14b4b;
}

.reports-kpi-trend.neutral {
  color: #6f7a9e;
}

.reports-summary-grid {
  display: grid;
  gap: var(--workspace-section-gap);
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
}

.reports-month-chart {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(74px, 1fr));
  gap: 10px;
  align-items: end;
  min-height: 230px;
}

.reports-month-bar {
  display: grid;
  gap: 6px;
  text-align: center;
}

.reports-month-bar small {
  color: var(--muted);
  font-weight: 700;
}

.reports-month-bar span {
  color: #566188;
  font-size: 12px;
}

.reports-month-bar-track {
  height: 150px;
  border-radius: 10px;
  background: #ecf0ff;
  border: 1px solid #dfe5fa;
  padding: 6px;
  display: flex;
  align-items: flex-end;
}

.reports-month-bar-fill {
  width: 100%;
  border-radius: 6px;
  background: linear-gradient(180deg, #74bb62 0%, #3e8a3b 100%);
  min-height: 4px;
}

.reports-hbar-list {
  display: grid;
  gap: 10px;
}

.reports-hbar-row {
  display: grid;
  grid-template-columns: 92px 1fr auto;
  gap: 10px;
  align-items: center;
}

.reports-hbar-row span {
  font-weight: 700;
  color: #58658f;
  font-size: 12px;
}

.reports-hbar-row strong {
  min-width: 30px;
  text-align: right;
  color: #495577;
}

.reports-hbar-track {
  height: 10px;
  border-radius: 999px;
  background: #ecf0ff;
  border: 1px solid #dfe5fa;
  overflow: hidden;
}

.reports-hbar-fill {
  display: block;
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(135deg, #4d5bff 0%, #9db2ff 100%);
}

.reports-donut-layout {
  display: grid;
  grid-template-columns: minmax(260px, 1.2fr) minmax(220px, 1fr);
  gap: 18px;
  align-items: center;
}

.reports-donut-wrap {
  display: grid;
  place-items: center;
}

.reports-donut {
  width: min(100%, 330px);
  aspect-ratio: 1;
  border-radius: 50%;
  background: var(--reports-donut-gradient, conic-gradient(#d8deef 0% 100%));
  position: relative;
}

.reports-donut::after {
  content: "";
  position: absolute;
  inset: 24%;
  border-radius: 50%;
  background: #fff;
  box-shadow: inset 0 0 0 1px #eef2ff;
}

.reports-donut-center {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: grid;
  place-content: center;
  text-align: center;
  gap: 3px;
}

.reports-donut-center strong {
  font-size: 34px;
  color: #4d5a81;
  line-height: 1.1;
}

.reports-donut-center span {
  color: #7a84a5;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.reports-legend {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 8px;
}

.reports-legend li {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px dashed #e6ebff;
  padding-bottom: 7px;
}

.reports-legend-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #4d587f;
  font-weight: 700;
  min-width: 0;
}

.reports-legend-value {
  color: #6f7ca3;
  font-size: 12px;
  white-space: nowrap;
}

.reports-legend-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex: 0 0 10px;
}

.reports-empty-row {
  color: var(--muted);
  font-size: 13px;
}

.panel-pad {
  padding: var(--workspace-panel-padding);
}

.stack {
  display: grid;
  gap: var(--workspace-element-gap);
}

.toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--workspace-element-gap);
  margin-bottom: var(--workspace-element-gap);
  flex-wrap: wrap;
}

.inline-form {
  display: grid;
  gap: var(--workspace-element-gap);
  grid-template-columns: repeat(auto-fit, minmax(var(--workspace-form-min-col), 1fr));
  margin-bottom: var(--workspace-element-gap);
  align-items: end;
}

.table-wrap {
  overflow-x: auto;
}

.team-member-name-cell {
  display: flex;
  align-items: center;
  gap: 12px;
}

.team-members-header {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 14px;
  flex-wrap: wrap;
}

.team-members-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.team-filters-panel {
  background: #eef1ff;
  border-color: #cbd4ff;
}

.team-filters-form {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.team-filters-form label {
  margin-bottom: 0;
  color: #37446b;
  font-size: 13px;
  font-weight: 600;
}

.team-filters-form input,
.team-filters-form select {
  margin-top: 8px;
}

.team-filters-actions {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.team-invite-panel {
  border-style: dashed;
  border-color: #c6d0ff;
}

.team-table-panel {
  overflow: hidden;
}

.team-members-table {
  min-width: 760px;
}

.team-members-table th,
.team-members-table td {
  padding: 14px 12px;
  vertical-align: middle;
}

.team-members-table th {
  background: #f4f6ff;
}

.team-members-table .badge {
  border-radius: 8px;
  padding: 5px 10px;
  font-size: 12px;
  font-weight: 700;
}

.team-table-name-cell {
  min-width: 220px;
}

.team-member-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  object-fit: cover;
  border: 1px solid #cfd7f3;
  background: #eef2ff;
  flex: 0 0 48px;
}

.team-member-avatar-fallback {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 30px;
  color: #3b4370;
  background: linear-gradient(135deg, #9ea2ad 0%, #858a96 100%);
  color: #fff;
}

.team-row-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.team-kebab-btn {
  width: 40px;
  height: 40px;
  padding: 0;
  font-size: 22px;
  line-height: 1;
  background: #fff;
  border-color: #d5dced;
  color: #46527a;
}

.team-kebab-btn:hover {
  background: #f5f7ff;
}

.team-delete-btn {
  color: #8d2230;
  border-color: #e8b9c1;
}

.team-products-field {
  display: grid;
  gap: 6px;
}

.team-products-field select {
  min-height: 104px;
}

.team-photo-preview img {
  width: 84px;
  height: 84px;
  border-radius: 10px;
  object-fit: cover;
  border: 1px solid #dbe2f8;
  background: #eef2ff;
}

@media (max-width: 900px) {
  .team-members-header h3 {
    font-size: clamp(26px, 8vw, 34px);
  }

  .team-members-actions,
  .team-filters-actions {
    width: 100%;
  }
}

table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}

th,
td {
  padding: 9px;
  border-bottom: 1px solid #e8ecff;
  text-align: left;
  vertical-align: top;
}

th {
  color: var(--muted);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.drag-handle-cell {
  width: 34px;
}

.drag-handle {
  display: inline-block;
  color: #7e88ad;
  cursor: grab;
  user-select: none;
  font-weight: 700;
  letter-spacing: 0.04em;
}

tbody[data-nav-scope] tr[data-nav-item] {
  cursor: grab;
}

tbody[data-nav-scope] tr[data-nav-item].dragging {
  opacity: 0.55;
  background: #edf3ff;
}

.badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 4px 8px;
  font-size: 11px;
  font-weight: 700;
}

.badge.good {
  background: #dbf8ed;
  color: var(--good);
}

.badge.warn {
  background: #fff2d8;
  color: #b56f00;
}

.badge.bad {
  background: #ffe2e2;
  color: #bf2020;
}

.badge.neutral {
  background: #edf1ff;
  color: #5061cb;
}

.cards {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.row-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

.billing-shell {
  display: grid;
  gap: var(--workspace-section-gap);
}

.billing-panel-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 12px;
}

.billing-panel-head h3 {
  margin: 0;
  font-size: clamp(24px, 2.2vw, 34px);
  line-height: 1.08;
  letter-spacing: -0.01em;
}

.billing-kicker {
  margin: 0 0 6px;
  color: #4b5ea5;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.billing-membership-panel {
  position: relative;
  overflow: hidden;
  border-color: #c9d7ff;
  background:
    radial-gradient(120% 120% at -8% -30%, rgba(77, 91, 255, 0.16), transparent 56%),
    linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

.billing-membership-panel::after {
  content: "";
  position: absolute;
  top: -46px;
  right: -58px;
  width: 190px;
  height: 190px;
  background: radial-gradient(circle, rgba(111, 120, 255, 0.24) 0%, rgba(111, 120, 255, 0) 72%);
  pointer-events: none;
}

.billing-membership-badge {
  font-size: 12px;
  padding: 6px 11px;
}

.billing-metrics-grid {
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 12px;
  margin-bottom: 8px;
}

.billing-metric {
  border-color: #ccd9ff;
  background: linear-gradient(180deg, #ffffff 0%, #f7faff 100%);
  box-shadow: 0 8px 20px rgba(49, 69, 171, 0.08);
}

.billing-metric h4 {
  color: #5d6da1;
  letter-spacing: 0.06em;
}

.billing-metric strong {
  font-size: clamp(28px, 2.2vw, 40px);
  line-height: 1.04;
  letter-spacing: -0.01em;
}

.billing-plan-note {
  margin-top: 2px;
  max-width: 82ch;
  line-height: 1.6;
}

.billing-activation-banner {
  margin-top: 14px;
  border: 1px solid #cad6ff;
  border-radius: 14px;
  background: linear-gradient(130deg, #eef3ff 0%, #f8faff 72%);
  padding: 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.billing-activation-title {
  margin: 0 0 3px;
  color: #2c3c7e;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  font-weight: 700;
}

.billing-activation-copy {
  margin: 0;
  color: #4e5d90;
  font-size: 14px;
}

.billing-payment-panel {
  border-color: #d1ddff;
  background: linear-gradient(180deg, #ffffff 0%, #fbfcff 100%);
}

.billing-payment-panel-readonly {
  background: linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
}

.billing-security-badge {
  font-size: 11px;
  padding: 5px 10px;
}

.billing-payment-intro {
  margin: 2px 0 12px;
  max-width: 82ch;
  line-height: 1.6;
}

.billing-method-card {
  border: 1px solid #d7e1ff;
  border-radius: 12px;
  background: #f6f9ff;
  padding: 11px 12px;
  margin-bottom: 12px;
}

.billing-method-card-hero {
  border-color: #cfdcff;
  background: linear-gradient(145deg, #f6f9ff 0%, #edf3ff 100%);
  box-shadow: 0 10px 24px rgba(52, 72, 171, 0.1);
}

.billing-method-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.billing-method-label {
  margin: 0 0 4px;
  color: #6070a4;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
}

.billing-method-value {
  margin: 0;
  color: #1c2a61;
  font-size: 16px;
  font-weight: 700;
}

.billing-method-purpose {
  font-size: 11px;
  padding: 5px 10px;
}

.billing-method-contact {
  margin: 6px 0 0;
}

.billing-payment-actions {
  margin-top: 2px;
}

.billing-payment-actions .btn {
  min-height: 42px;
  padding-inline: 20px;
}

.billing-payment-form {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  margin-bottom: 0;
}

.billing-payment-form .billing-field-contact {
  grid-column: span 2;
}

.billing-payment-submit {
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
}

.billing-payment-submit .btn {
  min-height: 42px;
  padding-inline: 20px;
}

.billing-security-note {
  margin-top: 12px;
}

.billing-invoices-panel {
  border-color: #d1ddff;
  background: linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
}

.billing-invoices-modal {
  width: min(980px, 100%);
  max-height: calc(100vh - 56px);
  overflow: auto;
  border-color: #cfd9ff;
  background: linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
}

.billing-invoices-modal-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.billing-invoices-modal-head h3 {
  margin: 0;
  font-size: clamp(26px, 2.3vw, 36px);
}

.billing-invoices-intro {
  margin: 4px 0 0;
  color: #5c688f;
}

.billing-invoices-table-wrap {
  border: 1px solid #d9e2ff;
  border-radius: 12px;
  background: #ffffff;
}

.billing-invoices-table thead th {
  background: #f3f6ff;
}

.billing-invoice-download-btn {
  min-height: 34px;
  padding: 7px 11px;
}

.billing-activation-modal {
  width: min(760px, 100%);
  border-color: #cfd9ff;
  background: linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
}

.billing-activation-intro {
  margin-bottom: 16px;
}

.billing-modal-current-method {
  border: 1px solid #d5e0ff;
  border-radius: 12px;
  background: #f5f8ff;
  padding: 12px;
  margin-bottom: 12px;
}

.billing-provider-note {
  border: 1px solid #d7e2ff;
  border-radius: 12px;
  background: #ffffff;
  padding: 12px;
  margin-bottom: 14px;
}

.billing-provider-title {
  margin: 0 0 4px;
  color: #2d3f84;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

.billing-provider-copy {
  margin: 0;
  color: #4f5d8d;
}

.billing-provider-note .row-actions {
  margin-top: 10px;
}

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

.billing-activation-form .row-actions {
  grid-column: 1 / -1;
}

@media (max-width: 980px) {
  .billing-payment-form .billing-field-contact {
    grid-column: span 1;
  }

  .billing-activation-banner {
    flex-direction: column;
    align-items: flex-start;
  }

  .billing-activation-banner .btn {
    width: 100%;
  }

  .billing-activation-form {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 640px) {
  .billing-panel-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .billing-panel-head h3 {
    font-size: clamp(22px, 7vw, 30px);
  }

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

  .billing-metric strong {
    font-size: clamp(22px, 7vw, 30px);
  }

  .billing-method-value {
    font-size: 15px;
  }

  .billing-method-top {
    flex-direction: column;
    align-items: flex-start;
  }

  .billing-payment-submit {
    grid-column: 1 / -1;
  }

  .billing-payment-submit .btn {
    width: 100%;
  }

  .billing-payment-actions .btn {
    width: 100%;
  }

  .billing-invoices-modal-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .billing-invoices-modal-head .btn {
    width: 100%;
  }
}

.logo-card {
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #f8faff;
  padding: 12px;
  margin-bottom: 12px;
  display: grid;
  gap: 12px;
}

.logo-preview {
  max-width: 220px;
  max-height: 90px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: #fff;
  object-fit: contain;
  padding: 8px;
}

.logo-placeholder {
  border: 1px dashed var(--line-strong);
  border-radius: 10px;
  padding: 14px;
  color: var(--muted);
  font-size: 13px;
  max-width: 280px;
  background: #fff;
}

.profile-avatar-card {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  padding: 12px;
  margin-bottom: 12px;
}

.profile-avatar-label {
  display: inline-block;
  font-size: 14px;
  font-weight: 700;
  color: #232f56;
  margin-bottom: 10px;
}

.profile-avatar-form {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.profile-avatar-input {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  overflow: hidden;
  white-space: nowrap;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
}

.profile-avatar-preview {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  object-fit: cover;
  border: 1px solid #dbe2f8;
  background: #eef2ff;
  flex: 0 0 56px;
}

.profile-avatar-fallback {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  color: #3b4370;
}

.profile-avatar-actions {
  gap: 10px;
}

.profile-avatar-actions .btn {
  min-width: 84px;
}

@media (max-width: 640px) {
  .profile-avatar-form {
    align-items: flex-start;
  }

  .profile-avatar-actions {
    width: 100%;
  }
}

.feature-list {
  margin: 8px 0;
  padding-left: 20px;
  color: #34406a;
  display: grid;
  gap: 5px;
}

.feature-list small {
  color: var(--muted);
}

.plan-editor {
  border-top: 1px solid #ebefff;
  margin-top: 10px;
  padding-top: 10px;
}

.feature-json {
  min-height: 140px;
  font-family: "SFMono-Regular", "Menlo", "Monaco", "Consolas", monospace;
  font-size: 12px;
}

.settings-grid {
  display: grid;
  gap: var(--workspace-element-gap);
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.settings-grid .full-span {
  grid-column: 1 / -1;
}

.settings-toggle {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #f9fbff;
  padding: 12px;
}

.settings-toggle input[type="checkbox"] {
  width: 18px;
  height: 18px;
  margin: 2px 0 0;
  flex: 0 0 auto;
  accent-color: var(--accent);
}

.settings-toggle-copy {
  display: grid;
  gap: 4px;
}

.settings-toggle-copy strong {
  color: #2d375d;
  font-size: 13px;
  line-height: 1.3;
}

.settings-toggle-copy span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

.settings-toggle code {
  font-size: 11px;
}

.client-restricted-photographers-picker[hidden] {
  display: none;
}

.plans-table {
  min-width: 980px;
}

.waitlist-table {
  min-width: 1180px;
}

.waitlist-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.plans-plan-name {
  color: #2c3455;
  font-weight: 700;
  margin-bottom: 2px;
}

.plans-plan-id {
  color: var(--muted);
  font-size: 12px;
}

.plans-plan-description {
  color: #52608a;
  font-size: 12px;
  margin-top: 5px;
  max-width: 42ch;
}

.plans-includes {
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 3px;
  color: #33406a;
  font-size: 12px;
}

.plans-includes-empty {
  color: var(--muted);
  font-size: 12px;
}

.plans-action-cell {
  white-space: nowrap;
}

.plans-row-actions {
  display: inline-flex;
  gap: 8px;
  flex-wrap: wrap;
}

.admin-modal-backdrop {
  z-index: 1100;
}

.plans-modal {
  width: min(760px, 100%);
  max-height: calc(100vh - 56px);
  overflow: auto;
  border-radius: 12px;
  padding: 20px;
  box-shadow: 0 20px 48px rgba(16, 24, 58, 0.24);
  display: grid;
  gap: 10px;
}

.plans-modal-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.plans-modal-head h3 {
  margin: 0;
}

.plans-modal-head p {
  margin: 5px 0 0;
  color: var(--muted);
}

.plans-modal-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.plans-modal-grid .full-span {
  grid-column: 1 / -1;
}

.plans-id-chip {
  border: 1px dashed #cfd9ff;
  border-radius: 10px;
  background: #f6f9ff;
  padding: 10px 12px;
  color: #37416e;
  font-size: 13px;
}

.plans-feature-input {
  min-height: 140px;
}

.plans-modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.user-row-actions {
  display: inline-flex;
  gap: 8px;
  flex-wrap: wrap;
}

.user-edit-modal {
  width: min(720px, 100%);
}

.user-edit-summary {
  border: 1px dashed #cfd9ff;
  border-radius: 10px;
  background: #f6f9ff;
  padding: 10px 12px;
  display: grid;
  gap: 4px;
}

.user-edit-summary strong {
  color: #222f60;
}

.user-edit-summary span {
  color: #566393;
  font-size: 13px;
}

.user-activate-toggle {
  margin-top: 2px;
}

.brand-row {
  display: flex;
  gap: 10px;
  align-items: center;
}

.tenant-brand-row {
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
}

.brand-logo {
  width: 42px;
  height: 42px;
  object-fit: contain;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: #fff;
  padding: 5px;
}

.brand-mark {
  width: 42px;
  height: 42px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: #fff;
  color: #1f2d4d;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
}

.card {
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 12px;
  background: #fff;
}

.card h3 {
  margin: 0 0 8px;
}

.card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.5;
}

.app-store-overview-panel {
  margin-bottom: 12px;
}

.app-store-catalog-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(290px, 1fr));
}

.app-store-catalog-card {
  display: grid;
  gap: 12px;
  align-content: start;
  padding: 12px;
  border: 1px solid #d8dde9;
}

.app-store-catalog-card.is-enabled {
  border-color: #22c55e;
  box-shadow: inset 0 0 0 1px rgba(34, 197, 94, 0.18);
}

.app-store-catalog-logo-wrap {
  width: 100%;
}

.app-store-catalog-body {
  display: grid;
  gap: 8px;
}

.app-store-catalog-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.app-store-catalog-title {
  margin: 0;
  color: #1f2937;
  font-size: 19px;
  line-height: 1.25;
  font-weight: 700;
}

.app-store-catalog-subtitle {
  margin: 0;
  font-size: 13px;
  color: #4b5563;
  line-height: 1.4;
}

.app-store-logo {
  background: var(--logo-bg, #3f4a76);
  color: var(--logo-fg, #ffffff);
}

.app-store-logo-banner {
  width: 100%;
  min-height: 118px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(31, 41, 55, 0.08);
  padding: 16px;
  text-align: center;
}

.app-store-logo-image {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
}

.app-store-logo-image-banner {
  max-height: 72px;
}

.app-store-logo-image-badge {
  max-width: 36px;
  max-height: 36px;
}

.app-store-logo-wordmark {
  font-size: clamp(24px, 2.7vw, 36px);
  line-height: 1.1;
  font-weight: 700;
  letter-spacing: -0.02em;
}

.app-store-logo-fallback.is-hidden,
.app-store-logo-image.is-hidden {
  display: none;
}

.app-store-logo-badge {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 14px;
  letter-spacing: 0.03em;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.app-store-status-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 10px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 700;
  white-space: nowrap;
}

.app-store-status-chip.is-enabled {
  background: #dcfce7;
  color: #15803d;
}

.app-store-status-chip.is-disabled {
  background: #f3f4f6;
  color: #374151;
}

.app-store-detail-hero {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  margin-bottom: 10px;
}

.app-store-detail-hero-copy {
  display: grid;
  gap: 6px;
}

.app-store-detail-hero-copy p {
  margin: 0;
}

.integration-card-meta {
  display: grid;
  gap: 6px;
  margin: 10px 0;
}

.integration-card-meta p {
  margin: 0;
  font-size: 13px;
}

.integration-credential-form {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed #d9e1fb;
}

.platform-oauth-callback {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: linear-gradient(180deg, #ffffff 0%, #f8faff 100%);
  padding: 12px;
  margin-top: 10px;
}

.platform-oauth-callback .muted-note {
  margin-top: 10px;
}

.platform-oauth-groups {
  display: grid;
  gap: 14px;
  margin-top: 12px;
}

.platform-oauth-group {
  border: 1px solid #d7e0ff;
  border-radius: 14px;
  background: linear-gradient(180deg, #ffffff 0%, #f5f8ff 100%);
  padding: 12px;
  display: grid;
  gap: 10px;
}

.platform-oauth-group-head {
  display: grid;
  gap: 4px;
}

.platform-oauth-group-head h4 {
  margin: 0;
  font-size: 21px;
  line-height: 1.2;
}

.platform-oauth-group-head .muted-note {
  margin: 0;
}

.platform-oauth-grid {
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.platform-oauth-card {
  border-color: #d5ddf7;
  background: #ffffff;
  display: grid;
  gap: 9px;
}

.platform-oauth-provider-banner {
  min-height: 82px;
  position: relative;
  overflow: hidden;
}

.platform-oauth-provider-banner .app-store-logo-wordmark {
  font-size: clamp(24px, 2.3vw, 32px);
  line-height: 1.06;
}

.platform-oauth-provider-monogram {
  position: absolute;
  top: 10px;
  right: 10px;
  border: 1px solid rgba(255, 255, 255, 0.35);
  background: rgba(255, 255, 255, 0.14);
  border-radius: 999px;
  padding: 3px 8px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
}

.platform-oauth-card-title-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
}

.platform-oauth-card-title-row h4 {
  margin: 0;
  font-size: 23px;
  line-height: 1.12;
}

.platform-oauth-card-description {
  margin: 0;
}

.platform-oauth-fields {
  display: grid;
  gap: 8px;
}

.platform-oauth-fields label {
  margin-bottom: 0;
  font-size: 12px;
  color: #5b6691;
}

.platform-oauth-fields input {
  margin-top: 6px;
}

.platform-oauth-clear-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  font-size: 12px;
  color: #5d688f;
}

.platform-oauth-clear-toggle input {
  width: 16px;
  height: 16px;
  margin: 0;
}

.platform-oauth-meta {
  display: grid;
  gap: 4px;
}

.platform-oauth-meta .muted-note {
  margin: 0;
  font-size: 12px;
}

.platform-oauth-integrations {
  border-top: 1px dashed #d8e0f7;
  padding-top: 8px;
  display: grid;
  gap: 6px;
}

.platform-oauth-integrations-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #6374b8;
}

.platform-oauth-integration-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.platform-oauth-integration-tags .badge {
  font-size: 11px;
}

.platform-oauth-card--stripe .platform-oauth-provider-banner {
  border-color: rgba(99, 91, 255, 0.45);
}

.platform-oauth-card--google .platform-oauth-provider-banner {
  border-color: rgba(15, 23, 42, 0.14);
}

.platform-oauth-card--microsoft .platform-oauth-provider-banner {
  border-color: rgba(37, 99, 235, 0.24);
}

@media (max-width: 720px) {
  .app-store-catalog-grid {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  }

  .app-store-logo-wordmark {
    font-size: 30px;
  }

  .app-store-detail-hero {
    flex-direction: column;
    align-items: flex-start;
  }

  .platform-oauth-group {
    padding: 10px;
  }

  .platform-oauth-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .platform-oauth-provider-banner {
    min-height: 74px;
  }

  .platform-oauth-provider-banner .app-store-logo-wordmark {
    font-size: 25px;
  }

  .platform-oauth-card-title-row h4 {
    font-size: 20px;
  }
}

.products-main-content {
  gap: 12px;
}

.availability-page-layout {
  display: grid;
  grid-template-columns: 230px minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}

.availability-local-nav {
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #ffffff;
  padding: 10px;
  display: grid;
  gap: 8px;
  position: sticky;
  top: 74px;
}

.availability-back-btn {
  width: 100%;
  justify-content: flex-start;
  border: 0;
  border-radius: 10px;
  background: linear-gradient(135deg, #5a54f4 0%, #4f56ff 100%);
  color: #ffffff;
  font-size: 13px;
}

.availability-local-nav-group {
  display: grid;
  gap: 6px;
  margin-top: 6px;
}

.availability-local-nav-heading {
  color: #5a63f1;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 800;
  padding: 2px 6px;
}

.availability-local-nav-item {
  width: 100%;
  text-align: left;
  border: 1px solid transparent;
  background: #ffffff;
  color: #3f4767;
  border-radius: 9px;
  padding: 8px 9px;
  cursor: pointer;
  font-weight: 600;
  font-size: 13px;
}

.availability-local-nav-item:hover {
  background: #eef2ff;
}

.availability-local-nav-item.active {
  background: #eef1ff;
  border-color: #d8dffe;
  color: #25369e;
}

.availability-main-content {
  gap: 14px;
}

.availability-overview-shell {
  display: grid;
  gap: 14px;
}

.availability-overview-hero {
  border: 1px solid #dbe2f5;
  border-radius: 14px;
  background:
    radial-gradient(circle at top right, rgba(95, 112, 255, 0.12), transparent 42%),
    linear-gradient(180deg, #ffffff 0%, #f7f9ff 100%);
  padding: 18px;
  display: grid;
  gap: 14px;
  grid-template-columns: minmax(0, 1.35fr) minmax(280px, 1fr);
  align-items: start;
}

.availability-overview-hero-copy h2 {
  margin: 0;
  font-size: clamp(29px, 2.3vw, 39px);
  line-height: 1.08;
  color: #1f2948;
  letter-spacing: -0.01em;
}

.availability-overview-hero-copy p {
  margin: 8px 0 0;
  color: #5f6a8e;
  font-size: 15px;
  line-height: 1.5;
  max-width: 740px;
}

.availability-overview-kicker {
  margin: 0 0 6px;
  color: #4658bb;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.09em;
}

.availability-overview-hero-stats {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.availability-hero-stat {
  border: 1px solid #d7def4;
  border-radius: 11px;
  background: #ffffff;
  padding: 10px 12px;
  display: grid;
  gap: 4px;
  align-content: start;
}

.availability-hero-stat-value {
  font-size: 22px;
  font-weight: 800;
  color: #22305c;
  line-height: 1.05;
}

.availability-hero-stat-label {
  color: #617097;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 700;
}

.availability-overview-block {
  border: 1px solid #dbe2f5;
  border-radius: 14px;
  background: #ffffff;
  padding: 14px;
  display: grid;
  gap: 10px;
}

.availability-overview-block-head h3 {
  margin: 0;
  font-size: clamp(28px, 2vw, 34px);
  line-height: 1.08;
  color: #1f2948;
}

.availability-overview-block-head p {
  margin: 5px 0 0;
  color: #687395;
  font-size: 14px;
}

.availability-overview-block--when {
  border-top: 3px solid #5f70ff;
}

.availability-overview-block--where {
  border-top: 3px solid #2f8aa8;
}

.availability-overview-block--booking {
  border-top: 3px solid #7b58d1;
}

.availability-overview-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.availability-overview-card {
  width: 100%;
  border: 1px solid #dbe2f5;
  border-radius: 12px;
  background: #ffffff;
  padding: 14px;
  text-align: left;
  cursor: pointer;
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  transition: border-color 140ms ease, box-shadow 140ms ease, transform 140ms ease;
}

.availability-overview-card:hover {
  border-color: #c5d2ff;
  box-shadow: 0 10px 20px rgba(41, 58, 124, 0.12);
  transform: translateY(-1px);
}

.availability-overview-card > * {
  pointer-events: none;
}

.availability-overview-icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  border: 1px solid #d8e0fa;
  background: #eff3ff;
  color: #3d4fa1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.03em;
}

.availability-overview-copy {
  display: grid;
  gap: 3px;
}

.availability-overview-copy strong {
  color: #212d4d;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.12;
}

.availability-overview-copy span {
  color: #677394;
  font-size: 14px;
  line-height: 1.42;
}

.availability-overview-arrow {
  color: #4d5bff;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.availability-overview-card--when .availability-overview-icon {
  border-color: #d6deff;
  background: #eef2ff;
  color: #3f50b5;
}

.availability-overview-card--where .availability-overview-icon {
  border-color: #cde2eb;
  background: #ebf6fa;
  color: #24667c;
}

.availability-overview-card--booking .availability-overview-icon {
  border-color: #dfd3f8;
  background: #f4efff;
  color: #5d3ea7;
}

.availability-section-shell {
  display: grid;
  gap: 12px;
}

.availability-section-head h2 {
  margin: 0;
  font-size: 30px;
  color: #222b48;
}

.business-hours-editor {
  border: 1px solid #dbe1f0;
  border-radius: 12px;
  overflow: hidden;
}

.business-hours-row {
  display: grid;
  grid-template-columns: minmax(120px, 1fr) 92px minmax(120px, 1fr) minmax(120px, 1fr);
  gap: 10px;
  align-items: center;
  padding: 10px 12px;
  border-top: 1px solid #e8edfb;
}

.business-hours-row:first-child {
  border-top: 0;
}

.business-hours-day strong {
  font-size: 14px;
  color: #293354;
}

.business-hours-open-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin: 0;
  color: #4b567a;
  font-size: 13px;
}

.business-hours-open-toggle input {
  width: auto;
  margin: 0;
}

.business-hours-row label {
  margin: 0;
  font-size: 12px;
  color: #5b6486;
}

.business-hours-time-label {
  display: inline-block;
  margin-bottom: 4px;
}

.business-hours-row input[type="time"] {
  width: 100%;
  margin: 0;
}

.business-hours-row input[type="time"]:disabled {
  background: #f3f5fc;
  color: #9ca4bf;
}

.business-hours-advanced summary {
  cursor: pointer;
  color: #3e4b7a;
  font-weight: 700;
}

.business-hours-advanced .muted-note {
  margin-top: 8px;
  margin-bottom: 8px;
}

.twilight-availability-panel {
  display: grid;
  gap: 14px;
}

.twilight-default-card {
  border: 1px solid #dbe1f0;
  border-radius: 12px;
  background: #ffffff;
  overflow: hidden;
}

.twilight-default-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  padding: 16px 22px 14px;
  border-bottom: 1px solid #e8edfb;
}

.twilight-default-card-copy h3 {
  margin: 0;
  color: #273047;
  font-size: 31px;
  line-height: 1.08;
}

.twilight-default-card-copy p {
  margin: 6px 0 0;
  color: #67708d;
  line-height: 1.5;
  max-width: 760px;
}

.twilight-edit-page-btn {
  white-space: nowrap;
}

.twilight-grid-head {
  display: grid;
  grid-template-columns: minmax(150px, 1fr) 90px 90px;
  align-items: center;
  gap: 10px;
  padding: 14px 22px 8px;
  color: #566082;
  font-size: 12px;
  font-weight: 700;
}

.twilight-grid-head span {
  text-align: center;
}

.twilight-grid-head span:first-child {
  text-align: left;
}

.twilight-grid-body {
  display: grid;
  gap: 6px;
  padding: 0 22px 12px;
}

.twilight-grid-row {
  display: grid;
  grid-template-columns: minmax(150px, 1fr) 90px 90px;
  align-items: center;
  gap: 10px;
  min-height: 34px;
}

.twilight-grid-day {
  color: #2f3858;
  font-size: 14px;
}

.twilight-grid-check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0;
}

.twilight-grid-check input {
  width: 16px;
  height: 16px;
  margin: 0;
}

.twilight-card-actions {
  justify-content: flex-end;
  padding: 0 22px 16px;
}

.twilight-reset-btn {
  margin-right: auto;
  border: 0;
  background: transparent;
  color: #d12a2a;
  font-weight: 700;
  cursor: pointer;
  padding: 8px 0;
}

.twilight-reset-btn:hover {
  text-decoration: underline;
}

.twilight-overrides {
  display: grid;
  gap: 10px;
}

.twilight-overrides-head h3 {
  margin: 0;
  color: #273047;
  font-size: 32px;
  line-height: 1.1;
}

.twilight-overrides-head .muted-note {
  margin-top: 6px;
}

.twilight-overrides-note {
  border: 1px solid #c9dcff;
  background: #ebf3ff;
  color: #35549d;
  border-radius: 10px;
  padding: 10px 12px;
  font-size: 13px;
  line-height: 1.45;
}

.twilight-user-search {
  max-width: 420px;
}

.twilight-user-list {
  display: grid;
  gap: 8px;
}

.twilight-user-row {
  border: 1px solid #dbe1f0;
  border-radius: 10px;
  background: #ffffff;
  padding: 12px;
  display: flex;
  align-items: center;
  gap: 12px;
}

.twilight-user-avatar {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  border: 1px solid #d0d8ee;
  background: #f0f3ff;
  color: #3e4f94;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 16px;
  flex-shrink: 0;
}

.twilight-user-copy {
  display: grid;
  gap: 2px;
}

.twilight-user-copy strong {
  color: #2e3858;
  font-size: 18px;
  line-height: 1.2;
}

.twilight-user-copy span {
  color: #606b8f;
  font-size: 14px;
  line-height: 1.35;
}

.twilight-user-empty-search,
.twilight-user-empty-static {
  margin: 0;
}

.availability-sync-grid {
  margin-top: 10px;
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.availability-sync-card {
  border: 1px solid #dbe1f0;
  border-radius: 12px;
  background: #ffffff;
  padding: 14px;
  display: grid;
  gap: 10px;
  align-content: start;
  min-height: 150px;
}

.availability-sync-card h3 {
  margin: 0;
  font-size: 21px;
  line-height: 1.2;
  color: #232d4b;
}

.availability-sync-card p {
  margin: 0;
  min-height: 24px;
}

.availability-sync-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.availability-sync-card-head .badge {
  white-space: nowrap;
}

.availability-sync-card-copy {
  max-width: 480px;
  line-height: 1.4;
}

.availability-sync-card .btn {
  justify-self: start;
  width: auto;
  min-width: 150px;
}

.availability-sync-actions {
  margin-top: 4px;
}

.products-overview-group {
  border-top: 1px solid #e9edf9;
  padding-top: 18px;
}

.products-overview-group:first-child {
  border-top: 0;
  padding-top: 0;
}

.products-overview-group h2 {
  margin: 0;
  font-size: 34px;
  line-height: 1.1;
  color: #222b48;
}

.products-overview-group .muted-note {
  margin-top: 7px;
}

.products-overview-grid {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.products-overview-grid-single {
  grid-template-columns: minmax(0, 1fr);
  max-width: 520px;
}

.products-overview-card {
  width: 100%;
  border: 1px solid #dbe1f0;
  border-radius: 10px;
  background: #ffffff;
  padding: 14px 16px;
  text-align: left;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 12px;
}

.products-overview-card:hover {
  border-color: #c9d2ef;
  box-shadow: 0 5px 14px rgba(32, 52, 114, 0.08);
}

.products-overview-card > * {
  pointer-events: none;
}

.products-overview-icon {
  width: 34px;
  height: 34px;
  border-radius: 8px;
  border: 1px solid #edf1ff;
  background: #f7f9ff;
  color: #4f5876;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.products-overview-copy {
  display: grid;
  gap: 2px;
}

.products-overview-copy strong {
  color: #273047;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.15;
}

.products-overview-copy span {
  color: #68718d;
  font-size: 16px;
  line-height: 1.4;
}

.products-catalog-shell {
  display: grid;
  gap: 14px;
}

.products-services-head {
  border-top: 1px solid #e9edf9;
  border-bottom: 1px solid #e9edf9;
  padding: 12px 0 0;
}

.products-services-head h2 {
  margin: 0;
  font-size: 28px;
  color: #1f2641;
}

.products-services-tabs {
  display: flex;
  gap: 14px;
  margin-top: 12px;
}

.products-services-tab {
  border: 0;
  border-bottom: 2px solid transparent;
  background: transparent;
  color: #6a738f;
  font-weight: 700;
  font-size: 20px;
  padding: 9px 2px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
}

.products-services-tab svg {
  width: 15px;
  height: 15px;
  pointer-events: none;
}

.products-services-tab.active {
  color: #4b54eb;
  border-bottom-color: #4b54eb;
}

.products-catalog-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}

.products-catalog-toolbar h3 {
  margin: 0;
}

.products-new-btn {
  padding-inline: 16px;
}

.products-catalog-filters {
  border: 1px solid #d7def3;
  border-radius: 10px;
  overflow: hidden;
  background: #f4f6ff;
  margin-bottom: 12px;
}

.products-catalog-filters label {
  margin: 0;
  padding: 12px;
  font-size: 13px;
  color: #39466f;
  font-weight: 600;
}

.products-catalog-filters {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.products-catalog-filters input,
.products-catalog-filters select {
  margin-top: 6px;
  background: #ffffff;
}

.products-filter-actions {
  grid-column: 1 / -1;
  border-top: 1px solid #dce3f8;
  background: #e8edff;
  padding: 12px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.products-catalog-table-wrap {
  border: 1px solid #dde3f4;
  border-radius: 10px;
}

.products-catalog-table {
  width: 100%;
  border-collapse: collapse;
}

.products-catalog-table th {
  color: #737d98;
  background: #fafbff;
}

.products-catalog-table td {
  border-bottom: 1px solid #e8ecf8;
  vertical-align: middle;
}

.products-catalog-table tbody tr:last-child td {
  border-bottom: 0;
}

.products-handle-cell {
  width: 40px;
  color: #6f7995;
  font-size: 16px;
}

.products-info-cell strong {
  display: block;
  color: #273047;
}

.products-info-content {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.products-info-image {
  width: 72px;
  height: 54px;
  object-fit: cover;
  border-radius: 8px;
  border: 1px solid #e0e6f6;
  background: #f5f7ff;
  flex-shrink: 0;
}

.products-info-image-placeholder {
  width: 72px;
  height: 54px;
  border-radius: 8px;
  border: 1px dashed #d5dcef;
  background: #f7f9ff;
  color: #7e87a3;
  font-size: 11px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 6px;
  flex-shrink: 0;
}

.products-info-copy {
  display: grid;
  gap: 3px;
}

.products-info-cell p {
  margin: 2px 0 0;
  font-size: 13px;
}

.products-info-copy small {
  color: #67728f;
  font-size: 12px;
}

.products-tag-pill {
  display: inline-flex;
  border-radius: 8px;
  background: #dbe6ff;
  color: #385ec2;
  padding: 3px 9px;
  font-size: 12px;
  font-weight: 700;
}

.products-active-pill {
  display: inline-flex;
  border-radius: 8px;
  padding: 3px 9px;
  font-size: 12px;
  font-weight: 700;
}

.products-active-pill.active {
  background: #d8f6e3;
  color: #1b8f54;
}

.products-active-pill.inactive {
  background: #ffe2e2;
  color: #bf2020;
}

.products-price-cell {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.products-price-cell span {
  color: #2c3454;
  font-weight: 700;
}

.products-edit-link {
  border: 0;
  background: transparent;
  color: #4351ec;
  font-weight: 700;
  cursor: pointer;
  text-decoration: underline;
}

.products-editor-modal {
  width: min(560px, 100%);
  border-radius: 12px;
  padding: 20px;
  box-shadow: 0 20px 48px rgba(16, 24, 58, 0.24);
}

.products-editor-modal-wide {
  width: min(920px, 100%);
}

.package-editor-modal {
  width: min(760px, 100%);
}

.products-editor-modal h3 {
  margin: 0;
}

.products-editor-grid-two {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.products-editor-flags {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.products-editor-image-preview {
  display: grid;
  gap: 6px;
}

.products-editor-image-preview img {
  width: min(220px, 100%);
  max-height: 140px;
  object-fit: cover;
  border-radius: 10px;
  border: 1px solid #d8dff2;
  background: #f5f7ff;
}

.products-image-upload-card {
  border: 1px solid #d7def3;
  border-radius: 12px;
  background: #f7f9ff;
  padding: 12px;
  display: grid;
  gap: 10px;
}

.products-image-upload-label {
  display: inline-block;
  font-size: 14px;
  font-weight: 700;
  color: #24305a;
}

.products-image-upload-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 108px;
  gap: 10px;
  align-items: stretch;
}

.products-image-upload-input {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  overflow: hidden;
  white-space: nowrap;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
}

.products-image-upload-main {
  border: 1px solid #d9e2fb;
  border-radius: 12px;
  background: #fff;
  overflow: hidden;
  min-height: 240px;
  display: grid;
  place-items: center;
}

.products-image-upload-main img {
  width: 100%;
  height: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  display: block;
}

.products-image-upload-placeholder {
  color: #6a759c;
  font-size: 13px;
  font-weight: 600;
}

.products-image-upload-side {
  display: grid;
  gap: 8px;
  align-content: start;
  max-height: 240px;
  overflow-y: auto;
  padding-right: 2px;
}

.products-image-upload-thumb {
  border: 1px solid #d6def7;
  border-radius: 10px;
  background: #fff;
  padding: 0;
  width: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  cursor: pointer;
}

.products-image-upload-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.products-image-upload-thumb.is-active {
  border-color: #4d5bff;
  box-shadow: 0 0 0 2px rgba(77, 91, 255, 0.22);
}

.products-image-upload-thumb.is-readonly {
  cursor: default;
}

.products-image-upload-side-empty {
  border: 1px dashed #cbd7ff;
  border-radius: 10px;
  background: #fff;
  color: #6a759c;
  font-size: 12px;
  font-weight: 600;
  padding: 10px 8px;
  text-align: center;
}

.products-image-upload-actions {
  gap: 10px;
}

.products-image-upload-actions .btn {
  min-width: 120px;
}

.products-sqft-range-panel {
  border: 1px solid #d7def3;
  border-radius: 10px;
  background: #f7f9ff;
  padding: 12px;
  display: grid;
  gap: 10px;
}

.products-sqft-range-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}

.products-sqft-range-head h4 {
  margin: 0;
}

.products-sqft-range-list {
  display: grid;
  gap: 8px;
}

.products-sqft-range-row {
  border: 1px solid #dfe5f7;
  border-radius: 9px;
  background: #ffffff;
  padding: 10px;
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(3, minmax(0, 1fr)) auto;
  align-items: end;
}

.products-sqft-range-row label {
  margin: 0;
}

.products-sqft-range-actions {
  min-width: 80px;
}

.package-image-preview-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 8px;
}

.package-image-preview-grid img {
  width: 100%;
  height: 84px;
  object-fit: cover;
  border-radius: 8px;
  border: 1px solid #d8dff2;
  background: #f5f7ff;
}

.package-products-grid {
  border: 1px solid #d7def3;
  border-radius: 10px;
  background: #f8faff;
  padding: 10px;
  max-height: 220px;
  overflow: auto;
  display: grid;
  gap: 8px;
}

.package-product-option {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  border: 1px solid #dfe5f7;
  border-radius: 8px;
  background: #ffffff;
  padding: 8px;
}

.package-product-option span {
  display: grid;
  gap: 1px;
}

.package-product-option span strong {
  font-size: 13px;
  color: #273047;
}

.package-product-option span small {
  color: #67728f;
  font-size: 12px;
}

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

.packages-table th:nth-child(2) {
  width: 90px;
}

.packages-table th:nth-child(3) {
  width: 170px;
}

.packages-table th:nth-child(4) {
  width: 140px;
}

.packages-table th:nth-child(5) {
  width: 110px;
}

.pricing-plans-shell {
  display: grid;
  gap: 14px;
}

.pricing-plans-head {
  border-bottom: 1px solid #e9edf9;
  padding-bottom: 10px;
}

.pricing-plans-head h2 {
  margin: 0;
  font-size: 50px;
  color: #1f2641;
}

.pricing-plans-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 12px;
}

.pricing-plans-toolbar h3 {
  margin: 0;
}

.pricing-plans-toolbar .muted-note {
  margin-top: 6px;
  max-width: 80ch;
}

.pricing-plans-filters {
  margin-bottom: 14px;
}

.pricing-plans-table th:nth-child(1) {
  width: 48%;
}

.pricing-plans-table th:nth-child(2) {
  width: 22%;
}

.pricing-plans-table th:nth-child(3) {
  width: 22%;
}

.pricing-plans-name-cell strong,
.pricing-plans-coupon-cell strong {
  display: block;
  color: #2b3352;
}

.pricing-plans-name-cell p,
.pricing-plans-coupon-cell p {
  margin: 2px 0 0;
}

.pricing-plans-actions-cell {
  display: flex;
  justify-content: flex-end;
  gap: 16px;
  white-space: nowrap;
}

.products-delete-link {
  color: #e01f1f;
}

.travel-fees-shell {
  display: grid;
  gap: 14px;
}

.travel-fees-table th:nth-child(1) {
  width: 18%;
}

.travel-fees-table th:nth-child(2) {
  width: 47%;
}

.travel-fees-table th:nth-child(3) {
  width: 15%;
}

.travel-fees-table th:nth-child(4) {
  width: 10%;
}

.travel-fees-user-empty {
  color: #727b98;
}

.travel-fees-users-list {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.travel-fees-user-avatar {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  background: #8f919b;
  color: #ffffff;
  font-size: 12px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.travel-fees-user-extra {
  color: #66708f;
  font-size: 12px;
  font-weight: 700;
}

.travel-fee-editor-modal {
  width: min(760px, 100%);
  max-height: calc(100vh - 52px);
  overflow-y: auto;
}

.travel-fee-editor-modal .toolbar {
  position: sticky;
  top: 0;
  z-index: 2;
  background: #fff;
  padding-bottom: 10px;
  margin-bottom: 14px;
  border-bottom: 1px solid #e6ebff;
}

.travel-fee-distance-config {
  border: 1px solid #d6ddff;
  border-radius: 12px;
  background: #f7f9ff;
  padding: 12px;
  display: grid;
  gap: 10px;
}

.travel-fee-distance-head h4 {
  margin: 0;
  color: #263260;
  font-size: 16px;
}

.travel-fee-distance-head .muted-note {
  margin-top: 4px;
}

.travel-fee-distance-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.travel-fee-distance-meta {
  margin: 0;
}

.travel-fee-origin-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}

.travel-fee-map-preview-wrap .address-map-preview,
.travel-fee-map-preview-wrap .address-map-preview-empty {
  margin-top: 0;
}

.travel-fee-map-preview-wrap .address-map-preview-frame {
  height: 220px;
}

.travel-fee-assign-users {
  border: 1px solid #d6ddff;
  border-radius: 12px;
  background: #f7f9ff;
  padding: 12px;
  display: grid;
  gap: 10px;
}

.travel-fee-assign-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.travel-fee-assigned-summary {
  min-height: 32px;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.travel-fee-assigned-text {
  color: #4b567e;
  font-size: 12px;
  font-weight: 600;
}

.travel-fee-assign-modal {
  position: fixed;
  inset: 0;
  z-index: 960;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
}

.travel-fee-assign-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(14, 22, 52, 0.44);
}

.travel-fee-assign-panel {
  position: relative;
  width: min(560px, 100%);
  max-height: calc(100vh - 64px);
  overflow: auto;
  border-radius: 12px;
  padding: 18px;
  display: grid;
  gap: 12px;
}

.travel-fee-assign-list {
  display: grid;
  gap: 8px;
}

.travel-fee-team-option {
  margin: 0;
  border: 1px solid #d7dff9;
  border-radius: 10px;
  background: #fff;
  padding: 10px;
  display: flex;
  gap: 10px;
  align-items: flex-start;
  cursor: pointer;
}

.travel-fee-team-option input {
  width: 16px;
  height: 16px;
  margin: 2px 0 0;
}

.travel-fee-team-option-copy {
  display: grid;
  gap: 2px;
}

.travel-fee-team-option-copy strong {
  font-size: 13px;
  color: #25305a;
}

.travel-fee-team-option-copy small {
  color: #647099;
  font-size: 12px;
}

@media (max-width: 760px) {
  .travel-fee-distance-grid,
  .travel-fee-origin-grid {
    grid-template-columns: 1fr;
  }

  .travel-fee-assign-row {
    align-items: stretch;
  }

  .travel-fee-assign-row .btn {
    width: 100%;
  }
}

.tax-rates-shell {
  display: grid;
  gap: 14px;
}

.tax-rates-page-head {
  border-bottom: 1px solid #e9edf9;
  padding-bottom: 0;
}

.tax-rates-page-head h2 {
  margin: 0;
  font-size: 50px;
  color: #1f2641;
}

.tax-rates-tabs {
  display: flex;
  gap: 16px;
  margin-top: 12px;
}

.tax-rates-tab {
  border: 0;
  border-bottom: 2px solid transparent;
  background: transparent;
  color: #6a738f;
  font-size: 31px;
  font-weight: 700;
  padding: 8px 2px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
}

.tax-rates-tab svg {
  width: 15px;
  height: 15px;
  pointer-events: none;
}

.tax-rates-tab.active {
  color: #4b54eb;
  border-bottom-color: #4b54eb;
}

.tax-rates-empty {
  min-height: 260px;
  display: grid;
  place-content: center;
  justify-items: center;
  text-align: center;
  gap: 8px;
}

.tax-rates-empty-icon {
  width: 38px;
  height: 30px;
  border: 2px solid #9ca6bd;
  border-radius: 7px;
  color: #9ca6bd;
  font-size: 31px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.tax-rates-empty h4 {
  margin: 8px 0 0;
  color: #1f2641;
}

.tax-rates-empty p {
  margin: 0;
  color: #6e7793;
  max-width: 56ch;
}

.tax-rates-table th:nth-child(1) {
  width: 28%;
}

.tax-rates-table th:nth-child(2) {
  width: 28%;
}

.tax-rates-table th:nth-child(3) {
  width: 14%;
}

.tax-rates-table th:nth-child(4) {
  width: 16%;
}

.coupons-shell {
  display: grid;
  gap: 14px;
}

.coupons-shell .pricing-plans-toolbar .muted-note + .muted-note {
  margin-top: 4px;
}

.coupons-table th:nth-child(1) {
  width: 28%;
}

.coupons-table th:nth-child(2) {
  width: 14%;
}

.coupons-table th:nth-child(3) {
  width: 16%;
}

.coupons-table th:nth-child(4) {
  width: 30%;
}

.coupons-promo-empty {
  color: #727b98;
}

.product-filters-shell {
  display: grid;
  gap: 14px;
}

.product-filters-table th:nth-child(1) {
  width: 19%;
}

.product-filters-table th:nth-child(2) {
  width: 22%;
}

.product-filters-table th:nth-child(3) {
  width: 11%;
}

.product-filters-table th:nth-child(4) {
  width: 19%;
}

.product-filters-table th:nth-child(5) {
  width: 19%;
}

.product-filters-usage-cell {
  white-space: nowrap;
}

.product-filters-info-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  border-radius: 999px;
  border: 1px solid #3f63f3;
  color: #3f63f3;
  font-size: 11px;
  font-weight: 700;
  margin-left: 8px;
}

.products-plan-grid {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.products-plan-card {
  display: grid;
  gap: 7px;
}

.listing-layout {
  gap: 14px;
}

.listing-filter-panel {
  padding: 16px;
  background: linear-gradient(180deg, #f2f4ff 0%, #eef2ff 100%);
}

.listing-panel-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}

.listing-panel-head h3 {
  margin: 0;
}

.listing-panel-head p {
  margin: 2px 0 0;
  color: #58638a;
}

.listing-filters {
  display: grid;
  grid-template-columns: minmax(260px, 1.5fr) minmax(180px, 1fr) auto;
  gap: 10px;
  align-items: end;
}

.listing-filters label {
  margin: 0;
}

.listing-filters label span {
  display: block;
  margin-bottom: 4px;
  font-size: 12px;
  font-weight: 700;
  color: #505a7f;
}

.listing-filters input,
.listing-filters select {
  margin-top: 0;
  background: #fff;
}

.listing-filter-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.listing-create-shell {
  margin-top: 12px;
  border-top: 1px solid #dce2fb;
  padding-top: 12px;
}

.listing-create-shell h4 {
  margin: 0 0 8px;
}

.listing-results-head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 10px;
}

.listing-results-title h3 {
  margin: 0;
}

.listing-results-title p {
  margin: 3px 0 0;
  color: var(--muted);
  font-size: 13px;
}

.listing-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 12px;
  align-items: start;
}

.listing-card {
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 12px 26px rgba(39, 54, 129, 0.08);
  overflow: hidden;
}

.listing-thumb {
  border: none;
  width: 100%;
  min-height: 136px;
  padding: 10px;
  cursor: pointer;
  position: relative;
  text-align: left;
  color: #fff;
  background: transparent;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.listing-thumb::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--listing-thumb-a) 0%, var(--listing-thumb-b) 100%);
}

.listing-thumb.has-media-thumb::before {
  background:
    linear-gradient(135deg, rgba(19, 29, 67, 0.58) 0%, rgba(26, 38, 95, 0.46) 100%),
    var(--listing-thumb-image),
    linear-gradient(135deg, var(--listing-thumb-a) 0%, var(--listing-thumb-b) 100%);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.listing-thumb > * {
  position: relative;
  z-index: 1;
  pointer-events: none;
}

.listing-thumb-cta {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.listing-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.listing-chip {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 4px 8px;
  font-size: 11px;
  font-weight: 700;
}

.listing-chip-good {
  background: #dbf8ed;
  color: #0b7d58;
}

.listing-chip-warn {
  background: #fff2d8;
  color: #9d6500;
}

.listing-chip-neutral {
  background: #edf1ff;
  color: #3f4cb3;
}

.listing-card-body {
  padding: 12px;
  display: grid;
  gap: 8px;
}

.listing-card-body h3 {
  margin: 0;
  font-size: 24px;
  line-height: 1.18;
}

.listing-card-location {
  margin: 0;
  color: var(--muted);
}

.listing-card-client,
.listing-card-contact {
  margin: 0;
  color: #4f5a81;
  font-size: 14px;
}

.listing-card-order {
  border-top: 1px solid #e7ecff;
  border-bottom: 1px solid #e7ecff;
  padding: 8px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  color: #4a557b;
}

.listing-card-order strong {
  color: #232c4e;
}

.listing-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  color: #5f6a91;
  font-size: 12px;
}

.listing-detail-panel {
  overflow: hidden;
}

.listing-detail-topbar {
  padding: 14px 14px 10px;
  display: flex;
  justify-content: flex-end;
}

.listing-detail-hero {
  padding: 18px;
  background: linear-gradient(135deg, var(--listing-thumb-a) 0%, var(--listing-thumb-b) 100%);
  color: #fff;
  background-size: cover;
  background-position: center;
}

.listing-detail-hero.has-media-hero {
  background:
    linear-gradient(135deg, rgba(19, 29, 67, 0.58) 0%, rgba(26, 38, 95, 0.46) 100%),
    var(--listing-hero-image),
    linear-gradient(135deg, var(--listing-thumb-a) 0%, var(--listing-thumb-b) 100%);
}

.listing-detail-hero h2 {
  margin: 0 0 5px;
  font-size: clamp(28px, 3.2vw, 36px);
  text-shadow: 0 2px 12px rgba(11, 16, 40, 0.28);
}

.listing-detail-hero p {
  margin: 0 0 9px;
  color: rgba(255, 255, 255, 0.92);
  text-shadow: 0 2px 12px rgba(11, 16, 40, 0.28);
}

.listing-detail-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.listing-detail-grid {
  padding: 14px;
  border-bottom: 1px solid var(--line);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 10px;
}

.listing-info-card {
  border: 1px solid #e5eaff;
  border-radius: 12px;
  padding: 12px;
  background: #f8faff;
}

.listing-info-card h4 {
  margin: 0 0 8px;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #58628a;
}

.listing-info-card p {
  margin: 0 0 6px;
  color: #344066;
  font-size: 14px;
}

.listing-status-badges {
  margin-top: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.listing-client-actions {
  margin-top: 8px;
}

.listing-customer-header {
  margin-top: 6px;
  display: flex;
  align-items: stretch;
  gap: 10px;
}

.listing-customer-list {
  margin-top: 0;
  flex: 1 1 auto;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.listing-customer-header-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-self: flex-start;
}

.listing-download-lock-control {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.listing-download-lock-btn,
.listing-download-lock-icon {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  border: 1px solid #ccd7ff;
  background: #eef2ff;
  color: #4459bc;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  line-height: 1;
  padding: 0;
}

.listing-download-lock-btn.is-locked,
.listing-download-lock-icon.is-locked {
  background: #ffeae7;
  border-color: #f8c8c1;
  color: #bc4b39;
}

.listing-customer-add-btn {
  flex: 0 0 auto;
}

.listing-customer-add-card {
  border: 1px dashed #c9d5ff;
  border-radius: 10px;
  background: #f8faff;
  min-height: 92px;
  padding: 12px;
  display: grid;
  align-content: center;
  gap: 4px;
  text-align: left;
  color: #33468f;
  cursor: pointer;
  font: inherit;
  transition: background 0.18s ease, border-color 0.18s ease;
}

.listing-customer-add-card:hover {
  background: #eef3ff;
  border-color: #b3c4ff;
}

.listing-customer-add-card strong {
  font-size: 14px;
  font-weight: 700;
}

.listing-customer-add-card small {
  color: #5d6997;
  font-size: 12px;
}

.listing-customer-empty {
  grid-column: 1 / -1;
  border: 1px dashed #d6defa;
  border-radius: 10px;
  background: #ffffff;
  padding: 12px;
}

.listing-customer-row {
  border: 1px solid #e3e9ff;
  border-radius: 10px;
  background: #ffffff;
  padding: 10px;
  display: grid;
  gap: 10px;
}

.listing-customer-main {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 10px;
}

.listing-customer-avatar {
  width: 44px;
  height: 44px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 44px;
  background: linear-gradient(145deg, #92a6ff 0%, #6d7ef0 100%);
  color: #fff;
  font-size: 15px;
  font-weight: 800;
  overflow: hidden;
}

.listing-customer-avatar-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.listing-customer-avatar-fallback {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

.listing-customer-copy {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.listing-customer-copy strong {
  color: #263564;
  font-size: 14px;
}

.listing-customer-copy span {
  font-size: 12px;
  color: #5e6994;
}

.listing-customer-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-start;
}

.listing-customer-primary {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 5px 9px;
  font-size: 11px;
  font-weight: 800;
  color: #2f469f;
  background: #e9efff;
  border: 1px solid #ccd7ff;
}

.listing-client-actions input[data-role="listing-customer-search"] {
  flex: 1 1 180px;
  min-width: 180px;
  margin-top: 0;
}

.listing-media-wrap {
  padding: 18px;
  display: grid;
  gap: 14px;
}

.listing-media-wrap h3 {
  margin: 0;
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.01em;
}

.listing-accordion {
  border: 1px solid #e3e9ff;
  border-radius: 14px;
  background: linear-gradient(180deg, #ffffff 0%, #f8faff 100%);
  overflow: clip;
}

.listing-accordion summary {
  list-style: none;
  cursor: pointer;
  padding: 12px 16px;
  min-height: 60px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  font-weight: 700;
  transition: background 0.2s ease;
}

.listing-accordion summary:focus-visible {
  outline: 2px solid #6a7dff;
  outline-offset: -2px;
}

.listing-accordion summary:hover {
  background: #f4f7ff;
}

.listing-accordion summary::-webkit-details-marker {
  display: none;
}

.listing-accordion-main {
  display: grid;
  gap: 1px;
}

.listing-accordion-title {
  font-size: 20px;
  line-height: 1.18;
  font-weight: 700;
  color: #1c2440;
}

.listing-accordion-subtitle {
  font-size: 11px;
  font-weight: 600;
  color: #66739f;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.listing-accordion-right {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.listing-accordion-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  min-width: 30px;
  height: 24px;
  padding: 0 8px;
  background: #edf1ff;
  color: #4654c0;
  font-size: 12px;
  font-weight: 700;
  border: 1px solid #d4dcff;
}

.listing-accordion-chevron {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  border: 1px solid #d4dcff;
  color: #4a5ebf;
  font-size: 12px;
  line-height: 1;
  transition: transform 0.2s ease;
}

.listing-accordion[open] .listing-accordion-chevron {
  transform: rotate(180deg);
}

.listing-accordion[open] summary {
  background: linear-gradient(180deg, #f5f8ff 0%, #f0f5ff 100%);
}

.listing-accordion-body {
  border-top: 1px solid #e6edff;
  padding: 14px 16px 16px;
  display: grid;
  gap: 12px;
}

.listing-accordion-body p {
  margin: 0;
  color: #586289;
  font-size: 14px;
}

.listing-media-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
  border: 1px solid #dfe7ff;
  border-radius: 12px;
  background: linear-gradient(180deg, #f9fbff 0%, #f2f6ff 100%);
  padding: 10px;
}

.listing-media-toolbar-left {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 9px;
}

.listing-media-sort-select {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #4f5c88;
  font-size: 13px;
  font-weight: 700;
}

.listing-media-sort-select select {
  margin-top: 0;
  min-width: 180px;
}

.listing-media-order-hint {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: 12px;
  font-weight: 700;
  color: #32448a;
  background: #eaf0ff;
  border: 1px solid #cdd9ff;
  border-radius: 999px;
  padding: 7px 10px;
}

.listing-media-order-hint.is-inactive {
  color: #5e6a96;
  background: #f4f6fd;
  border-color: #dce2f8;
}

.listing-media-order-hint-icon {
  width: 18px;
  height: 18px;
  border-radius: 999px;
  display: inline-grid;
  place-items: center;
  font-size: 11px;
  font-weight: 800;
  background: #fff;
  color: #3e52b3;
  border: 1px solid #c5d4ff;
}

.listing-media-sync-btn {
  font-size: 12px;
  padding: 7px 11px;
  border-color: #bfcfff;
}

.listing-media-bulk-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

.listing-media-bulk-actions .btn {
  font-size: 12px;
  padding: 7px 10px;
}

.listing-gallery-grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 14px;
  contain: layout style;
}

.listing-gallery-card {
  border: 1px solid #dfe7ff;
  border-radius: 12px;
  padding: 10px;
  display: grid;
  gap: 10px;
  color: #374266;
  background: linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
  box-shadow: 0 8px 22px rgba(47, 68, 155, 0.08);
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
  content-visibility: auto;
  contain-intrinsic-size: 460px 420px;
  contain: layout paint style;
  touch-action: pan-y;
}

.listing-gallery-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.listing-gallery-card-head-meta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
}

.listing-gallery-order-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 30px;
  height: 24px;
  border-radius: 999px;
  padding: 0 9px;
  font-size: 12px;
  font-weight: 800;
  color: #34479a;
  background: #ecf1ff;
  border: 1px solid #cfd9ff;
}

.listing-tour-provider-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 3px 8px;
  font-size: 11px;
  font-weight: 800;
  color: #3047a0;
  background: #edf2ff;
  border: 1px solid #d2dcff;
}

.listing-gallery-drag-handle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 24px;
  border-radius: 8px;
  background: #f3f6ff;
  border: 1px solid #d7e0ff;
  color: #5a6aa5;
  font-size: 14px;
  letter-spacing: 1px;
}

.listing-gallery-card.is-draggable .listing-gallery-drag-handle {
  cursor: grab;
}

.listing-gallery-card.is-draggable {
  cursor: move;
}

.listing-gallery-card.is-draggable:hover {
  transform: translateY(-2px);
  border-color: #bcccff;
  box-shadow: 0 14px 32px rgba(43, 63, 152, 0.16);
}

.listing-gallery-card.is-dragging {
  opacity: 0.65;
  transform: scale(0.98) rotate(0.2deg);
  border-color: #91a8ff;
  box-shadow: 0 16px 34px rgba(37, 57, 145, 0.26);
}

.listing-gallery-media {
  border: 1px solid #e3eaff;
  border-radius: 10px;
  overflow: hidden;
  background: #eef2ff;
  aspect-ratio: 4 / 3;
  contain: paint;
}

.listing-gallery-media img,
.listing-gallery-media video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.listing-gallery-placeholder {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  color: #4f5c88;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.03em;
}

.listing-gallery-actions {
  display: flex;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
}

.listing-gallery-actions .btn {
  padding: 7px 10px;
  font-size: 12px;
}

.listing-gallery-actions .btn.is-disabled {
  opacity: 0.58;
  cursor: not-allowed;
}

.listing-gallery-select {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  color: #475684;
}

.listing-gallery-select input {
  margin: 0;
}

.listing-gallery-empty-cell {
  list-style: none;
  grid-column: 1 / -1;
  border: 1px dashed #d6deff;
  border-radius: 12px;
  background: #f9fbff;
  display: grid;
  place-items: center;
  min-height: 86px;
}

.listing-asset-form {
  border-top: 1px dashed #dce4ff;
  padding-top: 10px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto;
  gap: 8px;
  align-items: end;
}

.listing-asset-form input {
  margin-top: 0;
}

.listing-asset-form select {
  margin-top: 0;
}

.listing-asset-form-tours {
  grid-template-columns: minmax(180px, 0.9fr) minmax(0, 1.6fr) minmax(0, 1fr) auto;
}

.listing-asset-actions-row {
  border-top: 1px dashed #dce4ff;
  padding-top: 10px;
  display: flex;
  justify-content: center;
}

.listing-asset-empty {
  margin: 0;
  color: #6c77a2;
  padding: 18px 0;
  text-align: center;
}

.listing-delivery-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: end;
}

.listing-delivery-form label {
  margin: 0;
}

.listing-secondary-sections {
  border-top: 1px solid var(--line);
  padding: 14px;
  display: grid;
  gap: 14px;
}

.listing-secondary-section {
  display: grid;
  gap: 10px;
}

.listing-secondary-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.listing-secondary-head h3 {
  margin: 0;
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.01em;
}

.listing-secondary-row {
  border: 1px solid #dfe7ff;
  border-radius: 12px;
  background: #fff;
}

.listing-secondary-row > summary {
  list-style: none;
  cursor: pointer;
  padding: 12px 14px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.listing-secondary-row > summary::-webkit-details-marker {
  display: none;
}

.listing-secondary-row-main {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 8px;
}

.listing-secondary-row-main strong {
  color: #212e57;
  font-size: 16px;
  font-weight: 700;
}

.listing-secondary-row-main span {
  color: #5f6a93;
  font-size: 13px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.listing-secondary-inline-actions {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 8px;
}

.listing-secondary-inline-actions .btn {
  padding: 7px 12px;
}

.listing-secondary-chevron {
  color: #5f6a93;
  font-size: 14px;
  transition: transform 0.16s ease;
}

.listing-secondary-row[open] .listing-secondary-chevron {
  transform: rotate(180deg);
}

.listing-secondary-pill,
.listing-secondary-count-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 4px 9px;
  font-size: 12px;
  font-weight: 700;
  border: 1px solid #cfe0ff;
  background: #edf5ff;
  color: #3f5ab0;
}

.listing-secondary-body {
  border-top: 1px solid #edf2ff;
  padding: 11px 14px;
  display: grid;
  gap: 8px;
  background: #fbfcff;
}

.listing-secondary-row-media-match {
  border: 1px solid #e3e9ff;
  border-radius: 14px;
  background: linear-gradient(180deg, #ffffff 0%, #f8faff 100%);
  overflow: clip;
}

.listing-secondary-row-media-match > summary {
  padding: 12px 16px;
  min-height: 60px;
  justify-content: space-between;
  gap: 12px;
  transition: background 0.2s ease;
}

.listing-secondary-row-media-match > summary:focus-visible {
  outline: 2px solid #6a7dff;
  outline-offset: -2px;
}

.listing-secondary-row-media-match > summary:hover {
  background: #f4f7ff;
}

.listing-secondary-row-media-match .listing-secondary-row-main strong {
  font-size: 20px;
  line-height: 1.18;
  color: #1c2440;
}

.listing-secondary-row-media-match .listing-secondary-pill,
.listing-secondary-row-media-match .listing-secondary-count-badge {
  padding: 0 8px;
  min-width: 30px;
  height: 24px;
  justify-content: center;
  background: #edf1ff;
  border-color: #d4dcff;
  color: #4654c0;
}

.listing-secondary-row-media-match .listing-secondary-inline-actions {
  gap: 10px;
}

.listing-secondary-row-media-match .listing-secondary-chevron {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  border: 1px solid #d4dcff;
  color: #4a5ebf;
  font-size: 12px;
  line-height: 1;
  transition: transform 0.2s ease;
}

.listing-secondary-row-media-match[open] > summary {
  background: linear-gradient(180deg, #f5f8ff 0%, #f0f5ff 100%);
}

.listing-secondary-row-media-match > .listing-secondary-body {
  border-top: 1px solid #e6edff;
  padding: 14px 16px 16px;
}

.listing-property-details-stack {
  gap: 14px;
}

.listing-property-card {
  border: 1px solid #dfe7ff;
  border-radius: 12px;
  background: #fff;
  overflow: hidden;
}

.listing-property-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 14px;
  border-bottom: 1px solid #edf2ff;
  background: #f7f9ff;
}

.listing-property-card-head h4 {
  margin: 0;
  color: #202d57;
  font-size: 17px;
}

.listing-property-card-head .btn {
  padding: 7px 12px;
}

.listing-property-form {
  padding: 14px;
  display: grid;
  gap: 14px;
}

.listing-property-form label {
  margin: 0;
  display: grid;
  gap: 6px;
  color: #2f3d6e;
  font-weight: 700;
}

.listing-property-form label small {
  display: block;
  color: #5f6c98;
  font-weight: 500;
  font-size: 13px;
}

.listing-property-form input,
.listing-property-form select,
.listing-property-form textarea {
  margin-top: 0;
}

.listing-property-form textarea {
  resize: vertical;
  min-height: 120px;
}

.listing-property-form-actions {
  display: flex;
  justify-content: flex-end;
}

.listing-property-price-input {
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr);
  align-items: center;
  border: 1px solid #cfd9ff;
  border-radius: 8px;
  background: #fff;
  overflow: hidden;
}

.listing-property-price-input > span {
  display: grid;
  place-items: center;
  height: 100%;
  font-weight: 700;
  color: #53608d;
  background: #f4f7ff;
  border-right: 1px solid #d9e2ff;
}

.listing-property-price-input > input {
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

.listing-secondary-body p {
  margin: 0;
  color: #35406a;
  font-size: 14px;
}

.listing-secondary-empty {
  margin: 0;
  color: #5f6a93;
  border: 1px dashed #d8e1ff;
  border-radius: 12px;
  background: #fafbff;
  padding: 12px;
}

.listing-secondary-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 8px;
}

.listing-secondary-stat {
  border: 1px solid #e1e8ff;
  border-radius: 10px;
  background: #fff;
  padding: 9px 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.listing-secondary-stat strong {
  font-size: 13px;
  color: #304071;
}

.listing-secondary-stat em {
  font-style: normal;
  font-weight: 700;
  color: #4458b7;
}

.listing-marketing-card-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}

.listing-marketing-card {
  border: 1px solid #dbe4ff;
  border-radius: 12px;
  background: #ffffff;
  overflow: hidden;
  display: grid;
}

.listing-marketing-card-preview {
  position: relative;
  border-bottom: 1px solid #e5edff;
  background:
    linear-gradient(155deg, rgba(35, 55, 128, 0.68) 0%, rgba(66, 94, 204, 0.48) 44%, rgba(28, 41, 90, 0.74) 100%),
    var(--listing-flyer-image),
    linear-gradient(145deg, var(--listing-flyer-color-a, #66c8f5) 0%, var(--listing-flyer-color-b, #4d5ff3) 100%);
  background-size: cover;
  background-position: center;
  aspect-ratio: 4 / 5;
}

.listing-marketing-card-preview.format-social_square {
  aspect-ratio: 1 / 1;
}

.listing-marketing-card-preview.format-social_portrait {
  aspect-ratio: 4 / 5;
}

.listing-marketing-card-preview.format-story_vertical {
  aspect-ratio: 9 / 16;
}

.listing-marketing-card-preview.format-social_landscape {
  aspect-ratio: 16 / 9;
}

.listing-marketing-card-preview.format-email_banner {
  aspect-ratio: 3 / 1;
}

.listing-marketing-card-preview.format-email_feature {
  aspect-ratio: 5 / 3;
}

.listing-marketing-card-preview.format-print_letter {
  aspect-ratio: 8.5 / 11;
}

.listing-marketing-card-preview.format-print_landscape {
  aspect-ratio: 11 / 8.5;
}

.listing-marketing-card-preview.format-print_postcard {
  aspect-ratio: 6 / 4;
}

.listing-marketing-card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(6, 12, 34, 0.18) 0%, rgba(6, 12, 34, 0.64) 100%);
  padding: 12px;
  display: grid;
  align-content: end;
  gap: 4px;
  color: #f1f6ff;
}

.listing-marketing-template-chip {
  display: inline-flex;
  width: fit-content;
  border-radius: 999px;
  padding: 4px 8px;
  background: rgba(16, 25, 61, 0.46);
  border: 1px solid rgba(216, 229, 255, 0.42);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.listing-marketing-card-overlay strong {
  font-size: 20px;
  line-height: 1.08;
}

.listing-marketing-card-overlay span {
  font-size: 13px;
  opacity: 0.95;
}

.listing-marketing-card-overlay em {
  font-style: normal;
  margin-top: 3px;
  display: inline-flex;
  width: fit-content;
  border-radius: 999px;
  padding: 6px 10px;
  background: rgba(234, 242, 255, 0.95);
  color: #273986;
  font-size: 12px;
  font-weight: 800;
}

.listing-marketing-card-body {
  padding: 10px 11px 12px;
  display: grid;
  gap: 7px;
}

.listing-marketing-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.listing-marketing-card-head h4 {
  margin: 0;
  color: #23325f;
  font-size: 17px;
}

.listing-marketing-card-meta,
.listing-marketing-card-updated {
  margin: 0;
  font-size: 13px;
  color: #5c6996;
}

.listing-marketing-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 2px;
}

.listing-marketing-card-actions .btn {
  padding: 7px 11px;
  font-size: 12px;
}

.listing-marketing-modal {
  width: min(1280px, 100%);
  max-height: calc(100vh - 48px);
  overflow: auto;
  border-radius: 14px;
  padding: 24px;
  box-shadow: 0 20px 50px rgba(16, 24, 58, 0.24);
  display: grid;
  gap: 14px;
}

.listing-marketing-modal-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.listing-marketing-modal-head h3 {
  margin: 0;
}

.listing-marketing-modal-head p {
  margin: 6px 0 0;
  color: #58648f;
  max-width: 70ch;
}

.listing-marketing-modal-form {
  display: grid;
  gap: 12px;
}

.listing-marketing-modal-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.listing-marketing-modal-grid label {
  margin: 0;
  display: grid;
  gap: 6px;
  color: #2f3d6e;
  font-weight: 700;
}

.listing-marketing-modal-grid input,
.listing-marketing-modal-grid select {
  margin-top: 0;
}

.listing-marketing-template-grid {
  border: 1px solid #dce5ff;
  border-radius: 12px;
  background: #f9fbff;
  padding: 12px;
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.listing-flyer-template-tile {
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr);
  align-items: flex-start;
  gap: 8px;
  margin: 0;
}

.listing-flyer-template-tile input {
  margin: 4px 0 0;
  accent-color: var(--accent);
}

.listing-flyer-template-meta {
  border: 1px solid #d8e3ff;
  border-radius: 10px;
  background: #ffffff;
  padding: 9px 10px;
  display: grid;
  gap: 4px;
  min-height: 100%;
}

.listing-flyer-template-meta strong {
  color: #293765;
  font-size: 14px;
  line-height: 1.2;
}

.listing-flyer-template-meta em {
  font-style: normal;
  color: #4f5f95;
  font-size: 12px;
  font-weight: 700;
}

.listing-flyer-template-meta small {
  color: #62719f;
  font-size: 12px;
  line-height: 1.35;
}

.listing-flyer-template-tile input:checked + .listing-flyer-template-meta {
  border-color: #95adff;
  box-shadow: inset 0 0 0 1px rgba(83, 101, 232, 0.28);
  background: linear-gradient(180deg, #ffffff 0%, #f2f6ff 100%);
}

.listing-marketing-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  color: #3e4b7a;
}

.listing-marketing-toggle input {
  margin: 0;
  width: 16px;
  height: 16px;
}

.listing-website-body {
  gap: 14px;
}

.listing-website-config-form {
  display: grid;
  gap: 14px;
}

.listing-website-visibility-toggle {
  display: flex;
  align-items: center;
  gap: 10px;
  color: #3c4a7b;
  font-weight: 600;
  margin: 0;
}

.listing-website-visibility-toggle input[type="checkbox"] {
  width: auto;
  margin: 0;
}

.listing-website-link-stack {
  display: grid;
  gap: 10px;
}

.listing-website-link-stack label {
  margin: 0;
  display: grid;
  gap: 6px;
  color: #2f3d6e;
  font-weight: 700;
}

.listing-website-link-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 8px;
  align-items: center;
}

.listing-website-link-row input {
  margin-top: 0;
}

.listing-website-link-row .btn {
  padding: 7px 12px;
}

.listing-website-status-banner {
  border-radius: 12px;
  border: 1px solid #d8e2ff;
  background: #f7f9ff;
  padding: 12px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.listing-website-status-banner strong {
  color: #22305e;
}

.listing-website-status-banner p {
  margin: 4px 0 0;
  color: #53608b;
}

.listing-website-status-banner.is-active {
  border-color: #b8efd1;
  background: #eafbf1;
}

.listing-website-status-banner.is-active strong,
.listing-website-status-banner.is-active p {
  color: #1b5e3d;
}

.listing-website-analytics-panel {
  border: 1px solid #dde5ff;
  border-radius: 12px;
  background: #f7f9ff;
  padding: 12px 14px;
}

.listing-website-analytics-panel h4 {
  margin: 0 0 10px;
  font-size: 16px;
  color: #243164;
}

.listing-website-analytics-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.listing-website-analytics-grid article {
  border: 1px solid #dfe7ff;
  border-radius: 10px;
  background: #fff;
  padding: 10px;
  display: grid;
  gap: 4px;
}

.listing-website-analytics-grid article span {
  font-size: 12px;
  color: #5a6797;
  font-weight: 600;
}

.listing-website-analytics-grid article strong {
  font-size: 24px;
  line-height: 1;
  color: #2a3a72;
}

.listing-website-analytics-grid article small {
  color: #6a769f;
}

.listing-website-stats-btn {
  width: 100%;
  margin-top: 10px;
}

.listing-website-editor-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.listing-website-editor-grid label {
  margin: 0;
  display: grid;
  gap: 6px;
  color: #2f3d6e;
  font-weight: 700;
}

.listing-website-editor-grid select {
  margin-top: 0;
}

.property-websites-shell {
  display: grid;
  gap: 14px;
}

.property-website-defaults-form {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  align-items: end;
}

.property-website-defaults-form label {
  margin: 0;
  display: grid;
  gap: 6px;
  color: #2f3d6e;
  font-weight: 700;
}

.property-website-defaults-form select {
  margin-top: 0;
}

.property-website-defaults-actions {
  display: flex;
  align-items: flex-end;
}

.property-websites-create-form {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  align-items: end;
}

.property-websites-create-form label {
  margin: 0;
  display: grid;
  gap: 6px;
  color: #2f3d6e;
  font-weight: 700;
}

.property-websites-create-form input,
.property-websites-create-form select {
  margin-top: 0;
}

.property-websites-create-actions {
  display: flex;
  align-items: flex-end;
}

.property-websites-empty {
  border: 1px dashed #d7e0ff;
  border-radius: 12px;
  background: #f9fbff;
  padding: 14px;
  color: #4a5886;
}

.property-websites-empty strong {
  display: block;
  color: #2a3872;
  margin-bottom: 4px;
}

.property-websites-empty p {
  margin: 0;
}

.property-website-card {
  box-shadow: none;
}

.property-website-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.property-website-card-head h4 {
  margin: 0;
  color: #1f2c58;
}

.property-website-card-head p {
  margin: 5px 0 0;
  color: #5f6c98;
}

.property-website-card-badges {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.property-website-card-form {
  display: grid;
  gap: 12px;
}

.property-website-link-stack {
  display: grid;
  gap: 9px;
}

.property-website-link-stack label {
  margin: 0;
  display: grid;
  gap: 6px;
  color: #2f3d6e;
  font-weight: 700;
}

.property-website-link-row {
  display: grid;
  gap: 8px;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
}

.property-website-link-row input {
  margin-top: 0;
}

.property-website-link-row .btn {
  padding: 7px 12px;
}

.property-website-analytics-panel {
  border: 1px solid #dde5ff;
  border-radius: 12px;
  background: #f7f9ff;
  padding: 12px 14px;
}

.property-website-analytics-panel h5 {
  margin: 0 0 9px;
  font-size: 15px;
  color: #253265;
}

.property-website-analytics-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.property-website-analytics-grid article {
  border: 1px solid #dfe7ff;
  border-radius: 10px;
  background: #fff;
  padding: 10px;
  display: grid;
  gap: 4px;
}

.property-website-analytics-grid article span {
  color: #5a6797;
  font-size: 12px;
  font-weight: 600;
}

.property-website-analytics-grid article strong {
  color: #27366d;
  font-size: 23px;
  line-height: 1;
}

.property-website-edit-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.property-website-edit-grid label {
  margin: 0;
  display: grid;
  gap: 6px;
  color: #2f3d6e;
  font-weight: 700;
}

.property-website-edit-grid select {
  margin-top: 0;
}

.property-website-visibility-toggle {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: 10px;
  border: 1px dashed #d5deff;
  border-radius: 10px;
  padding: 10px 11px;
  background: #fbfcff;
  color: #3b4a7e;
  font-weight: 600;
}

.property-website-visibility-toggle input[type="checkbox"] {
  width: auto;
  margin: 0;
}

.property-website-card-actions {
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}

.listing-order-amount-chip {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 6px 10px;
  background: #eef2ff;
  border: 1px solid #d3ddff;
  color: #364a9d;
  font-size: 12px;
  font-weight: 800;
}

.listing-order-amount-chip-paid {
  background: #dcfce8;
  border-color: #bbefd0;
  color: #1f7646;
}

.listing-order-amount-chip-partial {
  background: #fff3da;
  border-color: #ffe0a4;
  color: #9f6700;
}

.listing-order-amount-chip-unpaid {
  background: #ffe6e3;
  border-color: #ffc7bf;
  color: #c32c1b;
}

.listing-order-amount-chip-neutral {
  background: #eef2ff;
  border-color: #d3ddff;
  color: #364a9d;
}

.listing-order-view-btn {
  border-color: #dadde8;
  background: #eceff4;
  color: #3f475d;
}

.listing-order-view-btn:hover {
  background: #e1e5ee;
  border-color: #cfd5e2;
  color: #30384f;
}

.listing-order-launch-btn {
  width: 36px;
  min-width: 36px;
  height: 36px;
  padding: 0;
  border-color: #d9deea;
  background: #f5f7fb;
  color: #374168;
  font-size: 16px;
}

.listing-order-launch-btn:hover {
  background: #e9edf5;
  border-color: #ccd5e6;
}

.listing-order-card .listing-secondary-body {
  padding: 0;
  gap: 0;
  background: #fff;
}

.listing-order-body {
  overflow: hidden;
}

.listing-order-items-list {
  display: grid;
  gap: 0;
}

.listing-order-item-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 14px 16px;
  border-top: 1px solid #eef2fb;
}

.listing-order-item-main {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
  color: #2f3b63;
  font-size: 17px;
}

.listing-order-item-main span:last-child {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.listing-order-item-icon {
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: #5850e7;
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 30px;
  font-size: 15px;
}

.listing-order-item-price {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
  color: #4b567f;
  font-size: 15px;
  white-space: nowrap;
}

.listing-order-item-price small {
  color: #6f7999;
  font-size: 13px;
}

.listing-order-item-price strong {
  color: #2a3354;
  font-size: 18px;
}

.listing-order-empty-items {
  margin: 0;
  padding: 16px;
  color: #5f6b93;
  border-top: 1px solid #eef2fb;
}

.listing-order-totals-row {
  border-top: 1px solid #dfe5f3;
  background: #f3f5fa;
  padding: 11px 16px;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  flex-wrap: wrap;
  gap: 14px;
  color: #505a7d;
  font-size: 13px;
}

.listing-order-meta-grid {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.listing-order-meta-grid p {
  margin: 0;
}

.listing-activity-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 8px;
}

.listing-activity-list li {
  border: 1px solid #e2e8ff;
  border-radius: 10px;
  background: #fff;
  padding: 10px 12px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
}

.listing-activity-copy {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.listing-activity-copy strong {
  color: #253463;
  font-size: 14px;
}

.listing-activity-copy span {
  color: #5f6a93;
  font-size: 12px;
}

.listing-activity-list time {
  color: #68739c;
  font-size: 12px;
  white-space: nowrap;
}

.listing-empty-state {
  text-align: center;
}

.listing-empty-state p {
  margin: 8px 0;
  color: var(--muted);
}

.daily-bars {
  display: grid;
  gap: 6px;
}

.bar-row {
  display: grid;
  gap: 6px;
  grid-template-columns: 90px 1fr 90px;
  align-items: center;
}

.bar-track {
  height: 9px;
  border-radius: 999px;
  background: #e6ecff;
  overflow: hidden;
}

.bar-fill {
  height: 100%;
  background: linear-gradient(135deg, #4d5bff 0%, #89a3ff 100%);
}

.calendar-weekdays {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 6px;
  margin-bottom: 6px;
}

.calendar-weekdays div {
  text-align: center;
  font-size: 12px;
  color: var(--muted);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 6px;
}

.calendar-scroll {
  overflow-x: auto;
}

.calendar-scroll .calendar-weekdays,
.calendar-scroll .calendar-grid {
  min-width: 760px;
}

.calendar-cell {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  min-height: 108px;
  padding: 8px;
  display: grid;
  gap: 6px;
}

.calendar-cell.muted {
  background: #f7f9ff;
  border-style: dashed;
}

.calendar-cell-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 6px;
}

.calendar-day-number {
  font-weight: 700;
}

.calendar-day-count {
  font-size: 11px;
  color: var(--muted);
}

.calendar-events {
  margin: 0;
  padding-left: 16px;
  display: grid;
  gap: 4px;
  font-size: 12px;
  color: #2e3b66;
}

.calendar-events li {
  line-height: 1.3;
}

.calendar-empty {
  color: var(--muted);
}

.dashboard-layout {
  display: grid;
  gap: var(--workspace-section-gap);
}

.dashboard-metrics-fixed .metrics-grid {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.dashboard-widget-board {
  display: grid;
  gap: 14px;
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
  align-items: start;
}

.dashboard-widget-column {
  display: grid;
  gap: var(--workspace-element-gap);
  align-content: start;
  min-height: 160px;
  padding: 4px;
  border-radius: 14px;
  transition: background 0.16s ease, box-shadow 0.16s ease;
}

.dashboard-widget-board.is-dragging .dashboard-widget-column {
  background: #f6f8ff;
  box-shadow: inset 0 0 0 1px #e2e9ff;
}

.dashboard-widget-column.is-drag-over {
  background: #edf2ff;
  box-shadow: inset 0 0 0 1px #b9c8ff;
}

.dashboard-column-empty {
  border: 1px dashed #c8d2f6;
  border-radius: 12px;
  color: #6e7aa6;
  font-size: 12px;
  text-align: center;
  padding: 18px 14px;
  background: #f8faff;
}

.dashboard-widget {
  cursor: default;
}

.dashboard-widget.is-dragging {
  opacity: 0.5;
  border-style: dashed;
}

.dashboard-widget-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: var(--workspace-element-gap);
  flex-wrap: wrap;
}

.dashboard-widget-head h3 {
  margin: 0;
}

.dashboard-widget-head-actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.dashboard-widget-drag-handle {
  width: 34px;
  min-height: 34px;
  border: 1px dashed #c7d1f7;
  border-radius: 8px;
  background: #f8faff;
  color: #566499;
  font-weight: 700;
  cursor: grab;
  line-height: 1;
}

.dashboard-widget-drag-handle:hover {
  border-color: #9cadee;
  background: #eef3ff;
}

.dashboard-widget-drag-handle:active {
  cursor: grabbing;
}

.calendar-day-action-target {
  cursor: pointer;
  transition: border-color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease;
}

.calendar-day-action-target:hover {
  border-color: #93a5ff;
  box-shadow: 0 8px 20px rgba(29, 46, 118, 0.08);
  transform: translateY(-1px);
}

.calendar-day-action-target:focus-visible {
  outline: 2px solid #4c63ff;
  outline-offset: 1px;
}

.calendar-day-action-target * {
  pointer-events: none;
}

.calendar-view-layout {
  gap: 14px;
}

.calendar-main-panel {
  margin-bottom: 6px;
}

.calendar-month-scroll .calendar-weekdays,
.calendar-month-scroll .calendar-grid {
  min-width: 980px;
}

.calendar-month-weekdays {
  gap: 0;
  margin-bottom: 0;
  border: 1px solid var(--line);
  border-bottom: none;
  border-radius: 12px 12px 0 0;
  overflow: hidden;
}

.calendar-month-weekdays div {
  background: #f6f8ff;
  border-right: 1px solid var(--line);
  padding: 9px 6px;
  color: #1f2947;
}

.calendar-month-weekdays div:last-child {
  border-right: none;
}

.calendar-month-grid {
  gap: 0;
  border: 1px solid var(--line);
  border-top: none;
  border-radius: 0 0 12px 12px;
  overflow: hidden;
  background: #fff;
}

.calendar-month-grid .calendar-cell {
  border-radius: 0;
  border: 0;
}

.calendar-month-cell {
  min-height: 148px;
  padding: 6px 6px 8px;
  border-right: 1px solid #e2e7fa !important;
  border-bottom: 1px solid #e2e7fa !important;
  align-content: start;
  background: #fff;
}

.calendar-month-cell.is-weekend {
  background: #f6f8ff;
}

.calendar-month-cell.is-today {
  background: #fdf8e7;
}

.calendar-month-cell.is-selected {
  box-shadow: inset 0 0 0 2px rgba(77, 91, 255, 0.32);
}

.calendar-month-grid .calendar-cell:nth-child(7n) {
  border-right: 0 !important;
}

.calendar-month-grid .calendar-cell:nth-last-child(-n + 7) {
  border-bottom: 0 !important;
}

.calendar-month-day-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
}

.calendar-month-day-number {
  font-size: 14px;
  font-weight: 700;
  color: #1f2947;
}

.calendar-day-number-action {
  border: 0;
  background: transparent;
  padding: 0;
  cursor: pointer;
  text-align: left;
}

.calendar-day-number-action:hover {
  text-decoration: underline;
}

.calendar-month-cell.muted .calendar-month-day-number {
  color: #9ea7c6;
}

.calendar-month-day-count {
  font-size: 11px;
  color: #6472a1;
  font-weight: 700;
}

.calendar-month-events {
  display: grid;
  align-content: start;
  gap: 4px;
  min-height: 0;
}

.calendar-month-event {
  border-radius: 3px;
  background: #ff1d14;
  color: #fff;
  padding: 4px 6px;
  display: grid;
  gap: 2px;
  line-height: 1.15;
}

.calendar-month-event strong {
  font-size: 11px;
  font-weight: 700;
}

.calendar-month-event span {
  font-size: 11px;
}

.calendar-month-event-button {
  width: 100%;
  border: none;
  text-align: left;
  cursor: pointer;
}

.calendar-month-event-button:hover {
  filter: brightness(0.95);
}

.calendar-month-event-button:focus-visible {
  outline: 2px solid #4c63ff;
  outline-offset: 1px;
}

.calendar-month-event.reserve {
  background: #6b4dff;
}

.calendar-day-action-target .calendar-month-event-button {
  pointer-events: auto;
}

.calendar-day-action-target .calendar-month-event-button * {
  pointer-events: none;
}

.calendar-month-empty {
  font-size: 11px;
  color: #8d97bb;
  padding-top: 2px;
}

.calendar-month-more {
  font-size: 11px;
  font-weight: 700;
  color: #5c6ac0;
}

.calendar-availability-layout {
  display: grid;
  gap: 12px;
  grid-template-columns: minmax(0, 1.8fr) minmax(260px, 1fr);
  align-items: start;
}

.calendar-availability-panel {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  padding: 12px;
  display: grid;
  gap: 12px;
}

.calendar-availability-panel h4 {
  margin: 0;
  font-size: 22px;
}

.calendar-side-group {
  display: grid;
  gap: 8px;
}

.calendar-side-group > strong {
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: #4f5c88;
}

.calendar-side-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 8px;
}

.calendar-side-item {
  border: 1px solid #e3e8fd;
  border-radius: 10px;
  padding: 8px 10px;
  display: grid;
  gap: 5px;
  background: #fbfcff;
}

.calendar-side-item strong {
  font-size: 12px;
}

.calendar-side-item span {
  color: #5f6b93;
  font-size: 12px;
}

.calendar-side-empty {
  color: #8a95bc;
  font-size: 12px;
  border: 1px dashed #d7def6;
  border-radius: 8px;
  padding: 8px 10px;
}

.calendar-day-select-btn {
  width: 100%;
  border: 1px solid #d8dff9;
  background: #f8faff;
  color: #445180;
  border-radius: 8px;
  padding: 7px;
  display: grid;
  gap: 4px;
  font-size: 12px;
  text-align: left;
  cursor: pointer;
}

.calendar-day-select-btn * {
  pointer-events: none;
}

.calendar-day-select-btn strong {
  color: #1f2947;
}

.calendar-day-select-btn.is-selected {
  border-color: #95a7ff;
  background: #eef2ff;
}

.calendar-reserve-form {
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
}

.btn-soft.is-active {
  background: #dfe6ff;
  border-color: #adbaf5;
}

@media (max-width: 1260px) {
  .dashboard-metrics-fixed .metrics-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .dashboard-widget-board {
    grid-template-columns: minmax(0, 1fr);
  }

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

  .dashboard-widget-head-actions {
    width: 100%;
    justify-content: space-between;
  }

  .calendar-availability-layout {
    grid-template-columns: 1fr;
  }

  .calendar-month-cell {
    min-height: 130px;
  }

  .calendar-month-event strong,
  .calendar-month-event span {
    font-size: 10px;
  }

  .calendar-day-action-grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 600px) {
  .dashboard-metrics-fixed .metrics-grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

.toaster-space {
  height: 46px;
}

.muted-note {
  margin: 8px 0 0;
  color: var(--muted);
  font-size: 13px;
}

.address-autocomplete-menu {
  position: fixed;
  z-index: 1100;
  border: 1px solid #d7defa;
  border-radius: 12px;
  background: #ffffff;
  box-shadow: 0 16px 34px rgba(16, 24, 58, 0.18);
  padding: 6px;
  display: grid;
  gap: 4px;
  max-height: min(320px, 40vh);
  overflow: auto;
}

.address-autocomplete-menu button {
  border: none;
  background: transparent;
  color: #1f2947;
  text-align: left;
  font-size: 14px;
  line-height: 1.35;
  padding: 8px 10px;
  border-radius: 9px;
  cursor: pointer;
}

.address-autocomplete-menu button:hover,
.address-autocomplete-menu button.is-active {
  background: #eef2ff;
  color: #1a2550;
}

.order-create-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(21, 28, 58, 0.44);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 22px;
  z-index: 900;
}

.order-create-modal {
  width: min(760px, 100%);
  border-radius: 12px;
  padding: 24px;
  box-shadow: 0 20px 48px rgba(16, 24, 58, 0.24);
}

.order-create-modal h3 {
  margin: 0 0 12px;
  font-size: 34px;
}

.order-create-modal p {
  margin: 0 0 22px;
  color: var(--muted);
  max-width: 62ch;
  line-height: 1.65;
}

.order-create-choice-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 1px minmax(0, 1fr);
  gap: 18px;
  align-items: stretch;
  margin-bottom: 22px;
}

.order-create-choice-divider {
  background: #dbe2ff;
  border-radius: 999px;
}

.order-create-choice {
  min-height: 88px;
  border-radius: 10px;
  display: grid;
  justify-items: center;
  gap: 2px;
  text-align: center;
  line-height: 1.25;
}

.order-create-actions {
  display: flex;
  justify-content: flex-start;
}

.listing-media-modal {
  width: min(1140px, 100%);
  max-height: calc(100vh - 56px);
  overflow: auto;
  border-radius: 12px;
  padding: 24px;
  box-shadow: 0 20px 48px rgba(16, 24, 58, 0.24);
  display: grid;
  gap: 10px;
}

.listing-media-modal-head {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
}

.listing-media-modal-head h3 {
  margin: 0;
}

.listing-media-modal p {
  margin: 0;
  color: var(--muted);
}

.listing-media-cloud-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.listing-media-modal-form {
  display: grid;
  gap: 10px;
}

.listing-media-upload-progress {
  border: 1px solid #dbe4ff;
  border-radius: 10px;
  padding: 10px 12px;
  background: linear-gradient(180deg, #f8faff 0%, #f1f5ff 100%);
  display: grid;
  gap: 8px;
}

.listing-media-upload-progress-head {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #273a84;
  font-weight: 700;
  font-size: 13px;
}

.listing-media-upload-progress p {
  margin: 0;
  color: #506090;
  font-size: 12px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.listing-media-upload-progress-track {
  height: 8px;
  border-radius: 999px;
  overflow: hidden;
  background: #dce5ff;
}

.listing-media-upload-progress-track span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.45), rgba(255, 255, 255, 0.05)),
    linear-gradient(90deg, #4e5bff 0%, #67a3ff 100%);
  transition: width 0.2s ease;
}

.listing-media-upload-spinner {
  width: 14px;
  height: 14px;
  border-radius: 999px;
  border: 2px solid #b7c6ff;
  border-top-color: #4d5bff;
  animation: listing-media-spin 0.9s linear infinite;
}

.listing-media-modal .btn.is-loading {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.listing-customer-modal {
  width: min(560px, 100%);
  border-radius: 12px;
  padding: 22px;
  box-shadow: 0 20px 48px rgba(16, 24, 58, 0.24);
  display: grid;
  gap: 12px;
}

.listing-customer-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.listing-customer-modal-head h3 {
  margin: 0;
  font-size: 24px;
}

.listing-customer-modal p {
  margin: 0;
  color: var(--muted);
}

.listing-customer-modal-search {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: end;
}

.listing-customer-modal-search input {
  margin-top: 0;
}

.listing-media-dropzone {
  position: relative;
  border: 2px dashed #c8d4ff;
  border-radius: 12px;
  background: #f7f9ff;
  padding: 28px 16px;
  text-align: center;
  display: grid;
  gap: 5px;
  cursor: pointer;
}

.listing-media-dropzone strong {
  color: #2f3a67;
  font-size: 16px;
}

.listing-media-dropzone span {
  color: #61709f;
  font-size: 13px;
}

.listing-media-dropzone input[type="file"] {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}

.listing-media-dropzone.is-drag-over {
  border-color: #5666ff;
  background: #edf1ff;
}

.listing-media-dropzone.is-uploading {
  cursor: wait;
  opacity: 0.75;
}

.listing-media-dropzone.is-uploading input[type="file"] {
  pointer-events: none;
}

.listing-media-selected {
  border: 1px solid #e4eaff;
  border-radius: 10px;
  padding: 10px;
  background: #fbfcff;
}

.listing-media-selected p {
  margin: 0;
  color: #61709f;
  font-size: 13px;
}

.listing-media-file-list {
  margin: 0;
  padding-left: 18px;
  max-height: 170px;
  overflow: auto;
  display: grid;
  gap: 4px;
  color: #3a4670;
  font-size: 13px;
}

@keyframes listing-media-spin {
  to {
    transform: rotate(360deg);
  }
}

.calendar-day-action-modal {
  width: min(560px, 100%);
  border-radius: 12px;
  padding: 24px;
  box-shadow: 0 20px 48px rgba(16, 24, 58, 0.24);
}

.calendar-reserve-modal {
  width: min(980px, 100%);
  max-height: calc(100vh - 56px);
  overflow: auto;
  border-radius: 12px;
  padding: 24px;
  box-shadow: 0 20px 48px rgba(16, 24, 58, 0.24);
}

.calendar-reserve-modal h3 {
  margin: 0 0 10px;
}

.calendar-reserve-modal p {
  margin: 0 0 18px;
  color: var(--muted);
}

.calendar-reserve-modal .calendar-reserve-form {
  margin-bottom: 12px;
}

.calendar-order-editor-modal {
  width: min(1320px, 100%);
  max-height: calc(100vh - 48px);
  overflow: auto;
  border-radius: 12px;
  padding: 16px;
  box-shadow: 0 20px 48px rgba(16, 24, 58, 0.24);
}

.calendar-day-action-modal h3 {
  margin: 0 0 10px;
}

.calendar-day-action-modal p {
  margin: 0 0 18px;
  color: var(--muted);
}

.calendar-day-action-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 18px;
}

.calendar-day-action-choice {
  min-height: 92px;
  display: grid;
  gap: 4px;
  align-content: center;
  text-align: center;
}

.calendar-day-action-choice strong {
  font-size: 15px;
}

.calendar-day-action-choice span {
  font-size: 12px;
  color: #dfe5ff;
}

.order-editor-top {
  margin-bottom: 12px;
}

.order-editor-top > .toolbar {
  align-items: flex-start;
}

.order-editor-top-customer {
  flex: 1 1 420px;
  min-width: min(100%, 320px);
}

.order-editor-top-actions {
  align-items: center;
}

.order-editor-autosave-note {
  white-space: nowrap;
}

.order-status-popover-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
}

.order-status-popover-toggle {
  min-width: 170px;
  justify-content: center;
}

.order-status-popover {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: min(230px, 82vw);
  z-index: 40;
  border-radius: 12px;
  box-shadow: 0 16px 34px rgba(20, 31, 74, 0.16);
  display: grid;
  gap: 8px;
}

.order-status-popover .muted-note {
  margin: 0;
  font-size: 12px;
}

.order-toolbar-actions {
  width: 100%;
  justify-content: flex-end;
}

.order-search-form {
  display: grid;
  grid-template-columns: minmax(260px, 380px) auto auto;
  gap: 8px;
  align-items: center;
}

.order-search-form input {
  margin-top: 0;
}

.order-row-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.orders-table th,
.orders-table td {
  padding-top: 12px;
  padding-bottom: 12px;
}

.orders-table th {
  white-space: nowrap;
}

.orders-table td:nth-child(1),
.orders-table td:nth-child(5),
.orders-table td:nth-child(6),
.orders-table td:nth-child(8),
.orders-table td:nth-child(9) {
  white-space: nowrap;
}

.order-id-link {
  color: var(--accent);
  text-decoration: none;
  font-weight: 700;
}

.order-list-row.is-clickable {
  cursor: pointer;
}

.order-list-row.is-clickable:hover td {
  background: #f7f9ff;
}

.order-list-row.is-clickable:focus-visible {
  outline: 2px solid #c7d4ff;
  outline-offset: -2px;
}

.order-main-text {
  font-weight: 600;
  color: #242a44;
}

.order-sub-text {
  color: #6c7594;
  font-size: 12px;
  margin-top: 2px;
}

.order-appointment-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 9px;
  padding: 4px 9px;
  font-size: 12px;
  font-weight: 600;
  color: #2f43b0;
  background: #e7ecff;
}

.order-editor-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: minmax(0, 1.55fr) minmax(320px, 1fr);
}

.order-editor-side {
  align-content: start;
}

.order-draft-inline-form {
  margin-bottom: 10px;
}

.order-payments-panel {
  display: grid;
  gap: 12px;
}

.order-payment-item-list {
  display: grid;
  gap: 0;
}

.order-payment-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  padding: 14px 0;
  border-bottom: 1px solid #e8ecff;
}

.order-payment-item:first-child {
  border-top: 1px solid #e8ecff;
}

.order-payment-item-copy {
  display: grid;
  gap: 4px;
  align-content: start;
}

.order-payment-item-copy strong {
  font-size: 17px;
  color: #1f2641;
}

.order-payment-item-side {
  display: grid;
  justify-items: end;
  align-content: start;
  gap: 8px;
}

.order-payment-item-total {
  font-weight: 700;
  color: #27315a;
  white-space: nowrap;
}

.order-payment-empty {
  border: 1px dashed #d5defc;
  border-radius: 10px;
  background: #f8faff;
  color: #5f6b92;
  padding: 14px 12px;
  font-size: 14px;
}

.order-payment-link-row {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.order-payment-add-form {
  display: grid;
  gap: 8px;
  border: 1px solid #dbe4ff;
  border-radius: 10px;
  background: #f8faff;
  padding: 10px;
}

.order-payment-add-form input {
  margin-top: 0;
}

.order-payment-add-form-product {
  grid-template-columns: minmax(0, 1fr) 120px auto;
}

.order-payment-add-form-custom {
  grid-template-columns: minmax(160px, 1fr) 170px 120px auto;
}

.order-payment-summary {
  margin-top: 4px;
  border-top: 1px solid #e8ecff;
  padding-top: 10px;
  display: grid;
  gap: 4px;
  justify-items: end;
}

.order-payment-summary p {
  margin: 0;
}

.order-payment-history-empty {
  border-top: 1px solid #e8ecff;
  border-bottom: 1px solid #e8ecff;
  padding: 26px 0;
  text-align: center;
}

.order-payment-history-empty p {
  margin: 0;
  color: #6e789a;
}

.order-payment-reminder-card {
  border: 1px solid #dbe4ff;
  border-radius: 10px;
  background: #fcfdff;
  padding: 12px;
  display: grid;
  gap: 10px;
}

.order-payment-reminder-card h4 {
  margin: 0;
  font-size: 24px;
  color: #20274a;
}

.order-payment-reminder-grid {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.order-payment-reminder-grid input {
  margin-top: 4px;
}

.order-payment-reminder-summary {
  margin: 0;
}

.order-payment-balance-row {
  border-top: 1px solid #e8ecff;
  padding-top: 10px;
  display: flex;
  justify-content: flex-end;
  align-items: baseline;
  gap: 8px;
  color: #2c365d;
}

.order-payment-footer-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.order-draft-summary {
  margin-top: 10px;
  border-top: 1px solid #e8ecff;
  padding-top: 10px;
  display: grid;
  gap: 4px;
  justify-items: end;
}

.order-draft-summary p {
  margin: 0;
}

.order-adjustments-row {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(auto-fit, minmax(140px, 180px));
  justify-content: end;
  align-items: end;
}

.order-adjustments-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  align-items: center;
  flex-wrap: wrap;
}

.order-discount-applied-note {
  justify-self: end;
  text-align: right;
}

.order-item-inline-input {
  margin-top: 0;
  min-width: 96px;
  max-width: 140px;
  padding: 8px 10px;
}

.order-item-action-group {
  display: inline-flex;
  gap: 8px;
  align-items: center;
}

.order-edit-icon-btn {
  width: 36px;
  height: 36px;
  min-width: 36px;
  min-height: 36px;
  padding: 0;
  border-radius: 10px;
  border-color: #d5defd;
  background: #f2f6ff;
  color: #3652c6;
  transition: background 120ms ease, border-color 120ms ease, color 120ms ease, transform 120ms ease;
}

.order-edit-icon-btn:hover {
  opacity: 1;
  background: #e9f0ff;
  border-color: #bccbfb;
  color: #2742b7;
}

.order-edit-icon-btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(54, 82, 198, 0.2);
}

.order-edit-icon-svg {
  width: 16px;
  height: 16px;
  fill: currentColor;
  pointer-events: none;
}

.order-delete-icon-btn {
  width: 36px;
  height: 36px;
  min-width: 36px;
  min-height: 36px;
  padding: 0;
  border-radius: 10px;
  border-color: #f2ccda;
  background: #fff4f8;
  color: #cd3b74;
  transition: background 120ms ease, border-color 120ms ease, color 120ms ease, transform 120ms ease;
}

.order-delete-icon-btn:hover {
  opacity: 1;
  background: #ffe8f1;
  border-color: #e7aac1;
  color: #b81f5e;
}

.order-delete-icon-btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(205, 59, 116, 0.2);
}

.order-delete-icon-svg {
  width: 17px;
  height: 17px;
  stroke: currentColor;
  stroke-width: 1.9;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
  pointer-events: none;
}

.order-draft-address-grid {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.address-map-preview {
  margin-top: 10px;
  border: 1px solid #d8e0ff;
  border-radius: 12px;
  overflow: hidden;
  background: #f5f8ff;
}

.address-map-preview-frame {
  display: block;
  width: 100%;
  height: 230px;
  border: 0;
}

.address-map-preview-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 9px 11px;
  border-top: 1px solid #d8e0ff;
  color: #546087;
  font-size: 12px;
}

.address-map-preview-meta span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.address-map-preview-meta a {
  color: #3947d9;
  font-weight: 700;
  text-decoration: none;
}

.address-map-preview-meta a:hover {
  text-decoration: underline;
}

.address-map-preview-empty {
  margin-top: 10px;
  border: 1px dashed #ccd7ff;
  border-radius: 12px;
  background: #f7f9ff;
  color: #66739a;
  font-size: 13px;
  padding: 12px;
}

.order-draft-client-form {
  border-top: 1px dashed #e3e8ff;
  padding-top: 8px;
}

.order-selected-customer-card {
  display: grid;
  gap: 2px;
  border: 1px solid #dce4ff;
  border-radius: 10px;
  background: #f8faff;
  padding: 10px 12px;
}

.order-selected-customer-card strong {
  color: #222947;
  font-size: 14px;
}

.order-selected-customer-card span {
  color: #65739b;
  font-size: 12px;
}

.order-customer-modal {
  width: min(680px, 100%);
  border-radius: 12px;
  padding: 20px;
  box-shadow: 0 20px 48px rgba(16, 24, 58, 0.24);
  display: grid;
  gap: 10px;
}

.order-customer-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.order-customer-modal-head h3 {
  margin: 0;
}

.order-customer-modal p {
  margin: 0;
  color: var(--muted);
}

.order-customer-modal-search {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
}

.order-discount-modal {
  width: min(640px, 100%);
  border-radius: 12px;
  padding: 20px;
  box-shadow: 0 20px 48px rgba(16, 24, 58, 0.24);
  display: grid;
  gap: 12px;
}

.order-discount-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.order-discount-modal-head h3 {
  margin: 0;
}

.order-discount-modal p {
  margin: 0;
  color: var(--muted);
}

.order-discount-source-list {
  display: grid;
  gap: 8px;
}

.order-discount-source-option {
  display: flex;
  align-items: center;
  gap: 8px;
  border: 1px solid #dbe3ff;
  border-radius: 10px;
  background: #f8faff;
  padding: 10px 12px;
  margin: 0;
}

.order-discount-source-option.is-disabled {
  opacity: 0.6;
}

.order-discount-source-option input[type="radio"] {
  margin: 0;
  width: auto;
}

.order-discount-manual-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.order-discount-modal-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.order-item-editor-modal {
  width: min(620px, 100%);
  border-radius: 12px;
  padding: 20px;
  box-shadow: 0 20px 48px rgba(16, 24, 58, 0.24);
  display: grid;
  gap: 12px;
}

.order-item-editor-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.order-item-editor-head h3 {
  margin: 0;
}

.order-item-editor-modal p {
  margin: 0;
  color: var(--muted);
}

.order-item-editor-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.order-appointments-section {
  display: grid;
  gap: 12px;
}

.order-appointment-card-list {
  display: grid;
  gap: 12px;
}

.order-appointments-empty {
  border: 1px dashed #d5defc;
  border-radius: 10px;
  background: #f8faff;
  color: #5f6b92;
  padding: 12px;
  font-size: 14px;
}

.order-appointments-add-row {
  display: flex;
  justify-content: flex-end;
}

.order-appointment-card {
  border: 1px solid #dbe3fb;
  border-radius: 10px;
  background: #fcfdff;
  padding: 14px;
  display: grid;
  gap: 10px;
}

.order-appointment-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.order-appointment-card-head h4 {
  margin: 0;
  font-size: 32px;
  color: #1f2641;
}

.order-appointment-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.order-appointment-card-body {
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  border-top: 1px solid #e7ecfb;
  border-bottom: 1px solid #e7ecfb;
  padding: 12px 0;
}

.order-appointment-card-col {
  display: grid;
  gap: 8px;
}

.order-appointment-card-col p {
  margin: 0;
  display: grid;
  gap: 2px;
}

.order-appointment-item-list,
.order-appointment-team-list {
  margin: 0;
  padding-left: 20px;
  display: grid;
  gap: 4px;
}

.order-appointment-team-list li {
  display: grid;
  gap: 1px;
}

.order-appointment-team-list li span {
  color: #6a738f;
  font-size: 12px;
}

.order-appointment-card-foot {
  color: #6a738f;
  font-size: 13px;
}

@media (max-width: 900px) {
  .order-payment-add-form-product,
  .order-payment-add-form-custom,
  .order-payment-reminder-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .order-payment-item {
    grid-template-columns: minmax(0, 1fr);
  }

  .order-payment-item-side {
    justify-items: start;
  }

  .order-payment-footer-actions {
    justify-content: flex-start;
  }

  .order-payment-footer-actions .btn {
    width: 100%;
  }

  .order-appointment-card-body {
    grid-template-columns: minmax(0, 1fr);
    gap: 12px;
  }
}

.order-custom-fields {
  max-height: 320px;
  overflow: auto;
  padding-right: 4px;
}

.order-custom-checkbox {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0;
}

.order-custom-checkbox input[type="checkbox"] {
  width: auto;
  margin: 0;
}

.order-appointments-modal {
  width: min(940px, 100%);
  max-height: calc(100vh - 60px);
  overflow: auto;
  border-radius: 12px;
  padding: 20px;
  box-shadow: 0 20px 48px rgba(16, 24, 58, 0.24);
  display: grid;
  gap: 10px;
}

.order-appointments-modal h3 {
  margin: 0;
  font-size: 30px;
}

.order-appointments-modal p {
  margin: 0 0 4px;
  color: var(--muted);
}

.order-with-appointment-modal {
  width: min(1280px, 100%);
  max-height: calc(100vh - 56px);
  overflow: auto;
  border-radius: 12px;
  padding: 18px;
  box-shadow: 0 20px 48px rgba(16, 24, 58, 0.24);
  display: grid;
  gap: 12px;
}

.order-with-appointment-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.order-with-appointment-head h3 {
  margin: 0;
  font-size: 36px;
}

.order-modal-close-icon {
  min-width: 42px;
  min-height: 42px;
  padding: 0;
  font-size: 24px;
  line-height: 1;
}

.order-with-appointment-layout {
  display: grid;
  gap: 12px;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 0.95fr);
  align-items: start;
}

.order-with-appointment-layout .panel {
  box-shadow: none;
}

.order-with-appointment-details-grid {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.order-with-appointment-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
}

.order-team-members-list {
  display: grid;
  gap: 8px;
}

.order-team-member-option {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  padding: 6px 8px;
  border: 1px solid #e3e8ff;
  border-radius: 9px;
  background: #fbfcff;
}

.order-team-member-option input[type="checkbox"] {
  width: auto;
  margin: 0;
}

.order-team-member-option.is-disabled {
  opacity: 0.68;
  background: #f5f7ff;
}

.order-team-member-copy {
  display: grid;
  gap: 2px;
}

.order-team-member-copy small {
  color: var(--muted);
  font-size: 11px;
}

.order-link-button {
  border: none;
  background: transparent;
  color: var(--accent);
  font-weight: 700;
  text-align: left;
  padding: 0;
  cursor: pointer;
}

.order-link-button:hover {
  text-decoration: underline;
}

.order-subtotal-row {
  margin: 4px 0 0;
  text-align: right;
}

.toast {
  position: fixed;
  right: 20px;
  bottom: 20px;
  background: #11162e;
  color: #fff;
  border-radius: 11px;
  padding: 10px 13px;
  box-shadow: 0 12px 24px rgba(5, 9, 33, 0.35);
  z-index: 999;
}

@media (max-width: 1050px) {
  .mk-hero-shell {
    grid-template-columns: 1fr;
  }

  .mk-story-grid {
    grid-template-columns: 1fr;
  }

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

  .mk-feature-row,
  .mk-feature-row-reverse {
    grid-template-columns: 1fr;
  }

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

  .mk-mobile-row {
    grid-template-columns: 1fr;
  }

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

  .mk-quote-row-4 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .mk-contact-grid {
    grid-template-columns: 1fr;
  }

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

  .mk-flow {
    grid-template-columns: 1fr;
  }

  .reports-summary-grid {
    grid-template-columns: 1fr;
  }

  .reports-donut-layout {
    grid-template-columns: 1fr;
  }

  .app-shell {
    grid-template-columns: 1fr;
    width: 100%;
    margin: 0;
    min-height: 100vh;
    border: 0;
    border-radius: 0;
    box-shadow: none;
  }

  .sidebar {
    position: static;
    max-height: none;
    border-right: none;
    border-bottom: 1px solid var(--line);
  }

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

  .listing-filters {
    grid-template-columns: 1fr 1fr;
  }

  .availability-page-layout {
    grid-template-columns: 1fr;
  }

  .availability-local-nav {
    position: static;
  }

  .availability-overview-grid {
    grid-template-columns: 1fr;
  }

  .availability-overview-hero {
    grid-template-columns: 1fr;
  }

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

  .availability-sync-grid {
    grid-template-columns: 1fr;
  }

  .business-hours-row {
    grid-template-columns: 1fr 1fr;
  }

  .business-hours-day {
    grid-column: 1 / -1;
  }

  .twilight-default-card-head {
    flex-direction: column;
    align-items: stretch;
  }

  .twilight-edit-page-btn {
    width: fit-content;
  }

  .twilight-grid-head,
  .twilight-grid-row {
    grid-template-columns: minmax(110px, 1fr) 64px 64px;
  }

  .twilight-card-actions {
    align-items: stretch;
  }

  .twilight-reset-btn {
    margin-right: 0;
    text-align: left;
  }

  .availability-overview-card {
    grid-template-columns: 34px minmax(0, 1fr);
  }

  .availability-overview-arrow {
    display: none;
  }

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

  .products-editor-grid-two,
  .products-editor-flags {
    grid-template-columns: 1fr;
  }

  .products-image-upload-shell {
    grid-template-columns: 1fr;
  }

  .products-image-upload-side {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    overflow-y: hidden;
    max-height: none;
    padding-bottom: 2px;
  }

  .products-image-upload-thumb {
    flex: 0 0 84px;
    width: 84px;
  }

  .products-sqft-range-row {
    grid-template-columns: 1fr;
  }

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

  .plans-table {
    min-width: 760px;
  }

  .plans-modal-head {
    flex-direction: column;
    align-items: stretch;
  }

  .plans-modal-grid {
    grid-template-columns: 1fr;
  }

  .pricing-plans-toolbar {
    flex-direction: column;
  }

  .listing-filter-actions {
    grid-column: 1 / -1;
  }

  .listing-detail-topbar {
    justify-content: flex-start;
  }

  .listing-secondary-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .listing-secondary-inline-actions {
    margin-left: 0;
    flex-wrap: wrap;
  }

  .listing-website-link-row,
  .property-website-link-row {
    grid-template-columns: minmax(0, 1fr) auto auto;
  }

  .listing-website-analytics-grid,
  .property-website-analytics-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .listing-website-editor-grid,
  .property-website-edit-grid {
    grid-template-columns: 1fr;
  }

  .property-websites-create-form {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .property-website-defaults-form {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .property-website-defaults-actions {
    grid-column: 1 / -1;
  }

  .property-websites-create-actions {
    grid-column: 1 / -1;
  }

  .listing-media-toolbar {
    flex-direction: column;
    align-items: flex-start;
  }

  .listing-media-toolbar-left {
    width: 100%;
  }

  .listing-media-order-hint {
    width: 100%;
    justify-content: center;
  }

  .listing-media-bulk-actions {
    width: 100%;
  }

  .listing-order-totals-row {
    justify-content: flex-start;
  }

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

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

  .order-editor-grid {
    grid-template-columns: 1fr;
  }

  .order-editor-top-actions {
    width: 100%;
    justify-content: flex-end;
  }

  .order-editor-autosave-note {
    width: 100%;
    text-align: right;
    white-space: normal;
  }

  .order-draft-address-grid {
    grid-template-columns: 1fr 1fr;
  }

  .address-map-preview-frame {
    height: 210px;
  }

  .order-with-appointment-layout {
    grid-template-columns: 1fr;
  }

  .order-with-appointment-details-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .order-search-form {
    grid-template-columns: minmax(220px, 1fr) auto auto;
  }
}

@media (max-width: 700px) {
  .order-status-popover {
    width: min(220px, 92vw);
  }

  .listing-media-wrap {
    padding: 14px;
    gap: 10px;
  }

  .listing-media-wrap h3 {
    font-size: 20px;
  }

  .listing-accordion summary {
    padding: 12px 14px;
    min-height: 56px;
  }

  .listing-accordion-title {
    font-size: 17px;
  }

  .listing-accordion-subtitle {
    font-size: 10px;
  }

  .listing-accordion-badge {
    min-width: 28px;
    height: 22px;
    font-size: 11px;
  }

  .listing-customer-modal-search {
    grid-template-columns: 1fr;
  }

  .listing-customer-modal-search .btn {
    width: 100%;
  }

  .mk-topbar {
    flex-direction: column;
    align-items: flex-start;
  }

  .listing-secondary-row > summary {
    align-items: flex-start;
    flex-direction: column;
  }

  .listing-secondary-row-main {
    width: 100%;
    justify-content: space-between;
  }

  .listing-secondary-inline-actions {
    width: 100%;
    justify-content: flex-start;
  }

  .listing-website-link-row,
  .property-website-link-row {
    grid-template-columns: 1fr;
  }

  .listing-website-link-row .btn,
  .property-website-link-row .btn {
    width: 100%;
  }

  .listing-website-status-banner {
    flex-direction: column;
    align-items: flex-start;
  }

  .listing-website-analytics-grid,
  .property-website-analytics-grid {
    grid-template-columns: 1fr;
  }

  .property-websites-create-form {
    grid-template-columns: 1fr;
  }

  .property-website-defaults-form {
    grid-template-columns: 1fr;
  }

  .property-website-card-head {
    flex-direction: column;
  }

  .property-website-card-badges {
    justify-content: flex-start;
  }

  .property-website-card-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .listing-property-card-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .listing-property-form-actions {
    justify-content: flex-start;
  }

  .listing-secondary-stats,
  .listing-order-meta-grid {
    grid-template-columns: 1fr;
  }

  .listing-order-item-row {
    flex-direction: column;
    align-items: flex-start;
  }

  .listing-order-item-main {
    width: 100%;
  }

  .listing-order-item-price {
    width: 100%;
    justify-content: flex-end;
  }

  .listing-order-totals-row {
    justify-content: flex-start;
    gap: 10px;
  }

  .listing-activity-list li {
    flex-direction: column;
  }

  .listing-activity-list time {
    white-space: normal;
  }

  .marketing-nav {
    width: 100%;
  }

  .marketing-nav > a[href^="#"] {
    display: none;
  }

  .marketing-doc .marketing-nav > a:not(.btn) {
    display: none;
  }

  .marketing-nav .btn {
    flex: 1;
  }

  .mk-stage-note-a {
    right: 10px;
    top: 10px;
  }

  .mk-stage-note-b {
    left: 10px;
    bottom: 10px;
  }

  .mk-metrics,
  .mk-process-grid,
  .mk-quote-row {
    grid-template-columns: 1fr;
  }

  .mk-app-grid,
  .mk-plan-grid,
  .mk-quote-row-4 {
    grid-template-columns: 1fr;
  }

  .mk-plan-card h3 {
    font-size: 24px;
  }

  .mk-plan-card-price {
    font-size: 34px;
  }

  .mk-plan-card-stats {
    display: grid;
    grid-template-columns: 1fr;
  }

  .mk-chat-bubble {
    max-width: 100%;
  }

  .mk-stage-floating {
    max-width: 170px;
    min-width: 0;
  }

  .mk-map-canvas {
    min-height: 350px;
  }

  .mk-map-node {
    position: static;
    margin: 10px 10px 0;
    display: inline-flex;
  }

  .mk-map-line {
    display: none;
  }

  .mk-footer-wrap {
    flex-direction: column;
    align-items: flex-start;
  }

  .mk-footer-links {
    order: 3;
  }

  .reports-filter-actions {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr;
  }

  .reports-month-chart {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .reports-hbar-row {
    grid-template-columns: 1fr;
    gap: 6px;
  }

  .reports-kpi-card strong,
  .reports-kpi-card-primary strong {
    font-size: 32px;
  }

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

  .topbar {
    display: flex;
    flex-direction: column;
    align-items: stretch;
  }

  .top-actions {
    justify-content: flex-end;
    flex-wrap: wrap;
  }

  .view-head h1 {
    font-size: 29px;
  }

  .products-overview-group h2 {
    font-size: 29px;
  }

  .products-overview-grid {
    grid-template-columns: 1fr;
  }

  .products-overview-copy strong {
    font-size: 17px;
  }

  .products-overview-copy span {
    font-size: 14px;
  }

  .products-services-tabs {
    flex-wrap: wrap;
    gap: 8px;
  }

  .products-services-tab {
    font-size: 16px;
  }

  .pricing-plans-head h2 {
    font-size: 34px;
  }

  .tax-rates-page-head h2 {
    font-size: 34px;
  }

  .tax-rates-tabs {
    flex-wrap: wrap;
    gap: 8px;
  }

  .tax-rates-tab {
    font-size: 16px;
  }

  .products-catalog-toolbar {
    flex-direction: column;
    align-items: flex-start;
  }

  .products-catalog-filters {
    grid-template-columns: 1fr;
  }

  .products-filter-actions {
    grid-column: auto;
  }

  .products-editor-grid-two,
  .products-editor-flags {
    grid-template-columns: 1fr;
  }

  .products-sqft-range-row {
    grid-template-columns: 1fr;
  }

  .pricing-plans-actions-cell {
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: 10px;
  }

  .listing-filters {
    grid-template-columns: 1fr;
  }

  .listing-filter-actions {
    grid-column: auto;
  }

  .listing-card-grid {
    grid-template-columns: 1fr;
  }

  .listing-card-footer {
    flex-direction: column;
    align-items: flex-start;
  }

  .listing-customer-row {
    gap: 8px;
  }

  .listing-customer-header {
    flex-direction: column;
  }

  .listing-customer-header-actions {
    width: 100%;
    justify-content: flex-start;
  }

  .listing-customer-list {
    grid-template-columns: 1fr;
  }

  .listing-customer-add-btn {
    width: auto;
  }

  .listing-customer-add-card {
    min-height: 78px;
  }

  .listing-customer-actions {
    width: 100%;
    justify-content: flex-start;
  }

  .listing-gallery-grid {
    grid-template-columns: 1fr;
  }

  .listing-marketing-card-grid {
    grid-template-columns: 1fr;
  }

  .listing-media-sort-select {
    width: 100%;
  }

  .listing-media-sort-select select {
    width: 100%;
    min-width: 0;
  }

  .listing-media-toolbar-left {
    display: grid;
    width: 100%;
    gap: 8px;
  }

  .listing-media-bulk-actions {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

  .listing-media-bulk-actions .btn {
    width: 100%;
  }

  .listing-asset-form {
    grid-template-columns: 1fr;
  }

  .listing-media-modal {
    padding: 16px;
  }

  .listing-marketing-modal {
    padding: 16px;
  }

  .listing-marketing-modal-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .listing-marketing-modal-grid {
    grid-template-columns: 1fr;
  }

  .listing-marketing-template-grid {
    grid-template-columns: 1fr;
    padding: 10px;
  }

  .listing-media-cloud-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .listing-delivery-form {
    grid-template-columns: 1fr;
  }

  .order-create-backdrop {
    padding: 12px;
  }

  .order-create-modal {
    padding: 18px;
  }

  .order-create-modal h3 {
    font-size: 29px;
  }

  .order-create-choice-grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .order-create-choice-divider {
    display: none;
  }

  .order-draft-address-grid {
    grid-template-columns: 1fr;
  }

  .order-customer-modal-search {
    grid-template-columns: 1fr;
  }

  .order-discount-manual-grid {
    grid-template-columns: 1fr;
  }

  .order-discount-modal-actions {
    justify-content: stretch;
  }

  .order-discount-modal-actions .btn {
    width: 100%;
  }

  .address-map-preview-frame {
    height: 190px;
  }

  .order-appointments-modal {
    padding: 14px;
  }

  .order-appointments-modal h3 {
    font-size: 26px;
  }

  .order-with-appointment-modal {
    padding: 12px;
  }

  .calendar-reserve-modal {
    padding: 16px;
  }

  .calendar-order-editor-modal {
    padding: 10px;
  }

  .order-with-appointment-head h3 {
    font-size: 28px;
  }

  .order-with-appointment-details-grid {
    grid-template-columns: 1fr;
  }

  .order-search-form {
    width: 100%;
    grid-template-columns: 1fr;
  }
}

/* Public Order Form */
.order-form-page {
  min-height: 100vh;
  background:
    radial-gradient(900px 320px at 8% -5%, rgba(77, 91, 255, 0.14), transparent 58%),
    radial-gradient(900px 320px at 92% 5%, rgba(34, 197, 94, 0.1), transparent 56%),
    linear-gradient(180deg, #ffffff 0%, #f4f7ff 100%);
}

.of-shell {
  width: min(1180px, 96vw);
  margin: 20px auto 34px;
  display: grid;
  gap: 12px;
}

.of-header {
  padding: 16px;
}

.of-brand-row {
  display: flex;
  align-items: center;
  gap: 12px;
}

.of-logo-shell {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  border: 1px solid var(--line-strong);
  background: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.of-logo {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 4px;
}

.of-logo-mark {
  font-family: "Sora", "Space Grotesk", sans-serif;
  font-weight: 700;
  color: var(--accent);
}

.of-brand-name {
  margin: 0;
  font-size: 13px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--muted);
}

.of-form-title {
  margin: 0;
}

.of-step-shell {
  padding: 10px;
}

.of-step-track {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.of-step-pill {
  display: flex;
  align-items: center;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 7px 12px;
  background: #fff;
  font-weight: 600;
  color: #39466f;
}

.of-step-pill.active {
  border-color: var(--accent);
  color: var(--accent);
  background: #e9eeff;
}

.of-step-pill.done {
  border-color: #b7e7d3;
  color: #0c9f6f;
  background: #e8faf2;
}

.of-step-number {
  width: 22px;
  height: 22px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid currentColor;
  font-size: 12px;
}

.of-access-panel {
  padding: 14px;
  display: grid;
  gap: 10px;
}

.of-access-form {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.of-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(280px, 0.85fr);
  gap: 12px;
}

.of-stage {
  min-height: 520px;
}

.of-stage-head h2 {
  margin: 0 0 6px;
}

.of-category-block + .of-category-block {
  margin-top: 12px;
}

.of-category-head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}

.of-category-head h2 {
  margin: 0;
  font-size: 21px;
}

.of-category-head p {
  margin: 2px 0 0;
  color: var(--muted);
  font-size: 13px;
}

.of-category-image {
  width: 48px;
  height: 48px;
  border-radius: 10px;
  object-fit: cover;
  border: 1px solid var(--line);
}

.of-product-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
}

.of-product-card {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  overflow: hidden;
  display: grid;
}

.of-product-card img {
  width: 100%;
  height: 130px;
  object-fit: cover;
  border-bottom: 1px solid var(--line);
}

.of-product-copy {
  padding: 10px;
  display: grid;
  gap: 7px;
}

.of-product-copy h3 {
  margin: 0;
  font-size: 17px;
}

.of-product-copy p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
}

.of-product-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  font-weight: 700;
}

.of-product-meta label {
  font-size: 13px;
  font-weight: 600;
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.of-product-meta input {
  width: 74px;
}

.of-day-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.of-day-card {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  padding: 10px;
}

.of-day-card h3 {
  margin: 0 0 4px;
  font-size: 16px;
}

.of-slot-grid {
  display: grid;
  gap: 6px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.of-slot-btn {
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 9px;
  padding: 6px 8px;
  font-weight: 600;
  cursor: pointer;
}

.of-slot-btn.selected,
.of-slot-btn:hover {
  border-color: var(--accent);
  background: #ebefff;
  color: var(--accent);
}

.of-checkout-form {
  gap: 12px;
}

.of-checkout-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.of-radio-group {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.of-radio-option {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 7px 10px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-weight: 600;
}

.of-actions {
  margin-top: 12px;
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}

.of-summary h2 {
  margin: 0 0 10px;
}

.of-summary-list {
  display: grid;
  gap: 8px;
  margin-bottom: 10px;
}

.of-summary-item,
.of-summary-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
}

.of-summary-item strong,
.of-summary-row strong {
  text-align: right;
}

.of-success {
  padding: 18px;
}

.of-success h2 {
  margin: 0 0 8px;
}

/* Storefront builder */
.storefront-builder-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.9fr);
}

.storefront-category-grid {
  display: grid;
  gap: 8px;
}

.storefront-category-row {
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 8px;
  display: grid;
  grid-template-columns: minmax(0, 160px) minmax(0, 1fr);
  gap: 8px;
  align-items: center;
}

.storefront-category-row h4 {
  margin: 0;
  font-size: 14px;
}

.storefront-category-row .muted-note {
  margin: 2px 0 0;
  font-size: 12px;
}

.storefront-share-cell {
  display: grid;
  gap: 6px;
}

.storefront-share-link {
  max-width: 260px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--accent);
  text-decoration: none;
}

.storefront-copy-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

@media (max-width: 960px) {
  .of-step-track {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .of-layout {
    grid-template-columns: 1fr;
  }

  .of-checkout-grid {
    grid-template-columns: 1fr;
  }

  .of-access-form {
    grid-template-columns: 1fr;
  }

  .storefront-builder-grid {
    grid-template-columns: 1fr;
  }

  .storefront-category-row {
    grid-template-columns: 1fr;
  }
}

.customer-portal-page {
  background: linear-gradient(180deg, #ffffff 0%, #eef3ff 85%);
}

.customer-portal-shell {
  width: min(1120px, 96vw);
  margin: 0 auto;
  padding: 28px 14px 40px;
  display: grid;
  gap: 14px;
}

.cp-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.cp-content {
  display: grid;
  gap: 14px;
}

.cp-metrics {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 10px;
}

.cp-product-picker {
  display: grid;
  gap: 8px;
}

.cp-product-row {
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 10px 12px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 12px;
}

.cp-product-row input[type="number"] {
  width: 90px;
}

.cp-product-price {
  font-weight: 700;
  color: var(--text);
}

@media (max-width: 720px) {
  .cp-product-row {
    grid-template-columns: 1fr;
  }

  .cp-product-row input[type="number"] {
    width: 100%;
  }
}

/* Clean marketing landing refresh */
.marketing-clean {
  --cln-line: #d8e0ff;
  --cln-line-strong: #cbd7ff;
  --cln-surface: #ffffff;
  --cln-surface-soft: #f7f9ff;
  --cln-shadow: 0 10px 24px rgba(46, 65, 165, 0.08);
  background:
    radial-gradient(960px 320px at 8% -12%, rgba(77, 91, 255, 0.11), transparent 62%),
    radial-gradient(960px 320px at 94% -14%, rgba(111, 120, 255, 0.09), transparent 62%),
    linear-gradient(180deg, #ffffff 0%, #f6f8ff 56%, #f9fbff 100%);
}

.marketing-clean .marketing-wrap {
  width: min(93vw, 1180px);
}

.marketing-clean .marketing-top {
  background: rgba(255, 255, 255, 0.9);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(10px);
}

.marketing-clean .cln-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 0;
}

.marketing-clean .cln-nav {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
}

.marketing-clean .cln-nav a:not(.btn) {
  text-decoration: none;
  color: #33436d;
  font-weight: 600;
  border-radius: 8px;
  padding: 7px 9px;
  font-size: 14px;
}

.marketing-clean .cln-nav a:not(.btn):hover {
  background: #edf1ff;
}

.marketing-clean .cln-main {
  padding-bottom: 14px;
}

.marketing-clean .btn {
  border-radius: 10px;
  padding: 10px 14px;
  font-size: 14px;
  box-shadow: 0 8px 16px rgba(77, 91, 255, 0.16);
  transition: transform 120ms ease, box-shadow 120ms ease, opacity 120ms ease;
}

.marketing-clean .btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(77, 91, 255, 0.2);
}

.marketing-clean .btn-soft {
  box-shadow: none;
  border-color: var(--cln-line-strong);
}

.marketing-clean .btn-soft:hover {
  background: #edf2ff;
  box-shadow: none;
}

.marketing-clean .cln-hero {
  padding: 40px 0 20px;
}

.marketing-clean .cln-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
  gap: 16px;
  align-items: stretch;
}

.marketing-clean .cln-hero-copy,
.marketing-clean .cln-hero-panel {
  animation: cln-rise 420ms ease both;
}

.marketing-clean .cln-hero-copy h1 {
  margin: 0 0 10px;
  font-size: clamp(34px, 4.8vw, 52px);
  line-height: 1.05;
  max-width: 18ch;
  letter-spacing: -0.015em;
}

.marketing-clean .cln-hero-copy p {
  margin: 0 0 14px;
  color: var(--muted);
  max-width: 60ch;
  line-height: 1.62;
  font-size: 16px;
}

.marketing-clean .cln-hero-panel {
  padding: 16px;
  border-color: var(--cln-line);
  background: linear-gradient(180deg, var(--cln-surface) 0%, var(--cln-surface-soft) 100%);
  box-shadow: var(--cln-shadow);
}

.marketing-clean .cln-hero-panel h2 {
  margin: 0 0 8px;
  font-size: clamp(24px, 2.8vw, 32px);
  line-height: 1.12;
}

.marketing-clean .cln-step-list {
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 8px;
}

.marketing-clean .cln-step-list li {
  color: #3f4f7a;
  line-height: 1.45;
}

.marketing-clean .cln-step-list strong {
  display: block;
  margin-bottom: 2px;
  color: #2a3a62;
  font-size: 14px;
}

.marketing-clean .cln-step-list span {
  color: #60709a;
  font-size: 13px;
}

.marketing-clean .cln-hero-preview {
  margin-top: 12px;
  border: 1px solid var(--cln-line);
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
}

.marketing-clean .cln-preview-bar {
  height: 30px;
  border-bottom: 1px solid var(--cln-line);
  background: #f2f5ff;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 0 10px;
}

.marketing-clean .cln-preview-bar span {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #c2cffb;
}

.marketing-clean .cln-preview-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  padding: 8px;
}

.marketing-clean .cln-preview-col {
  display: grid;
  gap: 8px;
}

.marketing-clean .cln-preview-tile {
  min-height: 58px;
  border-radius: 8px;
  border: 1px solid var(--cln-line);
  background: linear-gradient(180deg, #f4f7ff 0%, #ffffff 100%);
}

.marketing-clean .cln-preview-tile-lg {
  min-height: 82px;
}

.marketing-clean .cln-preview-tile-xl {
  min-height: 148px;
}

.marketing-clean .cln-proof-grid {
  margin-top: 12px;
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.marketing-clean .cln-proof-card {
  border-color: var(--cln-line);
  background: rgba(255, 255, 255, 0.95);
  box-shadow: none;
}

.marketing-clean .cln-proof-card h3 {
  margin-bottom: 4px;
  font-size: 17px;
}

.marketing-clean .cln-section {
  padding: 36px 0 8px;
}

.marketing-clean .cln-section-soft {
  margin-top: 10px;
  border-top: 1px solid #e3e9ff;
  border-bottom: 1px solid #e3e9ff;
  background: linear-gradient(180deg, rgba(242, 246, 255, 0.7), rgba(249, 252, 255, 0.8));
}

.marketing-clean .cln-section-head {
  max-width: 760px;
  margin-bottom: 14px;
}

.marketing-clean .cln-section-head h2 {
  margin: 0 0 7px;
  font-size: clamp(30px, 3.5vw, 40px);
  line-height: 1.1;
  letter-spacing: -0.01em;
}

.marketing-clean .cln-section-head p {
  margin: 0;
  color: var(--muted);
  line-height: 1.58;
  font-size: 15px;
}

.marketing-clean .cln-feature-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.marketing-clean .cln-feature-card {
  padding: 14px;
  border-color: var(--cln-line);
  box-shadow: var(--cln-shadow);
}

.marketing-clean .cln-feature-card h3 {
  margin: 0 0 6px;
  font-size: 20px;
}

.marketing-clean .cln-feature-card p {
  margin: 0 0 4px;
  color: var(--muted);
  font-size: 14px;
}

.marketing-clean .cln-platform-visual {
  margin-top: 10px;
  padding: 14px;
  border-color: var(--cln-line);
  box-shadow: none;
  background: #fff;
}

.marketing-clean .cln-platform-lane {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 10px;
}

.marketing-clean .cln-platform-chip {
  border-radius: 999px;
  border: 1px solid var(--cln-line-strong);
  background: #f1f5ff;
  color: #415393;
  padding: 5px 10px;
  font-size: 12px;
  font-weight: 700;
}

.marketing-clean .cln-platform-line {
  width: 32px;
  height: 2px;
  background: linear-gradient(90deg, #b8c8ff 0%, #7f95ff 100%);
}

.marketing-clean .cln-platform-panels {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.marketing-clean .cln-platform-panel {
  border: 1px solid var(--cln-line);
  border-radius: 10px;
  padding: 8px;
  background: #fafbff;
  display: grid;
  gap: 7px;
}

.marketing-clean .cln-platform-row {
  height: 12px;
  border-radius: 999px;
  background: linear-gradient(90deg, #d9e2ff 0%, #ecf1ff 100%);
}

.marketing-clean .cln-platform-row-wide {
  width: 82%;
}

.marketing-clean .cln-workflow-grid {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.marketing-clean .cln-workflow-card {
  border-color: var(--cln-line);
  background: #ffffff;
  box-shadow: none;
  padding: 14px;
}

.marketing-clean .cln-step-number {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid var(--cln-line-strong);
  background: #edf1ff;
  color: var(--accent);
  padding: 4px 9px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.04em;
  margin-bottom: 8px;
}

.marketing-clean .cln-workflow-card h3 {
  margin: 0 0 5px;
  font-size: 18px;
}

.marketing-clean .cln-workflow-card p {
  font-size: 14px;
}

.marketing-clean .cln-flow-strip {
  margin-top: 8px;
  border-color: var(--cln-line);
  box-shadow: none;
  padding: 10px 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 8px;
}

.marketing-clean .cln-flow-node {
  border: 1px solid var(--cln-line-strong);
  background: #f1f5ff;
  color: #415393;
  border-radius: 10px;
  padding: 6px 10px;
  font-size: 12px;
  font-weight: 700;
}

.marketing-clean .cln-flow-connector {
  width: 24px;
  height: 2px;
  background: linear-gradient(90deg, #b9c8ff 0%, #879bff 100%);
}

.marketing-clean .cln-kpi-grid {
  margin-top: 8px;
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.marketing-clean .cln-kpi-card {
  padding: 12px;
  border-color: var(--cln-line);
  box-shadow: none;
}

.marketing-clean .cln-kpi-card h3 {
  margin: 0 0 4px;
  font-size: 17px;
}

.marketing-clean .cln-kpi-card p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
}

.marketing-clean .cln-plan-label {
  margin: 0;
  width: fit-content;
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid #c9d4ff;
  background: #eef2ff;
  color: #4055a4;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.marketing-clean .cln-plan-label-inline {
  margin-bottom: 6px;
}

.marketing-clean .cln-plan-price {
  margin: 0;
  color: #263b90;
  font-size: 34px;
  font-weight: 800;
  line-height: 1.05;
}

.marketing-clean .cln-plan-price span {
  margin-left: 3px;
  font-size: 12px;
  font-weight: 700;
  color: #5a6ca6;
}

.marketing-clean .cln-plan-btn {
  margin-top: 8px;
  width: 100%;
}

.marketing-clean .cln-payg-strip {
  border-color: #d4ddfc;
  padding: 14px;
  display: grid;
  gap: 10px;
  margin-bottom: 12px;
  box-shadow: var(--cln-shadow);
}

.marketing-clean .cln-payg-strip h3 {
  margin: 2px 0 0;
  font-size: 30px;
  line-height: 1.04;
}

.marketing-clean .cln-payg-strip > p {
  margin: 0;
  color: var(--muted);
}

.marketing-clean .cln-pricing-compare {
  border-color: #d4ddfc;
  padding: 14px;
  display: grid;
  gap: 8px;
  box-shadow: var(--cln-shadow);
}

.marketing-clean .cln-pricing-scroll-hint {
  display: none;
  margin: 0;
  color: #5f709f;
  font-size: 12px;
}

.marketing-clean .cln-pricing-table-wrap {
  overflow-x: auto;
  border: 1px solid #dbe4ff;
  border-radius: 12px;
  background: #fff;
}

.marketing-clean .cln-pricing-table {
  width: 100%;
  min-width: 980px;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 14px;
}

.marketing-clean .cln-pricing-table thead th {
  padding: 12px 10px;
  text-align: left;
  vertical-align: top;
  background: #f6f8ff;
  border-bottom: 1px solid #dbe4ff;
  color: #405290;
  font-size: 12px;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.marketing-clean .cln-pricing-table thead th:first-child {
  min-width: 190px;
}

.marketing-clean .cln-pricing-table thead th.is-featured {
  background: linear-gradient(175deg, rgba(95, 113, 255, 0.13), #f6f8ff 45%);
}

.marketing-clean .cln-pricing-plan-head h3 {
  margin: 0 0 3px;
  color: #1f2a4e;
  font-size: 22px;
  line-height: 1.03;
  letter-spacing: -0.01em;
  text-transform: none;
}

.marketing-clean .cln-pricing-plan-head p {
  margin: 0;
  color: #263b90;
  font-size: 26px;
  font-weight: 800;
  line-height: 1.05;
  text-transform: none;
}

.marketing-clean .cln-pricing-plan-head p span {
  margin-left: 3px;
  color: #5a6ca6;
  font-size: 12px;
  font-weight: 700;
}

.marketing-clean .cln-pricing-table tbody th {
  padding: 11px 10px;
  border-bottom: 1px solid #edf1ff;
  color: #4d5f9d;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  vertical-align: top;
  background: #fcfdff;
}

.marketing-clean .cln-pricing-table tbody td {
  padding: 11px 10px;
  border-bottom: 1px solid #edf1ff;
  color: #304074;
  vertical-align: top;
}

.marketing-clean .cln-pricing-table tbody tr:last-child th,
.marketing-clean .cln-pricing-table tbody tr:last-child td {
  border-bottom: none;
}

.marketing-clean .cln-enterprise-estimate-row th,
.marketing-clean .cln-enterprise-estimate-row td {
  background: #f9fbff;
}

.marketing-clean .cln-enterprise-empty {
  color: #5f6fa0;
  font-size: 13px;
}

.marketing-clean .cln-enterprise-cell {
  min-width: 260px;
}

.marketing-clean .cln-enterprise-inline-title {
  margin: 0 0 6px;
  color: #4f619a;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.35;
}

.marketing-clean .cln-unique-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 4px;
}

.marketing-clean .cln-unique-list li {
  position: relative;
  padding-left: 13px;
  font-size: 13px;
  line-height: 1.4;
  color: #334579;
}

.marketing-clean .cln-unique-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 7px;
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: #5c73ff;
}

.marketing-clean .cln-pricing-action-row th {
  background: #f8faff;
}

.marketing-clean .cln-pricing-action-row .cln-plan-btn {
  margin-top: 0;
  width: 100%;
  padding: 9px 8px;
  font-size: 13px;
  box-shadow: none;
}

.marketing-clean .cln-enterprise-slider {
  margin-top: 0;
  border: 1px solid #dde5ff;
  border-radius: 10px;
  padding: 9px;
  background: #f8faff;
}

.marketing-clean .cln-enterprise-slider label {
  margin: 0 0 4px;
  display: block;
  color: #5c6d9f;
  font-size: 11px;
  font-weight: 700;
}

.marketing-clean .cln-enterprise-slider input[type="range"] {
  margin-top: 0;
}

.marketing-clean .cln-enterprise-readout {
  margin: 8px 0 0;
  display: grid;
  gap: 2px;
}

.marketing-clean .cln-enterprise-readout strong {
  color: #334aa2;
  font-size: 15px;
}

.marketing-clean .cln-enterprise-readout span,
.marketing-clean .cln-enterprise-readout small {
  color: #6276b2;
  font-size: 11px;
}

.marketing-clean .cln-final {
  padding-bottom: 22px;
}

.marketing-clean .cln-final-card {
  border-color: var(--cln-line);
  text-align: center;
  padding: 20px;
  background:
    radial-gradient(circle at 8% 0%, rgba(77, 91, 255, 0.1), transparent 42%),
    radial-gradient(circle at 100% 100%, rgba(111, 120, 255, 0.1), transparent 42%),
    #ffffff;
}

.marketing-clean .cln-final-card h2 {
  margin: 0 0 7px;
  font-size: clamp(28px, 3.4vw, 38px);
}

.marketing-clean .cln-final-card p {
  margin: 0 auto 12px;
  max-width: 60ch;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.58;
}

.marketing-clean .cln-final-card .row-actions {
  justify-content: center;
}

@media (max-width: 1100px) {
  .marketing-clean .cln-hero-grid,
  .marketing-clean .cln-proof-grid,
  .marketing-clean .cln-feature-grid,
  .marketing-clean .cln-workflow-grid,
  .marketing-clean .cln-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .marketing-clean .cln-plan-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  .marketing-clean .cln-topbar {
    flex-direction: column;
    align-items: flex-start;
  }

  .marketing-clean .cln-nav {
    width: 100%;
  }

  .marketing-clean .cln-nav .btn,
  .marketing-clean .cln-nav a:not(.btn) {
    flex: 1 1 auto;
    text-align: center;
  }

  .marketing-clean .cln-hero-grid,
  .marketing-clean .cln-proof-grid,
  .marketing-clean .cln-feature-grid,
  .marketing-clean .cln-workflow-grid,
  .marketing-clean .cln-kpi-grid,
  .marketing-clean .cln-plan-grid {
    grid-template-columns: 1fr;
  }

  .marketing-clean .cln-hero {
    padding-top: 30px;
  }

  .marketing-clean .cln-hero-copy h1 {
    max-width: 100%;
  }

  .marketing-clean .cln-platform-panels {
    grid-template-columns: 1fr;
  }

  .marketing-clean .cln-payg-strip,
  .marketing-clean .cln-pricing-compare {
    padding: 12px;
  }

  .marketing-clean .cln-pricing-table {
    min-width: 860px;
  }

  .marketing-clean .cln-pricing-scroll-hint {
    display: block;
  }

  .marketing-clean .cln-pricing-plan-head h3 {
    font-size: 20px;
  }

  .marketing-clean .cln-pricing-plan-head p {
    font-size: 23px;
  }
}

@media (max-width: 640px) {
  .marketing-clean .cln-hero-panel,
  .marketing-clean .cln-feature-card,
  .marketing-clean .cln-workflow-card,
  .marketing-clean .cln-kpi-card,
  .marketing-clean .cln-plan-card,
  .marketing-clean .cln-platform-visual,
  .marketing-clean .cln-final-card {
    padding: 12px;
  }

  .marketing-clean .cln-nav a:not(.btn) {
    padding: 7px 7px;
  }

  .marketing-clean .cln-flow-strip {
    justify-content: flex-start;
  }

  .marketing-clean .cln-flow-connector {
    display: none;
  }

  .marketing-clean .cln-plan-grid {
    grid-template-columns: 1fr;
  }

  .marketing-clean .cln-payg-strip h3 {
    font-size: 26px;
  }

  .marketing-clean .cln-plan-price {
    font-size: 30px;
  }

  .marketing-clean .cln-pricing-table {
    min-width: 760px;
    font-size: 13px;
  }

  .marketing-clean .cln-pricing-action-row .cln-plan-btn {
    font-size: 12px;
    padding: 8px 6px;
  }
}

@keyframes cln-rise {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.property-site-page {
  --ps-accent-a: #4f75df;
  --ps-accent-b: #5ac8e6;
  margin: 0;
  min-height: 100vh;
  background: radial-gradient(circle at 10% -10%, #e8edff 0%, #f5f7ff 44%, #f9fbff 100%);
  color: #1f2b4e;
}

.property-site-page .ps-shell {
  width: min(1280px, 100% - 28px);
  margin: 18px auto 38px;
  display: grid;
  gap: 14px;
}

.property-site-page .ps-hero {
  position: relative;
  overflow: hidden;
  border: 1px solid #dce4ff;
  background: linear-gradient(120deg, var(--ps-accent-b) 0%, var(--ps-accent-a) 100%);
  color: #fff;
  padding: 18px;
  min-height: 270px;
}

.property-site-page .ps-hero.has-hero-image {
  background:
    linear-gradient(120deg, rgba(23, 36, 82, 0.58) 0%, rgba(25, 38, 84, 0.4) 100%),
    var(--ps-hero-image),
    linear-gradient(120deg, var(--ps-accent-b) 0%, var(--ps-accent-a) 100%);
  background-size: cover;
  background-position: center;
}

.property-site-page .ps-hero-top {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
  flex-wrap: wrap;
}

.property-site-page .ps-brand-row {
  display: flex;
  gap: 10px;
  align-items: center;
}

.property-site-page .ps-brand-logo {
  width: 48px;
  height: 48px;
  border-radius: 10px;
  object-fit: cover;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(255, 255, 255, 0.8);
}

.property-site-page .ps-brand-name {
  margin: 0;
  color: rgba(255, 255, 255, 0.9);
  font-size: 13px;
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.property-site-page .ps-mode-badge-wrap {
  margin-top: 5px;
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.property-site-page .ps-mode-badge,
.property-site-page .ps-template-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.58);
  background: rgba(23, 33, 71, 0.3);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  padding: 4px 10px;
}

.property-site-page .ps-link-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.property-site-page .ps-hero-copy {
  margin-top: 38px;
}

.property-site-page .ps-hero-copy h1 {
  margin: 0 0 8px;
  font-size: clamp(30px, 3.8vw, 54px);
  line-height: 1.04;
}

.property-site-page .ps-hero-copy p {
  margin: 0 0 10px;
  font-size: 20px;
  color: rgba(255, 255, 255, 0.95);
}

.property-site-page .ps-status-chips {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.property-site-page .ps-chip {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 6px 11px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.01em;
}

.property-site-page .ps-chip-property-for_sale,
.property-site-page .ps-chip-property-published {
  background: #d7f7e8;
  color: #126443;
}

.property-site-page .ps-chip-payment-paid,
.property-site-page .ps-chip-fulfillment-fulfilled,
.property-site-page .ps-chip-fulfillment-delivered {
  background: #dff7e0;
  color: #20673a;
}

.property-site-page .ps-chip-payment-partial {
  background: #fff0cc;
  color: #9b6500;
}

.property-site-page .ps-chip-payment-unpaid {
  background: #ffe2de;
  color: #b92c1f;
}

.property-site-page .ps-chip[class*="property-"],
.property-site-page .ps-chip[class*="fulfillment-"] {
  background: #e8efff;
  color: #3551b2;
}

.property-site-page .ps-section-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}

.property-site-page .ps-section-head h2 {
  margin: 0;
  font-size: clamp(24px, 2.4vw, 34px);
  line-height: 1.1;
}

.property-site-page .ps-count-badge {
  display: inline-flex;
  min-width: 34px;
  height: 28px;
  border-radius: 999px;
  align-items: center;
  justify-content: center;
  border: 1px solid #d7e0ff;
  background: #ecf2ff;
  color: #4760c2;
  font-weight: 800;
  font-size: 12px;
}

.property-site-page .ps-details-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 8px;
}

.property-site-page .ps-detail-card {
  border: 1px solid #dfe7ff;
  border-radius: 10px;
  background: #fbfcff;
  padding: 10px;
  display: grid;
  gap: 4px;
}

.property-site-page .ps-detail-card span {
  font-size: 11px;
  color: #556292;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
}

.property-site-page .ps-detail-card strong {
  font-size: 16px;
  color: #243462;
}

.property-site-page .ps-description {
  margin: 14px 0 0;
  color: #364371;
  line-height: 1.65;
  font-size: 16px;
}

.property-site-page .ps-contact-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 8px;
}

.property-site-page .ps-contact-card {
  border: 1px solid #dfe7ff;
  border-radius: 10px;
  background: #fafcff;
  padding: 10px;
  display: grid;
  gap: 4px;
}

.property-site-page .ps-contact-card span {
  font-size: 11px;
  color: #556292;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
}

.property-site-page .ps-contact-card strong {
  color: #243462;
  font-size: 15px;
}

.property-site-page .ps-media-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 10px;
}

.property-site-page .ps-media-card {
  margin: 0;
  border: 1px solid #d9e2ff;
  border-radius: 12px;
  overflow: hidden;
  background: #f2f6ff;
  aspect-ratio: 4 / 3;
}

.property-site-page .ps-media-card img,
.property-site-page .ps-media-card video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.property-site-page .ps-link-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 10px;
}

.property-site-page .ps-link-card {
  border: 1px solid #d9e2ff;
  border-radius: 12px;
  background: #f9fbff;
  padding: 12px;
  display: grid;
  gap: 8px;
}

.property-site-page .ps-link-card h4 {
  margin: 0;
  font-size: 17px;
  color: #263665;
}

.property-site-page .ps-link-card a {
  color: #4361cc;
  font-weight: 700;
  text-decoration: none;
}

.property-site-page .ps-link-card a:hover {
  text-decoration: underline;
}

.property-site-page .ps-empty {
  margin: 0;
  padding: 16px;
  border-radius: 10px;
  border: 1px dashed #d5ddf9;
  background: #fbfcff;
  color: #6171a2;
}

.property-site-page.template-editorial-story {
  --ps-accent-a: #3155c4;
  --ps-accent-b: #92b3ff;
}

.property-site-page.template-editorial-story .ps-shell {
  width: min(1180px, 100% - 24px);
}

.property-site-page.template-editorial-story .ps-media-grid {
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
}

.property-site-page.template-minimal-mls {
  --ps-accent-a: #4a5266;
  --ps-accent-b: #8793ac;
  background: #f4f6fa;
}

.property-site-page.template-minimal-mls .ps-hero {
  min-height: 220px;
}

.property-site-page.template-minimal-mls .ps-hero-copy h1 {
  font-size: clamp(28px, 3.1vw, 44px);
}

.property-site-page.template-minimal-mls .ps-link-actions .btn {
  background: rgba(255, 255, 255, 0.94);
}

@media (max-width: 980px) {
  .property-site-page .ps-hero-top {
    flex-direction: column;
    align-items: flex-start;
  }

  .property-site-page .ps-hero-copy {
    margin-top: 26px;
  }
}

@media (max-width: 700px) {
  .property-site-page .ps-shell {
    width: min(1280px, 100% - 16px);
    margin: 10px auto 24px;
  }

  .property-site-page .ps-hero {
    padding: 14px;
    min-height: 220px;
  }

  .property-site-page .ps-hero-copy p {
    font-size: 17px;
  }

  .property-site-page .ps-link-actions {
    width: 100%;
  }

  .property-site-page .ps-link-actions .btn {
    flex: 1;
  }
}

.customers-toolbar-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.customers-toolbar-form {
  margin-bottom: 0;
  grid-template-columns: minmax(220px, 320px) auto auto;
}

@media (max-width: 900px) {
  .customers-toolbar-form {
    grid-template-columns: 1fr auto auto;
  }
}

@media (max-width: 640px) {
  .customers-toolbar-actions {
    width: 100%;
  }

  .customers-toolbar-form {
    width: 100%;
    grid-template-columns: 1fr;
  }
}
