/* ===== Vusani360 — site styles ===== */
:root{
  --burgundy:#46122a;
  --burgundy-2:#5e1838;
  --magenta:#bd1f6a;
  --magenta-dark:#9c1759;
  --teal:#14a098;
  --gold:#c39a2b;
  --ink:#2c1822;
  --muted:#6d5b64;
  --bg:#faf6f7;
  --paper:#ffffff;
  --line:#ecdfe4;
  --grad:linear-gradient(120deg,#46122a 0%,#7c1a47 55%,#bd1f6a 100%);
  --radius:16px;
  --shadow:0 18px 40px -22px rgba(70,18,42,.45);
  --shadow-sm:0 8px 22px -14px rgba(70,18,42,.4);
  --maxw:1180px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--magenta);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
section{padding:84px 0}
h1,h2,h3,h4{line-height:1.2;color:var(--burgundy);font-weight:700}
h2{font-size:2rem;margin-bottom:14px}
.lead{font-size:1.08rem;color:var(--muted)}
.center{text-align:center}
.center .lead{max-width:680px;margin:0 auto}

/* ---- buttons ---- */
.btn{
  display:inline-block;padding:13px 26px;border-radius:999px;
  font-weight:600;font-size:.97rem;cursor:pointer;border:2px solid transparent;
  transition:transform .15s ease,box-shadow .15s ease,background .15s ease;
}
.btn:hover{text-decoration:none;transform:translateY(-2px)}
.btn-primary{background:var(--magenta);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--magenta-dark)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn-ghost:hover{background:rgba(255,255,255,.12)}
.btn-outline{background:#fff;color:var(--magenta);border-color:var(--magenta)}
.btn-outline:hover{background:var(--magenta);color:#fff}

/* ---- header / nav ---- */
.site-header{
  position:sticky;top:0;z-index:50;background:var(--grad);
  box-shadow:0 6px 18px -10px rgba(0,0,0,.5);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;max-width:var(--maxw);margin:0 auto}
.nav-logo{display:flex;align-items:center}
.nav-logo img{height:74px;width:auto;transition:transform .2s ease}
.nav-logo:hover img{transform:scale(1.04)}
.nav-links{display:flex;align-items:center;gap:8px;list-style:none}
.nav-links a{
  color:#f4e7ee;font-weight:500;padding:8px 14px;border-radius:8px;font-size:.96rem;
}
.nav-links a:hover{background:rgba(255,255,255,.12);text-decoration:none;color:#fff}
.nav-links a.active{color:#fff;background:rgba(255,255,255,.16)}
.nav-links .btn{margin-left:8px;padding:9px 20px}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:6px}
.nav-toggle span{display:block;width:26px;height:3px;background:#fff;margin:5px 0;border-radius:2px;transition:.2s}

/* ---- hero ---- */
.hero{background:var(--grad);color:#fff;padding:84px 0 96px;position:relative;overflow:hidden}
.hero::after{
  content:"";position:absolute;right:-120px;top:-120px;width:420px;height:420px;
  background:radial-gradient(circle,rgba(255,255,255,.12),transparent 70%);border-radius:50%;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.08) 1px,transparent 1px);
  background-size:30px 30px;opacity:.7;
}
.hero .container{position:relative;z-index:2}
.hero h1{color:#fff;font-size:2.85rem;max-width:760px}
.hero .tagline{
  display:inline-block;background:rgba(255,255,255,.14);color:#f6e3ec;
  padding:6px 16px;border-radius:999px;font-size:.82rem;font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;margin-bottom:22px;
}
.hero p.intro{font-size:1.12rem;color:#f0dde5;max-width:640px;margin:18px 0 30px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-shot{margin-top:60px;filter:drop-shadow(0 40px 70px rgba(0,0,0,.5))}

/* ---- pillars strip ---- */
.pillars{background:var(--paper);border-bottom:1px solid var(--line)}
.pillars .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.pillar{text-align:center}
.pillar .icon{
  width:54px;height:54px;margin:0 auto 12px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;font-size:1.5rem;
  background:#fbe9f1;color:var(--magenta);
}
.pillar h4{font-size:1.05rem;margin-bottom:4px}
.pillar p{font-size:.93rem;color:var(--muted)}

/* ---- cards / features ---- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}
.card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:28px;box-shadow:var(--shadow-sm);transition:transform .18s ease,box-shadow .18s ease;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card .tag{
  width:46px;height:46px;border-radius:12px;display:flex;align-items:center;
  justify-content:center;font-weight:700;color:#fff;background:var(--grad);margin-bottom:14px;
}
.card h3{font-size:1.16rem;margin-bottom:8px}
.card p{font-size:.96rem;color:var(--muted)}

/* ---- alt section ---- */
.alt{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

/* ---- screenshot gallery ---- */
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;margin-top:40px}
.shot{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .18s ease;
}
.shot:hover{transform:translateY(-4px)}
.shot img{border-bottom:1px solid var(--line)}
.shot .cap{padding:16px 20px}
.shot .cap h4{font-size:1.02rem;margin-bottom:2px}
.shot .cap p{font-size:.88rem;color:var(--muted)}

/* ---- split / highlight ---- */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:50px;align-items:center}
.split.rev .split-text{order:2}
.badge{
  display:inline-block;background:#fbe9f1;color:var(--magenta-dark);
  font-size:.78rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  padding:5px 13px;border-radius:999px;margin-bottom:14px;
}
.checklist{list-style:none;margin-top:16px}
.checklist li{position:relative;padding-left:30px;margin-bottom:10px;color:var(--ink)}
.checklist li::before{
  content:"\2713";position:absolute;left:0;top:1px;width:20px;height:20px;
  background:var(--teal);color:#fff;border-radius:50%;font-size:.72rem;
  display:flex;align-items:center;justify-content:center;font-weight:700;
}
.split-media img{border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--line)}

/* ---- quote ---- */
.quote{background:var(--grad);color:#fff}
.quote blockquote{
  max-width:820px;margin:0 auto;text-align:center;font-size:1.5rem;
  font-weight:600;line-height:1.45;
}
.quote blockquote span{color:#f5c6dc}
.quote cite{display:block;margin-top:18px;font-size:.95rem;color:#e9cdd9;font-style:normal;font-weight:500}

/* ---- benefits ---- */
.benefits{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px}
.benefit{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;border-left:4px solid var(--magenta);box-shadow:var(--shadow-sm);
}
.benefit h4{font-size:1.05rem;margin-bottom:4px}
.benefit p{font-size:.93rem;color:var(--muted)}

/* ---- industries ---- */
.industries{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:34px}
.industries span{
  background:var(--paper);border:1px solid var(--line);padding:10px 20px;
  border-radius:999px;font-weight:600;font-size:.93rem;color:var(--burgundy);
}

/* ---- pricing ---- */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:44px;align-items:start}
.plan{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 26px;box-shadow:var(--shadow-sm);position:relative;
}
.plan.featured{border:2px solid var(--magenta);box-shadow:var(--shadow)}
.plan .flag{
  position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--magenta);color:#fff;font-size:.74rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;padding:5px 16px;border-radius:999px;
}
.plan h3{font-size:1.3rem}
.plan .target{font-size:.86rem;color:var(--muted);margin-bottom:16px}
.plan .price{font-size:1.9rem;color:var(--magenta);font-weight:700;line-height:1.2}
.plan .price small{display:block;font-size:.82rem;color:var(--muted);font-weight:500}
.plan .price-sub{font-size:.86rem;color:var(--muted);margin:4px 0 18px}
.plan ul{list-style:none;margin:18px 0 24px}
.plan ul li{
  position:relative;padding-left:26px;margin-bottom:8px;font-size:.93rem;color:var(--ink);
}
.plan ul li::before{
  content:"\2713";position:absolute;left:0;color:var(--teal);font-weight:700;
}
.plan .btn{width:100%;text-align:center}
.pricing-note{
  margin-top:30px;background:#fdf3f7;border:1px dashed var(--magenta);
  border-radius:var(--radius);padding:22px 26px;font-size:.92rem;color:var(--muted);
}
.pricing-note ul{margin:8px 0 0 18px}

/* ---- contact ---- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:46px;margin-top:40px;align-items:start}
.contact-info .item{display:flex;gap:14px;margin-bottom:20px;align-items:flex-start}
.contact-info .item .ic{
  width:42px;height:42px;flex:0 0 42px;border-radius:10px;background:#fbe9f1;
  color:var(--magenta);display:flex;align-items:center;justify-content:center;font-size:1.1rem;
}
.contact-info .item h4{font-size:.95rem;margin-bottom:1px}
.contact-info .item p,.contact-info .item a{font-size:.95rem;color:var(--muted)}
.form{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm)}
.form label{display:block;font-size:.86rem;font-weight:600;color:var(--burgundy);margin-bottom:6px}
.form .field{margin-bottom:16px}
.form input,.form textarea,.form select{
  width:100%;padding:11px 14px;border:1px solid var(--line);border-radius:10px;
  font-family:inherit;font-size:.95rem;color:var(--ink);background:#fff;
}
.form input:focus,.form textarea:focus,.form select:focus{
  outline:none;border-color:var(--magenta);box-shadow:0 0 0 3px rgba(189,31,106,.12);
}
.form textarea{resize:vertical;min-height:110px}
.form-note{font-size:.82rem;color:var(--muted);margin-top:10px}

/* ---- CTA band ---- */
.cta-band{background:var(--grad);color:#fff;text-align:center}
.cta-band h2{color:#fff;font-size:2rem}
.cta-band p{color:#f0dde5;max-width:560px;margin:10px auto 26px}

/* ---- page hero (inner pages) ---- */
.page-hero{background:var(--grad);color:#fff;padding:64px 0}
.page-hero h1{color:#fff;font-size:2.3rem}
.page-hero p{color:#f0dde5;max-width:640px;margin-top:10px}
.crumb{font-size:.84rem;color:#e6c8d6;margin-bottom:10px}
.crumb a{color:#f5c6dc}

/* ---- footer ---- */
.site-footer{background:var(--burgundy);color:#dcc6d0;padding:56px 0 24px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px}
.site-footer img{height:42px;margin-bottom:14px}
.site-footer p{font-size:.92rem;color:#c7adb8;max-width:320px}
.site-footer h4{color:#fff;font-size:.95rem;margin-bottom:12px;letter-spacing:.04em}
.site-footer ul{list-style:none}
.site-footer ul li{margin-bottom:8px}
.site-footer ul a{color:#dcc6d0;font-size:.92rem}
.site-footer ul a:hover{color:#fff}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.12);margin-top:40px;padding-top:20px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;
  font-size:.85rem;color:#b394a3;
}
.tagline-strip{text-align:center;font-style:italic;color:#e6c8d6;margin-top:6px;font-size:.9rem}
.site-footer .product-of{
  text-align:center;font-size:clamp(.5rem,2.4vw,.92rem);color:#dcc6d0;
  margin:16px auto 0;max-width:none;white-space:nowrap;
}
.site-footer .product-of strong{color:#fff;font-weight:700}

/* ---- reveal animation ---- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ===== tech / app aesthetic ===== */

/* page-hero dotted grid */
.page-hero{position:relative;overflow:hidden}
.page-hero::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.08) 1px,transparent 1px);
  background-size:30px 30px;opacity:.7;
}
.page-hero .container{position:relative;z-index:2}

/* mono label */
.mono{
  font-family:'Consolas','SF Mono',Menlo,monospace;
  letter-spacing:.02em;
}

/* live badge with pulsing dot */
.live{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.12);color:#f6e3ec;
  padding:6px 14px;border-radius:999px;font-size:.78rem;font-weight:600;
}
.pulse{
  width:9px;height:9px;border-radius:50%;background:#28c840;
  box-shadow:0 0 0 0 rgba(40,200,64,.7);animation:pulse 2.2s infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(40,200,64,.6)}
  70%{box-shadow:0 0 0 12px rgba(40,200,64,0)}
  100%{box-shadow:0 0 0 0 rgba(40,200,64,0)}
}

/* app window frame for screenshots */
.window{
  border-radius:14px;overflow:hidden;background:#fff;
  border:1px solid var(--line);box-shadow:var(--shadow);
}
.window-bar{
  display:flex;align-items:center;gap:7px;padding:11px 15px;
  background:#2c1822;
}
.window-bar i{width:11px;height:11px;border-radius:50%;display:block}
.window-bar i.r{background:#ff5f57}
.window-bar i.y{background:#febc2e}
.window-bar i.g{background:#28c840}
.window-url{
  margin-left:12px;flex:1;background:rgba(255,255,255,.09);color:#c7adb8;
  font-size:.74rem;padding:5px 13px;border-radius:6px;
  font-family:'Consolas','SF Mono',monospace;white-space:nowrap;overflow:hidden;
  text-overflow:ellipsis;
}
.window>img{display:block;width:100%}
.window.float{transition:transform .25s ease}
.window.float:hover{transform:translateY(-6px)}

/* glowing accent under hero window */
.hero-shot{position:relative}
.hero-shot .live{position:absolute;top:-16px;left:22px;z-index:3;
  background:#fff;color:var(--burgundy);box-shadow:var(--shadow);}

/* stat band with counters */
.stat-band{background:var(--burgundy);color:#fff;padding:52px 0;position:relative;overflow:hidden}
.stat-band::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px);
  background-size:28px 28px;
}
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center;position:relative;z-index:2}
.stat .num{
  font-size:2.7rem;font-weight:800;color:#fff;line-height:1;
  font-family:'Consolas','SF Mono',monospace;
}
.stat .num em{color:#f5a8c9;font-style:normal}
.stat .lbl{font-size:.9rem;color:#dcc6d0;margin-top:8px;letter-spacing:.03em}

/* module toolbar / filter */
.module-toolbar{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:30px 0 4px}
.filter-btn{
  border:1px solid var(--line);background:#fff;color:var(--burgundy);
  padding:9px 22px;border-radius:999px;font-weight:600;font-size:.9rem;
  cursor:pointer;font-family:inherit;transition:.15s ease;
}
.filter-btn:hover{border-color:var(--magenta);color:var(--magenta)}
.filter-btn.active{background:var(--grad);color:#fff;border-color:transparent}

/* module grid */
.module-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:26px}
.module-card{
  background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:24px 24px 22px 28px;box-shadow:var(--shadow-sm);position:relative;
  overflow:hidden;transition:transform .18s ease,box-shadow .18s ease;
}
.module-card::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--grad);
}
.module-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.module-card.hide{display:none}
.m-top{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.m-ico{
  width:46px;height:46px;flex:0 0 46px;border-radius:12px;background:#fbe9f1;
  color:var(--magenta);display:flex;align-items:center;justify-content:center;font-size:1.35rem;
}
.m-no{font-family:'Consolas',monospace;font-size:.76rem;color:var(--muted);display:block}
.module-card h3{font-size:1.06rem;margin-top:1px}
.module-card p{font-size:.91rem;color:var(--muted);margin-top:2px}
.m-cat{
  display:inline-block;margin-top:14px;font-size:.68rem;font-weight:700;
  letter-spacing:.07em;text-transform:uppercase;padding:4px 11px;border-radius:999px;
}
.m-cat.sheq{background:#e0f4f2;color:#0d7a72}
.m-cat.grc{background:#fbe9f1;color:var(--magenta-dark)}
.m-cat.both{background:#fdf0d6;color:#9a7716}

/* spotlight rows */
.spotlight + .spotlight{margin-top:64px}
.feat-list{list-style:none;margin-top:14px}
.feat-list li{
  position:relative;padding-left:26px;margin-bottom:9px;font-size:.95rem;color:var(--ink);
}
.feat-list li::before{
  content:"\203A";position:absolute;left:6px;top:-1px;color:var(--magenta);
  font-weight:800;font-size:1.1rem;
}

/* tech chips */
.chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:18px}
.chips span{
  font-family:'Consolas',monospace;font-size:.8rem;
  background:#fff;border:1px solid var(--line);color:var(--burgundy);
  padding:6px 13px;border-radius:7px;
}

/* responsive */
@media(max-width:900px){
  section{padding:60px 0}
  .hero{padding:60px 0 70px}
  .hero h1{font-size:2.1rem}
  .nav-logo img{height:58px}
  .nav-toggle{display:block}
  .nav-links{
    position:absolute;top:100%;left:0;right:0;background:var(--burgundy-2);
    flex-direction:column;align-items:stretch;gap:0;padding:10px 16px 18px;
    display:none;box-shadow:0 18px 30px -16px rgba(0,0,0,.6);
  }
  .nav-links.open{display:flex}
  .nav-links a{padding:13px 12px;border-radius:8px;font-size:1rem}
  .nav-links .btn{margin:8px 0 0;text-align:center}
  .pillars .grid,.cards,.gallery,.benefits,.pricing,.contact-grid{grid-template-columns:1fr}
  .module-grid{grid-template-columns:1fr}
  .split,.split.rev .split-text{grid-template-columns:1fr;order:0}
  .footer-grid{grid-template-columns:1fr}
  .quote blockquote{font-size:1.2rem}
  .stat-row{grid-template-columns:repeat(2,1fr);gap:32px 18px}
}
@media(max-width:560px){
  .container{padding:0 18px}
  .hero h1{font-size:1.72rem}
  h2{font-size:1.55rem}
  .nav-logo img{height:50px}
  .hero-actions .btn,.hero-actions{width:100%}
  .hero-actions .btn{text-align:center}
  .stat .num{font-size:2.1rem}
  .window-url{font-size:.66rem}
  .module-card{padding:22px 20px 20px 24px}
}

/* window img overrides */
.split-media .window img,.window img{border:0;border-radius:0;box-shadow:none}
.shot img{border:0}
