:root {
    --orange: #FF5E00;
    --orange-soft: #FFE9D9;
    --orange-deep: #E04F00;
    --blue: #346897;
    --blue-deep: #1F4970;
    --blue-soft: #E4EEF7;

    --bg: #FAFAF7;
    --surface: #FFFFFF;
    --surface-2: #F4F2EC;
    --ink: #0E1620;
    --ink-2: #2A323D;
    --muted: #6B7380;
    --line: rgba(14,22,32,0.08);
    --line-strong: rgba(14,22,32,0.14);

    --dark: #0E1620;
    --dark-2: #1A2330;

    --r-sm: 10px;
    --r-md: 16px;
    --r-lg: 24px;
    --r-xl: 32px;

    --shadow-sm: 0 1px 2px rgba(14,22,32,0.04), 0 2px 6px rgba(14,22,32,0.04);
    --shadow-md: 0 4px 12px rgba(14,22,32,0.06), 0 14px 36px rgba(14,22,32,0.06);
    --shadow-lg: 0 24px 60px -12px rgba(14,22,32,0.18), 0 8px 18px rgba(14,22,32,0.06);
    --shadow-orange: 0 14px 36px -8px rgba(255,94,0,0.45), 0 6px 14px rgba(255,94,0,0.18);
    --shadow-blue: 0 14px 36px -8px rgba(52,104,151,0.45), 0 6px 14px rgba(52,104,151,0.18);
    --nude: #F1ECE2;
    --nude-2: #E8E1D2;

    --container: 1200px;
  }

  *,*::before,*::after { box-sizing: border-box; }
  html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; scroll-behavior: smooth; }
  body {
    margin: 0;
    font-family: "Inter", system-ui, -apple-system, sans-serif;
    color: var(--ink);
    background: var(--bg);
    font-size: 16px;
    line-height: 1.55;
    overflow-x: hidden;
  }
  img { max-width: 100%; height: auto; display: block; }
  a { color: inherit; text-decoration: none; }
  button { font-family: inherit; cursor: pointer; border: 0; background: none; }

  h1,h2,h3,h4 { font-family: "Geist", "Inter", sans-serif; font-weight: 600; letter-spacing: -0.02em; margin: 0; line-height: 1.05; color: var(--ink); }
  h1 { font-size: clamp(40px, 6vw, 78px); font-weight: 700; letter-spacing: -0.035em; line-height: 0.98; }
  h2 { font-size: clamp(32px, 4.2vw, 56px); font-weight: 700; letter-spacing: -0.03em; line-height: 1.02; }
  h3 { font-size: clamp(22px, 2.2vw, 30px); font-weight: 600; }
  h4 { font-size: 18px; font-weight: 600; }
  p { margin: 0; color: var(--ink-2); }

  .mono { font-family: "Geist Mono", ui-monospace, monospace; font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted); }

  .container { max-width: var(--container); margin: 0 auto; padding: 0 24px; }
  .section { padding: 80px 0; position: relative; }
  .section-tight { padding: 80px 0; }

  /* ---------- BUTTONS ---------- */
  .btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 10px;
    padding: 14px 22px; border-radius: 999px; font-weight: 600; font-size: 15px;
    transition: transform .2s cubic-bezier(.2,.7,.3,1), box-shadow .25s, background .2s, color .2s;
    white-space: nowrap;
  }
  .btn:active { transform: translateY(1px); }
  .btn-primary { background: var(--orange); color: #fff; box-shadow: var(--shadow-orange);}
  .btn-primary:hover { background: var(--orange-deep); transform: translateY(-1px); }
  .btn-ghost { background: transparent; color: var(--ink); border: 1px solid var(--line-strong); }
  .btn-ghost:hover { background: var(--surface); border-color: var(--ink); }
  .btn-dark { background: var(--blue); color: #fff; }
  .btn-dark:hover { background: var(--blue-deep); transform: translateY(-1px); }
  .btn-lg { padding: 17px 28px; font-size: 16px; }

  .btn .arrow { transition: transform .2s; }
  .btn:hover .arrow { transform: translateX(3px); }

  /* ---------- STORE BUTTONS (custom redesign) ---------- */
  .store-row { display: flex; gap: 12px; flex-wrap: wrap; }
  .store-btn {
    display: inline-flex; align-items: center; gap: 12px;
    background: var(--ink); color: #fff;
    padding: 14px 24px;
    border-radius: 14px;
    transition: transform .2s, background .2s, box-shadow .25s;
    box-shadow: var(--shadow-sm);
    min-width: 200px;
    line-height: 1;
  }
  .store-btn:hover { background: #000; transform: translateY(-2px); box-shadow: var(--shadow-md);}
  .store-btn .ico { width: 28px; height: 28px; flex: 0 0 28px; display: block; color: #fff; }
  .store-btn .lbl { display: flex; flex-direction: column; gap: 3px; line-height: 1.1; }
  .store-btn .lbl .top { font-size: 11px; opacity: .75; letter-spacing: 0.04em; line-height: 1; }
  .store-btn .lbl .bot { font-size: 17px; font-weight: 600; letter-spacing: -0.01em; font-family: "Geist", sans-serif; line-height: 1.1; white-space: nowrap; }
  .store-btn.on-light { background: var(--blue); color: #fff; }
  .store-btn.on-orange { background: #fff; color: var(--ink); }
  .store-btn.on-orange:hover { background: #fff; }

  /* ---------- NAV ---------- */
  .nav-wrap { position: sticky; top: 0; z-index: 50; background: rgba(250,250,247,0.78); backdrop-filter: saturate(150%) blur(14px); border-bottom: 1px solid transparent; transition: border-color .2s, background .2s; }
  .nav-wrap.scrolled { border-color: var(--line); }
  .nav { display: flex; align-items: center; justify-content: space-between; padding: 16px 0; }
  .logo { display: flex; align-items: center; gap: 10px; font-family: "Geist", sans-serif; font-weight: 700; font-size: 17px; letter-spacing: -0.02em; }
  .logo-mark { width: 32px; height: 32px; border-radius: 9px; background: url("images/logo.jpg") center/cover no-repeat; }
  .nav-links { display: flex; gap: 28px; }
  .nav-links a { font-size: 14px; color: var(--ink-2); font-weight: 500; transition: color .2s; }
  .nav-links a:hover { color: var(--blue); }
  .nav-cta { display: flex; gap: 10px; align-items: center; }
  @media (max-width: 880px) {
    .nav-links { display: none; }
  }

  /* ---------- HERO ---------- */
  .hero { padding: 80px 0 140px; position: relative; overflow: hidden; }
  .hero::before {
    content: "";
    position: absolute;
    width: 800px; height: 800px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(52,104,151,0.18) 0%, rgba(52,104,151,0) 60%);
    top: -200px; right: -150px;
    pointer-events: none;
    z-index: 0;
  }
  .hero::after {
    content: "";
    position: absolute;
    width: 500px; height: 500px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(52,104,151,0.10) 0%, rgba(52,104,151,0) 60%);
    bottom: -200px; left: -100px;
    pointer-events: none;
    z-index: 0;
  }
  .hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: 1.1fr 1fr; gap: 60px; align-items: center; }
  .hero-eyebrow { display: inline-flex; align-items: center; gap: 8px; background: var(--surface); border: 1px solid var(--line); padding: 6px 12px; border-radius: 999px; font-size: 13px; font-weight: 500; color: var(--ink-2); margin-bottom: 24px; }
  .hero-eyebrow .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--blue); box-shadow: 0 0 0 4px rgba(52,104,151,0.18); }
  .hero h1 { margin-bottom: 22px; }
  .hero h1 .accent { color: var(--orange); }
  .hero-sub { font-size: 19px; color: var(--ink-2); max-width: 540px; margin-bottom: 32px; line-height: 1.45; }
  .hero-meta { display: flex; gap: 24px; flex-wrap: wrap; margin-top: 28px; padding-top: 28px; border-top: 1px solid var(--line); }
  .meta-item { display: flex; flex-direction: column; gap: 2px; }
  .meta-item .v { font-family: "Geist", sans-serif; font-size: 22px; font-weight: 700; color: var(--ink); letter-spacing: -0.02em; }
  .meta-item .l { font-size: 12px; color: var(--muted); }
  .hero-cta-row { display: flex; gap: 12px; flex-wrap: wrap; }

  /* Phone mock */
  .hero-phone-stage {
    position: relative;
    height: 620px;
    display: flex; align-items: center; justify-content: center;
  }
  .phone-frame {
    position: relative;
    width: 320px; height: 640px;
    background: var(--ink);
    border-radius: 50px;
    box-shadow: var(--shadow-lg), inset 0 0 0 2px rgba(255,255,255,0.06);
    padding: 14px;
    transform: rotate(-3deg);
    transition: transform .8s cubic-bezier(.2,.7,.3,1);
  }
  .phone-frame::before {
    content: "";
    position: absolute; top: 22px; left: 50%; transform: translateX(-50%);
    width: 110px; height: 28px; background: #000; border-radius: 14px;
    z-index: 2;
  }
  .phone-screen {
    width: 100%; height: 100%;
    background: #1a1a1a;
    border-radius: 38px;
    overflow: hidden;
    position: relative;
    display: flex; flex-direction: column;
  }
  .phone-screen-img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .phone-status { padding: 20px 24px 0; display: flex; justify-content: space-between; font-size: 11px; font-weight: 600; color: var(--ink); }
  .phone-status .right { display: flex; gap: 4px; align-items: center; }
  .phone-app-header { padding: 50px 22px 14px; }
  .phone-app-header .greet { font-size: 11px; color: var(--muted); }
  .phone-app-header .name { font-family: "Geist", sans-serif; font-size: 20px; font-weight: 700; color: var(--ink); margin-top: 2px; }
  .phone-stat-card {
    margin: 8px 22px 0;
    padding: 16px;
    background: #fff;
    border-radius: 18px;
    box-shadow: 0 6px 18px rgba(14,22,32,0.06);
  }
  .phone-stat-card .top { display: flex; justify-content: space-between; align-items: center; }
  .phone-stat-card .lbl { font-size: 11px; color: var(--muted); font-weight: 500; }
  .phone-stat-card .pill { font-size: 10px; font-weight: 600; color: #0a8043; background: rgba(10,128,67,0.1); padding: 3px 8px; border-radius: 999px; }
  .phone-stat-card .val { font-family: "Geist", sans-serif; font-weight: 700; font-size: 28px; color: var(--ink); margin-top: 6px; letter-spacing: -0.02em; }
  .phone-stat-card .sub { font-size: 11px; color: var(--muted); margin-top: 2px; }
  .phone-spark {
    height: 36px;
    margin-top: 10px;
    background: linear-gradient(180deg, rgba(52,104,151,0.18) 0%, rgba(52,104,151,0) 100%);
    border-radius: 6px;
    position: relative;
  }
  .phone-spark::before {
    content: "";
    position: absolute; inset: 0;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 40' preserveAspectRatio='none'><polyline fill='none' stroke='%23FF5E00' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round' points='0,30 20,26 40,28 60,18 80,22 100,12 120,16 140,8 160,14 180,4 200,10'/></svg>") no-repeat;
    background-size: 100% 100%;
  }

  .phone-orders { padding: 20px 22px 0; flex: 1; display: flex; flex-direction: column; gap: 10px; }
  .phone-orders .head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 4px; }
  .phone-orders .head .t { font-family: "Geist", sans-serif; font-weight: 600; font-size: 14px; }
  .phone-orders .head .c { font-size: 11px; color: var(--muted); }
  .order-row {
    background: #fff;
    border-radius: 14px;
    padding: 12px 14px;
    display: flex; justify-content: space-between; align-items: center;
    box-shadow: 0 2px 8px rgba(14,22,32,0.04);
  }
  .order-row .l .t { font-family: "Geist", sans-serif; font-weight: 600; font-size: 13px; color: var(--ink); }
  .order-row .l .s { font-size: 11px; color: var(--muted); margin-top: 2px; }
  .order-row .r { text-align: right; }
  .order-row .r .price { font-family: "Geist", sans-serif; font-weight: 700; font-size: 14px; color: var(--ink); }
  .order-row .r .badge { display: inline-block; margin-top: 3px; font-size: 9px; font-weight: 600; padding: 2px 6px; border-radius: 4px; letter-spacing: 0.04em; text-transform: uppercase; }
  .badge-paid { background: rgba(10,128,67,0.12); color: #0a8043; }
  .badge-new { background: rgba(52,104,151,0.14); color: var(--blue); }
  .badge-prep { background: rgba(52,104,151,0.14); color: var(--blue); }

  .phone-floating {
    position: absolute;
    bottom: 70px;
    right: -30px;
    background: #fff;
    border-radius: 14px;
    padding: 12px 14px;
    box-shadow: var(--shadow-md);
    display: flex; align-items: center; gap: 10px;
    transform: rotate(4deg);
    z-index: 3;
    width: 200px;
  }
  .phone-floating .icon { width: 36px; height: 36px; border-radius: 10px; background: var(--blue-soft); display: grid; place-items: center; flex: 0 0 36px; color: var(--blue); }
  .phone-floating .t { font-family: "Geist", sans-serif; font-weight: 600; font-size: 13px; color: var(--ink); }
  .phone-floating .s { font-size: 11px; color: var(--muted); margin-top: 1px; }

  .phone-floating-2 {
    position: absolute;
    top: 50px;
    left: -10px;
    background: var(--ink);
    color: #fff;
    border-radius: 14px;
    padding: 12px 14px 12px 12px;
    box-shadow: var(--shadow-md);
    display: flex; align-items: center; gap: 10px;
    transform: rotate(-5deg);
    z-index: 3;
    width: 190px;
  }
  .phone-floating-2 .ic { width: 32px; height: 32px; border-radius: 10px; background: var(--blue); display: grid; place-items: center; flex: 0 0 32px; }
  .phone-floating-2 .t { font-family: "Geist", sans-serif; font-weight: 700; font-size: 14px; }
  .phone-floating-2 .s { font-size: 11px; opacity: 0.7; margin-top: 1px; }

  @media (max-width: 920px) {
    .hero-grid { grid-template-columns: 1fr; }
    .hero-phone-stage { height: 540px;  }
    .phone-frame { --phone-scale: 0.8; }
    .phone-floating { right: 10px; }
    .phone-floating-2 { left: 10px; }
  }

  /* ---------- LOGOS / SOCIAL PROOF ---------- */
  .proof { padding: 50px 0; border-top: 1px solid var(--line); }
  .proof-row { display: flex; align-items: center; justify-content: center; gap: 24px; flex-wrap: wrap; }
  .proof-label { font-size: 24px; color: var(--black); font-weight: 500; }
  .proof-stats { display: flex; gap: 14px; flex-wrap: wrap; }
  .proof-stat {
    background: linear-gradient(135deg, var(--blue-soft) 0%, #F4F2EC 100%);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 20px 32px;
    box-shadow: 0 1px 2px rgba(14,22,32,0.04);
    display: flex; flex-direction: column; gap: 4px; min-width: 140px;
  }
  .proof-stat .v { font-family: "Geist", sans-serif; font-size: 26px; font-weight: 700; color: var(--ink); letter-spacing: -0.02em; }
  .proof-stat .v .accent { color: var(--blue); }
  .proof-stat .l { font-size: 12px; color: var(--muted); }
@media (max-width: 880px) {
  .proof-stat {
    padding: 12px 24px;
  }
}

  /* ---------- SECTION HEADERS ---------- */
  .sec-head { max-width: 760px; margin-bottom: 24px; }
  .sec-head.center { margin: 0 auto 56px; text-align: center; }
  .sec-head .eyebrow {
    display: inline-flex; align-items: center; gap: 8px;
    font-family: "Geist Mono", monospace; text-transform: uppercase;
    font-size: 12px; letter-spacing: 0.1em; color: var(--blue); font-weight: 500;
    margin-bottom: 16px;
  }
  .sec-head .eyebrow::before { content: ""; width: 24px; height: 1px; background: var(--blue); }
  .sec-head h2 { margin-bottom: 16px; }
  .sec-head .lede { font-size: 18px; color: var(--ink-2); max-width: 620px; }
  .sec-head.center .lede { margin-left: auto; margin-right: auto; }
  .sec-head.center .eyebrow::before { display: none; }

  /* ---------- FREE TIER ---------- */
  .free-tier { background: var(--surface); border-radius: var(--r-xl); padding: 64px; border: 1px solid var(--line); position: relative; overflow: hidden; }
  .free-tier::before { content: ""; position: absolute; right: -100px; top: -100px; width: 320px; height: 320px; border-radius: 50%; background: radial-gradient(circle, rgba(52,104,151,0.10) 0%, rgba(52,104,151,0) 70%); }
  .free-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 60px; align-items: center; position: relative; z-index: 1; }
  .free-features { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 32px; margin: 32px 0; }
  .free-feature { display: flex; align-items: center; gap: 10px; font-size: 15px; color: var(--ink); font-weight: 500; }
  .free-feature .check { width: 22px; height: 22px; border-radius: 50%; background: var(--blue); display: grid; place-items: center; flex: 0 0 22px; }
  .commission-card {
    background: linear-gradient(135deg, var(--nude) 0%, var(--nude-2) 100%);
    color: #fff; border-radius: var(--r-lg); padding: 40px; text-align: center;
    position: relative; overflow: hidden;
  }
  .commission-card::before {
    content: "";
    position: absolute; bottom: -60px; right: -60px;
    width: 220px; height: 220px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(52,104,151,0.4) 0%, rgba(52,104,151,0) 70%);
  }
  .commission-card .label { font-family: "Geist Mono", monospace; font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); margin-bottom: 12px; }
  .commission-card .num {
    font-family: "Geist", sans-serif; font-weight: 700;
    font-size: clamp(80px, 10vw, 130px);
    line-height: 0.9; letter-spacing: -0.05em;
    color: var(--blue);
    position: relative; z-index: 1;
  }
  .commission-card .desc { font-size: 14px; color: var(--ink-2); margin-top: 12px; position: relative; z-index: 1; }
  .commission-card .free-trial { margin-top: 18px; padding: 10px; background: rgba(14,22,32,0.05); border-radius: 10px; font-size: 12px; color: var(--ink); position: relative; z-index: 1; border: 1px solid rgba(14,22,32,0.08); }
  .commission-card .free-trial b { color: var(--blue); }

  @media (max-width: 880px) {
    .free-tier { padding: 32px; }
    .free-grid { grid-template-columns: 1fr; gap: 32px; }
    .free-features { grid-template-columns: 1fr; }
  }

  /* ---------- FEATURE GRID ---------- */
  .feature-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
  .feature-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--r-lg);
    padding: 28px;
    transition: transform .25s, box-shadow .25s, border-color .2s;
    position: relative;
    overflow: hidden;
  }
  .feature-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: var(--line-strong); }
  .feature-card .ic-wrap {
    width: 48px; height: 48px; border-radius: 12px;
    display: grid; place-items: center;
    flex: 0 0 48px;
  }
  .feature-card .ic-row { display: flex; align-items: center; gap: 14px; margin-bottom: 12px; }
  .feature-card .ic-row h4 { margin: 0; font-size: 19px; font-family: "Geist", sans-serif; font-weight: 600; }
  .feature-grid > .feature-card:nth-child(1) .ic-wrap { background: #E4EEF7; color: #346897; }
  .feature-grid > .feature-card:nth-child(2) .ic-wrap { background: #DDEDEC; color: #2C8C8A; }
  .feature-grid > .feature-card:nth-child(3) .ic-wrap { background: #F6E6D2; color: #C97A1F; }
  .feature-grid > .feature-card:nth-child(4) .ic-wrap { background: #F4DDE3; color: #B85770; }
  .feature-grid > .feature-card:nth-child(5) .ic-wrap { background: #E5E1F2; color: #6B5BA8; }
  .feature-grid > .feature-card:nth-child(6) .ic-wrap { background: #DEEBDD; color: #5C8C5A; }
  .feature-card h4 { font-size: 19px; font-family: "Geist", sans-serif; font-weight: 600; margin-bottom: 8px; }
  .feature-card p { font-size: 14px; color: var(--muted); line-height: 1.5; }

  @media (max-width: 880px) { .feature-grid { grid-template-columns: 1fr; } }

  /* ---------- POS DARK SECTION ---------- */
  .dark-section { background: var(--nude); color: var(--ink); padding: 120px 0; position: relative; overflow: hidden; }
  .dark-section h2, .dark-section h3, .dark-section h4 { color: var(--ink); }
  .dark-section .sec-head .eyebrow { color: var(--blue); }
  .dark-section .sec-head .lede { color: var(--ink-2); }
  .dark-section p { color: var(--ink-2); }
  .dark-section::before {
    content: "";
    position: absolute;
    top: 50%; left: -200px;
    width: 500px; height: 500px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(52,104,151,0.18) 0%, rgba(52,104,151,0) 60%);
    transform: translateY(-50%);
  }
  .pos-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 80px; align-items: center; position: relative; z-index: 1; }
  .pos-features { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 24px; margin-top: 32px; }
  .pos-feature { display: flex; align-items: center; gap: 10px; font-size: 18px; color: var(--ink); }
  .pos-feature .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--blue); }
  .pos-mock {
    position: relative;
  }
  .pos-mock-stack { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin: 0 auto; }
  .pos-mock-stack img { width: 100%; height: auto; border-radius: 16px; display: block; box-shadow: 0 8px 24px rgba(0,0,0,0.25); }
  @media (max-width: 880px) { .pos-mock-stack { display: flex; flex-direction: row; gap: 12px; max-width: none; } .pos-mock-stack img { flex: 1 1 0; min-width: 0; } }
  .pos-mock-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; padding-bottom: 16px; border-bottom: 1px solid rgba(255,255,255,0.08); }
  .pos-mock-head .left { display: flex; align-items: center; gap: 10px; }
  .pos-mock-head .av { width: 36px; height: 36px; border-radius: 50%; background: var(--blue); display: grid; place-items: center; font-weight: 700; font-size: 13px; color: #fff; }
  .pos-mock-head .nm { font-family: "Geist", sans-serif; font-weight: 600; font-size: 14px; color: #fff; }
  .pos-mock-head .rl { font-size: 11px; color: rgba(255,255,255,0.55); }
  .pos-tile-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
  .pos-tile {
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: 14px;
    padding: 16px;
    transition: background .2s, border-color .2s;
  }
  .pos-tile:hover { background: rgba(52,104,151,0.08); border-color: rgba(52,104,151,0.3); }
  .pos-tile .lb { font-size: 11px; color: rgba(255,255,255,0.5); }
  .pos-tile .vl { font-family: "Geist", sans-serif; font-size: 24px; font-weight: 700; margin-top: 4px; color: #fff; letter-spacing: -0.02em; }
  .pos-tile .vl .accent { color: var(--blue); }
  .pos-tile .sb { font-size: 11px; color: rgba(255,255,255,0.5); margin-top: 4px; }

  .pos-table-list { margin-top: 16px; }
  .pos-table-row { display: flex; justify-content: space-between; align-items: center; padding: 12px 0; border-bottom: 1px solid rgba(255,255,255,0.05); }
  .pos-table-row:last-child { border-bottom: none; }
  .pos-table-row .left { display: flex; align-items: center; gap: 12px; }
  .pos-table-row .num { width: 32px; height: 32px; border-radius: 8px; background: rgba(52,104,151,0.14); color: var(--blue); display: grid; place-items: center; font-family: "Geist", sans-serif; font-weight: 700; font-size: 13px; }
  .pos-table-row .tt { font-family: "Geist", sans-serif; font-size: 14px; color: #fff; }
  .pos-table-row .ts { font-size: 11px; color: rgba(255,255,255,0.5); margin-top: 1px; }
  .pos-table-row .price { font-family: "Geist", sans-serif; font-weight: 700; font-size: 15px; color: #fff; }
  .pos-table-row .st { font-size: 10px; padding: 2px 8px; border-radius: 999px; }
  .st-active { background: rgba(10,128,67,0.18); color: #34D399; }
  .st-pending { background: rgba(52,104,151,0.18); color: var(--blue); }

  @media (max-width: 880px) {
    .dark-section { padding: 72px 0; }
    .pos-grid { display: flex; flex-direction: column; gap: 32px; align-items: stretch; }
    .pos-features { display: flex; flex-direction: column; gap: 12px; }
    .pos-tile-row { display: flex; flex-direction: column; gap: 12px; }
  }

  /* ---------- VENUES / BUILT-FOR ---------- */
  .venue-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
  .venue-card {
    aspect-ratio: 1.05;
    border-radius: var(--r-md);
    background: var(--surface);
    border: 1px solid var(--line);
    padding: 20px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    position: relative;
    overflow: hidden;
    transition: transform .25s, box-shadow .25s;
    cursor: pointer;
  }
  .venue-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
  .venue-card .glyph {
    width: 100%; aspect-ratio: 1.4 / 1;
    border-radius: 14px;
    overflow: hidden; flex: 0 0 auto;
    margin-bottom: 14px;
  }
  .venue-card .glyph img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .venue-card .name { font-family: "Geist", sans-serif; font-size: 17px; font-weight: 600; }
  .venue-card .meta { font-size: 12px; color: var(--muted); margin-top: 2px; }

  @media (max-width: 880px) {
    .venue-grid { grid-template-columns: repeat(2, 1fr); }
  }

  /* ---------- 2-COLUMN FEATURE BLOCK ---------- */
  .feat-block { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
  .feat-block.reverse > :first-child { order: 2; }
  .feat-block .visual { position: relative; }
  .feat-block .visual .img-wrap {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .feat-block .visual .img-wrap img { max-width: 100%; height: auto; display: block; }
  .feat-block .visual .img-wrap.placeholder {
    background:
      repeating-linear-gradient(45deg, var(--surface-2) 0 12px, #ECEAE3 12px 24px);
    display: grid; place-items: center;
    color: var(--muted);
    font-family: "Geist Mono", monospace;
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
  }
  .feat-bullets { margin-top: 24px; display: grid; gap: 12px; }
  .feat-bullet { display: flex; gap: 14px; align-items: flex-start; }
  .feat-bullet .ic { width: 28px; height: 28px; border-radius: 8px; background: var(--blue-soft); color: var(--blue); display: grid; place-items: center; flex: 0 0 28px; margin-top: 1px; }
  .feat-bullet .t { font-family: "Geist", sans-serif; font-weight: 600; font-size: 15px; color: var(--ink); }
  .feat-bullet .s { font-size: 13px; color: var(--muted); margin-top: 2px; }

  @media (max-width: 880px) {
    .feat-block { grid-template-columns: 1fr; gap: 40px; }
    .feat-block.reverse > :first-child { order: 2; }
    .feat-block .visual.branded .img-wrap {
      max-width: 80%;
      margin: auto;
    }
  }

  /* ---------- 3-COL EXPERIENCE ---------- */
  .exp-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
  .exp-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--r-lg);
    overflow: hidden;
    transition: transform .25s, box-shadow .25s;
  }
  .exp-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
  .exp-card .img {
    aspect-ratio: 4/3;
    background: var(--surface-2);
    background:
      repeating-linear-gradient(135deg, var(--surface-2) 0 14px, #ECEAE3 14px 28px);
    display: grid; place-items: center;
    color: var(--muted);
    font-family: "Geist Mono", monospace;
    font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase;
    position: relative;
  }
  .exp-card .img.real { background: none; padding: 0; }
  .exp-card .img.real img { width: 100%; height: 100%; object-fit: cover; }
  .exp-card .body { padding: 24px; }
  .exp-card .body h3 { font-size: 22px; margin-bottom: 8px; font-family: "Geist", sans-serif; }
  .exp-card .body p { font-size: 14px; color: var(--muted); }
  @media (max-width: 880px) { .exp-grid { grid-template-columns: 1fr; } }

  /* ---------- STEPS ---------- */
  .steps-section { background: var(--nude); color: var(--ink); padding: 120px 0; position: relative; overflow: hidden; }
  .steps-section::before {
    content: "";
    position: absolute; top: -200px; right: -200px;
    width: 600px; height: 600px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(52,104,151,0.18) 0%, rgba(52,104,151,0) 60%);
  }
  .steps-section h2, .steps-section h3, .steps-section h4 { color: var(--ink); }
  .steps-section .sec-head .lede { color: var(--ink-2); }
  .steps-section .sec-head .eyebrow { color: var(--blue); }
  .steps-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; position: relative; z-index: 1; }
  .step-card {
    border: 1px solid var(--line);
    border-radius: var(--r-md);
    padding: 28px 22px;
    position: relative;
    transition: transform .25s, box-shadow .25s;
    color: var(--ink);
  }
  .step-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
  .step-card .num {
    font-family: "Geist", sans-serif;
    font-weight: 700;
    font-size: 32px;
    color: var(--blue);
    line-height: 1;
    letter-spacing: -0.03em;
    margin-bottom: 22px;
  }
  .step-card .ic {
    width: 40px; height: 40px; border-radius: 12px;
    background: rgba(255,255,255,0.55); color: var(--blue);
    display: grid; place-items: center;
    margin-bottom: 18px;
  }
  .step-card h4 { color: var(--ink); font-size: 16px; }
  .steps-grid > .step-card:nth-child(1) { background: #F4EFE6; }
  .steps-grid > .step-card:nth-child(2) { background: #E8E8E7; }
  .steps-grid > .step-card:nth-child(3) { background: #DDE2E8; }
  .steps-grid > .step-card:nth-child(4) { background: #C7D3DD; }
  .steps-grid > .step-card:nth-child(5) { background: #B0C0CE; }
  .step-cta { margin-top: 48px; display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; }
  @media (max-width: 980px) {
    .steps-grid { grid-template-columns: repeat(2, 1fr); }
  }

  /* ---------- PRICING ---------- */
  .pricing-grid { display: flex; justify-content: center; }
  .pricing-grid > .price-card { width: 100%; }
  .price-card {
    background: transparent;
    border: 0;
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    border-radius: 0;
    padding: 64px 40px;
    position: relative;
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: 18px;
  }
  .price-card.feat {
    border-top: 2px solid var(--blue);
    border-bottom: 2px solid var(--blue);
    box-shadow: none;
  }
  .price-card .pop {
    position: absolute; top: -14px; left: 50%; transform: translateX(-50%);
    background: var(--blue); color: #fff;
    padding: 6px 14px; border-radius: 999px;
    font-size: 11px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase;
  }
  .price-card .name { font-family: "Geist", sans-serif; font-size: 14px; font-weight: 600; color: var(--muted); text-transform: uppercase; letter-spacing: 0.08em; }
  .price-card .head { font-family: "Geist", sans-serif; font-weight: 700; font-size: 36px; letter-spacing: -0.03em; line-height: 1.15; }
  .price-card .head .accent { color: var(--blue); }
  .price-card .head .unit { font-size: 18px; color: var(--muted); font-weight: 500; letter-spacing: 0; }
  .price-card .small { font-size: 13px; color: var(--muted); }
  .price-card hr { border: 0; border-top: 1px solid var(--line); margin: 0; width: 100%; }
  .price-card .feat-title { font-size: 14px; font-weight: 600; color: var(--ink); }
  .price-feats-wrap { display: flex; justify-content: center; }
  .price-feats { display: grid; gap: 10px; justify-items: start; }
  .price-feat { display: flex; align-items: center; gap: 10px; font-size: 14px; color: var(--ink-2); justify-content: flex-start; }
  .price-feat .ck { width: 18px; height: 18px; border-radius: 50%; background: var(--blue); display: grid; place-items: center; flex: 0 0 18px; }
  .price-cta { display: inline-flex; align-self: center; }

  .modules { margin-top: 24px; display: grid; gap: 12px; }
  .module-row {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--r-md);
    padding: 18px 20px;
    display: grid;
    grid-template-columns: 36px 1fr auto;
    gap: 16px; align-items: center;
  }
  .module-row .mc { width: 36px; height: 36px; border-radius: 10px; background: var(--blue-soft); color: var(--blue); display: grid; place-items: center; }
  .module-row .mt { font-family: "Geist", sans-serif; font-weight: 600; font-size: 15px; }
  .module-row .ms { font-size: 12px; color: var(--muted); margin-top: 2px; }
  .module-row .mp { font-family: "Geist", sans-serif; font-weight: 700; font-size: 16px; color: var(--ink); text-align: right; }
  .module-row .mp .free { display: block; font-size: 11px; font-weight: 500; color: #0a8043; margin-top: 2px; text-transform: uppercase; letter-spacing: 0.04em; }

  @media (max-width: 880px) {
    .pricing-grid { grid-template-columns: 1fr; }
    .pricing-grid > .price-card { max-width: 620px; }
    .price-card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-xl); padding: 40px 24px; text-align: left; gap: 12px; }
    .price-card.feat { border: 2px solid var(--blue); box-shadow: var(--shadow-md); }
    .price-card .pop { left: 24px; transform: none; }
    .price-card .head { font-size: 28px; }
    .price-card .head .unit { font-size: 15px; }
    .price-cta { width: 100%; align-self: stretch; justify-content: center; }
    .price-feats-wrap { justify-content: flex-start; }
  }

  /* ---------- HARDWARE ---------- */
  .hw-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
  .hw-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--r-md);
    padding: 24px;
    text-align: center;
    transition: transform .25s, box-shadow .25s;
  }
  .hw-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
  .hw-card .ic { width: 56px; height: 56px; margin: 0 auto 16px; border-radius: 14px; background: var(--blue-soft); color: var(--blue); display: grid; place-items: center; }
  .hw-card.alt .ic { background: var(--blue-soft); color: var(--blue); }
  .hw-card h4 { font-size: 15px; font-family: "Geist", sans-serif; }
  .hw-card p { font-size: 12px; color: var(--muted); margin-top: 4px; }
  @media (max-width: 880px) { .hw-grid { grid-template-columns: repeat(2, 1fr); } }

  /* ---------- FINAL CTA ---------- */
  .final-cta {
    background: linear-gradient(135deg, var(--blue) 0%, var(--blue-deep) 100%);
    color: #fff; border-radius: var(--r-xl); padding: 80px;
    position: relative; overflow: hidden;
    text-align: center;
  }
  .final-cta::before, .final-cta::after {
    content: "";
    position: absolute;
    border-radius: 50%;
    background: rgba(255,255,255,0.08);
    pointer-events: none;
  }
  .final-cta::before { width: 400px; height: 400px; top: -200px; right: -100px; }
  .final-cta::after { width: 300px; height: 300px; bottom: -150px; left: -50px; }
  .final-cta h2, .final-cta h3 { color: #fff; position: relative; z-index: 1; }
  .final-cta p { color: rgba(255,255,255,0.9); position: relative; z-index: 1; max-width: 580px; margin: 16px auto 32px; font-size: 18px; }
  .final-cta .store-row { justify-content: center; position: relative; z-index: 1; }
  .final-cta .store-btn { background: var(--ink); color: #fff; }
  .final-cta .store-btn:hover { background: #000; box-shadow: 0 14px 36px rgba(0,0,0,0.18); }
  @media (max-width: 880px) { .final-cta { padding: 48px 28px; } }

  /* ---------- CONTACT ---------- */
  .contact-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 60px; align-items: start; }
  .contact-info { display: grid; gap: 20px; }
  .contact-row {
    display: grid; grid-template-columns: 40px 1fr; gap: 16px; align-items: center;
    padding: 8px 0;
  }
  .contact-row .ic { width: 40px; height: 40px; border-radius: 10px; background: var(--blue-soft); color: var(--blue); display: grid; place-items: center; }
  .contact-row .lb { font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.06em; font-weight: 500; }
  .contact-row .vl { font-family: "Geist", sans-serif; font-size: 15px; font-weight: 500; color: var(--ink); margin-top: 2px; word-break: break-word; }

  .form-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--r-xl);
    padding: 36px;
  }
  .form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
  .form-grid .full { grid-column: 1 / -1; }
  .field label { display: block; font-size: 12px; font-weight: 500; color: var(--muted); margin-bottom: 6px; text-transform: uppercase; letter-spacing: 0.06em; }
  .field input, .field textarea, .field select {
    width: 100%;
    background: var(--bg);
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 12px 14px;
    font-size: 14px;
    font-family: inherit;
    color: var(--ink);
    transition: border-color .2s, background .2s;
  }
  .field input:focus, .field textarea:focus, .field select:focus {
    outline: none; border-color: var(--blue); background: #fff;
  }
  .field textarea { resize: vertical; min-height: 100px; }
  .form-card button { margin-top: 8px; width: 100%; }
  @media (max-width: 880px) {
    .contact-grid { grid-template-columns: 1fr; gap: 12px }
    .form-grid { grid-template-columns: 1fr; }
  }

  /* ---------- FOOTER ---------- */
  footer { padding: 60px 0 40px; border-top: 1px solid var(--line);   }
  .foot-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 40px; }
  .foot-grid h5 { font-family: "Geist", sans-serif; font-size: 13px; font-weight: 600; color: var(--ink); text-transform: uppercase; letter-spacing: 0.08em; margin: 0 0 16px; }
  .foot-grid ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
  .foot-grid a { font-size: 14px; color: var(--ink-2); transition: color .2s; }
  .foot-grid a:hover { color: var(--blue); }
  .foot-grid a.store-btn { color: #fff; }
  .foot-grid a.store-btn:hover { color: #fff; }
  .foot-bottom { display: flex; justify-content: space-between; align-items: center; padding-top: 24px; border-top: 1px solid var(--line); flex-wrap: wrap; gap: 16px; font-size: 13px; color: var(--muted); }
  .foot-bottom .legal { font-size: 11px; max-width: 480px; }
  @media (max-width: 880px) { .foot-grid { grid-template-columns: 1fr 1fr; } }

  /* ---------- ANIMATION (reveal on scroll) ---------- */
  .reveal { opacity: 0; transform: translateY(30px); transition: opacity .8s cubic-bezier(.2,.7,.3,1), transform .8s cubic-bezier(.2,.7,.3,1); }
  .reveal.in { opacity: 1; transform: translateY(0); }
  .reveal.delay-1 { transition-delay: 0.08s; }
  .reveal.delay-2 { transition-delay: 0.16s; }
  .reveal.delay-3 { transition-delay: 0.24s; }
  .reveal.delay-4 { transition-delay: 0.32s; }

  @media (prefers-reduced-motion: reduce) {
    .reveal { opacity: 1; transform: none; }
    html { scroll-behavior: auto; }
  }

  /* ---------- ANALYTICS ---------- */
  .analytics-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
  .analytics-grid > .exp-card { display: flex; flex-direction: column; }
  .analytics-grid > .exp-card .img.real {
    display: block;
    width: 100%;
    height: clamp(240px, 26vw, 360px);
    aspect-ratio: auto;
    flex: 0 0 auto;
    overflow: hidden;
  }
  .analytics-grid > .exp-card .img.real img { width: 100%; height: 100%; object-fit: contain; display: block; }
  .analytics-grid > .exp-card .body { flex: 1; }
  @media (max-width: 880px) {
    .analytics-grid { grid-template-columns: 1fr; }
    .analytics-grid > .exp-card .img.real { height: 220px; }
  }

  /* ---------- VENUE CARD MOBILE ---------- */
  @media (max-width: 880px) {
    .venue-card { aspect-ratio: auto; padding: 16px; }
    .venue-card .glyph { aspect-ratio: 1.6 / 1; margin-bottom: 12px; }
    .venue-card .name { font-size: 15px; }
    .venue-card .meta { font-size: 11px; }
  }

  /* ---------- PAYMENT CARD MOBILE ---------- */
  @media (max-width: 880px) {
    #payments .pos-grid > div:last-child > div { padding: 28px !important; }
  }
