/* ================================================================
   DINESH GHIMIRE — SHARED STYLESHEET
   Used across: index, systems, portfolio, about, contact
   ================================================================ */

/* ----- 1. TOKENS ----- */
:root {
  --blue-50:#eff6ff; --blue-100:#dbeafe; --blue-200:#bfdbfe; --blue-300:#93c5fd;
  --blue-500:#3b82f6; --blue-600:#2563eb; --blue-700:#1d4ed8; --blue-900:#1e3a8a;
  --violet-500:#8b5cf6; --violet-600:#7c3aed; --indigo-600:#4f46e5; --indigo-900:#312e81;

  --ink-950:#020617; --ink-900:#0f172a; --ink-800:#1e293b; --ink-700:#334155;
  --ink-600:#475569; --ink-500:#64748b; --ink-400:#94a3b8; --ink-300:#cbd5e1;
  --ink-200:#e2e8f0; --ink-100:#f1f5f9; --ink-50:#f8fafc; --white:#ffffff;

  --green-500:#10b981; --green-100:#d1fae5;
  --amber-500:#f59e0b; --amber-100:#fef3c7;
  --rose-500:#ef4444;  --rose-100:#fee2e2;

  --border:#e2e8f0; --border-soft:#eef2f7;

  --shadow-xs:0 1px 2px rgba(15,23,42,.04);
  --shadow-sm:0 2px 6px rgba(15,23,42,.06);
  --shadow-md:0 12px 32px -8px rgba(15,23,42,.12);
  --shadow-lg:0 30px 60px -20px rgba(37,99,235,.25);
  --shadow-xl:0 50px 100px -30px rgba(30,58,138,.35);

  --r-xs:6px; --r-sm:10px; --r-md:16px; --r-lg:22px; --r-xl:28px; --r-2xl:36px;
  --container:1200px;

  --grad-primary:linear-gradient(120deg,#2563eb 0%,#6366f1 50%,#8b5cf6 100%);
  --grad-text:linear-gradient(120deg,#1d4ed8 0%,#6366f1 60%,#8b5cf6 100%);
  --grad-dark:linear-gradient(135deg,#0f172a 0%,#1e1b4b 60%,#1e3a8a 100%);

  --ease:cubic-bezier(.2,.8,.2,1);
}

/* ----- 2. BASE ----- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  color:var(--ink-900);background:var(--white);line-height:1.6;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
a{color:var(--blue-600);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--blue-700)}
img,svg{display:block;max-width:100%}
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 24px}
.display{font-family:'Space Grotesk','Inter',sans-serif;letter-spacing:-.025em}
body.no-scroll{overflow:hidden}

/* Noise overlay */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;opacity:.025;z-index:9999;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ----- 3. BUTTONS ----- */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:15px 28px;font-weight:600;font-size:15px;
  border-radius:999px;border:1px solid transparent;
  cursor:pointer;white-space:nowrap;font-family:inherit;
  transition:transform .2s var(--ease),box-shadow .3s var(--ease),background .2s,color .2s,border-color .2s;
}
.btn:active{transform:translateY(1px)}
.btn svg{transition:transform .2s var(--ease)}
.btn:hover svg.arrow{transform:translateX(3px)}
.btn-primary{
  background:var(--grad-primary);color:#fff;
  box-shadow:0 10px 24px -6px rgba(37,99,235,.45),inset 0 1px 0 rgba(255,255,255,.18);
}
.btn-primary:hover{
  color:#fff;transform:translateY(-2px);
  box-shadow:0 18px 36px -8px rgba(37,99,235,.55),inset 0 1px 0 rgba(255,255,255,.22);
}
.btn-secondary{
  background:rgba(255,255,255,.7);color:var(--ink-900);
  border-color:var(--ink-200);backdrop-filter:blur(8px);
}
.btn-secondary:hover{
  background:#fff;border-color:var(--blue-300);color:var(--blue-700);
  transform:translateY(-2px);box-shadow:var(--shadow-sm);
}
.btn-ghost{background:transparent;color:var(--ink-700)}
.btn-ghost:hover{color:var(--blue-700)}
.btn-sm{padding:10px 18px;font-size:13px}
.btn-lg{padding:18px 34px;font-size:16px}
.btn-dark{background:var(--ink-900);color:#fff}
.btn-dark:hover{background:var(--ink-800);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md)}

/* ----- 4. NAVIGATION ----- */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.72);
  backdrop-filter:saturate(180%) blur(18px);
  -webkit-backdrop-filter:saturate(180%) blur(18px);
  border-bottom:1px solid rgba(226,232,240,.7);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:76px}
.brand{
  display:flex;align-items:center;gap:12px;
  font-weight:800;font-size:17px;color:var(--ink-900);
  font-family:'Space Grotesk',sans-serif;letter-spacing:-.01em;
}
.brand-mark{
  width:40px;height:40px;border-radius:12px;
  background:var(--grad-primary);color:#fff;
  display:grid;place-items:center;
  font-weight:800;font-size:15px;
  box-shadow:0 8px 20px -6px rgba(37,99,235,.55),inset 0 1px 0 rgba(255,255,255,.25);
}
.nav-links{display:flex;align-items:center;gap:32px}
.nav-links a:not(.nav-cta){
  color:var(--ink-700);font-weight:500;font-size:14.5px;position:relative;
}
.nav-links a:not(.nav-cta)::after{
  content:"";position:absolute;bottom:-6px;left:0;right:0;height:2px;
  background:var(--grad-primary);transform:scaleX(0);transform-origin:center;
  transition:transform .25s var(--ease);border-radius:2px;
}
.nav-links a:not(.nav-cta):hover{color:var(--ink-900)}
.nav-links a:not(.nav-cta):hover::after{transform:scaleX(1)}
.nav-links a.nav-current{color:var(--blue-700);font-weight:700}
.nav-links a.nav-current::after{transform:scaleX(1)}
.nav-cta{padding:11px 22px;font-size:14px}
.nav-toggle{
  display:none;background:transparent;border:1px solid var(--ink-200);
  border-radius:10px;padding:8px;color:var(--ink-800);cursor:pointer;
}
@media (max-width:880px){
  .nav-links{
    position:fixed;inset:76px 0 0 0;
    background:#fff;flex-direction:column;
    padding:32px 24px;gap:8px;align-items:stretch;
    border-top:1px solid var(--border);
    transform:translateX(100%);transition:transform .3s var(--ease);
    z-index:49;
  }
  body.nav-open .nav-links{transform:none}
  .nav-links a:not(.nav-cta){
    padding:14px 16px;border-radius:10px;font-size:16px;
  }
  .nav-links a:not(.nav-cta):hover{background:var(--ink-50)}
  .nav-links a:not(.nav-cta)::after{display:none}
  .nav-links .nav-cta{margin-top:12px;justify-content:center}
  .nav-toggle{display:inline-flex}
}

/* ----- 5. HERO (home) ----- */
.hero{
  position:relative;padding:100px 0 120px;overflow:hidden;background:#fff;
}
.hero::before,.hero::after{
  content:"";position:absolute;border-radius:50%;filter:blur(80px);z-index:0;
}
.hero::before{
  width:600px;height:600px;top:-200px;right:-200px;
  background:radial-gradient(circle,rgba(99,102,241,.25),transparent 60%);
}
.hero::after{
  width:500px;height:500px;bottom:-200px;left:-150px;
  background:radial-gradient(circle,rgba(37,99,235,.18),transparent 60%);
}
.hero-grid-bg{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(15,23,42,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(15,23,42,.04) 1px,transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse at center,#000 30%,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at center,#000 30%,transparent 75%);
  z-index:0;
}
.hero-inner{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center;
}
@media (max-width:980px){
  .hero-inner{grid-template-columns:1fr;gap:50px}
  .hero{padding:70px 0 90px}
}
.pill{
  display:inline-flex;align-items:center;gap:10px;
  padding:7px 16px;background:rgba(255,255,255,.7);backdrop-filter:blur(8px);
  color:var(--ink-800);border:1px solid var(--ink-200);
  border-radius:999px;font-size:13px;font-weight:600;
  margin-bottom:26px;box-shadow:var(--shadow-xs);
}
.pill .dot{
  width:8px;height:8px;background:var(--green-500);border-radius:50%;
  box-shadow:0 0 0 4px rgba(16,185,129,.18);
  animation:pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 4px rgba(16,185,129,.18)}
  50%{box-shadow:0 0 0 8px rgba(16,185,129,.04)}
}
h1.hero-title{
  font-family:'Space Grotesk',sans-serif;
  font-size:clamp(38px,5.6vw,68px);line-height:1.04;
  font-weight:700;letter-spacing:-.035em;margin:0 0 24px;
  color:var(--ink-900);
}
h1.hero-title .accent{
  background:var(--grad-text);
  -webkit-background-clip:text;background-clip:text;color:transparent;display:inline-block;
}
.hero-sub{
  font-size:19px;color:var(--ink-700);max-width:580px;margin:0 0 36px;line-height:1.6;
}
.hero-sub strong{color:var(--ink-900);font-weight:700}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px}
.trust-row{display:flex;gap:28px;flex-wrap:wrap;align-items:center}
.trust-item{display:flex;align-items:center;gap:10px;color:var(--ink-700);font-size:14px;font-weight:500}
.trust-item .check{
  width:22px;height:22px;border-radius:50%;
  background:var(--green-100);color:var(--green-500);
  display:grid;place-items:center;flex-shrink:0;
}

/* Floating hero card */
.hero-visual{position:relative;min-height:520px}
.float-card{
  position:absolute;background:#fff;border:1px solid var(--border);
  border-radius:var(--r-md);box-shadow:var(--shadow-lg);overflow:hidden;
  transition:transform .3s var(--ease);
}
.float-card:hover{transform:translateY(-6px) rotate(0deg)!important}
.fc-main{width:100%;max-width:460px;top:0;right:0;transform:rotate(-2deg);animation:fa 6s ease-in-out infinite}
.fc-main .topbar{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#f3f6fb;border-bottom:1px solid var(--border)}
.fc-main .topbar .d{width:11px;height:11px;border-radius:50%;background:var(--ink-300)}
.fc-main .topbar .d.r{background:#ef4444}.fc-main .topbar .d.y{background:#f59e0b}.fc-main .topbar .d.g{background:#10b981}
.fc-main .topbar .tab{
  margin-left:8px;background:#fff;border:1px solid var(--ink-200);
  border-radius:6px;padding:5px 12px;font-size:11px;color:var(--ink-700);font-weight:600;
  font-family:'Space Grotesk',sans-serif;
}
.fc-main .body{padding:18px 20px 22px}
.fc-main .greeting{font-size:13px;color:var(--ink-500);margin-bottom:4px}
.fc-main .hello{font-family:'Space Grotesk',sans-serif;font-size:20px;font-weight:700;color:var(--ink-900);margin-bottom:16px}
.fc-main .kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}
.fc-main .kpi{background:var(--ink-50);border-radius:var(--r-sm);padding:12px}
.fc-main .kpi .l{font-size:10px;color:var(--ink-500);font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.fc-main .kpi .v{font-family:'Space Grotesk',sans-serif;font-size:18px;font-weight:700;color:var(--ink-900);margin-top:4px}
.fc-main .kpi .v.up{color:var(--green-500)}
.fc-main .chart{height:90px;padding:12px;background:linear-gradient(180deg,var(--blue-50),transparent);border-radius:var(--r-sm);display:flex;align-items:flex-end;gap:6px}
.fc-main .chart .bar{flex:1;border-radius:4px 4px 0 0;background:linear-gradient(180deg,var(--blue-500),var(--blue-700));animation:grow 1.2s var(--ease) both}
@keyframes grow{from{transform:scaleY(.2);transform-origin:bottom}to{transform:scaleY(1)}}
.fc-notif{
  width:240px;bottom:60px;left:-30px;padding:14px 16px;
  transform:rotate(-4deg);animation:fb 7s ease-in-out infinite;
  display:flex;align-items:center;gap:12px;
}
.fc-notif .icon{
  width:40px;height:40px;border-radius:12px;
  background:linear-gradient(135deg,var(--green-500),#059669);
  color:#fff;display:grid;place-items:center;flex-shrink:0;
  box-shadow:0 8px 18px -4px rgba(16,185,129,.45);
}
.fc-notif .txt .t{font-size:13px;font-weight:700;color:var(--ink-900)}
.fc-notif .txt .s{font-size:11px;color:var(--ink-500);margin-top:2px}
.fc-pay{
  width:220px;top:-10px;left:-20px;padding:14px 16px;
  transform:rotate(3deg);animation:fc 8s ease-in-out infinite;
}
.fc-pay .label{font-size:11px;color:var(--ink-500);font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.fc-pay .amt{font-family:'Space Grotesk',sans-serif;font-size:22px;font-weight:700;color:var(--ink-900);margin:4px 0 6px}
.fc-pay .row{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--green-500);font-weight:700}
.fc-pay .row::before{content:"▲";font-size:8px}
@keyframes fa{0%,100%{transform:rotate(-2deg) translateY(0)}50%{transform:rotate(-2deg) translateY(-10px)}}
@keyframes fb{0%,100%{transform:rotate(-4deg) translateY(0)}50%{transform:rotate(-4deg) translateY(-8px)}}
@keyframes fc{0%,100%{transform:rotate(3deg) translateY(0)}50%{transform:rotate(3deg) translateY(-6px)}}
@media (max-width:600px){
  .fc-main{max-width:100%;transform:rotate(0)!important;animation:none}
  .fc-notif,.fc-pay{display:none}
  .hero-visual{min-height:380px}
}

/* ----- 6. PAGE HERO (subpages) ----- */
.page-hero{
  position:relative;padding:80px 0 70px;overflow:hidden;background:#fff;text-align:center;
}
.page-hero::before{
  content:"";position:absolute;
  width:700px;height:400px;top:-200px;right:-100px;
  border-radius:50%;filter:blur(80px);
  background:radial-gradient(circle,rgba(99,102,241,.18),transparent 60%);
}
.page-hero::after{
  content:"";position:absolute;
  width:500px;height:300px;bottom:-150px;left:-150px;
  border-radius:50%;filter:blur(80px);
  background:radial-gradient(circle,rgba(37,99,235,.14),transparent 60%);
}
.page-hero .container{position:relative;z-index:1}
.page-hero h1{
  font-family:'Space Grotesk',sans-serif;
  font-size:clamp(34px,4.8vw,56px);line-height:1.08;
  font-weight:700;letter-spacing:-.03em;margin:14px auto 18px;max-width:840px;
}
.page-hero h1 .accent{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}
.page-hero p{
  color:var(--ink-700);font-size:18px;max-width:680px;margin:0 auto 28px;
}

/* ----- 7. MARQUEE ----- */
.marquee{
  padding:30px 0;background:#fff;
  border-top:1px solid var(--border-soft);border-bottom:1px solid var(--border-soft);
  overflow:hidden;position:relative;
}
.marquee::before,.marquee::after{
  content:"";position:absolute;top:0;bottom:0;width:100px;z-index:2;pointer-events:none;
}
.marquee::before{left:0;background:linear-gradient(90deg,#fff,transparent)}
.marquee::after{right:0;background:linear-gradient(-90deg,#fff,transparent)}
.marquee-track{
  display:flex;gap:60px;align-items:center;
  animation:scroll 30s linear infinite;width:max-content;
}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee-item{
  font-family:'Space Grotesk',sans-serif;font-size:18px;font-weight:700;
  color:var(--ink-400);white-space:nowrap;
  display:flex;align-items:center;gap:10px;
}
.marquee-item .ic{font-size:22px}

/* ----- 8. SECTION COMMON ----- */
section{padding:110px 0;position:relative}
@media (max-width:700px){section{padding:72px 0}}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--blue-700);font-weight:700;font-size:12.5px;
  text-transform:uppercase;letter-spacing:.14em;margin-bottom:14px;
}
.eyebrow::before{content:"";width:24px;height:2px;background:var(--grad-primary);border-radius:2px}
h2.section-title{
  font-family:'Space Grotesk',sans-serif;
  font-size:clamp(30px,4vw,46px);font-weight:700;letter-spacing:-.03em;
  margin:0 0 16px;color:var(--ink-900);line-height:1.1;
}
.section-title .accent{
  background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.section-sub{color:var(--ink-700);font-size:17px;max-width:680px;margin:0 0 56px;line-height:1.6}
.section-head.center{text-align:center}
.section-head.center .eyebrow{justify-content:center}
.section-head.center .section-sub{margin-left:auto;margin-right:auto}

/* ----- 9. STATS (dark) ----- */
.stats{
  padding:60px 0;background:var(--grad-dark);color:#fff;
  position:relative;overflow:hidden;
}
.stats::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(600px 300px at 20% -20%,rgba(99,102,241,.4),transparent 60%),
    radial-gradient(500px 300px at 80% 120%,rgba(139,92,246,.3),transparent 60%);
}
.stats-grid{
  position:relative;z-index:1;display:grid;
  grid-template-columns:repeat(4,1fr);gap:30px;
}
.stat{text-align:center;padding:10px}
.stat .n{
  font-family:'Space Grotesk',sans-serif;
  font-size:clamp(36px,5vw,56px);font-weight:700;line-height:1;letter-spacing:-.03em;
  background:linear-gradient(180deg,#fff 0%,#cbd5e1 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.stat .l{margin-top:10px;color:rgba(255,255,255,.65);font-size:14px;font-weight:500;letter-spacing:.02em}
@media (max-width:720px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:24px}}

/* ----- 10. PRODUCT CARDS ----- */
.products{background:var(--ink-50);position:relative}
.products::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--border),transparent);
}
.product-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
@media (max-width:920px){.product-grid{grid-template-columns:1fr}}
.product{
  position:relative;background:#fff;border:1px solid var(--border);
  border-radius:var(--r-xl);overflow:hidden;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease);
  display:flex;flex-direction:column;
}
.product::before{
  content:"";position:absolute;inset:0;
  border-radius:var(--r-xl);padding:1px;background:var(--grad-primary);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .35s var(--ease);pointer-events:none;
}
.product:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:transparent}
.product:hover::before{opacity:1}
.product-meta{padding:28px 30px 30px;display:flex;flex-direction:column;gap:14px;flex:1}
.product-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.product-header h3{
  font-family:'Space Grotesk',sans-serif;font-size:22px;font-weight:700;
  margin:0;color:var(--ink-900);letter-spacing:-.02em;line-height:1.2;
}
.product-badge{
  background:var(--green-100);color:#047857;
  font-size:10.5px;font-weight:700;padding:5px 10px;border-radius:999px;
  text-transform:uppercase;letter-spacing:.08em;white-space:nowrap;flex-shrink:0;
  display:flex;align-items:center;gap:5px;
}
.product-badge::before{content:"";width:6px;height:6px;background:var(--green-500);border-radius:50%}
.product p.product-desc{color:var(--ink-700);font-size:14.5px;margin:0;line-height:1.6}
.product-tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:4px;padding:0}
.product-tags li{
  list-style:none;background:var(--ink-100);color:var(--ink-700);
  font-size:11.5px;font-weight:600;padding:5px 11px;border-radius:999px;
}
.product-actions{
  display:flex;gap:10px;margin-top:16px;
  padding-top:18px;border-top:1px solid var(--border-soft);
}

/* ----- 11. MOCKUPS ----- */
.mockup{
  position:relative;
  background:
    radial-gradient(420px 220px at 80% -20%,rgba(99,102,241,.22),transparent 60%),
    radial-gradient(420px 200px at 10% 120%,rgba(37,99,235,.18),transparent 60%),
    linear-gradient(160deg,#e6edff,#f3f6fb);
  padding:26px 24px 0;border-bottom:1px solid var(--border);
}
.mockup-window{
  background:#fff;border-radius:14px 14px 0 0;
  box-shadow:0 30px 60px -20px rgba(15,23,42,.30),0 0 0 1px rgba(15,23,42,.06),inset 0 1px 0 rgba(255,255,255,.9);
  overflow:hidden;height:320px;display:flex;flex-direction:column;
}
.app-bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:11px 14px;background:linear-gradient(180deg,#fff 0%,#f8fafc 100%);
  border-bottom:1px solid var(--ink-100);
}
.app-bar .brand-pill{display:flex;align-items:center;gap:8px}
.app-bar .b-sq{
  width:24px;height:24px;border-radius:7px;background:var(--grad-primary);color:#fff;
  display:grid;place-items:center;font-size:10px;font-weight:800;
  font-family:'Space Grotesk',sans-serif;
  box-shadow:0 4px 10px -2px rgba(37,99,235,.45);
}
.app-bar .b-sq.green{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 10px -2px rgba(16,185,129,.45)}
.app-bar .b-sq.amber{background:linear-gradient(135deg,#f59e0b,#ea580c);box-shadow:0 4px 10px -2px rgba(245,158,11,.45)}
.app-bar .b-sq.violet{background:linear-gradient(135deg,#8b5cf6,#6d28d9);box-shadow:0 4px 10px -2px rgba(139,92,246,.45)}
.app-bar .b-sq.rose{background:linear-gradient(135deg,#ec4899,#be185d);box-shadow:0 4px 10px -2px rgba(236,72,153,.45)}
.app-bar .b-sq.cyan{background:linear-gradient(135deg,#06b6d4,#0891b2);box-shadow:0 4px 10px -2px rgba(6,182,212,.45)}
.app-bar .b-nm{font-size:12px;font-weight:800;color:var(--ink-900);font-family:'Space Grotesk',sans-serif;letter-spacing:-.01em}
.app-bar .b-sub{font-size:9px;color:var(--ink-500);font-weight:500;margin-top:1px}
.app-bar .right{display:flex;align-items:center;gap:6px}
.app-bar .ic-btn{
  width:22px;height:22px;border-radius:6px;background:var(--ink-50);color:var(--ink-500);
  display:grid;place-items:center;border:1px solid var(--ink-100);position:relative;
}
.app-bar .ic-btn.dot::after{
  content:"";position:absolute;width:5px;height:5px;border-radius:50%;
  background:var(--rose-500);transform:translate(6px,-6px);
}
.app-bar .u-pill{
  display:flex;align-items:center;gap:5px;background:var(--ink-50);
  padding:2px 8px 2px 2px;border-radius:99px;font-size:10px;color:var(--ink-700);
  font-weight:700;border:1px solid var(--ink-100);
}
.app-bar .u-pill .av{
  width:18px;height:18px;border-radius:50%;background:var(--grad-primary);
  display:grid;place-items:center;color:#fff;font-size:8px;font-weight:800;
  font-family:'Space Grotesk',sans-serif;
}
.mockup-body{flex:1;display:grid;grid-template-columns:118px 1fr;min-height:0}
.m-side{background:#fafbfd;border-right:1px solid var(--ink-100);padding:12px 8px;display:flex;flex-direction:column;gap:3px;font-size:10.5px}
.m-nav{
  display:flex;align-items:center;gap:9px;padding:7px 8px;border-radius:7px;
  color:var(--ink-600);font-weight:600;transition:background .15s;
}
.m-nav svg{width:12px;height:12px;flex-shrink:0}
.m-nav.active{
  background:linear-gradient(180deg,rgba(37,99,235,.10),rgba(37,99,235,.04));
  color:var(--blue-700);font-weight:700;box-shadow:inset 2px 0 0 var(--blue-600);
}
.m-side .divider{height:1px;margin:6px 4px;background:var(--ink-100)}
.m-side .sec-label{
  font-size:8.5px;font-weight:700;color:var(--ink-400);
  text-transform:uppercase;letter-spacing:.06em;padding:4px 8px 2px;
}
.m-main{
  padding:14px 16px;overflow:hidden;min-width:0;
  background:radial-gradient(300px 150px at 100% 0%,rgba(37,99,235,.04),transparent 60%),#fff;
}
.m-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.m-title{font-size:13px;font-weight:800;color:var(--ink-900);font-family:'Space Grotesk',sans-serif;letter-spacing:-.01em}
.m-title small{font-size:9px;color:var(--ink-500);font-weight:500;display:block;margin-top:1px}
.m-action{
  background:var(--grad-primary);color:#fff;font-size:9px;font-weight:700;
  padding:5px 10px;border-radius:7px;display:flex;align-items:center;gap:4px;
  box-shadow:0 4px 10px -2px rgba(37,99,235,.45);
}
.m-action svg{width:10px;height:10px}
.m-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-bottom:10px}
.m-kpi{background:#fff;border:1px solid var(--ink-200);border-radius:6px;padding:7px 8px}
.m-kpi .lbl{font-size:8px;color:var(--ink-500);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.m-kpi .val{font-size:13px;font-weight:800;color:var(--ink-900);margin-top:2px;font-family:'Space Grotesk',sans-serif}
.m-kpi .delta{font-size:8px;color:var(--green-500);font-weight:700}
.m-kpi .delta.down{color:var(--rose-500)}
.m-tag{font-size:8px;padding:2px 7px;border-radius:99px;font-weight:700}
.m-tag.green{background:var(--green-100);color:#047857}
.m-tag.amber{background:var(--amber-100);color:#b45309}
.m-tag.rose{background:var(--rose-100);color:#b91c1c}
.m-tag.blue{background:var(--blue-50);color:var(--blue-700)}

/* Donut */
.donut{width:60px;height:60px;transform:rotate(-90deg)}
.donut .bg{fill:none;stroke:var(--ink-100);stroke-width:4}
.donut .fg{fill:none;stroke:var(--blue-600);stroke-width:4;stroke-linecap:round}
.donut-wrap{position:relative;display:inline-block}
.donut-label{
  position:absolute;inset:0;display:grid;place-items:center;
  font-family:'Space Grotesk',sans-serif;font-size:12px;font-weight:800;color:var(--ink-900);
}

/* POS */
.pos-layout{display:grid;grid-template-columns:1fr 120px;gap:8px;height:100%}
.pos-products{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;align-content:start}
.pos-prod{background:#fff;border:1px solid var(--ink-100);border-radius:8px;padding:8px 5px;text-align:center;font-size:9px;font-weight:600;color:var(--ink-700);box-shadow:0 1px 2px rgba(15,23,42,.04)}
.pos-prod .thumb{width:30px;height:30px;border-radius:8px;margin:0 auto 5px;display:grid;place-items:center;color:#fff}
.pos-prod .pr{font-size:9px;color:var(--blue-700);font-weight:800;margin-top:3px;font-family:'Space Grotesk',sans-serif}
.pos-cart{background:linear-gradient(160deg,#0f172a,#1e1b4b);color:#fff;border-radius:8px;padding:10px;font-size:9px;display:flex;flex-direction:column;gap:5px;position:relative;overflow:hidden}
.pos-cart::before{content:"";position:absolute;inset:0;background:radial-gradient(200px 100px at 100% 0%,rgba(99,102,241,.3),transparent 60%)}
.pos-cart>*{position:relative;z-index:1}
.pos-cart .ch{font-size:8px;color:rgba(255,255,255,.5);font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.pos-cart .ln{display:flex;justify-content:space-between;opacity:.95}
.pos-cart .ln .x{color:rgba(255,255,255,.55)}
.pos-cart .total{margin-top:auto;padding-top:6px;border-top:1px dashed rgba(255,255,255,.18);font-weight:800;font-size:12px;color:#fff;display:flex;justify-content:space-between;align-items:baseline;font-family:'Space Grotesk',sans-serif}
.pos-cart .total .v{color:#34d399;font-size:13px}
.pos-cart .pay-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff;text-align:center;padding:6px;border-radius:6px;font-weight:800;font-size:10px;font-family:'Space Grotesk',sans-serif;box-shadow:0 4px 10px -2px rgba(16,185,129,.5)}

/* School */
.school-top{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px}
.school-kpi-grid{display:grid;grid-template-rows:1fr 1fr;gap:6px}
.donut-block{background:linear-gradient(160deg,#faf5ff,#fff);border:1px solid #ede9fe;border-radius:8px;padding:8px;display:flex;align-items:center;gap:8px}
.donut-text .t{font-size:9.5px;font-weight:700;color:var(--ink-900);font-family:'Space Grotesk',sans-serif}
.donut-text .s{font-size:9px;color:var(--ink-500);margin-top:2px}
.school-card{background:#fff;border:1px solid var(--ink-100);border-radius:8px;padding:10px;font-size:9px;box-shadow:0 1px 2px rgba(15,23,42,.04)}
.school-card h5{margin:0 0 8px;font-size:10px;font-weight:800;color:var(--ink-900);font-family:'Space Grotesk',sans-serif;display:flex;align-items:center;justify-content:space-between}
.school-card h5::after{content:"View all →";font-size:8.5px;color:var(--blue-600);font-weight:600}
.exam-row{display:flex;align-items:center;gap:8px;padding:5px 0;border-top:1px solid var(--ink-100);font-size:9px}
.exam-row:first-of-type{border-top:none;padding-top:2px}
.exam-row .dt{width:22px;height:22px;border-radius:6px;background:var(--blue-50);color:var(--blue-700);display:grid;place-items:center;font-size:10px;font-weight:800;font-family:'Space Grotesk',sans-serif;flex-shrink:0}
.exam-row .nm{flex:1;color:var(--ink-700);font-weight:600}

/* Restaurant */
.resto-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:8px}
.resto-stat{background:linear-gradient(160deg,#fff,#fef2f2);border:1px solid #fee2e2;border-radius:7px;padding:7px 9px}
.resto-stat.green{background:linear-gradient(160deg,#fff,#ecfdf5);border-color:#d1fae5}
.resto-stat.amber{background:linear-gradient(160deg,#fff,#fefce8);border-color:#fef08a}
.resto-stat .l{font-size:8px;color:var(--ink-500);font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.resto-stat .v{font-size:12px;font-weight:800;color:var(--ink-900);margin-top:2px;font-family:'Space Grotesk',sans-serif}
.resto-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:5px}
.resto-tbl{position:relative;aspect-ratio:1;border-radius:8px;display:grid;place-items:center;font-size:9px;font-weight:800;border:1.5px solid var(--ink-200);background:#fff;color:var(--ink-700);font-family:'Space Grotesk',sans-serif}
.resto-tbl::before,.resto-tbl::after{content:"";position:absolute;width:5px;height:5px;border-radius:50%;background:var(--ink-300)}
.resto-tbl::before{top:-3px;left:50%;transform:translateX(-50%)}
.resto-tbl::after{bottom:-3px;left:50%;transform:translateX(-50%)}
.resto-tbl .l-chair,.resto-tbl .r-chair{position:absolute;width:5px;height:5px;border-radius:50%;background:var(--ink-300);top:50%;transform:translateY(-50%)}
.resto-tbl .l-chair{left:-3px}.resto-tbl .r-chair{right:-3px}
.resto-tbl.busy{background:linear-gradient(160deg,#fef2f2,#fff);color:#b91c1c;border-color:#fca5a5}
.resto-tbl.busy::before,.resto-tbl.busy::after,.resto-tbl.busy .l-chair,.resto-tbl.busy .r-chair{background:#ef4444}
.resto-tbl.open{background:linear-gradient(160deg,#ecfdf5,#fff);color:#047857;border-color:#86efac}
.resto-tbl.open::before,.resto-tbl.open::after,.resto-tbl.open .l-chair,.resto-tbl.open .r-chair{background:#10b981}
.resto-tbl.bill{background:linear-gradient(160deg,#fefce8,#fff);color:#b45309;border-color:#fcd34d}
.resto-tbl.bill::before,.resto-tbl.bill::after,.resto-tbl.bill .l-chair,.resto-tbl.bill .r-chair{background:#f59e0b}
.resto-legend{display:flex;gap:10px;font-size:9px;color:var(--ink-500);margin-top:8px}
.resto-legend span{display:inline-flex;align-items:center;gap:5px;font-weight:600}
.resto-legend span::before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%}
.resto-legend .o::before{background:var(--green-500)}
.resto-legend .b::before{background:var(--amber-500)}
.resto-legend .x::before{background:var(--rose-500)}

/* E-commerce */
.shop-hero{position:relative;overflow:hidden;background:radial-gradient(160px 100px at 80% 20%,rgba(255,255,255,.25),transparent 60%),linear-gradient(120deg,var(--blue-600),var(--violet-500),#ec4899);color:#fff;border-radius:9px;padding:12px 14px;font-size:10px;display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;box-shadow:0 8px 18px -4px rgba(99,102,241,.5)}
.shop-hero::after{content:"";position:absolute;width:80px;height:80px;right:-20px;top:-20px;border-radius:50%;background:rgba(255,255,255,.15)}
.shop-hero>*{position:relative;z-index:1}
.shop-hero .tag-up{font-size:8.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;opacity:.9}
.shop-hero strong{font-size:13px;font-weight:800;font-family:'Space Grotesk',sans-serif;display:block;margin:2px 0}
.shop-hero .sub{font-size:9px;opacity:.9}
.shop-hero .btn-mini{background:#fff;color:var(--blue-700);font-size:9px;padding:5px 11px;border-radius:99px;font-weight:800;font-family:'Space Grotesk',sans-serif;box-shadow:0 4px 10px -2px rgba(0,0,0,.15)}
.shop-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.shop-item{background:#fff;border:1px solid var(--ink-100);border-radius:8px;padding:6px;font-size:9px;color:var(--ink-700);box-shadow:0 1px 2px rgba(15,23,42,.04)}
.shop-item .img{width:100%;aspect-ratio:1;border-radius:6px;margin-bottom:6px;display:grid;place-items:center;font-size:22px}
.shop-item .nm{font-weight:700;color:var(--ink-900);font-size:9px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:2px}
.shop-item .row{display:flex;justify-content:space-between;align-items:center}
.shop-item .pr{color:var(--blue-700);font-weight:800;font-size:9.5px;font-family:'Space Grotesk',sans-serif}
.shop-item .star{font-size:8px;color:var(--amber-500);font-weight:700}

/* Hospital */
.hosp-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.hosp-list{background:linear-gradient(160deg,#fff,#f0f9ff);border:1px solid #dbeafe;border-radius:8px;padding:10px;font-size:9px;box-shadow:0 1px 2px rgba(15,23,42,.04)}
.hosp-doc{display:flex;align-items:center;gap:7px;padding-bottom:7px;margin-bottom:7px;border-bottom:1px solid var(--ink-100)}
.hosp-doc .pic{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--blue-500),var(--violet-500));color:#fff;display:grid;place-items:center;font-size:9px;font-weight:800;font-family:'Space Grotesk',sans-serif;flex-shrink:0}
.hosp-doc .pic.alt{background:linear-gradient(135deg,#10b981,#06b6d4)}
.hosp-doc .info .nm{font-size:9.5px;font-weight:800;color:var(--ink-900);font-family:'Space Grotesk',sans-serif}
.hosp-doc .info .ro{font-size:8.5px;color:var(--ink-500);font-weight:600}
.hosp-doc .live{margin-left:auto;font-size:8px;font-weight:700;background:var(--green-100);color:#047857;padding:2px 6px;border-radius:99px;display:flex;align-items:center;gap:4px}
.hosp-doc .live::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--green-500)}
.hosp-row{display:flex;align-items:center;gap:7px;padding:4px 0}
.hosp-row .tm{font-weight:800;color:var(--blue-700);font-size:9px;min-width:32px;font-family:'Space Grotesk',sans-serif;padding:2px 5px;background:var(--blue-50);border-radius:4px;text-align:center}
.hosp-row .nm{color:var(--ink-800);font-size:9px;flex:1;font-weight:600}
.hosp-row .st{font-size:8px;font-weight:700;padding:2px 6px;border-radius:99px}

/* HR */
.hr-top{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px}
.hr-stats-col{display:grid;grid-template-rows:1fr 1fr;gap:6px}
.hr-donut-block{background:linear-gradient(160deg,#ecfdf5,#fff);border:1px solid #d1fae5;border-radius:8px;padding:8px;display:flex;align-items:center;gap:8px}
.hr-donut-block .t{font-size:9.5px;font-weight:800;color:var(--ink-900);font-family:'Space Grotesk',sans-serif}
.hr-donut-block .s{font-size:8.5px;color:var(--ink-500);margin-top:2px}
.hr-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.hr-emp{position:relative;background:#fff;border:1px solid var(--ink-100);border-radius:8px;padding:8px;display:flex;align-items:center;gap:8px;font-size:9px;box-shadow:0 1px 2px rgba(15,23,42,.04)}
.hr-emp .pic{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--blue-500),var(--violet-500));flex-shrink:0;display:grid;place-items:center;color:#fff;font-size:9px;font-weight:800;font-family:'Space Grotesk',sans-serif;position:relative}
.hr-emp .pic::after{content:"";position:absolute;bottom:-1px;right:-1px;width:7px;height:7px;border-radius:50%;background:var(--green-500);border:1.5px solid #fff}
.hr-emp .info{flex:1;min-width:0;overflow:hidden}
.hr-emp .nm{font-weight:800;color:var(--ink-900);font-size:9.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:'Space Grotesk',sans-serif}
.hr-emp .ro{color:var(--ink-500);font-size:8.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hr-emp .sal{color:var(--green-500);font-weight:800;font-size:10px;font-family:'Space Grotesk',sans-serif}

/* More strip */
.more-strip{
  margin-top:50px;padding:24px 32px;background:#fff;
  border:1px solid var(--border);border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;gap:14px;
  text-align:center;flex-wrap:wrap;box-shadow:var(--shadow-xs);
}
.more-strip .label{color:var(--ink-500);font-size:14px;font-weight:500}
.more-strip .tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.more-strip .tags span{
  background:var(--ink-50);color:var(--ink-800);font-size:12px;font-weight:600;
  padding:6px 12px;border-radius:999px;border:1px solid var(--border-soft);
}

/* ----- 12. PLANS ----- */
.plans{background:#fff}
.plans-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media (max-width:900px){.plans-grid{grid-template-columns:1fr}}
.plan{
  position:relative;background:#fff;border:1px solid var(--border);
  border-radius:var(--r-xl);padding:40px 36px;
  display:flex;flex-direction:column;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease);
}
.plan:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.plan.featured{
  background:radial-gradient(400px 250px at 100% 0%,rgba(99,102,241,.15),transparent 60%),#fff;
  border-color:var(--blue-300);box-shadow:0 24px 60px -16px rgba(37,99,235,.25);
}
.plan-badge{
  position:absolute;top:-14px;left:36px;
  background:var(--grad-primary);color:#fff;
  padding:7px 16px;border-radius:999px;
  font-size:11.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
  box-shadow:0 10px 24px -6px rgba(37,99,235,.55);
}
.plan-icon{
  width:56px;height:56px;border-radius:16px;
  background:var(--blue-50);color:var(--blue-700);
  display:grid;place-items:center;margin-bottom:22px;
  box-shadow:inset 0 0 0 1px var(--blue-100);
}
.plan.featured .plan-icon{background:var(--grad-primary);color:#fff;box-shadow:0 10px 22px -6px rgba(37,99,235,.5)}
.plan h3{font-family:'Space Grotesk',sans-serif;font-size:26px;font-weight:700;margin:0 0 8px;letter-spacing:-.02em}
.plan-tagline{color:var(--ink-500);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;margin-bottom:18px}
.plan-desc{color:var(--ink-700);font-size:15px;margin:0 0 26px;line-height:1.6}
.plan-features{list-style:none;padding:0;margin:0 0 30px;display:flex;flex-direction:column;gap:12px;flex:1}
.plan-features li{display:flex;align-items:flex-start;gap:12px;color:var(--ink-800);font-size:14.5px}
.plan-features li .check{flex-shrink:0;width:20px;height:20px;border-radius:50%;background:var(--green-100);color:var(--green-500);display:grid;place-items:center}
.plan-price{padding:16px 20px;background:var(--ink-50);border-radius:var(--r-sm);margin-bottom:20px;border:1px solid var(--border-soft)}
.plan-price .l{font-size:12px;color:var(--ink-500);font-weight:600;text-transform:uppercase;letter-spacing:.08em}
.plan-price .v{font-family:'Space Grotesk',sans-serif;font-size:22px;font-weight:700;color:var(--ink-900);margin-top:4px}
.plans-note{text-align:center;margin-top:44px;color:var(--ink-700);font-size:16px;max-width:720px;margin-left:auto;margin-right:auto;line-height:1.6}
.plans-note strong{color:var(--ink-900)}

/* ----- 13. WHY ----- */
.why{background:var(--ink-50)}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:900px){.why-grid{grid-template-columns:1fr}}
.why-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);
  padding:32px;transition:transform .25s var(--ease),box-shadow .25s var(--ease);
}
.why-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.why-card .icon{
  display:inline-grid;place-items:center;width:50px;height:50px;
  background:var(--blue-50);color:var(--blue-700);border-radius:14px;margin-bottom:18px;
}
.why-card h3{font-family:'Space Grotesk',sans-serif;font-size:19px;font-weight:700;margin:0 0 10px;letter-spacing:-.01em}
.why-card p{color:var(--ink-700);margin:0;font-size:15px;line-height:1.6}

/* ----- 14. PROCESS ----- */
.process-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative}
@media (max-width:900px){.process-grid{grid-template-columns:1fr}}
.step{position:relative;background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:36px 28px 28px}
.step .step-num{
  position:absolute;top:-22px;left:28px;
  background:var(--grad-primary);color:#fff;
  width:44px;height:44px;border-radius:50%;
  display:grid;place-items:center;font-weight:800;
  font-family:'Space Grotesk',sans-serif;
  box-shadow:0 10px 22px -6px rgba(37,99,235,.55);
}
.step h3{font-family:'Space Grotesk',sans-serif;font-size:19px;margin:8px 0 8px;font-weight:700;letter-spacing:-.01em}
.step p{color:var(--ink-700);margin:0;font-size:15px;line-height:1.6}

/* ----- 15. TESTIMONIALS ----- */
.testimonials{background:var(--ink-50)}
.testimonial-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:980px){.testimonial-grid{grid-template-columns:1fr}}
.testimonial{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);
  padding:32px;position:relative;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease);
}
.testimonial:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.testimonial .quote-mark{position:absolute;top:20px;right:28px;font-family:'Space Grotesk',sans-serif;font-size:60px;font-weight:700;color:var(--blue-100);line-height:1}
.testimonial .stars{display:flex;gap:3px;margin-bottom:16px;color:var(--amber-500)}
.testimonial p.txt{color:var(--ink-800);font-size:15.5px;line-height:1.65;margin:0 0 22px;position:relative;z-index:1}
.testimonial .who{display:flex;align-items:center;gap:12px;padding-top:18px;border-top:1px solid var(--border-soft)}
.testimonial .ava{width:44px;height:44px;border-radius:50%;background:var(--grad-primary);color:#fff;display:grid;place-items:center;font-family:'Space Grotesk',sans-serif;font-weight:700;flex-shrink:0}
.testimonial .ava.a2{background:linear-gradient(135deg,#10b981,#06b6d4)}
.testimonial .ava.a3{background:linear-gradient(135deg,#f59e0b,#ef4444)}
.testimonial .ava.a4{background:linear-gradient(135deg,#8b5cf6,#ec4899)}
.testimonial .ava.a5{background:linear-gradient(135deg,#06b6d4,#3b82f6)}
.testimonial .ava.a6{background:linear-gradient(135deg,#ef4444,#f59e0b)}
.testimonial .who .nm{font-weight:700;color:var(--ink-900);font-size:15px}
.testimonial .who .pos{color:var(--ink-500);font-size:13px}
.testimonial .who .flag{margin-left:auto;font-size:22px}

/* ----- 16. FAQ ----- */
.faq-wrap{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq{background:#fff;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;transition:border-color .2s var(--ease),box-shadow .2s var(--ease)}
.faq[open]{border-color:var(--blue-200);box-shadow:var(--shadow-xs)}
.faq summary{
  list-style:none;cursor:pointer;padding:20px 24px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:16px;color:var(--ink-900);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary .icon{
  width:28px;height:28px;border-radius:50%;
  background:var(--blue-50);color:var(--blue-700);
  display:grid;place-items:center;
  transition:transform .25s var(--ease),background .25s var(--ease);
  flex-shrink:0;
}
.faq[open] summary .icon{background:var(--blue-600);color:#fff;transform:rotate(45deg)}
.faq .body{padding:0 24px 22px 24px;color:var(--ink-700);font-size:15px;line-height:1.65}

/* ----- 17. CONTACT ----- */
.contact{background:#fff;position:relative;overflow:hidden}
.contact::before{
  content:"";position:absolute;width:700px;height:700px;top:-300px;right:-200px;
  border-radius:50%;background:radial-gradient(circle,rgba(99,102,241,.12),transparent 60%);
  filter:blur(60px);
}
.contact-grid{
  display:grid;grid-template-columns:1fr 1.2fr;gap:60px;
  align-items:start;position:relative;z-index:1;
}
@media (max-width:980px){.contact-grid{grid-template-columns:1fr;gap:40px}}
.contact-info .eyebrow{justify-content:flex-start}
.contact-info h2{margin-bottom:16px}
.contact-info p.lead{color:var(--ink-700);font-size:17px;line-height:1.6;margin:0 0 30px}
.contact-channels{display:flex;flex-direction:column;gap:14px;margin-bottom:30px}
.channel{
  display:flex;align-items:center;gap:16px;padding:16px 20px;
  background:var(--ink-50);border:1px solid var(--border-soft);
  border-radius:var(--r-md);color:var(--ink-900);
  transition:transform .2s var(--ease),border-color .2s var(--ease),background .2s var(--ease);
}
.channel:hover{transform:translateX(4px);border-color:var(--blue-300);background:var(--blue-50);color:var(--ink-900)}
.channel .icon{width:44px;height:44px;border-radius:12px;background:#fff;color:var(--blue-700);display:grid;place-items:center;flex-shrink:0;box-shadow:var(--shadow-xs)}
.channel .label{font-size:12px;color:var(--ink-500);font-weight:600;text-transform:uppercase;letter-spacing:.08em}
.channel .value{font-weight:700;font-size:15px}
.form-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-xl);padding:40px;box-shadow:var(--shadow-lg)}
@media (max-width:600px){.form-card{padding:28px 22px}}
.form-card h3{font-family:'Space Grotesk',sans-serif;font-size:22px;font-weight:700;margin:0 0 8px;letter-spacing:-.02em}
.form-card p.fdesc{color:var(--ink-500);font-size:14px;margin:0 0 28px}
.field{margin-bottom:18px;position:relative}
.field label{display:block;font-weight:600;font-size:13px;color:var(--ink-800);margin-bottom:6px;letter-spacing:.01em}
.field input,.field select,.field textarea{
  width:100%;padding:13px 16px;font-size:15px;font-family:inherit;
  color:var(--ink-900);background:#fff;border:1px solid var(--ink-200);
  border-radius:var(--r-sm);
  transition:border-color .2s var(--ease),box-shadow .2s var(--ease);
  -webkit-appearance:none;
}
.field textarea{resize:vertical;min-height:120px;line-height:1.55}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--blue-600);
  box-shadow:0 0 0 4px rgba(37,99,235,.12);
}
.field .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:520px){.field .row{grid-template-columns:1fr}}
.form-actions{display:flex;gap:14px;align-items:center;margin-top:8px;flex-wrap:wrap}
.form-actions .btn{width:100%;justify-content:center}
.form-note{font-size:12.5px;color:var(--ink-500);margin-top:16px;line-height:1.5}
.form-status{margin-top:18px;padding:14px 18px;border-radius:var(--r-sm);font-size:14px;display:none;align-items:center;gap:10px}
.form-status.show{display:flex}
.form-status.success{background:var(--green-100);color:#047857}
.form-status.error{background:var(--rose-100);color:#b91c1c}
.form-status.loading{background:var(--blue-50);color:var(--blue-700)}
.hp{position:absolute;left:-9999px}

/* ----- 18. FINAL CTA BLOCK ----- */
.cta-block{
  background:radial-gradient(800px 400px at 80% 20%,rgba(255,255,255,.15),transparent 60%),linear-gradient(135deg,var(--blue-700),var(--blue-900));
  color:#fff;border-radius:var(--r-lg);padding:60px;text-align:center;box-shadow:var(--shadow-lg);
}
.cta-block h2{font-size:clamp(28px,3.6vw,38px);font-weight:800;margin:0 0 14px;letter-spacing:-.02em}
.cta-block p{color:rgba(255,255,255,.85);font-size:17px;max-width:600px;margin:0 auto 32px}
.cta-block .btn-primary{background:#fff;color:var(--blue-700)}
.cta-block .btn-primary:hover{background:var(--ink-50);color:var(--blue-900)}
.cta-block .btn-secondary{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.cta-block .btn-secondary:hover{background:rgba(255,255,255,.1);border-color:#fff}
.cta-block .ctas{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
@media (max-width:700px){.cta-block{padding:40px 24px}}

/* ----- 19. FOOTER ----- */
footer{background:var(--ink-950);color:rgba(255,255,255,.7);padding:70px 0 30px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:50px}
@media (max-width:800px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:480px){.footer-grid{grid-template-columns:1fr}}
.footer-brand .brand{color:#fff;margin-bottom:14px}
.footer-brand p{color:rgba(255,255,255,.55);font-size:14px;line-height:1.6;max-width:320px;margin:0 0 20px}
.footer-socials{display:flex;gap:10px}
.footer-socials a{
  width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.06);color:#fff;
  display:grid;place-items:center;
  transition:background .2s var(--ease),transform .2s var(--ease);
}
.footer-socials a:hover{background:var(--blue-600);transform:translateY(-2px);color:#fff}
.footer-col h4{color:#fff;font-family:'Space Grotesk',sans-serif;font-size:14px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin:0 0 18px}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.footer-col a{color:rgba(255,255,255,.65);font-size:14px}
.footer-col a:hover{color:#fff}
.footer-bottom{padding-top:26px;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;color:rgba(255,255,255,.5);font-size:13px}

/* ----- 20. REVEAL ANIMATIONS ----- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.is-visible{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.1s}
.reveal[data-delay="2"]{transition-delay:.2s}
.reveal[data-delay="3"]{transition-delay:.3s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .fc-main,.fc-notif,.fc-pay,.marquee-track,.pill .dot{animation:none!important}
  html{scroll-behavior:auto}
}

/* ================================================================
   NEW PAGES — PORTFOLIO, MARKETS, ABOUT
   ================================================================ */

/* ----- 21. MARKETS / GLOBAL REACH ----- */
.markets{background:#fff;position:relative;overflow:hidden}
.markets::before{
  content:"";position:absolute;width:600px;height:600px;
  top:-200px;left:-200px;border-radius:50%;filter:blur(80px);
  background:radial-gradient(circle,rgba(99,102,241,.10),transparent 60%);
}
.markets .container{position:relative;z-index:1}
.country-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:16px;
}
@media (max-width:900px){.country-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:520px){.country-grid{grid-template-columns:repeat(2,1fr)}}
.country{
  background:#fff;border:1px solid var(--border);
  border-radius:var(--r-md);padding:24px 16px;
  text-align:center;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease);
}
.country:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--blue-200)}
.country .flag{font-size:38px;margin-bottom:10px;line-height:1}
.country .nm{font-weight:700;color:var(--ink-900);font-size:15px;font-family:'Space Grotesk',sans-serif}
.country .reg{color:var(--ink-500);font-size:12px;margin-top:4px}
.timezone-note{
  margin-top:50px;padding:24px 28px;
  background:linear-gradient(135deg,var(--blue-50),#fff);
  border:1px solid var(--blue-100);border-radius:var(--r-md);
  display:flex;align-items:center;gap:18px;justify-content:center;flex-wrap:wrap;
  text-align:center;color:var(--ink-800);font-size:15px;
}
.timezone-note strong{color:var(--blue-700);font-weight:700}

/* ----- 22. PORTFOLIO ----- */
.portfolio{background:var(--ink-50)}
.portfolio-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
@media (max-width:920px){.portfolio-grid{grid-template-columns:1fr}}
.proj{
  position:relative;background:#fff;border:1px solid var(--border);
  border-radius:var(--r-xl);overflow:hidden;display:flex;flex-direction:column;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
}
.proj:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.proj-preview{
  position:relative;height:240px;
  background:radial-gradient(420px 220px at 80% -20%,rgba(99,102,241,.22),transparent 60%),
             radial-gradient(420px 200px at 10% 120%,rgba(37,99,235,.18),transparent 60%),
             linear-gradient(160deg,#e6edff,#f3f6fb);
  display:flex;align-items:flex-end;padding:24px;overflow:hidden;
}
.proj-preview .device{
  width:100%;background:#fff;
  border-radius:12px 12px 0 0;
  box-shadow:0 20px 40px -15px rgba(15,23,42,.30),0 0 0 1px rgba(15,23,42,.06);
  overflow:hidden;
}
.proj-preview .device .head{
  display:flex;align-items:center;gap:6px;padding:8px 12px;
  background:#f8fafc;border-bottom:1px solid var(--ink-100);
}
.proj-preview .device .head .d{width:8px;height:8px;border-radius:50%;background:var(--ink-300)}
.proj-preview .device .head .d.r{background:#ef4444}.proj-preview .device .head .d.y{background:#f59e0b}.proj-preview .device .head .d.g{background:#10b981}
.proj-preview .device .head .nm{margin-left:6px;font-size:10px;font-weight:700;color:var(--ink-700);font-family:'Space Grotesk',sans-serif}
.proj-preview .device .screen{
  padding:14px;min-height:130px;
  display:flex;flex-direction:column;gap:10px;
}
.proj-preview .device .screen .row{display:flex;gap:8px;align-items:center}
.proj-preview .device .screen .bx{
  flex:1;height:14px;border-radius:4px;
  background:linear-gradient(90deg,var(--ink-100),var(--ink-50));
}
.proj-preview .device .screen .bx.big{height:24px;background:linear-gradient(120deg,var(--blue-100),var(--blue-50))}
.proj-preview .device .screen .bx.brand{background:linear-gradient(90deg,var(--blue-600),var(--violet-500));max-width:60%}
.proj-preview .device .screen .grid-mini{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.proj-preview .device .screen .grid-mini .c{
  height:38px;border-radius:6px;
  background:linear-gradient(135deg,var(--ink-100),var(--blue-100));
}
.proj-flag{
  position:absolute;top:18px;left:18px;
  background:rgba(255,255,255,.95);
  padding:6px 10px;border-radius:99px;
  font-size:13px;font-weight:700;
  display:flex;align-items:center;gap:6px;
  box-shadow:var(--shadow-sm);
  color:var(--ink-800);
}
.proj-flag .em{font-size:18px}
.proj-cat{
  position:absolute;top:18px;right:18px;
  background:var(--ink-900);color:#fff;
  padding:6px 10px;border-radius:99px;
  font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  box-shadow:var(--shadow-sm);
}
.proj-body{padding:26px 28px 28px;display:flex;flex-direction:column;gap:12px;flex:1}
.proj-body h3{
  font-family:'Space Grotesk',sans-serif;font-size:21px;font-weight:700;
  margin:0;color:var(--ink-900);letter-spacing:-.01em;
}
.proj-body .client{
  color:var(--ink-500);font-size:13px;font-weight:600;
}
.proj-body p.proj-desc{color:var(--ink-700);font-size:14.5px;margin:0;line-height:1.6}
.proj-body .stack{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.proj-body .stack span{
  font-size:11px;font-weight:700;
  background:var(--ink-100);color:var(--ink-700);
  padding:4px 9px;border-radius:99px;
  border:1px solid var(--border-soft);
}

/* Portfolio filter / categories */
.proj-filter{
  display:flex;justify-content:center;flex-wrap:wrap;gap:8px;
  margin-bottom:40px;
}
.proj-filter button{
  background:#fff;border:1px solid var(--border);
  padding:8px 16px;border-radius:99px;
  font-size:13px;font-weight:600;color:var(--ink-700);
  font-family:inherit;cursor:pointer;
  transition:all .2s var(--ease);
}
.proj-filter button:hover{border-color:var(--blue-300);color:var(--blue-700)}
.proj-filter button.active{
  background:var(--grad-primary);color:#fff;border-color:transparent;
  box-shadow:0 6px 14px -4px rgba(37,99,235,.4);
}

/* Tech stack section */
.techstack{background:#fff}
.tech-grid{
  display:grid;grid-template-columns:repeat(6,1fr);gap:14px;
}
@media (max-width:900px){.tech-grid{grid-template-columns:repeat(4,1fr)}}
@media (max-width:560px){.tech-grid{grid-template-columns:repeat(3,1fr)}}
.tech-tile{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-md);
  padding:22px 12px;text-align:center;
  transition:all .2s var(--ease);
}
.tech-tile:hover{transform:translateY(-3px);border-color:var(--blue-300);box-shadow:var(--shadow-sm)}
.tech-tile .ic{
  width:42px;height:42px;border-radius:10px;margin:0 auto 10px;
  display:grid;place-items:center;
  font-family:'Space Grotesk',sans-serif;
  font-size:14px;font-weight:800;color:#fff;
}
.tech-tile .nm{font-size:13px;font-weight:700;color:var(--ink-900);font-family:'Space Grotesk',sans-serif}

/* Client logos strip */
.clients{
  padding:50px 0;background:#fff;
  border-top:1px solid var(--border-soft);
  border-bottom:1px solid var(--border-soft);
}
.clients-head{text-align:center;color:var(--ink-500);font-size:13px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:30px}
.clients-grid{
  display:grid;grid-template-columns:repeat(6,1fr);gap:30px;align-items:center;
}
@media (max-width:900px){.clients-grid{grid-template-columns:repeat(3,1fr);gap:24px}}
@media (max-width:520px){.clients-grid{grid-template-columns:repeat(2,1fr)}}
.client-logo{
  text-align:center;padding:14px 8px;
  font-family:'Space Grotesk',sans-serif;
  font-size:16px;font-weight:800;color:var(--ink-400);
  letter-spacing:-.01em;
  border:1px dashed var(--border);border-radius:var(--r-sm);
  transition:color .2s var(--ease),border-color .2s var(--ease);
}
.client-logo:hover{color:var(--ink-700);border-color:var(--ink-300)}
.client-logo .mark{display:inline-block;margin-right:6px;color:var(--blue-600)}

/* ----- 23. ABOUT PAGE ----- */
.about-bio{background:#fff}
.bio-grid{
  display:grid;grid-template-columns:1fr 1.4fr;gap:60px;align-items:center;
}
@media (max-width:900px){.bio-grid{grid-template-columns:1fr;gap:40px}}
.bio-photo{
  position:relative;aspect-ratio:1;border-radius:var(--r-xl);
  background:
    radial-gradient(circle at 30% 30%,rgba(255,255,255,.4),transparent 50%),
    var(--grad-primary);
  display:grid;place-items:center;
  color:#fff;
  font-family:'Space Grotesk',sans-serif;
  font-size:90px;font-weight:800;
  box-shadow:var(--shadow-lg);
  overflow:hidden;
}
.bio-photo::after{
  content:"";position:absolute;
  inset:auto -40px -40px auto;
  width:200px;height:200px;border-radius:50%;
  background:rgba(255,255,255,.1);
}
.bio-content h2{margin-bottom:16px}
.bio-content p{color:var(--ink-700);font-size:17px;line-height:1.7;margin:0 0 18px}
.bio-meta{
  display:grid;grid-template-columns:repeat(2,1fr);gap:16px;
  margin-top:30px;padding-top:30px;border-top:1px solid var(--border);
}
.bio-meta .b-item .l{font-size:12px;color:var(--ink-500);font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.bio-meta .b-item .v{font-family:'Space Grotesk',sans-serif;font-size:18px;font-weight:700;color:var(--ink-900);letter-spacing:-.01em}

/* Experience timeline */
.timeline{background:var(--ink-50)}
.tl-wrap{position:relative;max-width:780px;margin:0 auto;padding:20px 0}
.tl-wrap::before{
  content:"";position:absolute;
  left:30px;top:0;bottom:0;width:2px;
  background:linear-gradient(180deg,var(--blue-200),var(--blue-600),var(--violet-500));
  border-radius:99px;
}
.tl-item{
  position:relative;padding-left:80px;padding-bottom:36px;
}
.tl-item::before{
  content:"";position:absolute;left:22px;top:6px;
  width:18px;height:18px;border-radius:50%;
  background:#fff;border:3px solid var(--blue-600);
  box-shadow:0 0 0 4px rgba(37,99,235,.15);
}
.tl-item .yr{
  display:inline-block;
  background:var(--grad-primary);color:#fff;
  font-family:'Space Grotesk',sans-serif;
  font-size:12px;font-weight:800;letter-spacing:.05em;
  padding:4px 12px;border-radius:99px;margin-bottom:8px;
}
.tl-item h4{
  font-family:'Space Grotesk',sans-serif;
  font-size:18px;font-weight:700;letter-spacing:-.01em;
  margin:0 0 6px;color:var(--ink-900);
}
.tl-item p{color:var(--ink-700);font-size:15px;line-height:1.6;margin:0}

/* Values grid */
.values-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
@media (max-width:760px){.values-grid{grid-template-columns:1fr}}
.value{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);
  padding:30px;display:flex;gap:20px;align-items:flex-start;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease);
}
.value:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.value .icon{
  flex-shrink:0;width:52px;height:52px;border-radius:14px;
  background:var(--blue-50);color:var(--blue-700);
  display:grid;place-items:center;
  box-shadow:inset 0 0 0 1px var(--blue-100);
}
.value h3{font-family:'Space Grotesk',sans-serif;font-size:18px;font-weight:700;margin:0 0 6px;letter-spacing:-.01em}
.value p{color:var(--ink-700);font-size:15px;margin:0;line-height:1.6}

/* ----- 24. SECTION LINK CARDS (used on home for "See all systems") ----- */
.see-more-row{
  display:flex;justify-content:center;margin-top:50px;
}
