:root{
  --bg:#06181a;
  --bg-2:#08211f;
  --surface:#0c2c28;
  --surface-2:#0f3631;
  --ink:#e9fbf4;
  --muted:#8eb0a8;
  --muted-2:#5f817a;
  --aqua:#2fe6c6;
  --aqua-deep:#0fb89e;
  --teal:#0d7d6f;
  --coral:#ff6a3d;
  --coral-2:#ff8a5c;
  --gold:#ffb627;
  --line:rgba(233,251,244,.10);
  --line-2:rgba(233,251,244,.18);
  --glow:0 0 0 1px rgba(47,230,198,.18),0 0 40px rgba(47,230,198,.15);
  --shadow:0 20px 60px rgba(0,0,0,.45);
  --display:"Bricolage Grotesque",system-ui,sans-serif;
  --sans:"Albert Sans",-apple-system,sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);background:var(--bg);color:var(--ink);
  line-height:1.55;overflow-x:hidden;-webkit-font-smoothing:antialiased;cursor:none;
}
@media(hover:none){body{cursor:auto}}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:none}
::selection{background:var(--aqua);color:var(--bg)}

/* atmospheric background */
.bg-mesh{position:fixed;inset:0;z-index:-2;overflow:hidden;pointer-events:none}
.bg-mesh i{position:absolute;border-radius:50%;filter:blur(90px);opacity:.45;animation:drift 24s var(--ease) infinite alternate}
.m1{width:60vw;height:60vw;background:radial-gradient(circle,#0c5a52,transparent 65%);top:-25vw;right:-15vw}
.m2{width:50vw;height:50vw;background:radial-gradient(circle,#103e6a,transparent 65%);bottom:-20vw;left:-12vw;animation-delay:-8s}
.m3{width:34vw;height:34vw;background:radial-gradient(circle,#7a3a1e,transparent 65%);top:40%;left:30%;opacity:.25;animation-delay:-14s}
@keyframes drift{to{transform:translate(40px,-30px) scale(1.12)}}
.grain{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");}

/* custom cursor */
.cursor,.cursor-dot{position:fixed;top:0;left:0;z-index:10000;pointer-events:none;border-radius:50%;mix-blend-mode:screen}
.cursor{width:34px;height:34px;border:1.5px solid var(--aqua);transition:width .25s,height .25s,background .25s,opacity .2s;transform:translate(-50%,-50%)}
.cursor-dot{width:5px;height:5px;background:var(--aqua);transform:translate(-50%,-50%)}
.cursor.big{width:64px;height:64px;background:rgba(47,230,198,.12)}
@media(hover:none){.cursor,.cursor-dot{display:none}}

/* scroll progress */
.progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:200;
  background:linear-gradient(90deg,var(--aqua),var(--coral));box-shadow:0 0 12px var(--aqua)}

.wrap{width:min(1240px,90vw);margin-inline:auto}
.eyebrow{font-family:var(--sans);font-weight:700;font-size:.72rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--aqua);display:inline-flex;align-items:center;gap:.6rem}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--coral)}
h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1;letter-spacing:-.03em}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-weight:700;font-size:.95rem;
  padding:.9rem 1.7rem;border-radius:100px;border:1.5px solid transparent;position:relative;
  transition:transform .3s var(--ease),box-shadow .3s,background .3s,color .3s;overflow:hidden}
.btn-primary{background:var(--aqua);color:#04201c}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(47,230,198,.4)}
.btn-ghost{border-color:var(--line-2);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--bg);transform:translateY(-3px)}
/* Override global cursor:none for conversion CTAs — trackpad users need feedback on hover */
.btn,.btn-primary,.btn-light,.btn-ghost,[data-waitlist]{cursor:pointer!important}

/* ===== NAV ===== */
header{position:fixed;top:0;left:0;right:0;z-index:150;transition:.4s}
header.scrolled{backdrop-filter:blur(16px);background:rgba(6,24,26,.7);box-shadow:0 1px 0 var(--line)}
nav{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 0}
/* BulaCore portal wordmark — Poppins 700, navy "Bula" + teal "POS",
   radial swoosh underline, slow sheen sweep across the entire mark. */
.brand{display:inline-flex;flex-direction:column;align-items:flex-start;gap:2px;text-decoration:none;cursor:none}
.brand-row{position:relative;display:inline-block;
  font-family:"Poppins",-apple-system,system-ui,sans-serif;font-weight:700;font-size:1.65rem;
  letter-spacing:-.01em;line-height:1;padding:2px 4px 10px 4px;overflow:hidden}
.brand-bula{color:var(--navy)}
.brand-pos{color:var(--aqua)}
.brand-books{color:var(--coral)}
.brand-core{color:var(--aqua)}
/* Teal swoosh under the wordmark — matches BulaCore portal exactly */
.brand-row::before{content:"";position:absolute;left:5%;right:5%;bottom:2px;height:6px;
  background:radial-gradient(ellipse 100% 100% at center bottom,var(--aqua) 0%,var(--aqua) 30%,transparent 70%);
  border-radius:50% 50% 0 0 / 100% 100% 0 0;opacity:.85;pointer-events:none}
/* Slow sheen across the whole wordmark (was 4.5s, now 8s with longer rest) */
.brand-row::after{content:"";position:absolute;inset:0;
  background:linear-gradient(115deg,transparent 44%,rgba(255,255,255,.35) 50%,transparent 56%);
  transform:translateX(-130%);animation:sheen 8s ease-in-out infinite;pointer-events:none}
@keyframes sheen{0%,75%{transform:translateX(-130%)}92%,100%{transform:translateX(130%)}}
.brand small{display:block;font-family:var(--sans);font-weight:700;font-size:.56rem;letter-spacing:.24em;
  text-transform:uppercase;color:var(--muted);margin-top:1px;padding-left:4px}
.nav-links{display:flex;gap:.4rem;align-items:center;background:rgba(233,251,244,.04);
  border:1px solid var(--line);border-radius:100px;padding:.3rem}
.nav-links a{padding:.5rem 1rem;border-radius:100px;font-weight:600;font-size:.9rem;color:var(--muted);transition:.25s}
.nav-links a:hover{color:var(--ink)}
.nav-links a.active{background:var(--ink);color:var(--bg)}
.nav-cta{display:flex;gap:.6rem;align-items:center}
.nav-signin{font-weight:600;font-size:.9rem;color:var(--muted);padding:.55rem .9rem;border-radius:100px;transition:.25s}
.nav-signin:hover{color:var(--ink)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;padding:8px}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}

/* ===== PAGE / ROUTING ===== */
main{padding-top:84px}
.page{display:none;animation:pageIn .7s var(--ease)}
.page.active{display:block}
@keyframes pageIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.swipe{position:fixed;inset:0;z-index:300;transform:scaleY(0);transform-origin:bottom;pointer-events:none;background:rgba(233,251,244,.05);backdrop-filter:blur(20px) saturate(140%);-webkit-backdrop-filter:blur(20px) saturate(140%);border-top:1px solid rgba(47,230,198,.28);border-bottom:1px solid rgba(47,230,198,.28)}
.swipe.go{animation:swipe 1s var(--ease)}
@keyframes swipe{0%{transform:scaleY(0);transform-origin:bottom}45%{transform:scaleY(1);transform-origin:bottom}55%{transform:scaleY(1);transform-origin:top}100%{transform:scaleY(0);transform-origin:top}}

/* reveal */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}.reveal[data-d="4"]{transition-delay:.32s}
.reveal[data-d="5"]{transition-delay:.4s}.reveal[data-d="6"]{transition-delay:.48s}

.sec{padding:6.5rem 0}
.sec-head{max-width:46rem;margin-bottom:3.5rem}
.sec-head h2{font-size:clamp(2.2rem,4.6vw,3.6rem);margin:1.1rem 0 1rem;letter-spacing:-.035em}
.sec-head p{font-size:1.15rem;color:var(--muted)}

/* ===== HERO ===== */
.hero{position:relative;padding:4rem 0 3rem;min-height:90vh;display:flex;align-items:center}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:2.2rem;align-items:center;max-width:1180px;margin-inline:auto}
.hero h1{font-size:clamp(3rem,7.5vw,6.6rem);font-weight:700;letter-spacing:-.045em;margin:1.4rem 0}
.hero h1 .word{display:inline-block;overflow:hidden;vertical-align:top}
.hero h1 .word span{display:inline-block;transform:translateY(110%);animation:rise .9s var(--ease) forwards}
.hero h1 .word span{display:inline-block;transform:translateY(110%);animation:rise .9s var(--ease) forwards}
@keyframes rise{to{transform:none}}
.hero h1 em{font-style:italic;font-weight:400;background:linear-gradient(100deg,var(--aqua),var(--gold));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.hero .lead{font-size:1.22rem;color:var(--muted);max-width:36ch;margin-bottom:2rem;opacity:0;animation:fadeUp .9s var(--ease) .7s forwards}
.hero-actions{display:flex;gap:.8rem;flex-wrap:wrap;opacity:0;animation:fadeUp .9s var(--ease) .85s forwards}
.hero-trust{margin-top:2.2rem;display:flex;gap:1.6rem;flex-wrap:wrap;font-size:.86rem;color:var(--muted);
  font-weight:600;opacity:0;animation:fadeUp .9s var(--ease) 1s forwards}
.hero-trust span{display:flex;align-items:center;gap:.5rem}
.tdot{width:7px;height:7px;border-radius:50%;background:var(--aqua);box-shadow:0 0 10px var(--aqua)}
.tdot.c{background:var(--coral);box-shadow:0 0 10px var(--coral)}
.tdot.g{background:var(--gold);box-shadow:0 0 10px var(--gold)}
@keyframes fadeUp{to{opacity:1;transform:none}}

/* ===== POS DEVICE ===== */
.device{position:relative;opacity:0;animation:fadeUp 1s var(--ease) .5s forwards}
.frame{background:linear-gradient(160deg,#103732,#0a2723);border-radius:28px;padding:16px;
  box-shadow:var(--shadow),inset 0 0 0 1px var(--line-2);position:relative}
.frame::before{content:"";position:absolute;inset:-1px;border-radius:28px;padding:1px;
  background:linear-gradient(160deg,rgba(47,230,198,.4),transparent 40%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.pos{background:#04211d;border-radius:18px;overflow:hidden;font-size:.84rem;box-shadow:inset 0 0 30px rgba(0,0,0,.4)}
.pos-top{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;
  background:rgba(47,230,198,.05);border-bottom:1px solid var(--line)}
.pos-top .tt{display:flex;align-items:center;gap:.55rem;font-weight:700;font-size:.82rem}
.live-dot{width:8px;height:8px;border-radius:50%;background:var(--aqua);box-shadow:0 0 0 0 rgba(47,230,198,.6);animation:pulse 2s infinite}
@keyframes pulse{70%{box-shadow:0 0 0 8px rgba(47,230,198,0)}}
.pos-top .meta{font-size:.66rem;color:var(--muted-2);font-weight:600}
.pos-body{display:grid;grid-template-columns:1.35fr 1fr;min-height:340px}
.menu{padding:.8rem;display:grid;grid-template-columns:repeat(2,1fr);gap:.55rem;align-content:start}
.cat-row{grid-column:1/-1;display:flex;gap:.4rem;margin-bottom:.2rem;flex-wrap:wrap}
.chip{font-size:.62rem;font-weight:700;padding:.34rem .62rem;border-radius:100px;
  background:rgba(233,251,244,.06);color:var(--muted);transition:.2s}
.chip.on{background:var(--gold);color:#3a2700}
.item{background:rgba(233,251,244,.04);border:1px solid var(--line);border-radius:12px;
  padding:.65rem;text-align:left;color:inherit;transition:.18s var(--ease)}
.item:hover{background:rgba(47,230,198,.1);transform:translateY(-3px);border-color:rgba(47,230,198,.3)}
.item:active{transform:scale(.96)}
.item .emo{font-size:1.2rem}
.item .nm{font-weight:700;font-size:.72rem;margin-top:.4rem}
.item .pr{font-size:.68rem;color:var(--muted);font-weight:600;margin-top:.1rem}
.cart{background:#031916;display:flex;flex-direction:column;border-left:1px solid var(--line)}
.cart-h{padding:.7rem .85rem;font-weight:700;font-size:.72rem;display:flex;justify-content:space-between;
  border-bottom:1px solid var(--line);color:var(--muted)}
.cart-items{flex:1;overflow:auto;padding:.3rem .5rem;min-height:96px}
.empty{color:var(--muted-2);font-size:.72rem;text-align:center;padding:2.4rem .5rem;font-weight:500}
.line{display:flex;align-items:center;justify-content:space-between;gap:.4rem;padding:.42rem .35rem;
  border-bottom:1px dashed var(--line);animation:lineIn .35s var(--ease)}
@keyframes lineIn{from{opacity:0;transform:translateX(10px)}to{opacity:1;transform:none}}
.line .l-nm{font-weight:600;font-size:.72rem}
.line .l-q{font-size:.62rem;color:var(--muted-2)}
.line .l-pr{font-weight:700;font-size:.72rem}
.qbtn{background:rgba(233,251,244,.1);border:0;color:var(--ink);width:19px;height:19px;border-radius:6px;font-weight:700;line-height:1;transition:.15s}
.qbtn:hover{background:var(--aqua);color:var(--bg)}
.cart-foot{padding:.75rem .85rem;background:rgba(0,0,0,.25);font-size:.72rem}
.srow{display:flex;justify-content:space-between;padding:.13rem 0;color:var(--muted)}
.srow.tot{font-weight:800;font-size:.96rem;color:var(--ink);padding-top:.5rem;margin-top:.35rem;border-top:1px solid var(--line-2)}
.charge{width:100%;margin-top:.65rem;background:var(--coral);color:#fff;border:0;padding:.72rem;border-radius:11px;
  font-weight:800;font-size:.84rem;transition:.2s;display:flex;align-items:center;justify-content:center;gap:.4rem}
.charge:hover{filter:brightness(1.08);transform:translateY(-1px)}
.fbadge{position:absolute;z-index:10;background:rgba(8,33,31,.96);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--line-2);
  border-radius:14px;padding:.6rem .8rem;font-size:.74rem;font-weight:700;display:flex;align-items:center;gap:.5rem;box-shadow:0 18px 42px rgba(0,0,0,.55),0 0 0 1px rgba(47,230,198,.15)}
.fb1{top:-14px;left:28px;color:var(--aqua);animation:float1 5s ease-in-out infinite}
.fb2{bottom:-14px;right:32px;color:var(--gold);animation:float1 5s ease-in-out infinite .8s}
@keyframes float1{50%{transform:translateY(-9px)}}
.fb-ico{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;font-size:.9rem}
.fb1 .fb-ico{background:rgba(47,230,198,.15)}.fb2 .fb-ico{background:rgba(255,182,39,.15)}

/* ===== STATS ===== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);padding:3rem 0;margin-top:1rem}
.stat{text-align:center}
.stat .big{font-family:var(--display);font-size:clamp(2.4rem,4.5vw,3.6rem);font-weight:700;
  background:linear-gradient(120deg,var(--aqua),var(--gold));-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:-.04em}
.stat .lbl{color:var(--muted);font-size:.92rem;font-weight:500;margin-top:.3rem}

/* ===== MARQUEE ===== */
.marquee{padding:1.4rem 0;overflow:hidden;position:relative;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.marquee::before,.marquee::after{content:"";position:absolute;top:0;bottom:0;width:120px;z-index:2}
.marquee::before{left:0;background:linear-gradient(90deg,var(--bg),transparent)}
.marquee::after{right:0;background:linear-gradient(-90deg,var(--bg),transparent)}
.track{display:flex;gap:2.6rem;white-space:nowrap;width:max-content;animation:scroll 30s linear infinite}
.track span{font-family:var(--display);font-weight:500;font-size:1.6rem;color:var(--muted-2);display:flex;align-items:center;gap:1.6rem;letter-spacing:-.02em}
.track span::after{content:"›";color:var(--aqua);font-size:1rem}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ===== generic cards / grids reused across pages ===== */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.card{background:linear-gradient(160deg,var(--surface),var(--bg-2));border:1px solid var(--line);
  border-radius:22px;padding:2rem 1.8rem;transition:.4s var(--ease);position:relative;overflow:hidden}
.card:hover{transform:translateY(-7px);border-color:var(--line-2);box-shadow:var(--shadow)}
.card::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;
  background:var(--accent,var(--aqua));transform:scaleX(0);transform-origin:left;transition:.45s var(--ease)}
.card:hover::before{transform:scaleX(1)}
.card .ico{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;font-size:1.4rem;margin-bottom:1.1rem;
  background:rgba(47,230,198,.1);border:1px solid var(--line)}
.card .num{font-family:var(--display);font-style:italic;font-size:.92rem;color:var(--accent,var(--aqua));font-weight:600}
.card h3{font-size:1.4rem;margin:.55rem 0 .6rem}
.card p{color:var(--muted);font-size:.96rem}
.card .tag{margin-top:1.1rem;display:inline-block;font-size:.68rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.1em;color:var(--aqua);background:rgba(47,230,198,.08);padding:.32rem .7rem;border-radius:100px}

/* showpiece */
.show{background:linear-gradient(150deg,var(--surface-2),#04201c);border:1px solid var(--line);
  border-radius:30px;padding:3.6rem;display:grid;grid-template-columns:1fr 1fr;gap:3.2rem;align-items:center;position:relative;overflow:hidden}
.show::after{content:"";position:absolute;width:380px;height:380px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,182,39,.18),transparent 70%);top:-110px;right:-70px}
.show h2{font-size:clamp(1.9rem,3.6vw,2.9rem);margin:1.1rem 0 1.2rem}
.show p{color:var(--muted);font-size:1.06rem;margin-bottom:1.7rem}
.checklist{list-style:none;display:grid;gap:.9rem}
.checklist li{display:flex;gap:.75rem;align-items:flex-start;font-size:1rem;color:var(--ink)}
.ck{flex:none;width:24px;height:24px;border-radius:8px;background:rgba(47,230,198,.16);
  display:grid;place-items:center;color:var(--aqua);font-weight:800;font-size:.82rem;margin-top:1px}
/* receipt */
.receipt{background:#f6efe1;color:#14201d;border-radius:14px;padding:1.7rem 1.6rem;position:relative;box-shadow:var(--shadow);font-family:var(--sans)}
.receipt::before,.receipt::after{content:"";position:absolute;left:0;right:0;height:14px;
  background-image:radial-gradient(circle at 7px -3px,transparent 7px,#f6efe1 7px);background-size:14px 14px}
.receipt::before{top:-7px;transform:rotate(180deg)}.receipt::after{bottom:-7px}
.r-head{text-align:center;border-bottom:2px dashed rgba(0,0,0,.25);padding-bottom:.9rem;margin-bottom:.9rem}
.r-head .rb{font-family:var(--display);font-weight:700;font-size:1.25rem}
.r-head .rs{font-size:.72rem;color:#5c6b66;font-weight:600}
.r-line{display:flex;justify-content:space-between;font-size:.84rem;padding:.2rem 0}
.r-line.muted{color:#5c6b66}
.r-tot{display:flex;justify-content:space-between;font-weight:800;font-size:1.05rem;
  border-top:2px dashed rgba(0,0,0,.25);margin-top:.7rem;padding-top:.7rem}
.r-foot{text-align:center;font-size:.7rem;color:#5c6b66;margin-top:1.1rem;font-weight:700;letter-spacing:.06em}

/* industries */
.ind{position:relative;border-radius:22px;padding:5.2rem 2rem 2rem 2rem;min-height:300px;display:flex;flex-direction:column;
  justify-content:flex-end;overflow:hidden;color:#fff;transition:.4s var(--ease);border:1px solid var(--line)}
.ind:hover{transform:translateY(-8px)}
.ind .emo{font-size:2.4rem;position:absolute;top:1.6rem;left:1.8rem;transition:.4s var(--ease)}
.ind:hover .emo{transform:scale(1.15) rotate(-6deg)}
.ind h3{font-size:1.6rem;position:relative;z-index:2}
.ind p{font-size:.92rem;opacity:.9;position:relative;z-index:2;margin-top:.4rem}
.ind .glow{position:absolute;inset:0;opacity:.85}
.ind.a .glow{background:linear-gradient(160deg,#0d7d6f,#042a26)}
.ind.b .glow{background:linear-gradient(160deg,#d9551f,#5e2009)}
.ind.c .glow{background:linear-gradient(160deg,#1390a8,#063a4a)}
.ind.d .glow{background:linear-gradient(160deg,#c98a0f,#5c3c06)}
.ind ul{list-style:none;display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1rem;position:relative;z-index:2}
.ind li{font-size:.7rem;font-weight:700;background:rgba(255,255,255,.16);padding:.28rem .6rem;border-radius:100px}

/* ecosystem */
.eco-modules{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:1rem}
.mod{background:linear-gradient(160deg,var(--surface),var(--bg-2));border:1px solid var(--line);
  border-radius:22px;padding:2rem;position:relative;transition:.4s var(--ease)}
.mod:hover{transform:translateY(-7px);box-shadow:var(--shadow)}
.mod.active{border-color:var(--aqua);box-shadow:var(--glow)}
.mhead{display:flex;align-items:center;gap:.8rem;margin-bottom:.9rem}
.mmark{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;
  font-family:var(--display);font-weight:800;font-size:1.2rem;color:#04201c}
.mod h3{font-size:1.35rem}.mod p{color:var(--muted);font-size:.94rem}
.pill{position:absolute;top:1.2rem;right:1.2rem;font-size:.6rem;font-weight:800;letter-spacing:.1em;
  text-transform:uppercase;padding:.28rem .6rem;border-radius:100px}
.pill.live{background:rgba(47,230,198,.16);color:var(--aqua)}
.pill.soon{background:rgba(233,251,244,.08);color:var(--muted)}
.flow{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap;margin-top:3rem;
  padding:2rem;background:rgba(233,251,244,.03);border:1px solid var(--line);border-radius:22px}
.flow .node{padding:.8rem 1.3rem;border-radius:14px;font-weight:700;font-size:.92rem;border:1px solid var(--line-2)}
.flow .arrow{color:var(--aqua);font-size:1.4rem;animation:nudge 1.6s ease-in-out infinite}
@keyframes nudge{50%{transform:translateX(6px)}}

/* "Most popular" / "Founders 50" pill — sits at the top edge of the highlighted card */
.ptop{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--aqua);color:#04201c;
  font-size:.66rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:.32rem 1rem;border-radius:100px}
/* faq */
.faq{max-width:48rem;margin:0 auto}
.q{border-bottom:1px solid var(--line);padding:1.3rem 0;cursor:none}
.q .qh{display:flex;justify-content:space-between;align-items:center;gap:1rem;font-family:var(--display);font-size:1.2rem;font-weight:500}
.q .qh .pm{font-size:1.6rem;color:var(--aqua);transition:.3s;line-height:1}
.q.open .qh .pm{transform:rotate(45deg)}
.q .qa{max-height:0;overflow:hidden;transition:max-height .4s var(--ease),margin .4s,opacity .4s;color:var(--muted);opacity:0}
.q.open .qa{max-height:200px;margin-top:.8rem;opacity:1}

/* CTA — clear panel with soft depth: faint dual-glow corners + a subtle
   tinted gradient so it reads as a contained block, not empty space. */
.cta{background:linear-gradient(150deg,rgba(0,181,168,.05),transparent 55%,rgba(255,107,91,.04));
  border:1px solid var(--line-2);border-radius:30px;padding:4.5rem;text-align:center;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;width:280px;height:280px;border-radius:50%;
  background:radial-gradient(circle,rgba(0,181,168,.16),transparent 70%);top:-100px;left:-80px;pointer-events:none}
.cta::after{content:"";position:absolute;width:240px;height:240px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,107,91,.12),transparent 70%);bottom:-90px;right:-70px;pointer-events:none}
.cta h2{font-size:clamp(2.1rem,4.4vw,3.3rem);color:var(--ink);margin-bottom:1rem;position:relative}
.cta p{font-size:1.2rem;color:var(--muted);max-width:42ch;margin:0 auto 2.2rem;position:relative}
.btn-light{background:#fff;color:#04201c;position:relative;font-weight:800}
.btn-light:hover{transform:translateY(-3px);box-shadow:0 14px 34px rgba(0,0,0,.45)}

/* footer — clean 4-col layout (brand + 3 link columns), full width */
footer{border-top:1px solid var(--line);padding:4.5rem 0 2rem;margin-top:5rem}
.foot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid var(--line)}
.foot-grid .brand{margin-bottom:1.1rem}
.foot-desc{color:var(--muted);font-size:.94rem;max-width:30ch;margin-bottom:1.4rem;line-height:1.5}
.foot-col h4{font-family:var(--sans);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);margin-bottom:1rem;font-weight:700}
.foot-col a{display:block;padding:.35rem 0;font-size:.93rem;color:var(--muted);transition:.2s}
.foot-col a:hover{color:var(--ink);transform:translateX(4px)}
.foot-bot{display:flex;justify-content:space-between;align-items:center;padding-top:1.6rem;font-size:.84rem;color:var(--muted-2);flex-wrap:wrap;gap:1rem}

.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(140px);background:var(--ink);color:var(--bg);
  padding:.95rem 1.5rem;border-radius:100px;font-weight:800;font-size:.92rem;box-shadow:var(--shadow);z-index:400;
  transition:transform .5s var(--ease);display:flex;align-items:center;gap:.5rem}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ===== WAITLIST MODAL ===== */
.wl-overlay{position:fixed;inset:0;z-index:500;background:rgba(2,12,14,.78);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);display:none;align-items:center;justify-content:center;padding:1.5rem;opacity:0;transition:opacity .35s var(--ease)}
.wl-overlay.open{display:flex;opacity:1}
.wl-modal{background:linear-gradient(160deg,var(--surface),var(--bg-2));border:1px solid var(--line-2);border-radius:24px;padding:2.4rem;max-width:480px;width:100%;position:relative;max-height:92vh;overflow-y:auto;transform:translateY(24px) scale(.98);transition:transform .45s var(--ease);box-shadow:0 30px 80px rgba(0,0,0,.6),0 0 0 1px rgba(47,230,198,.12)}
.wl-overlay.open .wl-modal{transform:translateY(0) scale(1)}
.wl-close{position:absolute;top:1rem;right:1rem;background:rgba(233,251,244,.06);border:1px solid var(--line);color:var(--muted);font-size:1.15rem;width:32px;height:32px;border-radius:50%;display:grid;place-items:center;line-height:1;transition:.2s;cursor:none}
.wl-close:hover{background:var(--aqua);color:var(--bg);border-color:var(--aqua)}
.wl-field{margin-bottom:1.05rem}
.wl-field label{display:block;font-size:.74rem;font-weight:700;color:var(--muted);margin-bottom:.4rem;letter-spacing:.04em;text-transform:uppercase}
.wl-field label .req{color:var(--coral);margin-left:.2rem}
.wl-field input,.wl-field select,.wl-field textarea{width:100%;background:rgba(0,0,0,.32);border:1px solid var(--line);border-radius:11px;padding:.78rem 1rem;color:var(--ink);font-family:inherit;font-size:.96rem;transition:border .2s,background .2s;cursor:auto}
.wl-field input:focus,.wl-field select:focus,.wl-field textarea:focus{outline:none;border-color:var(--aqua);background:rgba(0,0,0,.46);box-shadow:0 0 0 3px rgba(47,230,198,.12)}
.wl-field select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238eb0a8' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;background-size:12px 8px;padding-right:2.6rem}
.wl-modal .btn{width:100%;justify-content:center}
.wl-modal .btn:disabled{opacity:.55;cursor:not-allowed}
.wl-row{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.wl-success{text-align:center;padding:1rem 0}
.wl-success .check{width:64px;height:64px;border-radius:50%;background:rgba(47,230,198,.16);color:var(--aqua);font-size:2rem;font-weight:800;display:grid;place-items:center;margin:0 auto 1.2rem;animation:lineIn .5s var(--ease)}
@media(max-width:560px){.wl-row{grid-template-columns:1fr}.wl-modal{padding:1.8rem 1.4rem}}

@media(max-width:920px){
  .hero-grid,.show,.grid-2,.foot-grid{grid-template-columns:1fr}
  .hero-visual{order:-1;max-width:460px;margin-inline:auto;width:100%}
  .grid-3,.grid-4,.eco-modules,.stats{grid-template-columns:1fr 1fr}
  .nav-links{display:none}.burger{display:flex}
  body{cursor:auto}.cursor,.cursor-dot{display:none}
  .show,.cta,.eco{padding:2.4rem}.fbadge{display:none}
}
@media(max-width:560px){
  .grid-3,.grid-4,.eco-modules,.stats,.foot-grid{grid-template-columns:1fr}
  .sec{padding:4rem 0}.flow{flex-direction:column}.flow .arrow{transform:rotate(90deg)}
}

/* ===== Mobile responsive sweep v2 (2026-06-04) — aggressive ===== */
html,body{overflow-x:hidden;max-width:100vw}
*{min-width:0}
img,svg,video,canvas{max-width:100%;height:auto}


@media(max-width:920px){
  .wrap{padding:0 1.2rem}
  nav{padding:.9rem 0}
  .brand small{display:none}
  .nav-cta{gap:.4rem}
  .nav-signin{padding:.45rem .6rem;font-size:.85rem}
  .nav-cta .btn{padding:.55rem 1rem !important;font-size:.85rem}
  main{padding-top:72px}
  .hero,.hero-platform{padding:5rem 0 3rem !important}
  .sec{padding:3rem 0}
  h1{font-size:clamp(2rem,8vw,3rem) !important;line-height:1.1}
  h2{font-size:clamp(1.6rem,6vw,2.2rem) !important;line-height:1.15}
  .lead{font-size:1.05rem !important;line-height:1.55}
}
@media(max-width:560px){
  .wrap{padding:0 1rem;max-width:100%}
  .nav-cta{flex-wrap:wrap;justify-content:flex-end;max-width:55%}
  main{padding-top:64px}
  .hero,.hero-platform{padding:4rem 0 2.5rem !important}
  .hero-trust,.stats{display:none}
  .modules-grid,.tiers,.callouts{gap:1rem}
  .mod,.tier{padding:1.5rem 1.2rem}
  table{font-size:.85rem}
  /* Catch every inline-styled padding-heavy section */
  main[style],section[style*="padding"]{padding:3rem 1rem !important}
  /* Any inline grid → single col */
  div[style*="grid-template-columns"]{grid-template-columns:1fr !important}
  /* Stop inline max-widths from overflowing the viewport */
  [style*="max-width:1180px"],[style*="max-width:1280px"],[style*="max-width:1440px"]{max-width:100% !important}
  /* The hero <br> forces an awkward narrow break */
  .hero h1 br,.hero-platform h1 br,h1 br{display:none}
  /* Tighten any inline-styled large clamp fonts */
  [style*="font-size:clamp(2"],[style*="font-size:clamp(3"],[style*="font-size:clamp(4"]{font-size:1.8rem !important;line-height:1.2 !important}
  /* Long words shouldn't push the viewport */
  h1,h2,h3,p,a,li{overflow-wrap:break-word;word-break:break-word}
}

/* ========================================
   BulaCore — umbrella additions
   Inherits the BulaPOS / BulaBooks design system, adds a
   "platform" treatment: dual-color "Bula" + "Core" wordmark
   blending aqua (POS) with coral (Books), and a 3-module
   showcase grid distinct from the per-product layouts.
   ======================================== */

.brand-core{
  background:linear-gradient(95deg,var(--aqua) 0%,var(--coral) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* Hero — wider, gives the umbrella story room */
.hero-platform{padding:9rem 0 5rem;position:relative}
.hero-platform .wrap{position:relative;z-index:2}
.hero-platform h1{font-size:clamp(2.6rem,6vw,5.4rem);line-height:1;margin:1.2rem 0 1.6rem}
.hero-platform .lead{font-size:clamp(1.1rem,1.5vw,1.35rem);color:var(--muted);max-width:60ch;margin-bottom:2rem;line-height:1.55}
.hero-platform h1 em{
  font-style:italic;font-family:"Bricolage Grotesque",serif;
  background:linear-gradient(105deg,var(--aqua) 0%,var(--gold) 50%,var(--coral) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* Stats row */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1px;background:var(--line);border-radius:18px;overflow:hidden;margin-top:3.5rem}
.stat{background:var(--surface);padding:1.6rem 1.8rem;display:flex;flex-direction:column;gap:.35rem}
.stat .big{font-family:var(--display);font-weight:700;font-size:2.4rem;line-height:1;color:var(--ink)}
.stat .big small{font-family:var(--sans);font-weight:600;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-left:.4rem;vertical-align:top}
.stat .lbl{font-size:.78rem;color:var(--muted);letter-spacing:.04em}

/* Three-module showcase */
.modules-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin:3rem 0}
@media(max-width:880px){.modules-grid{grid-template-columns:1fr}}
.mod{background:var(--surface);border:1px solid var(--line);border-radius:24px;padding:2rem 1.8rem;position:relative;overflow:hidden;transition:transform .3s var(--ease),border-color .3s,box-shadow .3s}
.mod::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent,var(--aqua));opacity:.85}
.mod:hover{transform:translateY(-4px);border-color:var(--line-2);box-shadow:0 24px 60px rgba(0,0,0,.4)}
.mod-icon{width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;border-radius:12px;background:color-mix(in oklab,var(--accent,var(--aqua)) 16%,transparent);color:var(--accent,var(--aqua));margin-bottom:1.2rem;font-size:1.4rem}
.mod h3{font-size:1.55rem;margin-bottom:.5rem;color:var(--ink)}
.mod .tagline{font-size:.85rem;font-weight:600;color:var(--accent,var(--aqua));letter-spacing:.02em;margin-bottom:1rem}
.mod p{font-size:.95rem;color:var(--muted);line-height:1.6;margin-bottom:1.4rem}
.mod ul{list-style:none;padding:0;margin:0 0 1.6rem}
.mod ul li{display:flex;align-items:flex-start;gap:.6rem;font-size:.88rem;color:var(--ink);padding:.35rem 0;line-height:1.45}
.mod ul li::before{content:"";flex-shrink:0;width:6px;height:6px;border-radius:50%;background:var(--accent,var(--aqua));margin-top:.55rem}
.mod-cta{display:inline-flex;align-items:center;gap:.4rem;font-size:.88rem;font-weight:700;color:var(--accent,var(--aqua));text-decoration:none;border-bottom:1px solid color-mix(in oklab,var(--accent,var(--aqua)) 32%,transparent);padding-bottom:2px;transition:gap .25s}
.mod-cta:hover{gap:.7rem}

/* "Why bundle" callouts */
.callouts{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.2rem;margin-top:2.5rem}
.callout{background:var(--surface-2);border:1px solid var(--line);border-radius:18px;padding:1.6rem;display:flex;flex-direction:column;gap:.4rem}
.callout .num{font-family:var(--display);font-weight:700;font-size:.9rem;color:var(--aqua);letter-spacing:.18em}
.callout h4{font-size:1.15rem;color:var(--ink);margin:.2rem 0 .4rem;line-height:1.25}
.callout p{font-size:.9rem;color:var(--muted);line-height:1.6}

/* Pricing cards */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin:2.5rem 0 1rem}
@media(max-width:880px){.tiers{grid-template-columns:1fr}}
.tier{background:var(--surface);border:1px solid var(--line);border-radius:22px;padding:2rem 1.8rem;display:flex;flex-direction:column;gap:1rem;position:relative}
.tier.popular{border-color:var(--aqua);box-shadow:0 0 0 1px var(--aqua),0 24px 60px rgba(47,230,198,.2)}
.tier .pop{position:absolute;top:-12px;right:1.4rem;background:var(--aqua);color:var(--bg);padding:.3rem .8rem;border-radius:100px;font-size:.65rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase}
.tier .name{font-family:var(--display);font-weight:600;font-size:1.4rem;color:var(--ink)}
.tier .price{display:flex;align-items:baseline;gap:.4rem;margin:.3rem 0 1rem}
.tier .price .amt{font-family:var(--display);font-weight:700;font-size:2.6rem;color:var(--ink);line-height:1}
.tier .price .per{font-size:.85rem;color:var(--muted)}
.tier .blurb{font-size:.9rem;color:var(--muted);line-height:1.55;margin-bottom:.2rem}
.tier ul{list-style:none;padding:0;margin:.5rem 0 1.4rem;flex:1}
.tier ul li{display:flex;align-items:flex-start;gap:.55rem;font-size:.88rem;color:var(--ink);padding:.3rem 0;line-height:1.45}
.tier ul li::before{content:"✓";color:var(--aqua);font-weight:800;flex-shrink:0}

/* Compliance / integrations strip */
.compliance{margin-top:4rem;padding:3rem 0;background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.compliance .wrap{display:grid;grid-template-columns:1.2fr 1fr;gap:3rem;align-items:center}
@media(max-width:880px){.compliance .wrap{grid-template-columns:1fr}}
.compliance h2{font-size:2rem;margin-bottom:.8rem}
.compliance p{color:var(--muted);font-size:1rem;line-height:1.6;margin-bottom:1.4rem}
.chips{display:flex;flex-wrap:wrap;gap:.5rem}
.chip{background:var(--surface-2);border:1px solid var(--line);padding:.55rem 1rem;border-radius:100px;font-size:.8rem;color:var(--ink);display:inline-flex;align-items:center;gap:.4rem}
.chip strong{color:var(--aqua);font-weight:700}

/* Footer styling extensions */
.footnote{font-size:.75rem;color:var(--muted-2);max-width:54ch;line-height:1.6}
