/* ============================================================
   NIPPYY — Design System
   The future of money movement for Africa.
   ============================================================ */

:root{
  /* Brand */
  --navy:        #0B0D47;
  --navy-deep:   #06082e;
  --navy-mid:    #11144f;
  --electric:    #0AA5DB;
  --electric-2:  #0AA5DB;
  --violet:      #8b6bff;
  --violet-soft: #b29bff;
  --cyan:        #0AA5DB;

  /* Neutrals */
  --white:       #ffffff;
  --ink:         #0a0c2e;
  --paper:       #f6f7fc;
  --paper-2:     #eef0fa;
  --mist:        #d9ddf0;
  --slate:       #5c6189;
  --slate-2:     #8b8fb3;

  /* Surfaces */
  --glass:       rgba(255,255,255,0.06);
  --glass-2:     rgba(255,255,255,0.10);
  --glass-line:  rgba(255,255,255,0.14);
  --glass-light: rgba(11,13,70,0.04);
  --glass-light-line: rgba(11,13,70,0.08);

  /* Effects */
  --glow-blue:   0 0 60px rgba(77,107,255,0.45);
  --glow-violet: 0 0 70px rgba(139,107,255,0.40);
  --shadow-card: 0 30px 80px -30px rgba(6,8,46,0.55);
  --shadow-soft: 0 20px 50px -25px rgba(6,8,46,0.25);

  /* Type */
  --display: "Clash Display","Space Grotesk",system-ui,sans-serif;
  --body:    "Montserrat","Helvetica Neue",system-ui,sans-serif;

  --maxw: 1200px;
  --r: 22px;
  --r-lg: 30px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  width:100%;
  max-width:100vw;
  position:relative;
  line-height:1.55;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{position:relative;padding:130px 0;overflow:hidden}
.section-sm{padding:90px 0;overflow:hidden}
@media(max-width:760px){.section{padding:88px 0}.section-sm{padding:64px 0}}

/* Section themes */
.dark{background:var(--navy-deep);color:#eef0fb;overflow:hidden}
.dark h1,.dark h2,.dark h3{color:#fff}
.darker{background:#040528;color:#eef0fb;overflow:hidden}
.darker h1,.darker h2,.darker h3{color:#fff}
.light{background:var(--paper);color:var(--ink);overflow:hidden}

/* ---------- Type ---------- */
h1,h2,h3{font-family:var(--display);font-weight:600;line-height:1.04;letter-spacing:-0.03em;text-wrap:balance}
.h-hero{font-size:clamp(2.7rem,6.6vw,5.4rem);font-weight:600}
.h1{font-size:clamp(2.3rem,5vw,4rem)}
.h2{font-size:clamp(1.9rem,3.6vw,3rem)}
.h3{font-size:clamp(1.25rem,2vw,1.6rem)}
.eyebrow{
  font-family:var(--body);font-weight:600;font-size:.74rem;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--electric-2);display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:26px;height:1px;background:linear-gradient(90deg,var(--electric),transparent)}
.dark .eyebrow{color:var(--violet-soft)}
.lead{font-size:clamp(1.05rem,1.5vw,1.28rem);color:var(--slate);max-width:56ch;text-wrap:pretty}
.dark .lead{color:#aeb3da}
.grad-text{color:var(--electric-2)}
.light .grad-text{color:var(--electric)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  padding:15px 26px;border-radius:100px;font-weight:600;font-size:.96rem;
  transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s,background .25s;
  will-change:transform;
}
.btn svg{width:17px;height:17px}
.btn-primary{
  background:#0AA5DB;
  color:#0B0D47;box-shadow:0 14px 36px -12px rgba(10,165,219,.5);
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 22px 50px -14px rgba(10,165,219,.7)}
.btn-ghost{
  background:var(--glass-2);color:#fff;border:1px solid var(--glass-line);
  backdrop-filter:blur(10px);
}
.btn-ghost:hover{transform:translateY(-3px);background:rgba(255,255,255,.16)}
.light .btn-ghost{background:#fff;color:var(--navy);border:1px solid var(--glass-light-line);box-shadow:var(--shadow-soft)}
.light .btn-ghost:hover{background:#fff}

/* ---------- Navbar ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:background .3s,backdrop-filter .3s,border-color .3s,padding .3s;
  padding:18px 0;border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(6,8,46,.72);backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid rgba(255,255,255,.08);padding:12px 0;
}
.nav-in{display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--display);font-weight:600;font-size:1.32rem;color:#fff;letter-spacing:-.02em}
.brand .dot{width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,var(--electric),var(--violet));display:grid;place-items:center;box-shadow:var(--glow-blue)}
.brand .dot span{color:#fff;font-weight:700;font-size:1.05rem}
.brand-logo{height:36px;width:auto;display:block;max-width:none;flex-shrink:0}
.foot .brand-logo{height:42px}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links a{padding:9px 15px;border-radius:10px;color:#cfd3f2;font-size:.93rem;font-weight:500;transition:color .2s,background .2s}
.nav-links a:hover{color:#fff;background:rgba(255,255,255,.07)}
.nav-cta{display:flex;align-items:center;gap:14px}
.menu-btn{display:none;width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.08);border:1px solid var(--glass-line);place-items:center}
.menu-btn span{display:block;width:18px;height:2px;background:#fff;position:relative}
.menu-btn span::before,.menu-btn span::after{content:"";position:absolute;left:0;width:18px;height:2px;background:#fff}
.menu-btn span::before{top:-6px}.menu-btn span::after{top:6px}

/* dropdown */
.has-drop{position:relative}
.drop{
  position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);
  min-width:230px;background:rgba(10,12,46,.92);backdrop-filter:blur(20px);
  border:1px solid var(--glass-line);border-radius:18px;padding:10px;
  opacity:0;visibility:hidden;transition:.25s;box-shadow:var(--shadow-card);
}
.has-drop:hover .drop,
.has-drop:focus-within .drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.drop a{display:flex;flex-direction:column;gap:2px;padding:11px 13px;border-radius:11px}
.drop a b{color:#fff;font-size:.93rem;font-weight:600}
.drop a small{color:#9498c4;font-size:.78rem}

@media screen and (max-width:920px){
  .nav-links,.nav-cta .btn{display:none}
  .menu-btn{display:grid}
  .nav-cta{gap:0}
}

/* mobile drawer */
.drawer{
  position:fixed;inset:0;z-index:1100;background:rgba(4,5,40,.97);backdrop-filter:blur(20px);
  display:flex;flex-direction:column;padding:22px 28px;gap:2px;
  transform:translateY(-100%);transition:transform .4s cubic-bezier(.2,.8,.2,1);
}
.drawer.open{transform:translateY(0)}
.drawer-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.drawer a{color:#dfe2fa;font-family:var(--display);font-size:1.05rem;font-weight:500;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.07)}
.drawer .btn{margin-top:16px;font-size:.93rem;padding:12px 22px;justify-content:center;width:100%}
.x-btn{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.08);color:#fff;font-size:1.3rem;display:grid;place-items:center}

/* ---------- Glass cards ---------- */
.glass{
  background:var(--glass);border:1px solid var(--glass-line);
  border-radius:var(--r-lg);backdrop-filter:blur(16px);box-shadow:var(--shadow-card);
}
.glass-light{
  background:#fff;border:1px solid var(--glass-light-line);
  border-radius:var(--r-lg);box-shadow:var(--shadow-soft);
}

/* ---------- Atmosphere ---------- */
.orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.55;pointer-events:none;z-index:0}
.orb-blue{background:radial-gradient(circle,var(--electric),transparent 70%)}
.orb-violet{background:radial-gradient(circle,var(--violet),transparent 70%)}
.orb-cyan{background:radial-gradient(circle,var(--cyan),transparent 70%)}
canvas.particles{position:absolute;inset:0;z-index:0;pointer-events:none}
.section > .wrap{position:relative;z-index:2}

/* grid helpers */
.grid{display:grid;gap:26px}
.g2{grid-template-columns:1fr 1fr}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.g2,.g3,.g4{grid-template-columns:1fr}.g4{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.g4{grid-template-columns:1fr}}

.center{text-align:center}
.center .lead{margin-left:auto;margin-right:auto}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{animation-duration:.001ms!important;animation-iteration-count:1!important}
  html{scroll-behavior:auto}
}

/* ---------- Feature cards ---------- */
.fcard{padding:34px 30px;position:relative;overflow:hidden;transition:transform .4s,box-shadow .4s,border-color .4s}
.fcard:hover{transform:translateY(-8px)}
.dark .fcard:hover{border-color:rgba(139,107,255,.5);box-shadow:var(--glow-violet)}
.ficon{
  width:56px;height:56px;border-radius:16px;display:grid;place-items:center;margin-bottom:22px;
  background:linear-gradient(135deg,rgba(77,107,255,.22),rgba(139,107,255,.22));
  border:1px solid var(--glass-line);
}
.ficon svg{width:26px;height:26px;stroke:var(--electric-2);fill:none;stroke-width:1.8}
.fcard h3{margin-bottom:10px}
.fcard p{color:#a9ade0;font-size:.97rem}
.light .fcard p{color:var(--slate)}

/* ---------- Stats ---------- */
.stat .num{font-family:var(--display);font-weight:600;font-size:clamp(2.2rem,4vw,3.4rem);letter-spacing:-.03em}
.stat .lbl{color:#9498c4;font-size:.9rem;margin-top:6px}
.light .stat .lbl{color:var(--slate)}

/* ---------- Footer ---------- */
.foot{background:#040528;color:#aeb3da;padding:80px 0 40px;overflow-x:hidden}
.foot-grid{display:grid;grid-template-columns:1.6fr repeat(4,1fr);gap:40px}
@media(max-width:900px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.foot-grid{grid-template-columns:1fr}}
.foot h4{color:#fff;font-family:var(--body);font-weight:600;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:18px}
.foot ul{list-style:none}
.foot li{margin-bottom:11px}
.foot a{color:#9498c4;font-size:.93rem;transition:color .2s}
.foot a:hover{color:#fff}
.foot-bottom{margin-top:60px;padding-top:28px;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;font-size:.85rem;color:#6f73a0}
.foot-disclaimer{width:100%;font-size:.76rem;color:#565a80;line-height:1.75;padding-top:18px;border-top:1px solid rgba(255,255,255,.06);margin-top:4px}
.foot .foot-email{color:var(--electric);font-size:.88rem;display:block;margin-top:14px;transition:color .2s}
.foot .foot-email:hover{color:#fff}
.foot-socials{display:flex;gap:10px;margin-top:16px}
.foot .foot-socials a{width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);display:grid;place-items:center;color:#9498c4;transition:background .2s,color .2s;flex-shrink:0}
.foot .foot-socials a:hover{background:rgba(255,255,255,.14);color:#fff}
.foot-socials svg{width:15px;height:15px}

/* ---------- Page hero (interior) ---------- */
.phero{position:relative;padding:190px 0 120px;overflow:hidden}
.phero .eyebrow{margin-bottom:22px}
.phero .lead{margin-top:24px}

/* ---------- Accordion ---------- */
.acc{border-radius:18px;overflow:hidden;margin-bottom:14px}
.acc-q{width:100%;text-align:left;padding:24px 26px;display:flex;justify-content:space-between;align-items:center;gap:20px;font-family:var(--display);font-weight:500;font-size:1.1rem;color:#fff}
.acc-q .ic{width:30px;height:30px;flex:none;border-radius:50%;border:1px solid var(--glass-line);display:grid;place-items:center;transition:transform .3s,background .3s;font-size:1.1rem}
.acc.open .acc-q .ic{transform:rotate(45deg);background:var(--electric)}
.acc-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.acc-a p{padding:0 26px 24px;color:#a9ade0;font-size:.98rem}

/* ---------- Floating mock UI ---------- */
.float{animation:floaty 6s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
.float.slow{animation-duration:8s}
.float.delay{animation-delay:-3s}

/* phone mock */
.phone{
  width:280px;max-width:calc(100vw - 80px);border-radius:42px;padding:14px;background:linear-gradient(160deg,#1a1d5c,#0a0c30);
  border:1px solid rgba(255,255,255,.12);box-shadow:0 50px 120px -30px rgba(0,0,0,.7),var(--glow-blue);
  position:relative;
}
.phone-screen{border-radius:30px;overflow:hidden;background:linear-gradient(180deg,#0e1140,#060828);padding:22px 18px;min-height:520px}
.notch{position:absolute;top:24px;left:50%;transform:translateX(-50%);width:90px;height:6px;background:rgba(255,255,255,.18);border-radius:10px}

/* mini ui rows */
.uirow{display:flex;align-items:center;gap:12px;padding:13px;border-radius:15px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.07);margin-bottom:10px}
.uirow .av{width:38px;height:38px;border-radius:11px;flex:none;background:linear-gradient(135deg,var(--electric),var(--violet))}
.uirow .av.v2{background:linear-gradient(135deg,var(--violet),var(--cyan))}
.uirow .av.v3{background:linear-gradient(135deg,var(--cyan),var(--electric))}
.uirow .t1{font-size:.86rem;color:#fff;font-weight:600}
.uirow .t2{font-size:.74rem;color:#8c90bd}
.uirow .amt{margin-left:auto;font-weight:700;font-size:.9rem;color:#5af0a0}
.uirow .amt.out{color:#ff8aa3}

/* currency chip */
.chip{display:inline-flex;align-items:center;gap:8px;padding:9px 15px;border-radius:100px;background:var(--glass-2);border:1px solid var(--glass-line);font-size:.85rem;font-weight:600;color:#fff;backdrop-filter:blur(8px)}
.chip .flag{width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,var(--electric),var(--violet));font-size:.7rem;display:grid;place-items:center}
.chip svg{width:14px;height:14px;flex:none;color:var(--electric)}

/* pill marquee */
.marquee{display:flex;gap:14px;animation:scrollx 28s linear infinite;width:max-content}
@keyframes scrollx{to{transform:translateX(-50%)}}
.marquee-wrap{overflow:hidden;-webkit-mask:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}

/* steps */
.steps{position:relative}
.step{display:grid;grid-template-columns:auto 1fr;gap:26px;align-items:start;padding-bottom:54px;position:relative}
.step:last-child{padding-bottom:0}
.step-n{width:62px;height:62px;border-radius:50%;flex:none;display:grid;place-items:center;font-family:var(--display);font-weight:600;font-size:1.4rem;color:#fff;background:linear-gradient(135deg,var(--electric),var(--violet));box-shadow:var(--glow-blue);position:relative;z-index:2}
.step::before{content:"";position:absolute;left:31px;top:62px;bottom:0;width:2px;background:linear-gradient(180deg,var(--violet),transparent);opacity:.5}
.step:last-child::before{display:none}
.step h3{margin-bottom:8px}
.step p{color:#a9ade0;max-width:46ch}

/* badges / trust */
.tline{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.tbadge{display:inline-flex;align-items:center;gap:9px;padding:11px 18px;border-radius:100px;background:var(--glass);border:1px solid var(--glass-line);font-size:.86rem;font-weight:600;color:#dfe2fa}
.tbadge svg{width:16px;height:16px;stroke:var(--cyan)}

/* shield */
.shield{width:200px;height:230px;position:relative;margin:0 auto}
.shield svg{width:100%;filter:drop-shadow(0 0 40px rgba(77,107,255,.6))}
.shield .ring{position:absolute;inset:-30px;border:1px solid rgba(111,140,255,.3);border-radius:50%;animation:pulsering 3s ease-out infinite}
.shield .ring.r2{animation-delay:1.5s}
@keyframes pulsering{0%{transform:scale(.7);opacity:.7}100%{transform:scale(1.4);opacity:0}}

/* team */
.tmember{padding:26px;text-align:center;transition:transform .35s}
.tmember:hover{transform:translateY(-6px)}
.tphoto{width:96px;height:96px;border-radius:26px;margin:0 auto 18px;background:linear-gradient(135deg,var(--electric),var(--violet));display:grid;place-items:center;font-family:var(--display);font-size:1.8rem;color:#fff;font-weight:600}
.tmember h3{font-size:1.2rem;margin-bottom:4px}
.tmember .role{color:var(--electric-2);font-size:.85rem;font-weight:600}

/* contact cards */
.contact-card{padding:32px;display:flex;gap:18px;align-items:flex-start;transition:transform .35s,border-color .35s}
.contact-card:hover{transform:translateY(-6px)}
.contact-card .ci{width:50px;height:50px;border-radius:15px;flex:none;display:grid;place-items:center;background:linear-gradient(135deg,rgba(77,107,255,.2),rgba(139,107,255,.2));border:1px solid var(--glass-line)}
.contact-card .ci svg{width:24px;height:24px;stroke:var(--electric-2);fill:none;stroke-width:1.7}

/* live dot */
.live{display:inline-flex;align-items:center;gap:8px;font-size:.85rem;font-weight:600;color:#5af0a0}
.live .d{width:9px;height:9px;border-radius:50%;background:#5af0a0;box-shadow:0 0 0 0 rgba(90,240,160,.6);animation:livepulse 1.8s infinite}
@keyframes livepulse{0%{box-shadow:0 0 0 0 rgba(90,240,160,.6)}70%{box-shadow:0 0 0 12px rgba(90,240,160,0)}100%{box-shadow:0 0 0 0 rgba(90,240,160,0)}}

/* whatsapp bubble */
.wa{max-width:320px;margin:0 auto}
.bubble{padding:13px 16px;border-radius:18px;margin-bottom:10px;font-size:.9rem;line-height:1.5;max-width:80%}
.bubble.them{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08);color:#e7e9fb;border-bottom-left-radius:5px}
.bubble.me{background:linear-gradient(135deg,var(--electric),var(--violet));color:#fff;margin-left:auto;border-bottom-right-radius:5px}

/* value list */
.vrow{display:grid;grid-template-columns:auto 1fr;gap:18px;padding:24px 0;border-bottom:1px solid var(--glass-line)}
.dark .vrow{border-color:rgba(255,255,255,.08)}
.vrow .vk{font-family:var(--display);font-size:1.3rem;color:var(--electric-2);font-weight:600}
.vrow h3{margin-bottom:6px}
.vrow p{color:#a9ade0;max-width:60ch}

/* hero headline rotator */
.rotator{position:relative;min-height:1.15em;display:block}
.rotator .line{position:absolute;inset:0;opacity:0;transform:translateY(20px);transition:opacity .7s,transform .7s}
.rotator .line.active{opacity:1;transform:none;position:relative}

/* convert widget */
.convert{padding:26px}
.convert .field{display:flex;justify-content:space-between;align-items:center;padding:18px;border-radius:16px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);margin-bottom:12px}
.convert .field .v{font-family:var(--display);font-size:1.7rem;color:#fff;font-weight:600}
.convert .swap{width:44px;height:44px;border-radius:50%;margin:-22px auto;position:relative;z-index:3;display:grid;place-items:center;background:linear-gradient(135deg,var(--electric),var(--violet));color:#fff;box-shadow:var(--glow-blue)}
.convert .rate{text-align:center;color:#8c90bd;font-size:.85rem;margin-top:16px}

/* use case */
.uc{padding:30px;transition:transform .35s}
.uc:hover{transform:translateY(-6px)}
.uc .ucn{font-size:.8rem;color:var(--violet-soft);font-weight:600;letter-spacing:.1em;margin-bottom:12px}
.uc h3{font-size:1.25rem;margin-bottom:10px}
.uc p{color:#a9ade0;font-size:.95rem}

/* big cta band */
.ctaband{position:relative;overflow:hidden;border-radius:36px;padding:80px 60px;text-align:center;background:linear-gradient(135deg,var(--navy-deep),#1a1066)}
@media(max-width:600px){.ctaband{padding:54px 26px}}

/* ---------- Asymmetric features grid ---------- */
.features-grid{display:grid;grid-template-columns:1.5fr 1fr;grid-template-rows:auto auto;gap:26px}
.features-grid > :first-child{grid-row:1/3}
@media(max-width:900px){
  .features-grid{grid-template-columns:1fr;grid-template-rows:auto}
  .features-grid > :first-child{grid-row:auto}
}

/* ---------- Waitlist form ---------- */
.waitlist{max-width:480px;margin:0 auto}
.wl-row{display:flex;gap:10px;flex-wrap:wrap}
.wl-row input[type=email]{
  flex:1;min-width:220px;padding:15px 20px;border-radius:100px;
  background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.18);
  color:#fff;font-size:.96rem;font-family:var(--body);
  outline:none;transition:border-color .25s,background .25s;
}
.wl-row input[type=email]::placeholder{color:rgba(255,255,255,.45)}
.wl-row input[type=email]:focus{border-color:var(--electric-2);background:rgba(255,255,255,.14)}
.wl-confirm{font-size:.9rem;color:#5af0a0;margin-top:14px;text-align:center}

/* ---------- Footer legal links ---------- */

/* ---------- Nav active state ---------- */
.nav-links a[aria-current]{color:#fff;background:rgba(255,255,255,.09)}

/* ---------- Proof bar ---------- */
.proof-outer{max-width:720px;margin:0 auto}
.proof-grid{display:grid;grid-template-columns:1fr 1fr}
.proof-cell-r{border-left:1px solid var(--mist)}
@media(max-width:540px){
  .proof-grid{grid-template-columns:1fr}
  .proof-cell-r{border-left:none;border-top:1px solid var(--mist);padding-top:32px!important;margin-top:8px}
}

/* ---------- Mobile horizontal scroll prevention ---------- */
@media(max-width:768px){
  /* Orbs are decorative; hide on mobile to eliminate the main overflow source */
  .orb{display:none}
  /* Comprehensive containment — body position:relative is set globally above */
  section,header,footer{overflow-x:hidden;max-width:100%}
  /* Ensure no child element escapes the viewport */
  .wrap{overflow-x:hidden}
}
