  /* ============ DESIGN TOKENS (drop in app.css) ============ */
  :root {
    --primary:  #1f3b2d;
    --primary-soft: color-mix(in oklab, var(--primary) 7%, white);
    --primary-line: color-mix(in oklab, var(--primary) 15%, white);
    --bg:       #faf8f3;
    --surface:  #ffffff;
    --ink:      #1a1a1a;
    --ink-soft: #5a5a5a;
    --ink-faint:#8a8a8a;
    --line:     #e6e2d8;
    --danger:   #b13a2f;

    --serif:    "Fraunces", Georgia, "Times New Roman", serif;
    --ui:       "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
    --mono:     "JetBrains Mono", ui-monospace, monospace;
  }

  html, body { margin:0; padding:0; }
  body { background: var(--bg); }
  .app, .app * { box-sizing: border-box; }

  .app {
    background: var(--bg);
    color: var(--ink);
    font-family: var(--ui);
    font-size: 15px;
    line-height: 1.6;
    min-height: 100vh;
    display: flex; flex-direction: column;
  }
  .app a { color: var(--primary); text-underline-offset: 3px; }
  .app a:hover { color: var(--ink); }
  .app h1, .app h2, .app h3, .app h4 {
    font-family: var(--serif);
    font-weight: 500;
    letter-spacing: -0.015em;
    color: var(--ink);
    margin: 0;
    text-wrap: balance;
  }
  .app h1 { font-size: clamp(32px, 4vw, 44px); line-height: 1.1; }
  .app h2 { font-size: 28px; line-height: 1.2; }
  .app h3 { font-size: 19px; line-height: 1.3; }
  .app p { margin: 0; }

  .wrap { max-width: 1040px; margin: 0 auto; padding: 0 32px; width: 100%; }

  /* Kicker */
  .kicker {
    font-family: var(--ui);
    font-size: 11px; font-weight: 600;
    letter-spacing: 0.18em; text-transform: uppercase;
    color: var(--primary);
    display: inline-flex; align-items: center; gap: 10px;
    margin-bottom: 12px;
  }
  .kicker::before { content:""; width: 22px; height: 1px; background: var(--primary); }

  /* App header */
  .app-hdr { background: var(--surface); border-bottom: 1px solid var(--line) }
  .app-hdr-in {
    max-width: 1040px; margin: 0 auto;
    padding: 14px 32px;
	  min-height: 65px;
    display:flex; align-items:center; justify-content: space-between; gap: 24px;
  }
  .app-brand { display:flex; align-items:center; gap: 10px; text-decoration:none; color: var(--ink); }
  .app-mark {
    height: 30px; padding: 0 8px;
    background: var(--primary); color: #fff;
    display:inline-flex; align-items:center; justify-content:center;
    font-family: var(--serif); font-weight: 600; font-size: 12px; letter-spacing: 0.04em;
    white-space: nowrap;
  }
  .app-brand-name { font-family: var(--serif); font-weight: 600; font-size: 18px; letter-spacing: -0.01em; color: var(--primary); }
  .app-nav { display:flex; align-items:center; gap: 22px; font-size: 14px; }
  .app-nav a { color: var(--ink-soft); text-decoration: none; }
  .app-nav a:hover { color: var(--primary); }
  .app-nav .is-active { color: var(--ink); font-weight: 500; }
  .app-user { color: var(--ink-faint); font-size: 13px; padding-left: 6px; border-left: 1px solid var(--line); }
  .app-logout { font-size: 13px; }
  .btn-pill {
    background: var(--primary); color: #fff !important;
    padding: 8px 16px; border-radius: 999px;
    font-size: 13px; font-weight: 500;
  }
  .btn-pill:hover { background: var(--ink); color: #fff !important; }

  /* Main + footer */
  .app-main { flex: 1; }
  .app-ftr { background: var(--surface); border-top: 1px solid var(--line); padding: 18px 0; }
  .app-ftr-in {
    max-width: 1040px; margin: 0 auto; padding: 0 32px;
    display:flex; justify-content: space-between;
    font-size: 12.5px; color: var(--ink-faint);
  }
  .app-ftr a { color: var(--ink-faint); text-decoration: none; }
  .app-ftr a:hover { color: var(--primary); }

  /* ============ Buttons ============ */
  .b {
    display:inline-flex; align-items:center; gap: 8px;
    padding: 12px 20px;
    font-family: var(--ui); font-size: 14px; font-weight: 500;
    border-radius: 0;
    border: 1px solid transparent;
    cursor: pointer;
    text-decoration: none;
    transition: background .15s, color .15s, border-color .15s, transform .12s;
    line-height: 1;
  }
  .b-primary { background: var(--primary); color: #fff !important; border-color: var(--primary); }
  .b-primary:hover { background: var(--ink); border-color: var(--ink); color: #fff !important; transform: translateY(-1px); }
  .b-ghost { background: var(--surface); color: var(--ink); border-color: var(--line); }
  .b-ghost:hover { border-color: var(--primary); color: var(--primary); }
  .b-ghost-danger { background: var(--surface); color: var(--danger); border-color: var(--line); }
  .b-ghost-danger:hover { border-color: var(--danger); }
  .b-sm { padding: 8px 14px; font-size: 13px; }
  .arr { transition: transform .15s; }
  .b:hover .arr { transform: translateX(3px); }

  /* ============ Forms ============ */
  .form .field { margin-bottom: 22px; }
  .field label { display: block; font-size: 13px; font-weight: 600; color: var(--ink); margin-bottom: 6px; letter-spacing: 0.005em; }
  .inp {
    width: 100%; padding: 11px 14px;
    font-family: var(--ui); font-size: 15px; color: var(--ink);
    background: var(--surface); border: 1px solid var(--line);
    border-radius: 0;
  }
  .inp:focus { outline: 2px solid var(--primary); outline-offset: -1px; border-color: var(--primary); }
  textarea.inp { resize: vertical; min-height: 96px; line-height: 1.55; }
  .field .hint { display:block; margin-top: 6px; font-size: 12px; color: var(--ink-faint); }
  .field .err  { display:block; margin-top: 6px; font-size: 12px; color: var(--danger); }
  .check { display:flex; align-items:center; gap: 8px; font-size: 14px; color: var(--ink-soft); margin-bottom: 18px; cursor: pointer; }
  .slug { display:flex; }
  .slug-pre {
    display:flex; align-items: center; padding: 0 14px;
    background: var(--primary-soft); border: 1px solid var(--line); border-left: 0;
    color: var(--primary); font-family: var(--mono); font-size: 12px;
    white-space: nowrap; flex-shrink: 0;
  }
  .slug .inp { border-radius: 0; }

  /* ============ Marketing landing ============ */
  .hero-marketing {
    padding: 80px 0 88px;
    border-bottom: 1px solid var(--line);
    background: linear-gradient(180deg,
      color-mix(in oklab, var(--primary) 11%, var(--bg)) 0%,
      color-mix(in oklab, var(--primary) 4%, var(--bg)) 100%);
  }
  .hm-wrap { max-width: 1040px; margin: 0 auto; padding: 0 32px; }
  .hm-wrap h1 {
    font-size: clamp(40px, 5.5vw, 60px);
    line-height: 1.05; letter-spacing: -0.02em;
    margin: 0 0 22px;
  }
  .hm-wrap .lede {
    font-size: 19px; color: var(--ink-soft);
    max-width: 56ch; margin: 0 0 32px;
  }
  .hero-actions { display:flex; gap: 14px; flex-wrap: wrap; align-items:center; }
  .hm-strikes { margin-bottom: 28px; padding-bottom: 24px; border-bottom: 1px solid var(--line); }
  .hm-strikes s { display:block; color: var(--ink-faint); font-size: 14px; margin-bottom: 6px; text-decoration-color: color-mix(in oklab, var(--ink-faint) 40%, transparent); }

  /* Guest editor tabs (step 8) */
  .ge-tabs { display:flex; gap:0; border-bottom: 1px solid var(--line); margin-bottom: 24px; }
  .ge-tab-btn { background:none; border:none; padding: 10px 20px; font-family: var(--ui); font-size: 14px; font-weight: 500; color: var(--ink-soft); cursor:pointer; border-bottom: 2px solid transparent; margin-bottom: -1px; }
  .ge-tab-btn.active { color: var(--primary); border-bottom-color: var(--primary); }

  .block { padding: 80px 0; border-bottom: 1px solid var(--line); }
  .block.band { background: var(--surface); }
  .block h2 { margin: 0 0 32px; max-width: 24ch; }
  .how-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 22px; }
  .how-list li { display: grid; grid-template-columns: 60px 1fr; gap: 20px; padding: 22px 0; border-top: 1px solid var(--line); }
  .how-list li:first-child { border-top: 0; padding-top: 0; }
  .how-list .num { font-family: var(--serif); font-size: 32px; color: var(--primary); font-weight: 500; line-height: 1; }
  .how-list b { font-family: var(--serif); font-size: 20px; font-weight: 500; display:block; margin-bottom: 4px; }
  .how-list p { color: var(--ink-soft); font-size: 15px; }
  .how-list code { font-family: var(--mono); background: var(--primary-soft); color: var(--primary); padding: 1px 6px; font-size: 13px; }

  .price-grid { display:grid; grid-template-columns: 1fr 1fr; gap: 18px; max-width: 720px; }
  .price-card { padding: 32px; background: var(--bg); border: 1px solid var(--line); }
  .price-card.pc-pro { background: var(--primary); color: #fff; border-color: var(--primary); }
  .pc-pro .pk-name, .pc-pro .pk-price, .pc-pro li, .pc-pro h2 { color: #fff; }
  .pc-pro li { border-color: color-mix(in oklab, #fff 25%, var(--primary)) !important; }
  .pk-name { font-family: var(--ui); font-size: 11px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--primary); margin-bottom: 12px; }
  .pk-price { font-family: var(--serif); font-size: 44px; font-weight: 500; line-height: 1; margin-bottom: 24px; letter-spacing: -0.02em; }
  .pk-price span { font-size: 16px; color: var(--ink-faint); margin-left: 4px; font-family: var(--ui); font-weight: 400; }
  .pc-pro .pk-price span { color: color-mix(in oklab, #fff 70%, var(--primary)); }
  .price-card ul { list-style: none; padding: 0; margin: 0 0 24px; }
  .price-card li { padding: 10px 0; border-top: 1px solid var(--line); font-size: 14px; color: var(--ink-soft); }
  .pc-pro li { color: color-mix(in oklab, #fff 88%, var(--primary)); }
  .pc-pro .b-primary { background: #fff; color: var(--primary) !important; border-color: #fff; }
  .pc-pro .b-primary:hover { background: var(--bg); color: var(--primary) !important; border-color: var(--bg); }

  /* ============ Auth ============ */
  .auth-wrap { padding: 64px 0; min-height: 600px; display:flex; align-items: flex-start; justify-content: center; }
  .auth-card {
    width: 440px; max-width: 100%;
    padding: 40px 36px;
    background: var(--surface); border: 1px solid var(--line);
  }
  .auth-card h1 { margin-bottom: 8px; font-size: 32px; }
  .auth-card .lede { font-size: 15px; color: var(--ink-soft); margin: 0 0 28px; }
  .auth-alt { margin-top: 18px; font-size: 13.5px; color: var(--ink-soft); text-align: center; }

  /* ============ Dashboard ============ */
  .dash { padding: 56px 32px; }
  .dash-head { display:flex; justify-content: space-between; align-items: flex-end; margin-bottom: 28px; gap: 20px; flex-wrap: wrap; }
  .dash-head .kicker { margin-bottom: 6px; }

  .plan-banner {
    display:flex; justify-content: space-between; align-items: center;
    padding: 16px 22px; margin-bottom: 24px;
    background: var(--primary-soft);
    border: 1px solid var(--primary-line);
  }
  .plan-banner b { font-family: var(--serif); font-weight: 500; font-size: 16px; margin-right: 10px; }
  .plan-banner span { font-size: 13.5px; color: var(--ink-soft); }

  .site-list { display: flex; flex-direction: column; gap: 0; border-top: 1px solid var(--line); }
  .site-row {
    padding: 22px 4px;
    border-bottom: 1px solid var(--line);
    display: grid; grid-template-columns: 1.4fr 1fr auto; gap: 22px; align-items: center;
  }
  .sr-main { display:flex; align-items: center; gap: 14px; flex-wrap: wrap; }
  .sr-main h3 { font-size: 21px; }
  .sr-meta { font-size: 13.5px; color: var(--ink-soft); }
  .sr-meta a { font-family: var(--mono); font-size: 13px; }
  .sr-actions { display:flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }

  .status {
    font-size: 11px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase;
    padding: 3px 8px; border: 1px solid var(--line); color: var(--ink-faint);
    font-family: var(--ui);
  }
  .status.s-published { color: var(--primary); border-color: var(--primary-line); background: var(--primary-soft); }
  .status.s-draft { color: var(--ink-faint); }
  .status.s-unpublished { color: var(--danger); border-color: color-mix(in oklab, var(--danger) 25%, white); }

  /* ============ Editor ============ */
  .editor { display: flex; min-height: 100vh; }
  .editor-side {
    position: fixed; top: 0; left: 0;
    width: 280px; height: 100vh;
    overflow-y: auto;
    background: var(--surface);
    border-right: 1px solid var(--line);
    padding: 36px 28px;
    z-index: 40;
    flex-shrink: 0;
  }
  .es-head { padding-bottom: 24px; border-bottom: 1px solid var(--line); margin-bottom: 24px; }
  .es-head h3 { font-size: 22px; margin-bottom: 10px; }
  .es-preview { font-size: 13px; color: var(--primary); text-decoration: none; }
  .es-preview:hover { text-decoration: underline; }
  .es-steps { list-style: none; padding: 0; margin: 0; counter-reset: s; display: flex; flex-direction: column; gap: 2px; }
  .es-steps li {
    display: grid; grid-template-columns: 28px 1fr; gap: 12px; align-items: center;
    padding: 10px 12px;
    font-size: 14px; color: var(--ink-soft);
    border-left: 2px solid transparent;
  }
  .es-steps .es-num {
    width: 26px; height: 26px;
    display:grid; place-items:center;
    border: 1px solid var(--line);
    background: var(--surface);
    font-size: 12px; font-weight: 600; color: var(--ink-faint);
    font-family: var(--ui);
  }
  .es-steps .es-name { text-decoration: none; color: inherit; }
  .es-steps li:hover:not(.current) { background: var(--primary-soft); }
  .es-steps .done { color: var(--ink); }
  .es-steps .done .es-num { background: var(--primary); border-color: var(--primary); color: #fff; }
  .es-steps .current { color: var(--ink); font-weight: 600; border-left-color: var(--primary); background: var(--primary-soft); }
  .es-steps .current .es-num { border-color: var(--primary); color: var(--primary); }

  /* radio option rows (step 7) */
  .radio-opt { display:flex; align-items:flex-start; gap: 12px; cursor: pointer; padding: 14px; border: 1px solid var(--line); background: var(--surface); }
  .radio-opt:hover { border-color: var(--primary-line); }
  .radio-opt-dim { opacity: .5; cursor: default; }

  .editor-main { display: flex; flex-direction: column; min-height: 100vh; flex: 1; margin-left: 280px; }
  .editor-page { flex: 1; max-width: 600px; margin: 0 auto; padding: 56px 32px 120px; width: 100%; }
  .editor-page h1 { font-size: 32px; margin-bottom: 8px; }
  .editor-page .lede { font-size: 15px; color: var(--ink-soft); margin: 0 0 32px; }

  .stepper {
    position: sticky; bottom: 0; left: 0; right: 0;
    background: var(--surface); border-top: 1px solid var(--line);
    padding: 14px 32px 18px;
  }
  .step-progress { height: 3px; background: var(--line); margin-bottom: 12px; }
  .step-fill { height: 100%; background: var(--primary); transition: width .3s; }
  .step-ctrls { display:flex; justify-content: space-between; align-items: center; gap: 12px; }
  .step-count { font-family: var(--mono); font-size: 12.5px; color: var(--ink-faint); letter-spacing: 0.04em; }
  .step-nav-btn { display:inline-flex; align-items:center; }
  @media (max-width: 600px) { .nav-label { display:none; } }

  /* upload */
  .upload { display:flex; gap: 18px; align-items: center; padding: 18px; border: 1px dashed var(--line); }
  .upload-prev { width: 64px; height: 64px; display:grid; place-items:center; background: var(--bg); }
  .logo-mark-sm { width: 48px; height: 48px; background: var(--primary); color:#fff; display:grid; place-items:center; font-family: var(--serif); font-weight: 600; font-size: 18px; }
  .upload-ctrls { display:flex; flex-direction: column; gap: 6px; }
  .upload-ctrls .hint { font-size: 12px; color: var(--ink-faint); }

  /* auth tabs (step 8) */
  .auth-tabs { display: flex; gap: 4px; margin-bottom: 24px; border-bottom: 1px solid var(--line); }
  .auth-tab { background: none; border: none; border-bottom: 2px solid transparent; padding: 8px 16px; font: inherit; font-size: 14px; font-weight: 500; color: var(--ink-faint); cursor: pointer; margin-bottom: -1px; }
  .auth-tab.active { color: var(--ink); border-bottom-color: var(--primary); }
  .auth-tab:hover:not(.active) { color: var(--ink-soft); }
  .auth-panel { }

  /* gallery */
  .gallery-grid { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 16px; }
  .gallery-item { position: relative; }
  .gallery-item img { display: block; max-width: 300px; max-height: 300px; width: auto; height: auto; border: 1px solid var(--line); border-radius: 4px; object-fit: cover; }
  .gallery-item .remove-btn { position: absolute; top: 4px; right: 4px; background: rgba(0,0,0,.55); color: #fff; border: none; border-radius: 50%; width: 22px; height: 22px; font-size: 12px; cursor: pointer; line-height: 1; display: grid; place-items: center; }

  /* hours */
  .hours-list { display: flex; flex-direction: column; gap: 8px; }
  .hours-row { display:grid; grid-template-columns: 140px 1fr; gap: 14px; align-items: center; padding: 8px 0; }
  .hours-row.off { opacity: 0.5; }
  .hr-day { font-size: 14px; color: var(--ink); cursor: pointer; display:flex; align-items: center; gap: 8px; font-weight: 500; }
  .hr-day input { accent-color: var(--primary); }

  /* color swatches */
  .swatches { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
  .sw { display:flex; flex-direction: column; gap: 8px; align-items: center; padding: 16px 8px; cursor: pointer; border: 1px solid var(--line); background: var(--surface); }
  .sw:hover { border-color: var(--primary-line); }
  .sw.checked { border-color: var(--primary); background: var(--primary-soft); }
  .sw input { display: none; }
  .sw-dot { width: 36px; height: 36px; border-radius: 50%; border: 1px solid rgba(0,0,0,.06); }
  .sw-other { background: conic-gradient(red,yellow,lime,cyan,blue,magenta,red); }
  .sw-name { font-size: 12px; color: var(--ink-soft); }
  .sw.checked .sw-name { color: var(--ink); font-weight: 600; }

  /* ============ Analytics ============ */
  .an { padding: 56px 32px; }
  .back { display:block; font-size: 13.5px; color: var(--ink-faint); text-decoration: none; margin-bottom: 16px; }
  .back:hover { color: var(--primary); }
  .an h1 { font-size: 36px; margin-bottom: 8px; }
  .an .lede { font-size: 15px; color: var(--ink-soft); margin: 0 0 36px; }

  .stat-table-card { padding: 28px; background: var(--surface); border: 1px solid var(--line); margin-bottom: 18px; }
  .stat-table { width: 100%; border-collapse: collapse; font-size: 14px; }
  .stat-table tr { border-bottom: 1px solid var(--line); }
  .stat-table tr:last-child { border-bottom: 0; }
  .stat-table th { text-align: left; padding: 12px 0; font-weight: 500; color: var(--ink); }
  .stat-table td { text-align: right; padding: 12px 0; font-variant-numeric: tabular-nums; font-family: var(--serif); font-size: 18px; color: var(--ink); }
  .stat-table .rs { font-family: var(--mono); font-size: 13px; color: var(--ink); font-weight: 400; }

  /* Editor: sidebar visible on desktop only */
  @media (max-width: 900px) {
    .editor-side { display: none; }
    .editor-main { margin-left: 0; }
    .editor-page { padding: 32px 20px 120px; }
  }

  /* Mobile responsive */
  @media (max-width: 640px) {
    .app-hdr-in { padding: 12px 16px; gap: 10px; }
    .app-nav { gap: 12px; }
    .app-user { display: none; }
    .wrap { padding: 0 16px; }
    .dash { padding: 32px 16px; }
    .dash-head { flex-direction: column; align-items: flex-start; }
    .plan-banner { flex-direction: column; align-items: flex-start; gap: 12px; }
    .site-row { grid-template-columns: 1fr; gap: 12px; }
    .sr-actions { justify-content: flex-start; }
    .an { padding: 32px 16px; }
    .swatches { grid-template-columns: repeat(3, 1fr); }
    .price-grid { grid-template-columns: 1fr; }
  }
