/* Ported from order.html — scoped to .mf-order-flow */
body.mf-order-flow-page .site-content,
body.mf-order-flow-page #content,
body.mf-order-flow-page main,
body.mf-order-flow-page .entry-content { max-width: none !important; padding-left: 0; padding-right: 0; }
body.mf-order-flow-page { background: #f8fafc; }
.mf-order-flow {

  --color-promo-bg-from: #fff7ed;
  --color-promo-bg-to: #ffffff;
  --color-promo-border: #fed7aa;
  --color-promo-icon-bg: #fff7ed;
  --color-promo-accent: #ea580c;
  --color-success-emphasis: #16a34a;

    --color-primary: #ff3553;
    --color-primary-hover: #e72a46;
    --color-secondary: #ff8c42;
    --color-heading: #0f172a;
    --color-body: #1e293b;
    --color-muted: #64748b;
    --color-border: #e2e8f0;
    --color-border-hover: #cbd5e1;
    --color-surface: #ffffff;
    --color-surface-muted: #f8fafc;
    --color-surface-subtle: #f1f5f9;
    --color-success: #22c55e;
    --color-success-strong: #15803d;
    --color-success-bg: #f0fdf4;
    --color-success-border: #bbf7d0;
    --color-danger: #dc2626;
    --color-danger-bg: #fef2f2;
    --color-danger-border: #fecaca;
    --color-on-inverse: #ffffff;
    --shadow-sm: 0 1px 8px rgb(0 0 0 / 0.06);
    --shadow-md: 0 2px 8px rgb(0 0 0 / 0.06);
    --shadow-lg: 0 8px 28px rgb(0 0 0 / 0.08);
    --radius: 12px;
  }

.mf-order-flow * { box-sizing: border-box; margin: 0; padding: 0; }
  .mf-order-flow {
    font-family: Inter, sans-serif;
    background: var(--color-surface-muted);
    color: var(--color-body);
    line-height: 1.6;
    font-size: 15px;
  }
.mf-order-flow a { color: inherit; }

  .mf-order-flow .topbar {
    position: sticky;
    top: 0;
    z-index: 60;
    background: var(--color-surface);
    border-bottom: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
  }
  .mf-order-flow .topbar-inner {
    max-width: 1080px;
    margin: 0 auto;
    min-height: calc(64px + env(safe-area-inset-top, 0px));
    padding: env(safe-area-inset-top, 0px) clamp(1rem, 4vw, 2rem) 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
  }
  .mf-order-flow .brand {
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 1.18rem;
    font-weight: 800;
    color: var(--color-heading);
  }
  .brand span { color: var(--color-primary); }
  .brand img { height: 26px; width: auto; display: block; }
  .topbar-note { font-size: 0.8rem; color: var(--color-muted); font-weight: 600; }

  .mf-order-flow .page {
    max-width: 1080px;
    margin: 0 auto;
    padding: clamp(1rem, 3vw, 1.5rem) clamp(1rem, 4vw, 2rem) 3rem;
  }

  .mf-order-flow .steps-wrap {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-md);
    padding: 0.9rem;
    margin-bottom: 1rem;
  }
  .mf-order-flow .steps {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 0.6rem;
  }
  .mf-order-flow .step-pill {
    border-radius: 999px;
    border: 1px solid var(--color-border);
    background: var(--color-surface-muted);
    color: var(--color-muted);
    padding: 0.42rem 0.6rem;
    font-size: 0.78rem;
    font-weight: 700;
    text-align: center;
    white-space: nowrap;
  }
  .mf-order-flow .step-pill.is-active {
    color: var(--color-on-inverse);
    border-color: var(--color-primary);
    background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
  }
  .mf-order-flow .step-pill.is-complete {
    color: var(--color-success-strong);
    border-color: var(--color-success-border);
    background: var(--color-success-bg);
  }

  .mf-order-flow .mobile-progress {
    display: none;
    align-items: center;
    justify-content: space-between;
    gap: 0.85rem;
  }
  .mf-order-flow .mobile-progress h2 {
    font-size: 0.95rem;
    font-weight: 800;
    color: var(--color-heading);
  }
  .mf-order-flow .mobile-progress .bar {
    flex: 1;
    height: 8px;
    border-radius: 999px;
    background: var(--color-surface-subtle);
    overflow: hidden;
  }
  .mf-order-flow .mobile-progress .bar > span {
    display: block;
    height: 100%;
    width: 16.666%;
    background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
    transition: width 0.2s ease;
  }

  .mf-order-flow .card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-md);
    padding: clamp(1.1rem, 2.2vw, 1.5rem);
  }
  .step-panel[hidden] { display: none; }
  .step-header { margin-bottom: 1rem; }
  .mf-order-flow .eyebrow {
    display: inline-block;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-primary);
    margin-bottom: 0.35rem;
  }
  .mf-order-flow .step-title {
    font-size: clamp(1.3rem, 2.8vw, 1.85rem);
    font-weight: 900;
    color: var(--color-heading);
    letter-spacing: -0.02em;
    margin-bottom: 0.35rem;
  }
  .step-sub { font-size: 0.9rem; color: var(--color-muted); max-width: 66ch; }

  .field-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0.9rem; }
  .field-span-full { grid-column: 1 / -1; }
  .field { display: flex; flex-direction: column; gap: 0.35rem; margin-bottom: 0.9rem; }
  .field label,
  .field .field-label { font-weight: 700; color: var(--color-heading); font-size: 0.82rem; }
  .mf-order-flow .field input, .mf-order-flow .field textarea, .mf-order-flow .field select {
    border: 1px solid var(--color-border);
    border-radius: 8px;
    background: var(--color-surface);
    color: var(--color-body);
    padding: 0.72rem 0.75rem;
    font-size: 0.9rem;
    font-family: inherit;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
  }
  .field textarea { min-height: 120px; resize: vertical; }
  .mf-order-flow .field input:focus, .mf-order-flow .field textarea:focus, .mf-order-flow .field select:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgb(255 53 83 / 0.12);
  }
  /* Toggle switches (native checkbox + visual track) */
  .mf-order-flow .check-toggle-stack {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
    margin-top: 0.35rem;
  }
  .mf-order-flow .check.check--toggle {
    display: flex;
    align-items: flex-start;
    gap: 0.85rem;
    font-size: 0.86rem;
    color: var(--color-body);
    line-height: 1.45;
    cursor: pointer;
    user-select: none;
  }
  .mf-order-flow .check-toggle-wrap {
    position: relative;
    flex-shrink: 0;
    width: 52px;
    height: 30px;
    margin-top: 0.08rem;
  }
  .mf-order-flow .check-toggle-wrap input {
    position: absolute;
    inset: 0;
    opacity: 0;
    margin: 0;
    cursor: pointer;
    z-index: 2;
    width: 52px;
    height: 30px;
  }
  .mf-order-flow .check-toggle {
    position: absolute;
    inset: 0;
    border-radius: 999px;
    background: var(--color-border);
    box-shadow: inset 0 1px 3px rgb(15 23 42 / 0.08);
    transition: background 0.22s ease, box-shadow 0.22s ease;
    pointer-events: none;
  }
  .mf-order-flow .check-toggle::after {
    content: "";
    position: absolute;
    top: 3px;
    left: 3px;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--color-surface);
    box-shadow: 0 2px 6px rgb(15 23 42 / 0.12), 0 1px 2px rgb(15 23 42 / 0.08);
    transition: transform 0.22s cubic-bezier(0.4, 0, 0.2, 1);
  }
  .mf-order-flow .check-toggle-wrap input:checked + .check-toggle {
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-hover) 100%);
    box-shadow: inset 0 1px 0 rgb(255 255 255 / 0.22), 0 2px 10px color-mix(in srgb, var(--color-primary) 35%, transparent);
  }
  .mf-order-flow .check-toggle-wrap input:checked + .check-toggle::after {
    transform: translateX(22px);
  }
  .mf-order-flow .check-toggle-wrap input:focus-visible + .check-toggle {
    outline: 2px solid var(--color-primary);
    outline-offset: 3px;
  }
  .mf-order-flow .check-toggle-wrap input:disabled + .check-toggle {
    opacity: 0.5;
    cursor: not-allowed;
  }
  .check-label { flex: 1; min-width: 0; font-weight: 500; }
  @media (prefers-reduced-motion: reduce) {
    .check-toggle,
    .mf-order-flow .check-toggle::after {
      transition-duration: 0.01ms;
    }
  }

  .mf-order-flow .plan-grid, .mf-order-flow .option-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin-bottom: 0.95rem;
  }
  .mf-order-flow .pick-card {
    border: 2px solid var(--color-border);
    border-radius: var(--radius);
    background: var(--color-surface);
    padding: 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.7rem;
    min-height: 100%;
  }
  .mf-order-flow .pick-card.selected {
    border-color: var(--color-primary);
    box-shadow: 0 10px 32px rgb(255 53 83 / 0.13);
    background-color: var(--color-danger-bg);
  }
  .mf-order-flow .pick-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
  }
  .pick-name { font-size: 1rem; font-weight: 800; color: var(--color-heading); }
  .pick-price { font-size: 0.9rem; font-weight: 800; color: var(--color-heading); }
  .pick-price em { font-style: normal; color: var(--color-primary); }
  .mf-order-flow .pick-price--promo {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.35rem 0.55rem;
  }
  .mf-order-flow .pick-price-was {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--color-muted);
    text-decoration: line-through;
    text-decoration-thickness: 1px;
  }
  .mf-order-flow .badge {
    font-size: 0.66rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 0.2rem 0.5rem;
    border-radius: 999px;
    color: var(--color-on-inverse);
    background: var(--color-primary);
  }
  .mf-order-flow .badge--free {
    color: var(--color-success-emphasis);
    background: var(--color-success-bg);
    border: 1px solid var(--color-success-border);
  }
  .pick-sub { font-size: 0.84rem; color: var(--color-muted); line-height: 1.55; }
  .pick-list { list-style: none; display: flex; flex-direction: column; gap: 0.4rem; }
  .pick-list li { display: flex; gap: 0.45rem; align-items: flex-start; font-size: 0.82rem; color: var(--color-body); line-height: 1.35; }
  .pick-list li::before { content: "•"; color: var(--color-success); font-weight: 900; margin-top: 0.02rem; }
  /* Step 2 plan cards: check / X instead of bullets */
  .pick-list--plan-status li::before { display: none !important; content: none !important; }
  .pick-list--plan-status li { gap: 0.55rem; }
  .mf-order-flow .pick-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.2rem;
    height: 1.2rem;
    margin-top: 0.06rem;
    flex-shrink: 0;
    border-radius: 50%;
    font-size: 0.62rem;
    font-weight: 900;
    line-height: 1;
  }
  .mf-order-flow .pick-status--yes {
    background: var(--color-success-bg);
    color: var(--color-success-strong);
    border: 1px solid var(--color-success-border);
  }
  .mf-order-flow .pick-status--no {
    background: var(--color-danger-bg);
    color: var(--color-danger);
    border: 1px solid var(--color-danger-border);
  }
  .pick-line-text { flex: 1; min-width: 0; }
  .mf-order-flow .pick-note {
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--color-heading);
    background: var(--color-surface-subtle);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 0.6rem;
    line-height: 1.4;
  }
  .mf-order-flow .pick-card.selected .pick-note {
    background: var(--color-surface);
  }
  .mf-order-flow .pick-guarantee {
    margin-top: -0.2rem;
    font-size: 0.77rem;
    font-weight: 700;
    color: var(--color-success-strong);
    display: flex;
    align-items: flex-start;
    gap: 0.45rem;
    line-height: 1.35;
  }
  .mf-order-flow .pick-guarantee-icon {
    flex-shrink: 0;
    width: 1.05rem;
    height: 1.05rem;
    margin-top: 0.06rem;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .mf-order-flow .pick-guarantee-icon svg {
    width: 100%;
    height: 100%;
    stroke: currentColor;
    fill: none;
  }
  .mf-order-flow .pick-btn {
    margin-top: auto;
    width: 100%;
    border: 2px solid var(--color-border);
    background: var(--color-surface);
    color: var(--color-heading);
    border-radius: 8px;
    font-size: 0.84rem;
    font-weight: 800;
    padding: 0.65rem;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
  }
  .mf-order-flow .pick-card[data-article="writing"] .pick-btn-label--writing-selected {
    display: none;
    align-items: center;
    gap: 0.35rem;
  }
  .mf-order-flow .pick-card[data-article="writing"].selected .pick-btn-label--writing-default {
    display: none;
  }
  .mf-order-flow .pick-card[data-article="writing"].selected .pick-btn-label--writing-selected {
    display: inline-flex;
  }
  .mf-order-flow .pick-btn-check {
    width: 1.05em;
    height: 1.05em;
    flex-shrink: 0;
    stroke: currentColor;
    fill: none;
    stroke-width: 2.5;
    stroke-linecap: round;
    stroke-linejoin: round;
  }
  .mf-order-flow .pick-card.selected .pick-btn {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: var(--color-on-inverse);
  }
  .mf-order-flow .micro-note {
    font-size: 0.8rem;
    color: var(--color-muted);
    text-align: center;
    margin-top: 0.2rem;
  }
  .pick-section { margin: 0; }
  .mf-order-flow .pick-section-title {
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--color-heading);
    margin: 0.55rem 0 0.3rem;
  }
  .pick-section:first-of-type .pick-section-title { margin-top: 0.15rem; }
  .mf-order-flow .pick-section-body {
    font-size: 0.82rem;
    color: var(--color-body);
    line-height: 1.45;
    margin: 0;
  }
  .pick-list--plan-compact { gap: 0.32rem; }

  .article-fields[hidden] { display: none; }
  .helper { font-size: 0.78rem; color: var(--color-muted); margin-top: 0.2rem; }

  .mf-order-flow .article-editor-wrap {
    border: 1px solid var(--color-border);
    border-radius: 8px;
    background: var(--color-surface);
    overflow: hidden;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
  }
  .mf-order-flow .article-editor-wrap:focus-within {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgb(255 53 83 / 0.12);
  }
  .mf-order-flow .article-editor-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    padding: 0.45rem 0.5rem;
    border-bottom: 1px solid var(--color-border);
    background: var(--color-surface-muted);
  }
  .mf-order-flow .article-editor-toolbar button {
    border: 1px solid var(--color-border);
    border-radius: 6px;
    background: var(--color-surface);
    color: var(--color-heading);
    font-size: 0.78rem;
    font-weight: 700;
    padding: 0.35rem 0.55rem;
    cursor: pointer;
    font-family: inherit;
  }
  .mf-order-flow .article-editor-toolbar button:hover {
    border-color: var(--color-border-hover);
    background: var(--color-surface-subtle);
  }
  .mf-order-flow .article-editor-toolbar button.is-active {
    border-color: var(--color-primary);
    color: var(--color-primary);
    background: rgb(255 53 83 / 0.06);
  }
  .mf-order-flow .article-editor-host {
    min-height: 200px;
    max-height: min(55vh, 520px);
    overflow-y: auto;
    padding: 0.65rem 0.75rem 0.85rem;
  }
  @media (min-width: 768px) {
    .mf-order-flow .article-editor-host {
      min-height: 400px;
    }
  }
  .mf-order-flow .article-editor-prose {
    outline: none;
    font-size: 0.9rem;
    line-height: 1.55;
    color: var(--color-body);
  }
  .article-editor-prose p { margin: 0 0 0.55rem; }
  .article-editor-prose p:last-child { margin-bottom: 0; }
  .article-editor-prose .article-editor-h1,
  .article-editor-prose h2,
  .mf-order-flow .article-editor-prose h3 {
    font-weight: 400;
    color: var(--color-heading);
  }
  .mf-order-flow .article-editor-prose .article-editor-h1 {
    font-size: 2rem;
    margin: 0 0 0.5rem;
    letter-spacing: -0.02em;
    line-height: 1.25;
  }
  .article-editor-prose h2,
  .mf-order-flow .article-editor-prose h3 {
    margin: 0.65rem 0 0.4rem;
    line-height: 1.3;
  }
  .article-editor-prose h2 { font-size: 1.5rem; }
  .article-editor-prose h3 { font-size: 1.25rem; }
  .article-editor-prose ul,
  .mf-order-flow .article-editor-prose ol {
    margin: 0 0 0.55rem;
    padding-left: 1.35rem;
  }
  .article-editor-prose li { margin-bottom: 0.25rem; }
  .article-editor-prose li p { margin: 0 0 0.25rem; }
  .article-editor-prose li p:last-child { margin-bottom: 0; }
  .mf-order-flow .article-editor-prose .is-empty::before {
    content: attr(data-placeholder);
    float: left;
    color: var(--color-muted);
    pointer-events: none;
    height: 0;
  }
  .mf-order-flow .article-editor-wordcount {
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--color-muted);
    margin-top: 0.4rem;
  }
  .mf-order-flow .article-editor-wordcount.is-under-min {
    color: var(--color-primary);
  }
  .mf-order-flow .article-editor-wordcount.is-over-max {
    color: var(--color-danger);
  }
  .mf-order-flow .article-editor-wordcount.is-in-range {
    color: var(--color-muted);
  }

  .mf-order-flow .step-actions {
    margin-top: 1rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
  }
  .mf-order-flow .btn {
    border: none;
    border-radius: 8px;
    font-weight: 800;
    font-size: 0.9rem;
    padding: 0.78rem 1.25rem;
    text-decoration: none;
    cursor: pointer;
  }
  .mf-order-flow .btn-primary {
    background: var(--color-primary);
    color: var(--color-on-inverse);
    box-shadow: 0 4px 16px rgb(255 53 83 / 0.26);
  }
  .btn-primary:hover { background: var(--color-primary-hover); }
  .mf-order-flow .btn-outline {
    background: transparent;
    color: var(--color-heading);
    border: 2px solid var(--color-border);
  }

  .mf-order-flow .review-blocks {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.9rem;
    margin-bottom: 1rem;
  }
  .mf-order-flow .review-item {
    border: 1px solid var(--color-border);
    border-radius: 10px;
    background: var(--color-surface);
    padding: 0.85rem;
  }
  .mf-order-flow .review-item h4 {
    font-size: 0.84rem;
    font-weight: 800;
    color: var(--color-heading);
    display: flex;
    justify-content: space-between;
    gap: 0.7rem;
    margin-bottom: 0.4rem;
  }
  .mf-order-flow .edit-link {
    border: none;
    background: transparent;
    color: var(--color-primary);
    font-size: 0.73rem;
    font-weight: 700;
    cursor: pointer;
  }
  .review-item p { font-size: 0.83rem; color: var(--color-body); line-height: 1.45; }

  .mf-order-flow .total-box {
    border: 1px solid var(--color-border);
    border-radius: 10px;
    background: var(--color-surface-subtle);
    padding: 0.85rem;
    margin-bottom: 0.85rem;
  }
  .mf-order-flow .sum-row {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    font-size: 0.84rem;
    color: var(--color-body);
    margin-bottom: 0.45rem;
  }
  .sum-row:last-child { margin-bottom: 0; }
  .sum-row.total { font-size: 0.94rem; font-weight: 900; color: var(--color-heading); border-top: 1px solid var(--color-border); padding-top: 0.55rem; margin-top: 0.5rem; }
  .mf-order-flow .review-writing-not-selected {
    color: var(--color-primary);
    font-weight: 800;
  }

  .mf-order-flow .payment-layout {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr;
    gap: 1rem;
  }
  .mf-order-flow .payment-card, .mf-order-flow .summary-card {
    border: 1px solid var(--color-border);
    border-radius: 10px;
    background: var(--color-surface);
    padding: 0.95rem;
  }
  .summary-card { position: sticky; top: 90px; align-self: start; }
  .stripe-wrap { margin-top: 0.7rem; }
.mf-order-flow #payment-element { margin-bottom: 0.95rem; }
  .payment-msg { font-size: 0.82rem; margin-top: 0.5rem; color: var(--color-muted); }
  .payment-msg.error { color: #dc2626; font-weight: 600; }
  .payment-msg.ok { color: var(--color-success-strong); font-weight: 600; }

  .mf-order-flow .trust-row {
    margin-top: 0.95rem;
    border-top: 1px solid var(--color-border);
    padding-top: 0.8rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
  }
  .mf-order-flow .trust-pill {
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--color-muted);
    background: var(--color-surface-subtle);
    border: 1px solid var(--color-border);
    border-radius: 999px;
    padding: 0.28rem 0.6rem;
  }

  .mf-order-flow .alert {
    border: 1px solid var(--color-success-border);
    background: var(--color-success-bg);
    border-radius: 10px;
    padding: 0.65rem 0.75rem;
    font-size: 0.8rem;
    color: var(--color-success-strong);
    margin-bottom: 0.8rem;
    margin-top: 10px;
  }
  .mf-order-flow .error-line {
    margin-top: 0.3rem;
    color: #dc2626;
    font-size: 0.75rem;
    font-weight: 600;
  }

  @media (max-width: 900px) {
    .payment-layout { grid-template-columns: 1fr; }
    .summary-card { position: static; }
    .field-grid, .plan-grid, .option-grid, .review-blocks { grid-template-columns: 1fr; }
  }
  @media (max-width: 760px) {
    .steps { display: none; }
    .mobile-progress { display: flex; }
    .topbar-note { display: none; }
  }

.mf-order-flow .upsell-card { max-width: 900px; margin: 0 auto; background: linear-gradient(135deg, var(--color-promo-bg-from), var(--color-promo-bg-to)); border: 2px solid var(--color-promo-border); border-radius: 16px; padding: 1.5rem 2rem; display: flex; align-items: flex-start; gap: 1.5rem; flex-wrap: wrap; }
.mf-order-flow .upsell-icon-box { width: 52px; height: 52px; background: var(--color-promo-icon-bg); border: 1px solid var(--color-promo-border); border-radius: 12px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.mf-order-flow .upsell-icon-box svg { width: 26px; height: 26px; stroke: var(--color-promo-accent); fill: none; stroke-width: 1.75; stroke-linecap: round; stroke-linejoin: round; }
.mf-order-flow .upsell-left { display: flex; align-items: flex-start; gap: 1rem; flex: 1; min-width: 0; }
.mf-order-flow .upsell-copy h4 { font-size: 1rem; font-weight: 800; color: var(--color-heading); margin-bottom: 0.3rem; }
.mf-order-flow .upsell-copy p { font-size: 0.84rem; color: var(--color-muted); line-height: 1.55; margin: 0; }
.mf-order-flow .upsell-list { list-style: none; display: flex; flex-direction: column; gap: 0.45rem; margin-top: 0.9rem; padding: 0; }
.mf-order-flow .upsell-list li { display: flex; align-items: flex-start; gap: 0.5rem; font-size: 0.83rem; color: var(--color-body); line-height: 1.4; }
.mf-order-flow .upsell-list li::before { display: none; }
.mf-order-flow .upsell-list li .ptick { width: 16px; height: 16px; background: var(--color-success-bg); border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 1px; }
.mf-order-flow .upsell-list li .ptick svg { width: 9px; height: 9px; stroke: var(--color-success); fill: none; stroke-width: 3; stroke-linecap: round; stroke-linejoin: round; }
.mf-order-flow .upsell-clarity { margin-top: 0.85rem; font-size: 0.78rem; font-weight: 700; line-height: 1.45; color: var(--color-heading); background: var(--color-promo-icon-bg); border: 1px solid var(--color-promo-border); border-radius: 8px; padding: 0.6rem 0.7rem; }
.mf-order-flow .upsell-right { text-align: right; flex-shrink: 0; }
.mf-order-flow .upsell-amt { font-size: 2rem; font-weight: 900; color: var(--color-primary); line-height: 1.1; letter-spacing: -0.03em; }
.mf-order-flow .upsell-note { font-size: 0.75rem; color: var(--color-muted); margin-top: 0.25rem; }
.mf-order-flow .authority-toggle { display: flex; align-items: flex-start; gap: 1rem; cursor: pointer; width: 100%; margin: 0; }
.mf-order-flow .authority-toggle input { width: 1.25rem; height: 1.25rem; margin-top: 0.35rem; flex-shrink: 0; accent-color: var(--color-primary); }
