/* ===== Codify — design system ===== */
:root{
  --ink:#1E1B4B;        /* deep indigo: primary text, dark sections */
  --ink-soft:#2A2660;   /* lighter indigo for dark-section cards */
  --ink-line:#383275;   /* borders on dark */
  --indigo:#4F46E5;     /* brand indigo: links, secondary accent */
  --cyan:#06B6D4;       /* primary accent: the asterisk, highlights */
  --cyan-deep:#0E7490;  /* deeper teal for contrast moments */
  --paper:#FFFFFF;
  --mist:#F5F6FB;       /* light section bg */
  --mist-2:#EEF0F9;
  --line:#E6E8F2;
  --muted:#5B6172;
  --muted-2:#8B90A4;
  --ok:#16A34A; --warn:#D97706; --info:#2563EB;

  --display:'Poppins',system-ui,sans-serif;
  --body:'Inter',system-ui,sans-serif;

  --wrap:1200px;
  --radius:16px; --radius-sm:10px; --radius-lg:24px;
  --shadow:0 1px 2px rgba(30,27,75,.06),0 12px 32px -12px rgba(30,27,75,.18);
  --shadow-lg:0 30px 70px -30px rgba(30,27,75,.45);
  --ease:cubic-bezier(.2,.7,.2,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--body);color:var(--ink);background:var(--paper);
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.08;margin:0;letter-spacing:-.02em}
p{margin:0}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
.section{padding:96px 0}
.section--tight{padding:64px 0}
.dark{background:var(--ink);color:#EDEDFB}
.dark h1,.dark h2,.dark h3{color:#fff}
.mist{background:var(--mist)}

/* ---- type scale ---- */
.display{font-size:clamp(2.6rem,6vw,4.4rem);letter-spacing:-.035em}
.h1{font-size:clamp(2.2rem,4.6vw,3.4rem)}
.h2{font-size:clamp(1.8rem,3.4vw,2.6rem)}
.h3{font-size:1.3rem;letter-spacing:-.01em}
.lead{font-size:clamp(1.05rem,1.6vw,1.28rem);color:var(--muted);line-height:1.55}
.dark .lead{color:#B9B9E4}
.measure{max-width:62ch}

/* ---- eyebrow w/ asterisk signature ---- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--display);font-weight:600;font-size:.78rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--muted);
}
.eyebrow::before{content:"*";color:var(--cyan);font-size:1.5em;line-height:0;transform:translateY(.18em);font-weight:700}
.dark .eyebrow{color:#9FA0D6}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:.55em;font-family:var(--display);
  font-weight:600;font-size:.98rem;padding:.85em 1.4em;border-radius:999px;
  border:1.5px solid transparent;cursor:pointer;transition:.25s var(--ease);
  white-space:nowrap;
}
.btn--primary{background:var(--cyan);color:#04313b}
.btn--primary:hover{background:#22c6e3;transform:translateY(-2px);box-shadow:0 14px 30px -12px rgba(6,182,212,.7)}
.btn--ink{background:var(--ink);color:#fff}
.btn--ink:hover{background:#2a2660;transform:translateY(-2px)}
.btn--ghost{border-color:var(--line);color:var(--ink);background:#fff}
.btn--ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.dark .btn--ghost{color:#fff;border-color:var(--ink-line);background:transparent}
.dark .btn--ghost:hover{border-color:#fff}
.btn .ar{transition:transform .25s var(--ease)}
.btn:hover .ar{transform:translateX(4px)}

/* ---- header ---- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.82);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:32px;height:72px}
.brand{font-family:var(--display);font-weight:700;font-size:1.5rem;color:var(--ink);letter-spacing:-.03em;display:inline-flex;align-items:flex-start}
.brand .ast{color:var(--cyan);font-size:.7em;line-height:1;margin-left:.04em;transform:translateY(.05em)}
.nav__links{display:flex;gap:26px;margin-left:8px}
.nav__links a{font-weight:500;font-size:.96rem;color:var(--muted);position:relative;padding:4px 0;transition:color .2s}
.nav__links a:hover,.nav__links a.active{color:var(--ink)}
.nav__links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--cyan);border-radius:2px}
.nav__spacer{flex:1}
.nav__cta{display:flex;align-items:center;gap:14px}
.nav__toggle{display:none;background:none;border:0;cursor:pointer;padding:8px}
.nav__toggle span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;transition:.3s}

/* ---- hero ---- */
.hero{position:relative;overflow:hidden;padding:84px 0 72px}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{margin:18px 0 22px}
.hero .accent{color:var(--cyan)}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.hero__meta{display:flex;gap:28px;margin-top:38px;flex-wrap:wrap}
.hero__meta div{display:flex;flex-direction:column}
.hero__meta b{font-family:var(--display);font-size:1.5rem;color:var(--ink)}
.hero__meta span{font-size:.85rem;color:var(--muted)}
.spark{position:absolute;color:var(--cyan);opacity:.10;font-family:var(--display);font-weight:700;pointer-events:none;user-select:none}
.spark--1{font-size:30rem;top:-9rem;right:-5rem;animation:spin 60s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---- app mockup (browser frame) ---- */
.mock{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);overflow:hidden}
.mock__bar{display:flex;align-items:center;gap:7px;padding:12px 14px;background:#fbfbfe;border-bottom:1px solid var(--line)}
.mock__bar i{width:11px;height:11px;border-radius:50%;background:#e0e2ee;display:block}
.mock__bar i:nth-child(1){background:#ff6058}.mock__bar i:nth-child(2){background:#ffbd2e}.mock__bar i:nth-child(3){background:#28c840}
.mock__url{margin-left:10px;font-size:.72rem;color:var(--muted-2);font-family:var(--body)}
.app{display:grid;grid-template-columns:74px 1fr;min-height:330px}
.app__side{background:var(--ink);padding:16px 0;display:flex;flex-direction:column;align-items:center;gap:18px}
.app__logo{color:#fff;font-family:var(--display);font-weight:700;font-size:1.1rem}
.app__logo .ast{color:var(--cyan)}
.app__nav{display:flex;flex-direction:column;gap:14px;margin-top:6px}
.app__nav i{width:26px;height:26px;border-radius:8px;background:#322d6b;display:block}
.app__nav i.on{background:var(--cyan)}
.app__main{padding:18px 20px;background:var(--mist)}
.app__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.app__h{font-family:var(--display);font-weight:600;font-size:.98rem;color:var(--ink)}
.app__pill{font-size:.66rem;background:#fff;border:1px solid var(--line);color:var(--muted);padding:4px 10px;border-radius:999px;font-family:var(--display)}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:14px}
.stat{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 14px}
.stat b{font-family:var(--display);font-size:1.35rem;color:var(--ink);display:block;line-height:1}
.stat span{font-size:.68rem;color:var(--muted);display:block;margin-top:5px}
.stat em{font-style:normal;font-size:.62rem;color:var(--ok);font-weight:600}
.panel{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px}
.panel__h{font-family:var(--display);font-weight:600;font-size:.8rem;color:var(--ink);margin-bottom:10px;display:flex;justify-content:space-between;align-items:center}
.row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-top:1px solid var(--line);font-size:.74rem;color:var(--muted)}
.row:first-of-type{border-top:0}
.row .nm{color:var(--ink);font-weight:500}
.badge{font-size:.6rem;padding:3px 8px;border-radius:999px;font-weight:600;font-family:var(--display)}
.badge--ok{background:#dcfce7;color:#15803d}.badge--warn{background:#fef3c7;color:#b45309}
.badge--info{background:#dbeafe;color:#1d4ed8}.badge--mute{background:#eef0f6;color:#6b7280}
.bars{display:flex;align-items:flex-end;gap:8px;height:84px;padding-top:8px}
.bars span{flex:1;background:linear-gradient(var(--cyan),#3dd6ef);border-radius:5px 5px 0 0;min-height:8px}
.bars span:nth-child(even){background:linear-gradient(var(--indigo),#7c75f0)}
.two{display:grid;grid-template-columns:1.3fr 1fr;gap:12px}

/* ---- generic cards / grids ---- */
.grid{display:grid;gap:22px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;transition:.3s var(--ease)}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#d7dbeb}
.card .ico{width:46px;height:46px;border-radius:12px;background:var(--mist-2);display:grid;place-items:center;color:var(--indigo);margin-bottom:16px}
.card h3{margin-bottom:8px}
.card p{color:var(--muted);font-size:.96rem}
.dark .card{background:var(--ink-soft);border-color:var(--ink-line)}
.dark .card p{color:#B9B9E4}
.dark .card .ico{background:#322d6b;color:var(--cyan)}

/* asterisk list */
.alist{list-style:none;padding:0;margin:0;display:grid;gap:12px}
.alist li{position:relative;padding-left:28px;color:var(--muted);font-size:.98rem}
.alist li::before{content:"*";position:absolute;left:0;top:.05em;color:var(--cyan);font-family:var(--display);font-weight:700;font-size:1.25em}
.dark .alist li{color:#C3C3EA}

/* industries grid */
.ind-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ind{display:block;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;transition:.3s var(--ease);position:relative;overflow:hidden}
.ind:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:#cfd4e8}
.ind__tag{font-family:var(--display);font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--cyan)}
.ind h3{margin:10px 0 8px;font-size:1.22rem}
.ind p{color:var(--muted);font-size:.92rem;margin-bottom:16px}
.ind .go{font-family:var(--display);font-weight:600;font-size:.85rem;color:var(--indigo);display:inline-flex;gap:.4em;align-items:center}
.ind:hover .go .ar{transform:translateX(4px)}
.ind__num{position:absolute;top:18px;right:22px;font-family:var(--display);font-weight:700;color:var(--mist-2);font-size:1.4rem}

/* process steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:s}
.step{position:relative}
.step__n{font-family:var(--display);font-weight:700;font-size:.8rem;color:var(--cyan);letter-spacing:.1em}
.step h3{margin:10px 0 8px;font-size:1.12rem}
.step p{color:var(--muted);font-size:.92rem}
.dark .step p{color:#B9B9E4}

/* feature split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}

/* CTA band */
.cta{background:var(--ink);border-radius:var(--radius-lg);padding:64px;text-align:center;position:relative;overflow:hidden}
.cta h2{color:#fff;margin-bottom:14px}
.cta p{color:#B9B9E4;max-width:54ch;margin:0 auto 28px}
.cta .spark{font-size:18rem;opacity:.08;bottom:-6rem;right:-2rem;animation:spin 50s linear infinite}

/* footer */
.foot{background:var(--ink);color:#C9C9EC;padding:64px 0 30px}
.foot__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;margin-bottom:40px}
.foot .brand{color:#fff;font-size:1.6rem}
.foot p{color:#9FA0CE;font-size:.92rem;margin-top:14px;max-width:34ch}
.foot h4{font-family:var(--display);font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:#8B8DC4;margin-bottom:14px}
.foot ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.foot a{color:#C9C9EC;font-size:.92rem}
.foot a:hover{color:#fff}
.foot__bar{border-top:1px solid var(--ink-line);padding-top:22px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.84rem;color:#8B8DC4}

/* page hero (inner) */
.phero{padding:64px 0 40px}
.phero .eyebrow{margin-bottom:16px}
.phero h1{margin-bottom:18px}

/* forms */
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:18px}
.field label{font-family:var(--display);font-weight:600;font-size:.82rem;color:var(--ink)}
.field input,.field textarea,.field select{
  font-family:var(--body);font-size:1rem;padding:13px 15px;border:1.5px solid var(--line);
  border-radius:12px;background:#fff;color:var(--ink);transition:.2s;width:100%}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 4px rgba(6,182,212,.13)}
.field textarea{resize:vertical;min-height:130px}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.is-visible{opacity:1;transform:none}

/* focus */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:3px solid var(--cyan);outline-offset:2px;border-radius:4px}

/* responsive */
@media(max-width:980px){
  .hero__grid,.split,.two{grid-template-columns:1fr}
  .cols-4{grid-template-columns:repeat(2,1fr)}
  .cols-3,.ind-grid,.steps{grid-template-columns:repeat(2,1fr)}
  .foot__grid{grid-template-columns:1fr 1fr}
  .section{padding:72px 0}
  .hero__order{order:-1}
}
@media(max-width:640px){
  .nav__links{display:none}
  .nav__toggle{display:block}
  .nav.open .nav__links{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;background:#fff;padding:18px 24px;border-bottom:1px solid var(--line);gap:16px}
  .cols-2,.cols-3,.cols-4,.ind-grid,.steps{grid-template-columns:1fr}
  .cta{padding:40px 24px}
  .section{padding:56px 0}
  body{font-size:16px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* ===== logo images ===== */
.brand{padding:4px 0}
.brand__img{height:30px;width:auto;display:block}
.foot .brand__img{height:34px;margin-bottom:4px}
@media(max-width:640px){ .brand__img{height:26px} }

/* ===== justified body copy (per request) ===== */
.lead,.card p,.step p,.ind p,.foot p,.alist li,.phero p{ text-align:justify; -webkit-hyphens:auto; hyphens:auto; }
.cta p{ text-align:center; }  /* keep call-to-action centered */
@media(max-width:640px){ .lead,.card p,.step p,.ind p,.alist li{ text-align:left; } }

/* ===== brand asterisk used as hero spark ===== */
.spark-img{position:absolute;pointer-events:none;user-select:none;opacity:.09}
.spark-img--hero{width:30rem;top:-7rem;right:-6rem;animation:spin 70s linear infinite}
@media(prefers-reduced-motion:reduce){ .spark-img--hero{animation:none} }

/* ===== phone field with country code ===== */
.phone-row{display:flex;gap:10px}
.phone-row select{flex:0 0 auto;width:auto;min-width:120px;padding-left:12px;padding-right:8px}
.phone-row input{flex:1;min-width:0}

/* ============================================================
   MOBILE-ONLY REFINEMENTS (do not affect desktop ≥641px)
   ============================================================ */
.nav__mcta{display:none}
@media(max-width:640px){
  /* header: hide the oversized CTA, surface it inside the menu instead */
  .nav__cta{display:none}
  .nav__mcta{display:inline-flex;align-items:center;gap:.4em;background:var(--cyan);color:#04313b;
    font-family:var(--display);font-weight:600;padding:.7em 1.15em;border-radius:999px;margin-top:6px;width:max-content}

  /* left-align everything that's justified on desktop (justify looks bad in narrow columns) */
  .lead,.card p,.step p,.ind p,.foot p,.phero p,.alist li,.measure{ text-align:left; }

  /* hero: lead with the message, then the product shot */
  .hero{padding:44px 0 52px}
  .hero__order{order:0}
  .hero__cta{gap:10px}
  .hero__cta .btn{width:100%;justify-content:center}

  /* hero dashboard mockup: shrink internals so nothing clips */
  .app{grid-template-columns:50px 1fr}
  .app__side{padding:12px 0;gap:12px}
  .app__nav i{width:22px;height:22px}
  .app__main{padding:13px;min-width:0}
  .app__top{margin-bottom:12px}
  .app__h{font-size:.85rem}
  .stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:7px;margin-bottom:12px}
  .stat{padding:9px 8px;min-width:0}
  .stat b{font-size:1rem;line-height:1.1}
  .stat span{font-size:.58rem}
  .mock__url{font-size:.62rem}

  /* a touch more breathing room on stacked sections */
  .phero{padding:40px 0 28px}
  .cta{padding:36px 22px}
}
@media(max-width:380px){
  .stat b{font-size:.92rem}
  .display{font-size:2.25rem}
}
