/* SNOWBOT Landing Page — fonts */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('../fonts/PlusJakartaSans-300.woff2') format('woff2');
}

@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/PlusJakartaSans-400.woff2') format('woff2');
}

@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/PlusJakartaSans-500.woff2') format('woff2');
}

@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/PlusJakartaSans-600.woff2') format('woff2');
}

@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('../fonts/PlusJakartaSans-700.woff2') format('woff2');
}

@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url('../fonts/PlusJakartaSans-800.woff2') format('woff2');
}

@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/JetBrainsMono-400.woff2') format('woff2');
}

@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/JetBrainsMono-500.woff2') format('woff2');
}

@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/JetBrainsMono-600.woff2') format('woff2');
}

/* SNOWBOT Landing Page — styles */
:root {
      --green:      #F47820;
      --green-h:    #F5922E;
      --green-dim:  rgba(244,120,32,.12);
      --green-glow: rgba(244,120,32,.22);
      --btn-bg:   linear-gradient(135deg, #E05020 0%, #F5A020 100%);
      --btn-bg-h: linear-gradient(135deg, #E86030 0%, #F5B030 100%);
      --d:   #0a0a0a;
      --d1:  #111111;
      --d2:  #161616;
      --d3:  #1c1c1c;
      --bd:  #252525;
      --bd2: #333333;
      --t1:  #f0f0f0;
      --t2:  #999999;
      --t3:  #555555;
      --lb:  #f8f9fa;
      --lt:  #0f1d33;
      --lt2: #445570;
      --lbd: #e2e8f0;
      --font: "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;
      --mono: "JetBrains Mono", monospace;
      --max: 1280px;
      --r: 10px; --rl: 16px; --rs: 6px; --pill: 9999px;
      --ease: cubic-bezier(.2,0,0,1);
      --sec-py: 96px;
      --hero-min: calc(100vh - 64px);
    }
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; }
    body { font-family: var(--font); background: var(--d); color: var(--t1); line-height: 1.6; -webkit-font-smoothing: antialiased; overflow-x: hidden; }
    img { max-width: 100%; height: auto; display: block; }
    a { color: inherit; text-decoration: none; }
    ul { list-style: none; }
    .g { color: var(--green); }

    /* Layout */
    .wrap   { max-width: var(--max); margin: 0 auto; padding: 0 48px; }
    .sec    { padding: var(--sec-py) 0; }
    .sec-d  { background: var(--d);  }
    .sec-d1 { background: var(--d1); }
    .sec-lt { background: var(--lb); color: var(--lt); }
    .sec-gr { background: var(--btn-bg); color: #fff; }

    /* Type */
    .eyebrow { display: inline-flex; align-items: center; gap: 8px; font-size: 11px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--green); margin-bottom: 20px; }
    .eyebrow::after { content: ''; width: 28px; height: 1.5px; background: var(--green); display: block; }
    .stitle  { font-size: clamp(1.75rem,3.5vw,2.75rem); font-weight: 800; line-height: 1.15; letter-spacing: -.025em; color: var(--t1); text-wrap: pretty; }
    .stitle-gr { color: var(--green); }
    .ssub { font-size: 1.0625rem; color: var(--t2); line-height: 1.7; max-width: 600px; margin-top: 12px; }

    /* Buttons */
    .btn    { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font); font-weight: 600; letter-spacing: .02em; border: none; cursor: pointer; text-decoration: none; white-space: nowrap; border-radius: var(--rs); transition: background .2s var(--ease), color .2s var(--ease), border-color .2s var(--ease); }
    .btn-p  { background: var(--btn-bg); color: #fff; font-size: 13.5px; padding: 0 20px; height: 40px; }
    .btn-p:hover { background: var(--btn-bg-h); }
    .btn-pl { font-size: 15px; padding: 0 32px; height: 50px; }

    /* Nav */
    .nav { position: sticky; top: 0; z-index: 200; background: rgba(10,10,10,.94); backdrop-filter: blur(12px); border-bottom: 1px solid var(--bd); height: 64px; display: flex; align-items: center; }
    .nav-in { max-width: var(--max); width: 100%; margin: 0 auto; padding: 0 48px; display: flex; align-items: center; gap: 32px; }
    .nav-logo { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
    .nav-mark { width: 28px; height: 28px; }
    .nav-word { font-size: 22px; font-weight: 600; letter-spacing: -.01em; color: #fff; }
    .nav-mark { width: 32px; height: 32px; }
    /* Nav dropdowns */
    .nav-links { display: flex; align-items: stretch; gap: 0; flex: 1; justify-content: center; }
    .nav-item  { position: relative; display: flex; align-items: center; }
    .nav-link  { display: flex; align-items: center; gap: 3px; height: 64px; padding: 0 11px; font-size: 13px; font-weight: 500; color: var(--t2); background: none; border: none; cursor: pointer; font-family: var(--font); white-space: nowrap; transition: color .18s; text-decoration: none; }
    .nav-link:hover, .nav-item:hover > .nav-link, .nav-item.open > .nav-link { color: #fff; }
    .nav-chev { transition: transform .18s var(--ease); flex-shrink: 0; }
    .nav-item:hover > .nav-link .nav-chev, .nav-item.open > .nav-link .nav-chev { transform: rotate(180deg); }
    .nav-drop { position: absolute; top: calc(100% + 6px); left: -16px; background: #fbfbf9; border: 1px solid rgba(0,0,0,.05); border-radius: 22px; padding: 28px 34px; min-width: 320px; z-index: 300; box-shadow: 0 28px 70px rgba(0,0,0,.32); opacity: 0; visibility: hidden; pointer-events: none; transform: translateY(4px); transition: opacity .16s var(--ease), transform .16s var(--ease), visibility 0s .16s; }
    .nav-item:hover > .nav-drop, .nav-item.open > .nav-drop { opacity: 1; visibility: visible; pointer-events: auto; transform: translateY(0); transition: opacity .16s var(--ease), transform .16s var(--ease); }
    .nav-drop::before { content: ''; position: absolute; bottom: 100%; left: 0; right: 0; height: 14px; }
    .nav-drop.centered { left: 50%; transform: translateX(-50%) translateY(4px); }
    .nav-item:hover > .nav-drop.centered, .nav-item.open > .nav-drop.centered { transform: translateX(-50%) translateY(0); }
    .nav-drop-wide { min-width: 680px; display: grid; grid-template-columns: 1fr 1fr; gap: 6px 52px; padding: 32px 40px; }
    .nav-drop-col  { display: flex; flex-direction: column; }
    .nav-drop-label { padding: 0 0 12px; font-size: 14px; font-weight: 400; letter-spacing: 0; text-transform: none; color: #9b9b97; }
    .nav-drop-link { display: block; padding: 11px 0; border-radius: 0; white-space: normal; }
    .nav-drop-link .ndl-t { display: block; font-size: 19px; font-weight: 600; color: #15140f; letter-spacing: -.01em; line-height: 1.2; transition: color .14s var(--ease); }
    .nav-drop-link .ndl-d { display: block; font-size: 13.5px; font-weight: 400; color: #9b9b97; margin-top: 4px; line-height: 1.4; }
    .nav-drop-link:hover .ndl-t { color: var(--green); }
    .nav-drop-foot { grid-column: 1 / -1; border-top: 1px solid rgba(0,0,0,.08); margin: 16px -40px -32px; padding: 18px 40px 6px; }
    .nav-drop-all  { display: inline-flex; align-items: center; gap: 5px; font-size: 16px; font-weight: 600; color: var(--green); transition: color .15s; }
    .nav-drop-all:hover { color: var(--green-h); }
    .nav-burger { display: none; flex-direction: column; justify-content: center; gap: 5px; background: none; border: none; cursor: pointer; padding: 8px; margin-left: 6px; }
    .nav-burger span { display: block; width: 20px; height: 1.5px; background: var(--t2); border-radius: 2px; transition: transform .22s var(--ease), opacity .22s; }
    .nav-burger.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
    .nav-burger.open span:nth-child(2) { opacity: 0; }
    .nav-burger.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }
    .nav-mobile { display: none; position: fixed; inset: 64px 0 0; background: var(--d1); overflow-y: auto; z-index: 199; padding: 12px 20px 48px; border-top: 1px solid var(--bd); }
    .nav-mobile.open { display: block; }
    .nav-mob-link { display: block; padding: 14px 4px; font-size: 15px; font-weight: 500; color: var(--t2); border-bottom: 1px solid var(--bd); }
    .nav-mob-link:hover { color: #fff; }
    .nav-mob-btn { display: flex; align-items: center; justify-content: space-between; width: 100%; padding: 14px 4px; font-size: 15px; font-weight: 500; color: var(--t2); background: none; border: none; border-bottom: 1px solid var(--bd); cursor: pointer; font-family: var(--font); transition: color .18s; }
    .nav-mob-btn.open, .nav-mob-btn:hover { color: #fff; }
    .nav-mob-btn .nav-chev { transition: transform .2s; }
    .nav-mob-btn.open .nav-chev { transform: rotate(180deg); }
    .nav-mob-sub { display: none; padding: 4px 0 8px 12px; border-bottom: 1px solid var(--bd); }
    .nav-mob-sub.open { display: block; }
    .nav-mob-sub-lbl { font-size: 10px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--t3); padding: 10px 0 4px; }
    .nav-mob-sub a { display: block; padding: 9px 0; font-size: 14px; color: var(--t2); }
    .nav-mob-sub a:hover { color: #fff; }

    /* Hero */
    .hero { background: var(--d); min-height: var(--hero-min); display: flex; align-items: center; position: relative; overflow: hidden; padding: 80px 0; }
    .hero::before { content: ''; position: absolute; inset: 0; pointer-events: none; background: radial-gradient(ellipse 60% 60% at 68% 52%, rgba(244,120,32,.05) 0%, transparent 65%); }
    .hero-grid { max-width: var(--max); width: 100%; margin: 0 auto; padding: 0 48px; display: grid; grid-template-columns: 44fr 56fr; gap: 40px; align-items: center; }
    .hero-tag  { display: inline-flex; align-items: center; gap: 8px; background: var(--green-dim); border: 1px solid rgba(60,160,74,.3); border-radius: var(--pill); padding: 5px 14px; font-size: 10.5px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--green); width: fit-content; margin-bottom: 22px; }
    .hero-brand { font-size: 11.5px; font-weight: 600; letter-spacing: .2em; text-transform: uppercase; color: var(--t3); margin-bottom: 8px; }
    .hero-title { font-size: clamp(5rem,11vw,9.5rem); font-weight: 800; line-height: .9; letter-spacing: -.05em; color: #fff; }
    .hero-sub   { font-size: clamp(.7rem,1.3vw,.875rem); font-weight: 600; letter-spacing: .22em; text-transform: uppercase; color: var(--t2); margin-top: 16px; margin-bottom: 24px; }
    .hero-made  { display: flex; align-items: center; gap: 8px; font-size: 10.5px; font-weight: 500; letter-spacing: .08em; text-transform: uppercase; color: var(--t3); margin-bottom: 44px; }
    .hero-made::before { content: ''; width: 24px; height: 1px; background: var(--t3); }
    .hero-badges { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
    .hbadge { display: flex; align-items: flex-start; gap: 10px; background: var(--d2); border: 1px solid var(--bd); border-radius: var(--rs); padding: 12px 14px; transition: border-color .2s var(--ease); }
    .hbadge:hover { border-color: rgba(244,120,32,.4); }
    .hb-ic { width: 32px; height: 32px; background: var(--green-dim); border-radius: var(--rs); display: flex; align-items: center; justify-content: center; flex-shrink: 0; color: var(--green); }
    .hb-lb { font-size: 10.5px; font-weight: 600; letter-spacing: .05em; text-transform: uppercase; line-height: 1.4; }
    .hero-vis   { position: relative; display: flex; align-items: center; justify-content: center; min-height: 480px; }
    .hero-glow  { position: absolute; inset: -12% -8%; pointer-events: none; background: radial-gradient(ellipse 64% 60% at 52% 50%, var(--green-glow) 0%, rgba(244,120,32,.06) 44%, transparent 72%); }
    .hero-floor { position: absolute; left: 8%; right: 6%; bottom: 10%; height: 40px; background: radial-gradient(ellipse 50% 50% at 50% 50%, rgba(0,0,0,.6) 0%, transparent 75%); pointer-events: none; }
    .hero-robot { position: relative; z-index: 1; width: 122%; max-width: 780px; margin: 0 -11%; filter: drop-shadow(0 38px 60px rgba(0,0,0,.6)); }

    /* Capabilities */
    .cap-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1px; background: var(--bd); border: 1px solid var(--bd); border-radius: var(--r); overflow: hidden; margin-top: 52px; }
    .cap-card { background: var(--d1); padding: 26px 22px; transition: background .2s var(--ease); }
    .cap-card:hover { background: var(--d2); }
    .cap-ic    { width: 40px; height: 40px; background: var(--green-dim); border-radius: var(--rs); display: flex; align-items: center; justify-content: center; margin-bottom: 14px; color: var(--green); }
    .cap-title { font-size: 13.5px; font-weight: 700; margin-bottom: 7px; line-height: 1.3; }
    .cap-desc  { font-size: 12.5px; color: var(--t2); line-height: 1.55; }

    /* Spec tables */
    .tbl-wrap  { border: 1px solid var(--bd); border-radius: var(--r); overflow: hidden; }
    .stbl      { width: 100%; border-collapse: separate; border-spacing: 0; }
    .stbl tr   { transition: background .12s; }
    .stbl tr:not(:last-child) td { border-bottom: 1px solid var(--bd); }
    .stbl tr:hover { background: rgba(255,255,255,.02); }
    .stbl td   { padding: 13px 18px; font-size: 13px; vertical-align: top; line-height: 1.5; }
    .stbl td:first-child { color: var(--t2); font-weight: 500; width: 42%; border-right: 1px solid var(--bd); }
    .stbl td:last-child  { color: var(--t1); font-family: var(--mono); font-size: 12px; letter-spacing: .01em; }
    .specs-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; margin-top: 48px; }
    .mow-grid   { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: start; margin-top: 48px; }
    .perf-box  { background: var(--d2); border: 1px solid var(--bd); border-radius: var(--r); padding: 22px 24px; margin-top: 20px; }
    .perf-hd   { font-size: 10.5px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--green); margin-bottom: 14px; }
    .perf-list { display: flex; flex-direction: column; gap: 9px; }
    .perf-item { display: flex; align-items: flex-start; gap: 8px; font-size: 12.5px; color: var(--t2); line-height: 1.5; }
    .perf-item::before { content: ''; width: 5px; height: 5px; background: var(--green); border-radius: 50%; flex-shrink: 0; margin-top: 7px; }
    .sketch-frame  { border-radius: var(--rl); overflow: hidden; background: #f5f5ef; border: 1px solid var(--bd); box-shadow: 0 20px 60px rgba(0,0,0,.5); }
    .sketch-frame img { width: 100%; display: block; }
    .mow-img-frame { border-radius: var(--rl); overflow: hidden; background: #f4f4f4; border: 1px solid var(--bd); box-shadow: 0 16px 48px rgba(0,0,0,.5); }
    .mow-img-frame img { width: 100%; display: block; }

    /* Operational Modes */
    .modes-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin-top: 48px; }
    .mcard { background: var(--d2); border: 1px solid var(--bd); border-radius: var(--r); overflow: hidden; transition: border-color .2s var(--ease); }
    .mcard:hover { border-color: rgba(60,160,74,.35); }
    .mcard-hd { background: var(--btn-bg); padding: 13px 18px; font-size: 11.5px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; color: #fff; }
    .mcard-hd.neutral { background: var(--d3); color: var(--t2); border-bottom: 1px solid var(--bd); }
    .mcard-bd { padding: 18px; font-size: 13px; color: var(--t2); line-height: 1.6; }
    .op-sub { font-size: 13px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--t1); margin: 40px 0 0; padding-bottom: 14px; border-bottom: 1px solid var(--bd); }

    /* Workflow */
    .wf-wrap  { position: relative; margin-top: 56px; }
    .wf-line  { position: absolute; top: 30px; left: 8%; right: 8%; height: 1px; background: var(--bd); }
    .wf-steps { display: grid; grid-template-columns: repeat(5,1fr); gap: 16px; position: relative; z-index: 1; }
    .wf-step  { display: flex; flex-direction: column; align-items: center; text-align: center; padding: 0 8px; }
    .wf-num   { width: 60px; height: 60px; background: var(--d2); border: 1px solid var(--bd); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: var(--mono); font-size: 13px; font-weight: 600; color: var(--green); margin-bottom: 20px; transition: border-color .2s, box-shadow .2s; }
    .wf-step:hover .wf-num { border-color: var(--green); box-shadow: 0 0 20px var(--green-glow); }
    .wf-title { font-size: 10.5px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 8px; }
    .wf-desc  { font-size: 12px; color: var(--t2); line-height: 1.5; }
    /* Light workflow */
    #how-it-works.sec-lt .wf-line  { background: var(--lbd); }
    #how-it-works.sec-lt .wf-num   { background: #fff; border-color: var(--lbd); color: var(--green); }
    #how-it-works.sec-lt .wf-step:hover .wf-num { border-color: var(--green); box-shadow: 0 0 20px var(--green-glow); }
    #how-it-works.sec-lt .wf-title { color: var(--lt); }
    #how-it-works.sec-lt .wf-desc  { color: var(--lt2); }
    #how-it-works.sec-lt .stitle   { color: var(--lt); }
    #how-it-works.sec-lt .ssub     { color: var(--lt2); }

    /* Precision Mowing */
    .prec-grid  { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: center; }
    .prec-body  { font-size: 15px; color: var(--t2); line-height: 1.7; margin: 18px 0 26px; text-wrap: pretty; }
    .prec-blist { display: flex; flex-direction: column; gap: 12px; margin-bottom: 28px; }
    .prec-b     { display: flex; align-items: flex-start; gap: 10px; font-size: 13px; color: var(--t2); line-height: 1.55; }
    .prec-dot   { width: 18px; height: 18px; background: var(--green-dim); border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 2px; }
    .prec-dot::before { content: ''; width: 6px; height: 6px; background: var(--green); border-radius: 50%; }
    .prec-thumbs { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; }
    .prec-th    { border-radius: var(--rs); overflow: hidden; border: 1px solid var(--bd); }
    .prec-th-img { width: 100%; aspect-ratio: 4/3; background: var(--d2); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; padding: 12px; }
    img.prec-th-img { object-fit: cover; padding: 0; display: block; }
    .prec-th-cap { padding: 7px 10px; font-size: 9.5px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; color: var(--t2); background: var(--d2); }
    .prec-vis   { border-radius: var(--rl); overflow: hidden; background: #f4f4f4; border: 1px solid var(--bd); box-shadow: 0 20px 60px rgba(0,0,0,.6); }
    .prec-vis img { width: 100%; display: block; }

    /* Closing band */
    .close-band { background: var(--d2); border-top: 1px solid var(--bd); border-bottom: 1px solid var(--bd); padding: 72px 48px; text-align: center; }
    .close-h    { font-size: clamp(1.6rem,3vw,2.4rem); font-weight: 800; letter-spacing: -.02em; line-height: 1.2; margin-bottom: 14px; }
    .close-p    { font-size: 14.5px; color: var(--t2); max-width: 560px; margin: 0 auto 18px; line-height: 1.65; text-wrap: pretty; }
    .close-lnk  { font-size: 13px; color: var(--green); font-weight: 600; }
    .close-lnk:hover { text-decoration: underline; }

    /* Applications */
    .apps-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 16px; margin-top: 48px; }
    .acard     { background: #fff; border: 1px solid var(--lbd); border-radius: var(--r); overflow: hidden; transition: box-shadow .2s, transform .2s var(--ease); }
    .acard:hover { box-shadow: 0 8px 24px rgba(0,0,0,.09); transform: translateY(-2px); }
    .acard-hd  { background: var(--btn-bg); padding: 12px 18px; font-size: 11.5px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; color: #fff; }
    .acard-bd  { padding: 18px; font-size: 13.5px; color: var(--lt2); line-height: 1.65; text-wrap: pretty; }

    /* Comparison table */
    .ctbl-wrap { border: 1px solid var(--bd); border-radius: var(--r); overflow: hidden; margin-top: 48px; }
    .ctbl      { width: 100%; border-collapse: separate; border-spacing: 0; }
    .ctbl th   { padding: 14px 18px; font-size: 10.5px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; background: var(--d2); color: var(--t2); text-align: left; border-bottom: 1px solid var(--bd); }
    .ctbl th.hi { background: var(--green); color: #fff; }
    .ctbl td   { padding: 13px 18px; font-size: 13px; color: var(--t2); }
    .ctbl tr:not(:last-child) td { border-bottom: 1px solid var(--bd); }
    .ctbl td:first-child { font-weight: 600; color: var(--t1); }
    .ctbl td.hi { background: rgba(60,160,74,.08); color: var(--t1); font-weight: 600; }
    .ctbl tr:hover td    { background: rgba(255,255,255,.02); }
    .ctbl tr:hover td.hi { background: rgba(60,160,74,.13); }

    /* Platform (green) */
    .plat-in    { text-align: center; max-width: 760px; margin: 0 auto; }
    .plat-ew    { font-size: 10.5px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.65); margin-bottom: 14px; }
    .plat-title { font-size: clamp(1.8rem,3.5vw,2.8rem); font-weight: 800; letter-spacing: -.02em; line-height: 1.2; margin-bottom: 10px; }
    .plat-sub   { font-size: 14.5px; color: rgba(255,255,255,.8); margin-bottom: 40px; }
    .plat-flow  { display: flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: 0; row-gap: 12px; margin-bottom: 28px; }
    .plat-step  { background: rgba(255,255,255,.15); border: 1px solid rgba(255,255,255,.25); border-radius: var(--rs); padding: 14px 22px; font-size: 11.5px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
    .plat-arr   { color: rgba(255,255,255,.5); padding: 0 14px; font-size: 20px; line-height: 1; }
    .plat-note  { background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.2); border-radius: var(--r); padding: 18px 28px; font-size: 14px; font-weight: 500; color: rgba(255,255,255,.9); max-width: 480px; margin: 0 auto; line-height: 1.5; }

    /* CTA */
    .cta-in    { text-align: center; max-width: 700px; margin: 0 auto; }
    .cta-h     { font-size: clamp(2rem,4vw,3.2rem); font-weight: 800; letter-spacing: -.03em; line-height: 1.15; margin-bottom: 16px; text-wrap: pretty; }
    .cta-p     { font-size: 15.5px; color: var(--t2); line-height: 1.7; margin-bottom: 40px; }
    .cta-box   { background: var(--d2); border: 1px solid var(--bd); border-radius: var(--rl); padding: 36px; text-align: left; margin-bottom: 44px; }
    .cta-row   { display: grid; grid-template-columns: 1fr auto; gap: 32px; align-items: center; }
    .cta-shd   { font-size: 10.5px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--green); margin-bottom: 10px; }
    .cta-sp    { font-size: 13.5px; color: var(--t2); line-height: 1.6; margin-bottom: 22px; }
    .cta-url   { font-size: 12.5px; color: var(--t3); font-family: var(--mono); letter-spacing: .04em; display: block; margin-top: 12px; }
    .cta-qr    { width: 96px; height: 96px; background: #fff; border-radius: var(--rs); display: flex; align-items: center; justify-content: center; flex-shrink: 0; padding: 8px; }
    .cta-badges { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; }
    .cta-badge  { background: var(--d2); border: 1px solid var(--bd); border-radius: var(--pill); padding: 6px 14px; font-size: 11px; font-weight: 500; color: var(--t2); letter-spacing: .02em; }

    /* Footer */
    .foot       { background: var(--d); border-top: 1px solid var(--bd); padding: 28px 48px; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
    .foot-brand { font-size: 11.5px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--t3); }
    .foot-brand a { color: var(--green); }
    .foot-copy  { font-size: 11.5px; color: var(--t3); }

    /* Responsive */
    @media (max-width: 1100px) {
      .wrap, .nav-in, .hero-grid { padding-left: 32px; padding-right: 32px; }
      .cap-grid    { grid-template-columns: repeat(2,1fr); }
      .specs-2col  { grid-template-columns: 1fr; }
      .mow-grid    { grid-template-columns: 1fr; }
      .prec-grid   { grid-template-columns: 1fr; }
    }
    @media (max-width: 768px) {
      .wrap, .nav-in, .hero-grid, .close-band, .foot { padding-left: 20px; padding-right: 20px; }
      .sec { padding: 64px 0; }
      .nav-links { display: none; }
      .nav-burger { display: flex; }
      .hero { padding: 52px 0; min-height: auto; }
      .hero-grid { grid-template-columns: 1fr; gap: 36px; }
      .hero-vis  { order: -1; }
      .hero-title { font-size: clamp(4rem,14vw,6.5rem); }
      .hero-badges { grid-template-columns: 1fr; }
      .cap-grid    { grid-template-columns: 1fr; }
      .modes-grid  { grid-template-columns: 1fr; }
      .apps-grid   { grid-template-columns: 1fr; }
      .wf-steps    { grid-template-columns: 1fr; }
      .wf-line     { display: none; }
      .wf-step { flex-direction: row; text-align: left; }
      .wf-num  { margin-bottom: 0; margin-right: 16px; flex-shrink: 0; }
      .plat-flow   { flex-direction: column; }
      .plat-arr    { transform: rotate(90deg); }
      .cta-row     { grid-template-columns: 1fr; }
      .cta-qr      { display: none; }
      .foot        { flex-direction: column; text-align: center; padding-top: 24px; padding-bottom: 24px; }
      .close-band  { padding-top: 52px; padding-bottom: 52px; }
    }
  