html, body {
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
}

a, .btn-link {
    color: #006bb7;
}

.btn-primary {
    color: #fff;
    background-color: #1b6ec2;
    border-color: #1861ac;
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

.content {
    padding-top: 1.1rem;
}

h1:focus {
    outline: none;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid #e50000;
}

.validation-message {
    color: #e50000;
}

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }

.darker-border-checkbox.form-check-input {
    border-color: #929292;
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
    color: var(--bs-secondary-color);
    text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
    text-align: start;
}
  :root{
    /* brand — from logo */
    --teal-900:#0A3338;
    --teal-800:#0F4A50;
    --teal-700:#13616A;
    --teal-600:#177984;
    --teal-500:#1E8E99;
    --teal-300:#5BB9C0;
    --teal-100:#D6EEF1;
    --leaf-700:#3F9A3D;
    --leaf-500:#5DC04F;
    --leaf-300:#A6E091;
    --leaf-100:#E2F5DA;
    --honey-600:#E8AA1B;
    --honey-500:#F4C236;
    --honey-300:#FBE08A;
    --honey-100:#FFF4D1;

    /* surfaces */
    --bg:#FFFFFF;
    --bg-soft:#F6F9FA;
    --bg-tint:#EEF6F7;
    --ink:#08191B;
    --ink-2:#36545A;
    --ink-3:#6A8388;
    --line:#E1EAEC;
    --line-2:#C8D7DA;

    /* dark surfaces */
    --d-bg:#06181B;
    --d-bg-2:#0A2226;
    --d-bg-3:#0F2F33;
    --d-line:rgba(91,185,192,.15);
    --d-line-2:rgba(91,185,192,.25);
    --d-ink:#E6F2F3;
    --d-ink-2:#9FB8BC;

    --r-sm:8px;--r-md:14px;--r-lg:22px;--r-xl:28px;
    --shadow-sm:0 1px 2px rgba(8,25,27,.05), 0 2px 6px rgba(8,25,27,.04);
    --shadow-md:0 10px 24px -10px rgba(8,25,27,.10), 0 30px 60px -30px rgba(8,25,27,.18);
    --shadow-lg:0 20px 50px -22px rgba(8,25,27,.16), 0 60px 100px -40px rgba(8,25,27,.26);
    --glow-teal:0 0 40px rgba(91,185,192,.35);
    --glow-leaf:0 0 40px rgba(93,192,79,.35);
    --glow-honey:0 0 40px rgba(244,194,54,.35);

    --font:'Manrope',ui-sans-serif,system-ui,-apple-system,Segoe UI,sans-serif;
    --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  }

  *{box-sizing:border-box}
  html,body{margin:0;padding:0;scroll-behavior:smooth}
  body{
    font-family:var(--font);
    color:var(--ink);
    background:var(--bg);
    -webkit-font-smoothing:antialiased;
    line-height:1.55;
    font-size:15px;
  }
  a{color:inherit;text-decoration:none}
  button{font-family:inherit;border:0;cursor:pointer;background:none}
  img{max-width:100%;display:block}

  .wrap{max-width:1280px;margin:0 auto;padding:0 28px;position:relative;z-index:2}

  .mono{font-family:var(--mono);letter-spacing:.04em}
  .eyebrow{
    display:inline-flex;align-items:center;gap:10px;
    font-family:var(--mono);font-size:11px;font-weight:500;
    text-transform:uppercase;letter-spacing:.14em;
    color:var(--teal-600);
  }
  .eyebrow::before{content:"";width:24px;height:1px;background:var(--teal-600)}
  .eyebrow.on-dark{color:var(--teal-300)}
  .eyebrow.on-dark::before{background:var(--teal-300)}

  h1,h2,h3,h4{margin:0;font-weight:700;letter-spacing:-.025em;line-height:1.08}
  h1{font-size:64px;letter-spacing:-.035em}
  h2{font-size:44px}
  h3{font-size:22px;letter-spacing:-.015em;line-height:1.2}
  h4{font-size:17px;letter-spacing:-.01em;line-height:1.25}

  .grad-text{
    background:linear-gradient(95deg,var(--teal-500) 0%,var(--leaf-500) 60%,var(--honey-500) 100%);
    -webkit-background-clip:text;background-clip:text;color:transparent;
  }
  .grad-text-dark{
    background:linear-gradient(95deg,#9BE7ED 0%,#B6EFA5 55%,#FBE08A 100%);
    -webkit-background-clip:text;background-clip:text;color:transparent;
  }

  /* ─── BUTTONS ─── */
  .btn{
    display:inline-flex;align-items:center;gap:8px;
    padding:13px 20px;border-radius:12px;
    font-weight:600;font-size:14px;letter-spacing:-.005em;
    transition:transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
    border:1px solid transparent;white-space:nowrap;
  }
  .btn .arr{transition:transform .2s ease;display:inline-block}
  .btn:hover .arr{transform:translateX(3px)}
  .btn-primary{background:linear-gradient(180deg,var(--teal-600),var(--teal-700));color:#fff;box-shadow:0 6px 18px -8px rgba(19,97,106,.5), inset 0 1px 0 rgba(255,255,255,.1)}
  .btn-primary:hover{transform:translateY(-1px);box-shadow:0 12px 28px -10px rgba(19,97,106,.6), inset 0 1px 0 rgba(255,255,255,.15)}
  .btn-honey{background:linear-gradient(180deg,var(--honey-500),var(--honey-600));color:#1A1404;box-shadow:0 6px 18px -8px rgba(232,170,27,.55), inset 0 1px 0 rgba(255,255,255,.3)}
  .btn-honey:hover{transform:translateY(-1px);box-shadow:0 12px 28px -10px rgba(232,170,27,.65)}
  .btn-ghost{color:var(--ink);background:transparent}
  .btn-ghost:hover{color:var(--teal-600)}
  .btn-outline{border:1px solid var(--line-2);color:var(--ink)}
  .btn-outline:hover{background:var(--bg-soft);border-color:var(--teal-500)}
  .btn-on-dark{border:1px solid rgba(255,255,255,.18);color:#fff;background:rgba(255,255,255,.04);backdrop-filter:blur(8px)}
  .btn-on-dark:hover{background:rgba(255,255,255,.08);border-color:var(--teal-300)}
  .btn-lg{padding:15px 24px;font-size:14.5px;border-radius:14px}

  /* ─── NAV ─── */
  .nav{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.78);backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid var(--line)}
  .nav-in{display:flex;align-items:center;justify-content:space-between;height:72px;gap:24px;padding:0 28px;max-width:1320px;margin:0 auto}
  .logo{display:flex;align-items:center;gap:12px}
  .logo img{width:38px;height:38px;object-fit:contain;filter:drop-shadow(0 2px 6px rgba(19,97,106,.18))}
  .logo .lt{display:flex;flex-direction:column;line-height:1.05}
  .logo .lt b{font-weight:700;font-size:15.5px;letter-spacing:-.015em;color:var(--ink)}
  .logo .lt small{font-family:var(--mono);font-size:9.5px;color:var(--ink-3);letter-spacing:.12em;text-transform:uppercase;margin-top:3px}
  .nav-links{display:flex;gap:6px;align-items:center}
  .nav-links a{padding:9px 14px;font-size:14px;color:var(--ink-2);font-weight:500;border-radius:8px;display:inline-flex;align-items:center;gap:5px;transition:color .15s, background .15s}
  .nav-links a:hover{color:var(--ink);background:var(--bg-tint)}
  .nav-links a.active{color:var(--teal-700);background:var(--teal-100);font-weight:700}
  .nav-links a.active .caret{opacity:1}
  .nav-links a .caret{font-size:9px;opacity:.6}
  .nav-cta{display:flex;gap:10px;align-items:center}

  /* ─── HERO ─── */
  .hero{
    position:relative;overflow:hidden;
    background:
      radial-gradient(1100px 600px at 88% 0%, rgba(93,192,79,.18), transparent 60%),
      radial-gradient(900px 540px at 10% 10%, rgba(91,185,192,.22), transparent 55%),
      radial-gradient(700px 500px at 60% 100%, rgba(244,194,54,.10), transparent 60%),
      linear-gradient(180deg,#06181B 0%,#082225 60%,#0A2226 100%);
    color:#fff;
    padding:88px 0 96px;
  }
  .hero::before{
    content:"";position:absolute;inset:0;pointer-events:none;
    background-image:
      linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
      linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
    background-size:42px 42px;
    mask-image:radial-gradient(ellipse at 50% 30%,#000 30%,transparent 80%);
  }
  .hero::after{
    content:"";position:absolute;left:-10%;right:-10%;bottom:-100px;height:280px;
    background:radial-gradient(60% 100% at 50% 0%,rgba(91,185,192,.18),transparent);
    pointer-events:none;
  }
  .hero-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center}
  .hero-tag{
    display:inline-flex;align-items:center;gap:10px;
    padding:6px 12px 6px 6px;border-radius:999px;
    background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
    font-size:12px;color:#D5E7E9;backdrop-filter:blur(8px);
  }
  .hero-tag i{display:inline-flex;width:22px;height:22px;border-radius:999px;background:linear-gradient(135deg,var(--leaf-500),var(--teal-500));align-items:center;justify-content:center;color:#082225;font-weight:700;font-size:11px;font-family:var(--mono)}
  .hero-tag b{color:#fff;font-weight:600}
  h1.hero-title{
    font-size:68px;line-height:1.04;letter-spacing:-.035em;font-weight:700;
    color:#fff;margin:22px 0 22px;text-wrap:balance;
  }
  h1.hero-title em{font-style:normal}
  .hero-sub{font-size:18px;color:#B6CDD0;max-width:560px;line-height:1.6;text-wrap:pretty}
  .hero-ctas{display:flex;gap:12px;margin-top:32px;flex-wrap:wrap}
  .hero-strip{
    display:flex;gap:28px;margin-top:42px;padding-top:28px;
    border-top:1px solid rgba(255,255,255,.1);align-items:center;flex-wrap:wrap;
  }
  .hero-strip .h-stat{display:flex;flex-direction:column;gap:2px}
  .hero-strip .h-stat b{font-size:22px;font-weight:700;color:#fff;letter-spacing:-.015em}
  .hero-strip .h-stat small{font-size:11px;color:#88A6AA;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase}
  .hero-strip .h-div{width:1px;height:30px;background:rgba(255,255,255,.1)}

  /* ─── HERO VISUAL — stacked POS / dashboard / mPOS ─── */
  .hero-stage{position:relative;aspect-ratio:5/6;min-height:540px}
  .hero-stage .blob{position:absolute;border-radius:50%;filter:blur(40px);pointer-events:none}
  .hero-stage .blob.b1{top:-10%;right:-10%;width:60%;height:60%;background:radial-gradient(circle,rgba(93,192,79,.45),transparent 70%)}
  .hero-stage .blob.b2{bottom:-5%;left:-15%;width:55%;height:55%;background:radial-gradient(circle,rgba(91,185,192,.5),transparent 70%)}
  .hero-stage .blob.b3{top:30%;left:20%;width:30%;height:30%;background:radial-gradient(circle,rgba(244,194,54,.3),transparent 70%)}

  /* Dashboard card top-right */
  .dash{
    position:absolute;top:0;right:0;width:62%;
    background:linear-gradient(180deg,rgba(15,47,51,.85),rgba(10,34,38,.92));
    border:1px solid rgba(255,255,255,.08);border-radius:16px;
    backdrop-filter:blur(20px);
    box-shadow:0 30px 60px -20px rgba(0,0,0,.5);
    padding:14px;z-index:3;
  }
  .dash-h{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
  .dash-h .dots{display:flex;gap:5px}
  .dash-h .dots i{width:8px;height:8px;border-radius:999px;background:#FF6058;display:block}
  .dash-h .dots i:nth-child(2){background:#FFBD2E}
  .dash-h .dots i:nth-child(3){background:#28C940}
  .dash-h small{font-family:var(--mono);font-size:9px;color:#7E9EA3;letter-spacing:.1em}
  .dash-row{display:flex;gap:8px;margin-bottom:10px}
  .dash-kpi{flex:1;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:8px 10px}
  .dash-kpi small{display:block;font-family:var(--mono);font-size:8.5px;color:#88A6AA;letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px}
  .dash-kpi b{font-size:15px;color:#fff;font-weight:700;letter-spacing:-.01em;display:block}
  .dash-kpi .delta{font-size:9px;color:var(--leaf-300);font-family:var(--mono);font-weight:500}
  .dash-kpi .delta.honey{color:var(--honey-300)}
  .dash-chart{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:8px 8px 4px;position:relative}
  .dash-chart small{font-family:var(--mono);font-size:8.5px;color:#7E9EA3;letter-spacing:.08em;text-transform:uppercase}
  .dash-chart svg{width:100%;height:64px;margin-top:2px;display:block}
  .dash-bar{height:60px;display:flex;align-items:flex-end;gap:3px;padding:0 2px;margin-top:6px}
  .dash-bar i{flex:1;background:linear-gradient(180deg,var(--teal-300),var(--teal-600));border-radius:2px 2px 0 0;display:block;opacity:.85}
  .dash-bar i:nth-child(2n){background:linear-gradient(180deg,var(--leaf-500),var(--leaf-700));opacity:.95}
  .dash-bar i:last-child{background:linear-gradient(180deg,var(--honey-500),var(--honey-600));opacity:1}

  /* POS terminal centered */
  .pos-term{
    position:absolute;left:6%;bottom:8%;width:64%;z-index:4;
    transform:rotate(-2deg);
    filter:drop-shadow(0 30px 50px rgba(0,0,0,.45));
  }
  .pos-term .scr{
    background:linear-gradient(180deg,#0E2D31,#072023);
    border:7px solid #06141A;border-radius:14px;
    aspect-ratio:16/10;padding:12px;position:relative;overflow:hidden;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.04);
  }
  .pos-term .scr::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent 45%,rgba(255,255,255,.06) 55%,transparent 65%);pointer-events:none}
  .pt-top{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:8.5px;color:#7E9EA3;letter-spacing:.05em;margin-bottom:8px}
  .pt-top b{color:var(--honey-300)}
  .pt-pill{display:inline-flex;align-items:center;gap:5px;background:rgba(91,185,192,.12);border:1px solid rgba(91,185,192,.3);border-radius:999px;padding:2px 7px;color:var(--teal-300);font-size:8px;letter-spacing:.06em}
  .pt-pill i{width:5px;height:5px;border-radius:999px;background:var(--leaf-500);box-shadow:0 0 6px var(--leaf-500);display:block;animation:blink 1.6s infinite}
  @keyframes blink{50%{opacity:.35}}
  .pt-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(3,1fr);gap:4px;margin-bottom:8px}
  .pt-grid i{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:4px;height:24px;display:flex;align-items:center;justify-content:center;color:#B6C5DA;font-family:var(--mono);font-size:6.5px;font-weight:600}
  .pt-grid i.t{background:linear-gradient(180deg,rgba(91,185,192,.2),rgba(91,185,192,.05));border-color:rgba(91,185,192,.4);color:#9BE7ED}
  .pt-grid i.l{background:linear-gradient(180deg,rgba(93,192,79,.2),rgba(93,192,79,.05));border-color:rgba(93,192,79,.4);color:#B6EFA5}
  .pt-grid i.h{background:linear-gradient(180deg,rgba(244,194,54,.18),rgba(244,194,54,.04));border-color:rgba(244,194,54,.4);color:#FBE08A}
  .pt-tot{display:flex;justify-content:space-between;align-items:center;padding-top:7px;border-top:1px dashed rgba(255,255,255,.1);font-family:var(--mono);font-size:9px;color:#88A6AA}
  .pt-tot b{color:#fff;font-size:12px;font-weight:700;letter-spacing:-.01em}
  .pos-term .stand{height:18px;width:54%;margin:5px auto 0;background:linear-gradient(180deg,#1B3034,#0A1F23);border-radius:0 0 4px 4px}
  .pos-term .base{height:7px;width:78%;margin:0 auto;background:#06141A;border-radius:3px;box-shadow:0 4px 12px rgba(0,0,0,.3)}

  /* Floating mPOS handheld */
  .mpos{
    position:absolute;right:5%;bottom:0;width:24%;z-index:5;
    filter:drop-shadow(0 30px 50px rgba(0,0,0,.5));
    transform:rotate(8deg);
  }
  .mpos .body{
    background:linear-gradient(180deg,#0F2F33,#06141A);
    border-radius:18px 18px 22px 22px;padding:12px 8px;aspect-ratio:1/1.85;
    border:1px solid rgba(255,255,255,.08);
    position:relative;
  }
  .mpos .body::before{content:"";position:absolute;top:6px;left:50%;transform:translateX(-50%);width:32px;height:3px;background:#1B3034;border-radius:2px}
  .mpos .scr{
    background:linear-gradient(180deg,#072023,#03131A);border-radius:8px;
    aspect-ratio:9/13;padding:8px 6px;display:flex;flex-direction:column;gap:6px;
    border:1px solid rgba(91,185,192,.1);
  }
  .mpos .scr small{font-family:var(--mono);font-size:6.5px;color:var(--teal-300);letter-spacing:.08em}
  .mpos .scr .am{font-family:var(--font);font-size:16px;font-weight:800;color:#fff;letter-spacing:-.015em}
  .mpos .scr .rows{display:flex;flex-direction:column;gap:3px;margin-top:auto}
  .mpos .scr .rows i{height:5px;background:rgba(255,255,255,.06);border-radius:2px;display:block}
  .mpos .scr .rows i:nth-child(1){width:90%}
  .mpos .scr .rows i:nth-child(2){width:75%}
  .mpos .scr .rows i:nth-child(3){width:60%}
  .mpos .scr .pay{margin-top:6px;background:linear-gradient(180deg,var(--leaf-500),var(--leaf-700));border-radius:6px;height:24px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:8.5px;font-weight:700;letter-spacing:.04em}

  /* Floating analytic chips */
  .chip{
    position:absolute;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);
    backdrop-filter:blur(14px);border-radius:12px;padding:10px 14px;
    color:#fff;font-size:12px;display:flex;align-items:center;gap:10px;
    box-shadow:0 20px 40px -20px rgba(0,0,0,.4);z-index:6;
  }
  .chip i.dot{width:8px;height:8px;border-radius:999px;display:inline-block}
  .chip b{font-weight:700;font-size:13px;letter-spacing:-.005em}
  .chip small{display:block;font-size:9.5px;color:#9FB8BC;font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;margin-top:1px}
  .chip-1{top:14%;left:0;animation:float 6s ease-in-out infinite}
  .chip-2{top:48%;right:-2%;animation:float 7s ease-in-out infinite -2s}
  @keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

  /* ─── INDUSTRIES STRIP ─── */
  .strip{
    background:var(--bg-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line);
    padding:36px 0;
  }
  .strip-in{display:flex;align-items:center;gap:32px;flex-wrap:wrap;justify-content:space-between}
  .strip-lab{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);font-weight:500}
  .strip-items{display:flex;gap:14px;flex-wrap:wrap}
  .si{
    display:inline-flex;align-items:center;gap:10px;
    padding:10px 16px;background:#fff;border:1px solid var(--line);border-radius:999px;
    font-size:13.5px;font-weight:600;color:var(--ink);
    box-shadow:var(--shadow-sm);
    transition:transform .15s, box-shadow .2s, border-color .2s;
  }
  .si:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--teal-500)}
  .si .ic{width:24px;height:24px;border-radius:7px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:800}
  .si.s1 .ic{background:linear-gradient(135deg,var(--teal-500),var(--teal-700))}
  .si.s2 .ic{background:linear-gradient(135deg,var(--leaf-500),var(--leaf-700))}
  .si.s3 .ic{background:linear-gradient(135deg,var(--honey-500),var(--honey-600));color:#1A1404}
  .si.s4 .ic{background:linear-gradient(135deg,var(--teal-600),var(--leaf-700))}
  .si.s5 .ic{background:linear-gradient(135deg,var(--leaf-500),var(--teal-500))}
  .si.s6 .ic{background:linear-gradient(135deg,var(--honey-500),var(--leaf-500));color:#1A1404}
  .si.s7 .ic{background:linear-gradient(135deg,var(--teal-700),var(--teal-500))}

  /* ─── SECTIONS ─── */
  section.block{padding:120px 0;position:relative}
  .sec-head{max-width:780px;margin-bottom:64px}
  .sec-head h2{margin:16px 0 18px;text-wrap:balance}
  .sec-head p{font-size:17.5px;color:var(--ink-2);max-width:680px;line-height:1.6;text-wrap:pretty;margin:0}
  .sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
  .sec-head.center p{margin-left:auto;margin-right:auto}
  .sec-head.on-dark h2{color:#fff}
  .sec-head.on-dark p{color:var(--d-ink-2)}

  /* ─── ECOSYSTEM ─── */
  .eco{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:minmax(280px,auto);gap:18px}
  .ecard{
    grid-column:span 4;grid-row:span 1;
    background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
    padding:28px;display:flex;flex-direction:column;gap:14px;
    position:relative;overflow:hidden;
    transition:transform .2s, box-shadow .2s, border-color .2s;
  }
  .ecard:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--teal-300)}
  .ecard .tag{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--teal-600);display:flex;justify-content:space-between;align-items:center}
  .ecard .tag .sku{color:var(--ink-3)}
  .ecard h3{margin:6px 0 4px}
  .ecard p{font-size:14px;color:var(--ink-2);margin:0;line-height:1.55}
  .ecard ul{list-style:none;padding:0;margin:auto 0 0;display:flex;flex-wrap:wrap;gap:5px}
  .ecard ul li{font-family:var(--mono);font-size:10.5px;color:var(--ink-2);background:var(--bg-tint);border:1px solid var(--line);padding:3px 9px;border-radius:999px}

  .ecard.wide{grid-column:span 8}
  .ecard.tall{grid-row:span 2}

  /* Visual zones inside ecards */
  .vbox{
    margin-top:6px;border-radius:14px;
    background:linear-gradient(180deg,var(--bg-soft),var(--bg-tint));
    border:1px solid var(--line);
    min-height:180px;position:relative;overflow:hidden;
    display:flex;align-items:center;justify-content:center;padding:20px;
  }
  .vbox::before{
    content:"";position:absolute;inset:0;
    background-image:
      linear-gradient(rgba(8,25,27,.04) 1px,transparent 1px),
      linear-gradient(90deg,rgba(8,25,27,.04) 1px,transparent 1px);
    background-size:18px 18px;mask-image:radial-gradient(ellipse,#000 30%,transparent 80%);
  }
  .vbox > *{position:relative;z-index:1}

  /* Hero POS hardware card */
  .ecard.hero-hw .vbox{min-height:280px;flex-direction:row;gap:18px;padding:24px;justify-content:space-around}
  .hw-pos{width:60%;transform:rotate(-2deg)}
  .hw-pos .scr{background:linear-gradient(180deg,#0E2D31,#072023);border:6px solid #06141A;border-radius:10px;aspect-ratio:16/10;padding:10px;box-shadow:var(--shadow-md);position:relative;overflow:hidden}
  .hw-pos .scr::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent 45%,rgba(255,255,255,.05) 55%,transparent 65%)}
  .hw-pos .scr-h{display:flex;justify-content:space-between;font-family:var(--mono);font-size:7px;color:#7E9EA3;margin-bottom:6px;letter-spacing:.05em}
  .hw-pos .scr-h b{color:var(--honey-300)}
  .hw-pos .scr-g{display:grid;grid-template-columns:repeat(5,1fr);gap:3px}
  .hw-pos .scr-g i{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:2px;height:14px;display:block}
  .hw-pos .scr-g i.on{background:linear-gradient(180deg,var(--teal-500),var(--teal-700));border-color:var(--teal-500)}
  .hw-pos .scr-g i.lf{background:linear-gradient(180deg,var(--leaf-500),var(--leaf-700));border-color:var(--leaf-500)}
  .hw-pos .scr-g i.hn{background:linear-gradient(180deg,var(--honey-500),var(--honey-600));border-color:var(--honey-500)}
  .hw-pos .st{height:14px;width:55%;margin:4px auto 0;background:linear-gradient(180deg,#1B3034,#06141A);border-radius:0 0 4px 4px}
  .hw-pos .bs{height:5px;width:75%;margin:0 auto;background:#06141A;border-radius:3px}
  .hw-spec{flex:1;font-family:var(--mono);font-size:11px;display:flex;flex-direction:column;gap:6px}
  .hw-spec .r{display:flex;justify-content:space-between;padding:6px 10px;background:#fff;border:1px solid var(--line);border-radius:7px}
  .hw-spec .r span{color:var(--ink-3);font-size:9.5px;letter-spacing:.06em;text-transform:uppercase}
  .hw-spec .r b{color:var(--ink);font-weight:700}

  /* Printer mini */
  .hw-print{display:flex;gap:14px;align-items:end;width:100%}
  .pu{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px}
  .pbx{background:linear-gradient(180deg,#0F2F33,#06141A);border-radius:7px;aspect-ratio:1.5/1;width:100%;box-shadow:var(--shadow-sm);position:relative}
  .pbx.thr::before{content:"";position:absolute;top:5px;left:50%;transform:translateX(-50%);width:55%;height:3px;background:#1B3034;border-radius:2px}
  .pbx.thr::after{
    content:"";position:absolute;bottom:-12px;left:50%;transform:translateX(-50%);width:72%;height:16px;background:#FDFAF1;
    background-image:repeating-linear-gradient(transparent 0 2px,rgba(0,0,0,.08) 2px 3px);
    box-shadow:0 4px 8px rgba(0,0,0,.1);
  }
  .pbx.imp::before{content:"";position:absolute;top:5px;left:8%;right:8%;height:6px;background:#1B3034;border-radius:2px}
  .pbx.imp::after{content:"";position:absolute;bottom:10%;left:50%;transform:translateX(-50%);width:5px;height:5px;border-radius:999px;background:var(--leaf-500);box-shadow:0 0 6px var(--leaf-500)}
  .pu small{font-family:var(--mono);font-size:9px;color:var(--ink-3);letter-spacing:.08em;text-transform:uppercase}

  /* Scanner */
  .hw-scan{display:flex;gap:16px;width:100%;align-items:center;justify-content:center}
  .sc-h{width:38%;transform:rotate(-6deg)}
  .sc-h .b{background:linear-gradient(135deg,#0F2F33,#06141A);border-radius:4px 4px 14px 14px;aspect-ratio:1/2.2;position:relative;box-shadow:var(--shadow-md)}
  .sc-h .b::before{content:"";position:absolute;top:0;left:12%;right:12%;height:22%;background:#072023;border-radius:3px 3px 0 0;border-top:2px solid var(--leaf-500)}
  .sc-h .b::after{content:"";position:absolute;top:24%;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:999px;background:var(--leaf-500);box-shadow:0 0 6px var(--leaf-500)}
  .sc-o{width:46%}
  .sc-o .b{background:linear-gradient(180deg,#0F2F33,#06141A);border-radius:8px 8px 6px 6px;aspect-ratio:1/1.05;position:relative;box-shadow:var(--shadow-md)}
  .sc-o .b::before{content:"";position:absolute;top:14%;left:14%;right:14%;height:46%;background:#072023;border-radius:4px;border:1px solid rgba(91,185,192,.2)}
  .sc-o .b::after{content:"";position:absolute;top:18%;left:18%;right:18%;height:38%;background-image:repeating-linear-gradient(0deg,transparent 0 2px,rgba(244,194,54,.4) 2px 3px);border-radius:3px}

  /* Cash drawer */
  .hw-drw{width:80%}
  .drw{background:linear-gradient(180deg,#0F2F33,#06141A);border-radius:6px;aspect-ratio:5/3;position:relative;box-shadow:var(--shadow-md)}
  .drw::before{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:10px;height:10px;border-radius:999px;border:2px solid var(--honey-500);background:#06141A}
  .drw::after{content:"";position:absolute;left:6%;right:6%;top:54%;height:1px;background:#1B3034}
  .drw .tr{position:absolute;left:6%;right:6%;top:60%;bottom:8%;display:grid;grid-template-columns:repeat(4,1fr);gap:3px}
  .drw .tr i{background:#1B3034;border-radius:1px}

  /* CFD */
  .hw-cfd{width:88%}
  .cfd{background:linear-gradient(180deg,#0F2F33,#072023);border:5px solid #06141A;border-radius:8px;aspect-ratio:4/2.6;padding:10px 14px;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:4px}
  .cfd .lab{font-family:var(--mono);font-size:8px;color:var(--teal-300);letter-spacing:.1em;text-transform:uppercase}
  .cfd .amt{font-family:var(--font);font-size:28px;font-weight:800;color:#fff;letter-spacing:-.025em;line-height:1}
  .cfd .row{display:flex;justify-content:space-between;font-family:var(--mono);font-size:7px;color:var(--d-ink-2);padding-top:5px;border-top:1px dashed rgba(255,255,255,.1);letter-spacing:.05em}
  .cfd-st{height:10px;width:42%;margin:1px auto 0;background:#06141A;border-radius:0 0 4px 4px}

  /* Software */
  .hw-soft{width:100%;display:flex;flex-direction:column;gap:10px}
  .soft-screen{
    background:linear-gradient(180deg,#FFFFFF,#F4F8F9);border:1px solid var(--line);border-radius:10px;
    padding:10px 12px;box-shadow:var(--shadow-sm);
  }
  .soft-screen .ssh{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
  .soft-screen .ssh b{font-size:11px;font-weight:700;letter-spacing:-.01em;color:var(--ink)}
  .soft-screen .ssh small{font-family:var(--mono);font-size:9px;color:var(--ink-3);letter-spacing:.06em}
  .soft-screen .bars{display:flex;align-items:end;gap:3px;height:42px}
  .soft-screen .bars i{flex:1;background:var(--teal-100);border-radius:2px 2px 0 0;display:block}
  .soft-screen .bars i.h{background:var(--teal-500)}
  .soft-screen .bars i.j{background:var(--leaf-500)}
  .soft-screen .bars i.k{background:var(--honey-500)}

  .android-pos{
    background:linear-gradient(180deg,#062023,#0E2D31);border-radius:14px;padding:8px 6px;aspect-ratio:9/13;width:48%;
    border:1px solid rgba(91,185,192,.2);box-shadow:var(--shadow-md);position:relative;
    margin:0 auto;
  }
  .android-pos::before{content:"";position:absolute;top:4px;left:50%;transform:translateX(-50%);width:30px;height:3px;background:#1B3034;border-radius:2px}
  .android-pos .scr{
    background:linear-gradient(180deg,#072023,#031619);border-radius:8px;aspect-ratio:9/15;padding:6px 5px;
    display:flex;flex-direction:column;gap:5px;border:1px solid rgba(91,185,192,.15);
  }
  .android-pos .scr small{font-family:var(--mono);font-size:6px;color:var(--teal-300);letter-spacing:.08em}
  .android-pos .scr .am{font-size:14px;font-weight:800;color:#fff;letter-spacing:-.015em;line-height:1}
  .android-pos .scr .ln{height:4px;background:rgba(255,255,255,.06);border-radius:1px;display:block}
  .android-pos .scr .ln.s{width:80%}
  .android-pos .scr .ln.m{width:60%}
  .android-pos .scr .py{margin-top:auto;background:linear-gradient(180deg,var(--leaf-500),var(--leaf-700));border-radius:5px;height:20px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:7.5px;font-weight:700;letter-spacing:.06em}

  /* ─── CLOUD ARCHITECTURE — DARK ─── */
  .arch-sec{
    background:linear-gradient(180deg,#06181B 0%,#0A2226 100%);
    color:#fff;padding:120px 0;position:relative;overflow:hidden;
  }
  .arch-sec::before{
    content:"";position:absolute;inset:0;pointer-events:none;
    background-image:
      linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
      linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
    background-size:50px 50px;
    mask-image:radial-gradient(ellipse at 50% 40%,#000 30%,transparent 80%);
  }
  .arch-sec::after{
    content:"";position:absolute;top:-10%;left:-10%;width:60%;height:80%;
    background:radial-gradient(circle,rgba(91,185,192,.18),transparent 60%);
    pointer-events:none;
  }
  .arch-wrap{position:relative;z-index:2;display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start;margin-top:60px}
  .arch-svg{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1}
  .acard{
    background:linear-gradient(180deg,rgba(15,47,51,.6),rgba(10,34,38,.85));
    border:1px solid var(--d-line-2);border-radius:18px;
    padding:28px 26px;backdrop-filter:blur(14px);
    position:relative;z-index:2;
    display:flex;flex-direction:column;gap:14px;
    transition:border-color .2s, transform .2s;
  }
  .acard:hover{border-color:var(--teal-300);transform:translateY(-3px)}
  .acard .tag{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--teal-300)}
  .acard h3{color:#fff;margin:4px 0}
  .acard p{font-size:14px;color:var(--d-ink-2);margin:0;line-height:1.55}
  .acard .a-icon{
    width:54px;height:54px;border-radius:14px;
    background:linear-gradient(135deg,rgba(91,185,192,.16),rgba(91,185,192,.04));
    border:1px solid rgba(91,185,192,.3);
    display:flex;align-items:center;justify-content:center;color:var(--teal-300);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
  }
  .acard.leaf .a-icon{background:linear-gradient(135deg,rgba(93,192,79,.16),rgba(93,192,79,.04));border-color:rgba(93,192,79,.3);color:var(--leaf-300)}
  .acard.honey .a-icon{background:linear-gradient(135deg,rgba(244,194,54,.16),rgba(244,194,54,.04));border-color:rgba(244,194,54,.3);color:var(--honey-300)}
  .acard .a-icon svg{width:26px;height:26px}
  .acard ul{list-style:none;padding:14px 0 0;margin:0;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:8px}
  .acard ul li{display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;color:var(--d-ink-2)}
  .acard ul li b{color:#fff;font-weight:600}

  .arch-core{
    grid-column:1/-1;background:linear-gradient(180deg,rgba(91,185,192,.14),rgba(91,185,192,.04));
    border-color:rgba(91,185,192,.35);
    display:flex;align-items:center;justify-content:space-between;gap:24px;
    padding:22px 28px;flex-wrap:wrap;
  }
  .arch-core .a-icon{background:linear-gradient(135deg,var(--teal-500),var(--teal-700));color:#fff;border-color:transparent}
  .arch-core .chips{display:flex;gap:8px;flex-wrap:wrap}
  .arch-core .chips span{font-family:var(--mono);font-size:10.5px;color:#fff;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);padding:4px 10px;border-radius:999px;letter-spacing:.04em}
  .arch-core .pulse-dot{
    width:14px;height:14px;border-radius:999px;background:var(--leaf-500);
    box-shadow:0 0 0 0 rgba(93,192,79,.6);animation:pulse 2.5s infinite;flex-shrink:0;
  }
  @keyframes pulse{0%{box-shadow:0 0 0 0 rgba(93,192,79,.6)}70%{box-shadow:0 0 0 16px rgba(93,192,79,0)}100%{box-shadow:0 0 0 0 rgba(93,192,79,0)}}

  /* ─── FEATURES (Restaurant POS) — Dark cards on light ─── */
  .feat{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
  .fcard{
    background:linear-gradient(180deg,#0A2226,#06181B);
    border:1px solid var(--d-line-2);border-radius:18px;
    padding:24px 22px;color:#fff;
    position:relative;overflow:hidden;
    transition:transform .2s, box-shadow .2s, border-color .2s;
    display:flex;flex-direction:column;gap:12px;min-height:240px;
  }
  .fcard:hover{transform:translateY(-3px);border-color:var(--teal-300);box-shadow:0 24px 50px -20px rgba(0,0,0,.4)}
  .fcard::before{
    content:"";position:absolute;top:-30%;right:-30%;width:80%;height:80%;
    background:radial-gradient(circle,rgba(91,185,192,.18),transparent 70%);
    pointer-events:none;
  }
  .fcard.leaf::before{background:radial-gradient(circle,rgba(93,192,79,.18),transparent 70%)}
  .fcard.honey::before{background:radial-gradient(circle,rgba(244,194,54,.16),transparent 70%)}
  .fcard .f-icon{
    width:42px;height:42px;border-radius:12px;
    background:rgba(91,185,192,.14);color:var(--teal-300);
    border:1px solid rgba(91,185,192,.3);
    display:flex;align-items:center;justify-content:center;position:relative;z-index:1;
  }
  .fcard.leaf .f-icon{background:rgba(93,192,79,.14);color:var(--leaf-300);border-color:rgba(93,192,79,.3)}
  .fcard.honey .f-icon{background:rgba(244,194,54,.14);color:var(--honey-300);border-color:rgba(244,194,54,.3)}
  .fcard h3{color:#fff;font-size:18px;letter-spacing:-.005em;position:relative;z-index:1;line-height:1.2}
  .fcard p{font-size:13.5px;color:var(--d-ink-2);margin:0;line-height:1.55;position:relative;z-index:1}
  .fcard svg{width:22px;height:22px}

  /* ─── WHY / STATS ─── */
  .why-wrap{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:start}
  .why-points{display:flex;flex-direction:column;gap:14px;margin-top:36px}
  .why-pt{
    display:flex;gap:18px;padding:22px;
    background:#fff;border:1px solid var(--line);border-radius:16px;
    transition:transform .15s, box-shadow .2s, border-color .2s;
  }
  .why-pt:hover{transform:translateX(4px);box-shadow:var(--shadow-md);border-color:var(--teal-300)}
  .why-pt .n{
    width:44px;height:44px;flex-shrink:0;border-radius:12px;
    background:linear-gradient(135deg,var(--teal-100),#fff);
    border:1px solid var(--teal-100);color:var(--teal-700);
    display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-weight:600;font-size:13px;
  }
  .why-pt:nth-child(2) .n{background:linear-gradient(135deg,var(--leaf-100),#fff);border-color:var(--leaf-100);color:var(--leaf-700)}
  .why-pt:nth-child(3) .n{background:linear-gradient(135deg,var(--honey-100),#fff);border-color:var(--honey-100);color:#9C7110}
  .why-pt:nth-child(4) .n{background:linear-gradient(135deg,var(--teal-100),#fff);border-color:var(--teal-100);color:var(--teal-700)}
  .why-pt:nth-child(5) .n{background:linear-gradient(135deg,var(--leaf-100),#fff);border-color:var(--leaf-100);color:var(--leaf-700)}
  .why-pt h4{margin:0 0 6px;font-size:16px;letter-spacing:-.01em}
  .why-pt p{margin:0;font-size:13.5px;color:var(--ink-2);line-height:1.55}

  .stats{
    background:linear-gradient(180deg,#0F4A50,#082225);
    border-radius:24px;padding:36px;color:#fff;
    position:relative;overflow:hidden;
    box-shadow:var(--shadow-lg);
  }
  .stats::before{
    content:"";position:absolute;inset:0;
    background:
      radial-gradient(circle at 100% 0%,rgba(93,192,79,.25),transparent 50%),
      radial-gradient(circle at 0% 100%,rgba(244,194,54,.18),transparent 50%);
    pointer-events:none;
  }
  .stats h3{color:#fff;font-size:20px;margin-bottom:6px;position:relative;z-index:1}
  .stats p{color:var(--d-ink-2);font-size:13.5px;margin:0 0 24px;position:relative;z-index:1}
  .stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;position:relative;z-index:1}
  .stat{
    background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
    border-radius:14px;padding:18px 18px;
  }
  .stat b{font-size:32px;font-weight:800;letter-spacing:-.025em;color:#fff;display:block;line-height:1}
  .stat b .pct{color:var(--leaf-300);font-size:20px;margin-left:1px}
  .stat b .x{color:var(--honey-300)}
  .stat small{display:block;font-size:11px;color:var(--d-ink-2);margin-top:6px;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase}

  /* ─── CUSTOM SOFTWARE ─── */
  .sof{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:center}
  .sof-list{display:flex;flex-direction:column;gap:10px;margin-top:34px}
  .sli{display:flex;gap:14px;align-items:center;padding:14px 18px;background:#fff;border:1px solid var(--line);border-radius:12px;font-size:14px;color:var(--ink-2)}
  .sli .ck{width:24px;height:24px;border-radius:8px;background:var(--leaf-100);color:var(--leaf-700);display:flex;align-items:center;justify-content:center;flex-shrink:0}
  .sli b{color:var(--ink);font-weight:700;margin-right:6px}

  .sof-visual{
    position:relative;aspect-ratio:1/1;min-height:480px;
    background:linear-gradient(160deg,var(--bg-tint),var(--bg-soft));
    border:1px solid var(--line);border-radius:24px;overflow:hidden;
    box-shadow:var(--shadow-md);
  }
  .sof-visual::before{
    content:"";position:absolute;inset:0;
    background-image:
      linear-gradient(rgba(8,25,27,.04) 1px,transparent 1px),
      linear-gradient(90deg,rgba(8,25,27,.04) 1px,transparent 1px);
    background-size:24px 24px;
    mask-image:radial-gradient(ellipse,#000 40%,transparent 90%);
  }
  .sv{position:absolute;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px;box-shadow:var(--shadow-md);z-index:2}
  .sv .svh{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;gap:8px}
  .sv .svh b{font-size:12.5px;font-weight:700;color:var(--ink);letter-spacing:-.005em}
  .sv .svh small{font-family:var(--mono);font-size:9px;color:var(--ink-3);letter-spacing:.06em}
  .sv .pill{padding:2px 8px;border-radius:999px;background:var(--leaf-100);color:var(--leaf-700);font-family:var(--mono);font-size:8.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}

  .sv1{top:6%;left:5%;width:50%}
  .sv1 .rows{display:flex;flex-direction:column;gap:5px}
  .sv1 .rows .r{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;padding:4px 8px;border-radius:5px;background:var(--bg-soft);color:var(--ink-2)}
  .sv1 .rows .r b{color:var(--ink);font-weight:600}

  .sv2{top:36%;right:5%;width:48%}
  .sv2 .bars{display:flex;align-items:end;gap:4px;height:60px;margin-bottom:8px}
  .sv2 .bars i{flex:1;background:var(--teal-100);border-radius:3px 3px 0 0;display:block}
  .sv2 .bars i.t{background:var(--teal-500)}
  .sv2 .bars i.l{background:var(--leaf-500)}
  .sv2 .bars i.h{background:var(--honey-500)}
  .sv2 .leg{display:flex;justify-content:space-between;font-family:var(--mono);font-size:9px;color:var(--ink-3);letter-spacing:.05em}

  .sv3{bottom:6%;left:12%;width:54%;display:flex;align-items:center;gap:10px}
  .sv3 .ic{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--honey-500),var(--honey-600));color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:18px}
  .sv3 b{font-size:12.5px;color:var(--ink);font-weight:700}
  .sv3 .ms{font-family:var(--mono);font-size:9.5px;color:var(--ink-3);letter-spacing:.05em;display:block;margin-top:2px}

  .sof-visual .grad-orb{position:absolute;border-radius:50%;filter:blur(60px);pointer-events:none}
  .sof-visual .grad-orb.g1{top:-15%;right:-15%;width:55%;height:55%;background:radial-gradient(circle,rgba(91,185,192,.4),transparent 70%)}
  .sof-visual .grad-orb.g2{bottom:-15%;left:-15%;width:55%;height:55%;background:radial-gradient(circle,rgba(93,192,79,.35),transparent 70%)}

  /* ─── HARDWARE SHOWCASE — Apple-like presentation ─── */
  .show{
    background:linear-gradient(180deg,#FFFFFF,var(--bg-soft));
    border-top:1px solid var(--line);border-bottom:1px solid var(--line);
    padding:120px 0;
  }
  .show-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:50px}
  .show-card{
    background:#fff;border:1px solid var(--line);border-radius:22px;
    padding:40px;display:flex;gap:32px;align-items:center;min-height:340px;
    transition:transform .2s,box-shadow .2s,border-color .2s;
    position:relative;overflow:hidden;
  }
  .show-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--teal-300)}
  .show-card::before{
    content:"";position:absolute;inset:0;pointer-events:none;
    background-image:
      linear-gradient(rgba(8,25,27,.03) 1px,transparent 1px),
      linear-gradient(90deg,rgba(8,25,27,.03) 1px,transparent 1px);
    background-size:24px 24px;
    mask-image:radial-gradient(circle at 80% 50%,#000 30%,transparent 80%);
    opacity:.5;
  }
  .show-body{flex:1;position:relative;z-index:1}
  .show-body .stag{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--teal-600)}
  .show-body h3{margin:8px 0 8px;font-size:22px}
  .show-body p{font-size:14px;color:var(--ink-2);margin:0 0 16px;line-height:1.55}
  .show-body .row{display:flex;flex-wrap:wrap;gap:5px}
  .show-body .row span{font-family:var(--mono);font-size:10.5px;color:var(--ink-2);background:var(--bg-tint);border:1px solid var(--line);padding:3px 9px;border-radius:999px}
  .show-art{flex:1;display:flex;align-items:center;justify-content:center;position:relative;z-index:1;min-height:240px}

  /* ─── CTA BANNER ─── */
  .ctab{
    margin:0 28px;border-radius:28px;
    background:linear-gradient(135deg,#0F4A50 0%,#0A3338 60%,#082225 100%);
    color:#fff;padding:64px 56px;position:relative;overflow:hidden;
  }
  .ctab::before{
    content:"";position:absolute;inset:0;
    background:
      radial-gradient(circle at 90% 10%,rgba(93,192,79,.30),transparent 55%),
      radial-gradient(circle at 10% 90%,rgba(244,194,54,.20),transparent 55%);
    pointer-events:none;
  }
  .ctab::after{
    content:"";position:absolute;inset:0;
    background-image:
      linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
      linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
    background-size:42px 42px;
    mask-image:radial-gradient(ellipse,#000 30%,transparent 80%);
    pointer-events:none;
  }
  .ctab-in{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:center;gap:40px;flex-wrap:wrap}
  .ctab h2{color:#fff;font-size:42px;margin:8px 0 14px;letter-spacing:-.03em;text-wrap:balance;line-height:1.05}
  .ctab p{color:var(--d-ink-2);font-size:16px;margin:0;max-width:520px;line-height:1.6}
  .ctab-r{display:flex;gap:12px;flex-wrap:wrap}

  /* ─── FOOTER ─── */
  footer{background:#06181B;color:#A6BCBF;padding:80px 0 36px;margin-top:120px}
  .foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;gap:42px;margin-bottom:56px}
  .foot-brand .logo .lt b{color:#fff}
  .foot-brand .logo .lt small{color:#7E9EA3}
  .foot-brand p{font-size:14px;color:#9FB8BC;max-width:340px;margin:18px 0 22px;line-height:1.6}
  .foot-contact{display:flex;flex-direction:column;gap:6px;font-size:13px;font-family:var(--mono)}
  .foot-contact span{color:#9FB8BC}
  .foot-contact b{color:#fff;font-weight:500}
  .foot-col h5{font-size:11px;color:#7E9EA3;text-transform:uppercase;letter-spacing:.14em;font-weight:600;font-family:var(--mono);margin:0 0 18px}
  .foot-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
  .foot-col a{font-size:13.5px;color:#9FB8BC;transition:color .15s}
  .foot-col a:hover{color:#fff}
  .foot-bot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;padding-top:32px;border-top:1px solid rgba(255,255,255,.08);font-size:12px;font-family:var(--mono);letter-spacing:.04em;color:#7E9EA3}
  .foot-social{display:flex;gap:8px}
  .foot-social a{width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:#9FB8BC;transition:background .15s,color .15s,border-color .15s}
  .foot-social a:hover{background:rgba(91,185,192,.12);border-color:rgba(91,185,192,.3);color:var(--teal-300)}

  /* ─── HAMBURGER BUTTON ─── */
  .hamburger{
    display:none;align-items:center;justify-content:center;
    width:42px;height:42px;border-radius:10px;
    background:rgba(8,25,27,.06);border:1px solid var(--line);
    cursor:pointer;padding:0;color:var(--ink);
    transition:background .2s, border-color .2s, color .2s, transform .2s;
    flex-shrink:0;
  }
  .hamburger:hover{background:var(--bg-tint);border-color:var(--teal-500);color:var(--teal-700)}
  .hamburger.active{background:var(--teal-700);border-color:var(--teal-700);color:#fff}

  /* SVG line animations */
  .ham-icon line{transition:transform .3s cubic-bezier(.4,0,.2,1), opacity .25s ease}
  .ham-icon{transform-origin:center;overflow:visible}
  .hamburger.active .ham-top{transform:translateY(5px) rotate(45deg);transform-origin:center}
  .hamburger.active .ham-mid{opacity:0;transform:scaleX(0);transform-origin:center}
  .hamburger.active .ham-bot{transform:translateY(-5px) rotate(-45deg);transform-origin:center}

  /* ─── MOBILE NAV DRAWER ─── */
  .nav-overlay{
    position:fixed;inset:0;background:rgba(6,24,27,.55);z-index:199;
    backdrop-filter:blur(3px);animation:fadeIn .2s ease;
  }
  @keyframes fadeIn{from{opacity:0}to{opacity:1}}

  .nav-drawer-header{
    display:none;align-items:center;justify-content:space-between;
    padding-bottom:20px;margin-bottom:8px;
    border-bottom:1px solid var(--line);
  }
  .nav-drawer-title{
    font-family:var(--mono);font-size:11px;font-weight:600;
    letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);
  }
  .nav-drawer-close{
    width:34px;height:34px;border-radius:8px;background:var(--bg-soft);
    border:1px solid var(--line);color:var(--ink-2);cursor:pointer;padding:0;
    display:flex;align-items:center;justify-content:center;
    transition:background .15s,border-color .15s,color .15s;
  }
  .nav-drawer-close:hover{background:var(--bg-tint);border-color:var(--teal-300);color:var(--teal-700)}

  .nav-drawer-links{display:contents}
  .nav-drawer-footer{display:none}
  .nav-mobile-panel{display:none}

  /* ─── RESPONSIVE ─── */

  /* ── 1100px: tablet landscape ── */
  @media (max-width:1100px){
    h1.hero-title{font-size:52px}
    h2{font-size:38px}
    .hero-grid{gap:40px}
    .eco{grid-template-columns:repeat(6,1fr)}
    .ecard,.ecard.wide{grid-column:span 6}
    .ecard.tall{grid-row:auto}
    .feat{grid-template-columns:repeat(2,1fr)}
    .arch-wrap{grid-template-columns:1fr 1fr}
    .arch-core{grid-column:1/-1}
    .foot-grid{grid-template-columns:1.4fr 1fr 1fr}
  }

  /* ── 960px: tablet portrait / small laptop ── */
  @media (max-width:960px){
    .hamburger{display:flex}

    /* Hide desktop nav links, show mobile drawer */
    .nav-links{display:none}
    .nav-mobile-panel{
      display:flex;
      position:fixed;top:0;right:0;bottom:0;
      width:min(340px,88vw);
      height:100dvh;
      background:#fff;
      border-left:1px solid var(--line);
      padding:0;gap:0;
      z-index:200;
      transform:translateX(100%);
      transition:transform .32s cubic-bezier(.4,0,.2,1);
      box-shadow:-12px 0 40px rgba(8,25,27,.16);
      overflow:hidden;
      flex-direction:column;
    }
    .nav-mobile-panel.open{transform:translateX(0)}

    /* Show drawer header & footer */
    .nav-drawer-header{display:flex;padding:24px 24px 20px}
    .nav-drawer-links{display:flex;flex-direction:column;flex:1;overflow-y:auto;padding:8px 16px}
    .nav-drawer-footer{
      display:flex;flex-direction:column;gap:2px;
      padding:20px 24px;border-top:1px solid var(--line);
      font-size:12px;color:var(--ink-3);font-family:var(--mono);
      letter-spacing:.04em;
    }
    .nav-drawer-footer span{font-weight:600;color:var(--ink-2)}
    .nav-drawer-footer small{font-size:10.5px;color:var(--ink-3)}

    /* Link rows */
    .nav-drawer-links a{
      display:flex;align-items:center;gap:14px;
      padding:14px 12px;border-radius:12px;
      font-size:15px;font-weight:600;color:var(--ink);
      text-decoration:none;
      transition:background .15s, color .15s;
      position:relative;
      border:1px solid transparent;
    }
    .nav-drawer-links a:hover{
      background:var(--bg-tint);border-color:var(--line);color:var(--teal-700);
    }
    .nav-drawer-links a.active{
      background:var(--teal-50,#f0fafa);border-color:var(--teal-300);color:var(--teal-700);
    }
    .nav-drawer-links a.active .nav-link-icon{background:var(--teal-100);border-color:var(--teal-400);color:var(--teal-700)}
    .nav-drawer-links a.active .nav-link-arrow{opacity:1;transform:translateX(0);color:var(--teal-500)}
    .nav-drawer-links a .nav-link-icon{
      width:36px;height:36px;border-radius:10px;flex-shrink:0;
      background:var(--bg-soft);border:1px solid var(--line);
      display:flex;align-items:center;justify-content:center;
      color:var(--teal-600);transition:background .15s,border-color .15s;
    }
    .nav-drawer-links a:hover .nav-link-icon{background:var(--teal-100);border-color:var(--teal-300)}
    .nav-drawer-links a span:not(.nav-link-icon):not(.nav-link-arrow){flex:1}
    .nav-drawer-links a .nav-link-arrow{
      font-size:14px;color:var(--ink-3);opacity:0;
      transform:translateX(-4px);
      transition:opacity .15s, transform .15s;
    }
    .nav-drawer-links a:hover .nav-link-arrow{opacity:1;transform:translateX(0)}

    /* Contact CTA link */
    .nav-drawer-links a.nav-link-cta{
      margin-top:10px;
      background:linear-gradient(180deg,var(--teal-700),var(--teal-800));
      color:#fff;border-color:transparent;
    }
    .nav-drawer-links a.nav-link-cta .nav-link-icon{
      background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.18);color:#fff;
    }
    .nav-drawer-links a.nav-link-cta:hover{
      background:linear-gradient(180deg,var(--teal-600),var(--teal-700));
      color:#fff;
    }
    .nav-drawer-links a.nav-link-cta .nav-link-arrow{color:rgba(255,255,255,.7)}
    .nav-drawer-links a.nav-link-cta:hover .nav-link-arrow{opacity:1;color:#fff}

    /* Hide desktop-only caret */

    .hero-grid{grid-template-columns:1fr;gap:48px}
    .hero-stage{min-height:420px;margin-top:8px}
    h1.hero-title{font-size:48px}
    .why-wrap,.sof{grid-template-columns:1fr;gap:40px}
    .show-grid{grid-template-columns:1fr}
    .show-card{flex-direction:column;align-items:flex-start;padding:28px}
    .show-art{min-height:180px;width:100%}
    .arch-wrap{grid-template-columns:1fr;gap:18px}
    .arch-svg{display:none}
    .stats{margin-top:0}
  }

  /* ── 768px: tablet ── */
  @media (max-width:768px){
    h1.hero-title{font-size:40px}
    h2{font-size:32px}
    h3{font-size:20px}
    .hero{padding:64px 0 72px}
    .hero-sub{font-size:16px}
    .hero-strip{gap:18px;margin-top:32px;padding-top:22px}
    .hero-strip .h-stat b{font-size:18px}
    .hero-strip .h-div{display:none}
    section.block,.arch-sec,.show{padding:72px 0}
    .sec-head{margin-bottom:42px}
    .sec-head h2{font-size:30px}
    .feat{grid-template-columns:1fr 1fr}
    .fcard{min-height:200px}
    .stats-grid{grid-template-columns:1fr 1fr}
    .sof-visual{min-height:360px}
    .foot-grid{grid-template-columns:1fr 1fr}
    .ctab{margin:0 16px;padding:48px 32px}
    .ctab h2{font-size:32px}
    .strip-in{flex-direction:column;align-items:flex-start;gap:18px}
    .arch-wrap{margin-top:36px}
    /* hide heavy hero stage visuals on tablet to keep it clean */
    .chip{display:none}
  }

  /* ── 640px: large mobile ── */
  @media (max-width:640px){
    .wrap{padding:0 18px}
    h1.hero-title{font-size:34px;letter-spacing:-.025em}
    h2{font-size:28px}
    .hero{padding:56px 0 64px}
    .hero-tag{font-size:11px}
    .hero-ctas{flex-direction:column;gap:10px}
    .hero-ctas .btn{width:100%;justify-content:center;font-size:15px}
    .hero-strip{gap:14px}
    /* hide complex hero stage on mobile */
    .hero-stage{display:none}
    section.block,.arch-sec,.show{padding:56px 0}
    .feat{grid-template-columns:1fr}
    .fcard{min-height:auto;padding:20px 18px}
    .eco{grid-template-columns:1fr}
    .ecard,.ecard.wide{grid-column:span 1}
    .ecard{padding:20px}
    .ecard.hero-hw .vbox{flex-direction:column}
    .why-wrap{gap:32px}
    .stats{padding:24px}
    .stats-grid{grid-template-columns:1fr 1fr;gap:10px}
    .stat{padding:14px}
    .stat b{font-size:26px}
    .ctab{margin:0 12px;padding:36px 22px;border-radius:20px}
    .ctab h2{font-size:26px}
    .ctab-in{flex-direction:column;gap:28px}
    .ctab-r{flex-direction:column;width:100%}
    .ctab-r .btn{width:100%;justify-content:center}
    .show-card{padding:22px 18px}
    .show-grid{gap:12px}
    .foot-grid{grid-template-columns:1fr}
    .foot-bot{flex-direction:column;text-align:center;gap:16px}
    .sof{gap:32px}
    .sof-visual{min-height:300px}
    .arch-wrap{gap:12px}
    .acard{padding:20px 18px}
    .arch-core{flex-direction:column;gap:16px}
    footer{padding:56px 0 28px;margin-top:72px}
    .strip-items{gap:8px}
    .si{padding:8px 12px;font-size:12.5px}
  }

  /* ── 420px: small mobile ── */
  @media (max-width:420px){
    h1.hero-title{font-size:30px}
    h2{font-size:26px}
    .hero-strip{flex-direction:column;align-items:flex-start;gap:12px}
    .stats-grid{grid-template-columns:1fr}
    .feat{grid-template-columns:1fr}
    .ctab h2{font-size:23px}
    .nav-in{padding:0 16px}
  }


