:root {
  --ink:    #f0f7ff;
  --deep:   #e8f2ff;
  --panel:  #ffffff;
  --card:   #ffffff;
  --cyan:   #00b4f0;
  --cyan2:  #0090c8;
  --violet: #6d28d9;
  --violet2:#7c3aed;
  --lime:   #16a34a;
  --white:  #0f172a;
  --muted:  #64748b;
  --border: rgba(0,180,240,.15);
  --bordv:  rgba(109,40,217,.15);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;overflow-x:hidden;}
body{background:var(--ink);color:var(--white);font-family:"Plus Jakarta Sans",sans-serif;overflow-x:hidden;cursor:none;-webkit-text-size-adjust:100%;}

/* CURSOR */
.cur{width:8px;height:8px;background:var(--cyan);border-radius:50%;position:fixed;pointer-events:none;z-index:9999;transition:transform .12s;mix-blend-mode:multiply;}
@media(max-width:960px){.cur,.cur-ring{display:none;}body{cursor:auto;}}
.cur-ring{width:32px;height:32px;border:1px solid var(--cyan);border-radius:50%;position:fixed;pointer-events:none;z-index:9998;opacity:.4;transition:all .28s cubic-bezier(.23,1,.32,1);}

/* GRAIN */
/* grain removed for light mode */

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:500;padding:14px 52px;display:flex;justify-content:space-between;align-items:center;background:rgba(255,255,255,.95);backdrop-filter:blur(24px);border-bottom:1px solid rgba(0,180,240,.1);box-shadow:0 2px 24px rgba(0,180,240,.07);}
.nav-brand{display:flex;align-items:center;}
.nav-lockup{display:flex;align-items:center;gap:0;height:52px;background:white;border-radius:10px;padding:6px 14px;}
.nav-lockup-logo{display:flex;align-items:center;padding-right:14px;}
.nav-beeps-logo{height:40px;width:auto;object-fit:contain;}
.nav-lockup-divider{width:2px;height:32px;background:#e0e0e0;flex-shrink:0;}.nav-lockup-text{padding-left:14px;display:flex;flex-direction:column;justify-content:center;}
.nav-school-name{font-size:13px;font-weight:700;color:#1a1a2e;line-height:1.2;white-space:nowrap;}
.nav-school-sub{font-size:10px;color:var(--cyan);font-weight:700;letter-spacing:.08em;line-height:1.2;}
.nav-links{display:flex;gap:30px;list-style:none;}
.nav-links a{color:#475569;text-decoration:none;font-size:.78rem;font-weight:700;letter-spacing:.04em;transition:color .2s;}
.nav-links a:hover{color:var(--cyan);}
.nav-cta{background:linear-gradient(135deg,var(--cyan),var(--violet));color:#fff;padding:9px 22px;font-weight:800;font-size:.76rem;letter-spacing:.06em;border:none;cursor:pointer;text-decoration:none;border-radius:100px;transition:all .2s;text-transform:uppercase;box-shadow:0 4px 16px rgba(0,180,240,.25);}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 6px 24px rgba(0,180,240,.35);}

/* HERO */
.hero{min-height:100vh;position:relative;overflow:hidden;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:40px;padding:120px 52px 80px;}
.hero-bg{position:absolute;inset:0;}
/* animated grid */
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(0,180,240,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(0,180,240,.06) 1px,transparent 1px);background-size:60px 60px;animation:gridScroll 20s linear infinite;}
@keyframes gridScroll{0%{transform:translateY(0)}100%{transform:translateY(60px)}}
/* glow blobs */
.hero-blob1{position:absolute;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(0,180,240,.1) 0%,transparent 65%);top:-200px;right:-100px;animation:blobPulse 8s ease-in-out infinite alternate;}
.hero-blob2{position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(109,40,217,.1) 0%,transparent 65%);bottom:-100px;left:20%;animation:blobPulse 11s 3s ease-in-out infinite alternate;}
@keyframes blobPulse{from{transform:scale(1);opacity:.7}to{transform:scale(1.15);opacity:1}}

.hero-content{position:relative;z-index:2;}
.hero-badge{display:inline-flex;align-items:center;gap:10px;padding:7px 16px 7px 12px;border:1px solid rgba(0,229,255,.25);border-radius:6px;background:rgba(0,180,240,.06);font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--cyan);margin-bottom:40px;opacity:0;animation:slideIn .7s .15s forwards;}
.badge-pulse{width:6px;height:6px;border-radius:50%;background:var(--cyan);animation:pulse 1.4s infinite;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}

.hero-headline{font-size:clamp(3rem,6.5vw,7rem);font-weight:800;line-height:.97;letter-spacing:-.04em;margin-bottom:28px;opacity:0;animation:slideIn .8s .3s forwards;}
.hero-headline .h-white{color:var(--white);}
.hero-headline .h-cyan{color:var(--cyan);}
.hero-headline .h-italic{font-family:Fraunces,serif;font-style:italic;font-weight:200;color:rgba(168,85,247,.9);}

.hero-sub{font-size:1.1rem;color:var(--muted);line-height:1.7;max-width:520px;margin-bottom:48px;font-weight:400;opacity:0;animation:slideIn .8s .45s forwards;}
.hero-sub strong{color:var(--white);font-weight:700;}

.hero-actions{display:flex;gap:16px;align-items:center;opacity:0;animation:slideIn .8s .58s forwards;}
.btn-primary{background:var(--cyan);color:#fff;padding:16px 36px;font-weight:800;font-size:.92rem;border-radius:6px;border:none;cursor:pointer;text-decoration:none;display:inline-block;letter-spacing:.04em;transition:all .2s;box-shadow:0 4px 20px rgba(0,180,240,.3);}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,180,240,.35);}
.btn-outline{color:#0f172a;font-weight:700;font-size:.92rem;text-decoration:none;border:1px solid rgba(15,23,42,.2);padding:15px 30px;border-radius:6px;transition:all .2s;display:inline-block;}
.btn-outline:hover{border-color:var(--cyan);color:var(--cyan);}

.hero-proof{display:flex;flex-wrap:wrap;gap:32px 48px;margin-top:72px;padding-top:36px;border-top:1px solid var(--border);opacity:0;animation:slideIn .8s .72s forwards;}
.proof-num{font-size:2.4rem;font-weight:800;letter-spacing:-.04em;line-height:1;color:var(--white);}
.proof-num span{color:var(--cyan);}
.proof-label{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:5px;}

/* floating right panel — stacked workflow + terminal */
.hero-right-panel{position:relative;width:100%;display:flex;flex-direction:column;gap:14px;opacity:0;animation:slideIn .9s .6s forwards;z-index:2;}

/* n8n workflow canvas */
.workflow-canvas{background:var(--panel);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:0 8px 40px rgba(0,180,240,.12),0 1px 0 rgba(0,180,240,.1);}
.wf-bar{background:#f8fafc;padding:10px 14px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border);}
.wf-dot{width:9px;height:9px;border-radius:50%;}
.wf-title{font-family:"DM Mono",monospace;font-size:.6rem;color:#475569;margin-left:6px;letter-spacing:.06em;flex:1;}
.wf-status{font-family:"DM Mono",monospace;font-size:.58rem;color:var(--lime);letter-spacing:.08em;display:flex;align-items:center;gap:5px;}
.wf-status-dot{width:5px;height:5px;border-radius:50%;background:var(--lime);animation:pulse 1.4s infinite;}
.wf-body{padding:20px;position:relative;height:280px;}

/* SVG workflow styles */
.wf-svg{width:100%;height:100%;overflow:visible;touch-action:none;}
/* node base */
.wf-node{cursor:none;}
.wf-node rect{rx:8;ry:8;filter:drop-shadow(0 4px 12px rgba(0,0,0,.4));}
.wf-node text{font-family:"DM Mono",monospace;font-size:8px;font-weight:500;fill:var(--white);}
.wf-node .sub{font-size:6.5px;fill:var(--muted);}
/* node icon circle */
.node-icon{font-size:11px;}
/* connection paths */
.wf-edge{fill:none;stroke-width:1.5;stroke-linecap:round;}
/* data packet dot travelling along path */
.packet{r:4;opacity:0;}

/* terminal */
.hero-terminal{background:#0f172a;border:1px solid rgba(0,180,240,.2);border-radius:12px;overflow:hidden;box-shadow:0 8px 40px rgba(15,23,42,.15);}
.term-bar{background:#1e293b;padding:10px 14px;display:flex;align-items:center;gap:8px;border-bottom:1px solid rgba(255,255,255,.08);}
.term-dot{width:9px;height:9px;border-radius:50%;}
.term-dot.r{background:#ff5f57;} .term-dot.y{background:#febc2e;} .term-dot.g{background:#28c840;}
.term-title{font-family:"DM Mono",monospace;font-size:.6rem;color:var(--muted);margin-left:6px;letter-spacing:.06em;}
.term-body{padding:16px 18px 20px;font-family:"DM Mono",monospace;font-size:.68rem;line-height:1.75;color:#64b5f6;}
.term-line .prompt{color:var(--cyan);}
.term-line .cmd{color:var(--white);}
.term-line .out{color:#4db6ac;}
.term-line .comment{color:#546e7a;}
.term-line .highlight{color:var(--lime);}
.term-cursor{display:inline-block;width:7px;height:13px;background:var(--cyan);animation:blink2 1s infinite;vertical-align:middle;margin-left:2px;}
@keyframes blink2{0%,100%{opacity:1}50%{opacity:0}}

@keyframes slideIn{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

/* STATS BAR */
.stats-bar{background:#ffffff;border-top:1px solid rgba(0,180,240,.12);border-bottom:1px solid rgba(0,180,240,.12);padding:24px 52px;display:flex;justify-content:space-around;align-items:center;gap:24px;box-shadow:0 2px 16px rgba(0,180,240,.06);}
.stat-item{text-align:center;}
.stat-val{font-size:1.6rem;font-weight:800;letter-spacing:-.03em;color:var(--white);}
.stat-val span{color:var(--cyan);}
.stat-key{font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:4px;}
.stat-divider{width:1px;height:40px;background:var(--border);}

/* SECTION COMMON */
section{padding:110px 52px;}
.sec-eyebrow{font-size:.62rem;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:var(--cyan);margin-bottom:20px;display:flex;align-items:center;gap:10px;}
.sec-eyebrow::before{content:"";display:inline-block;width:24px;height:1.5px;background:var(--cyan);border-radius:2px;}
.sec-eyebrow.violet-ey{color:var(--violet2);}
.sec-eyebrow.violet-ey::before{background:var(--violet2);}
.sec-headline{font-size:clamp(2.2rem,4vw,3.8rem);font-weight:800;letter-spacing:-.04em;line-height:1.05;color:var(--white);}
.sec-headline em{font-family:Fraunces,serif;font-style:italic;font-weight:200;color:var(--cyan);}
.sec-headline .vi{color:var(--violet2);}

/* WHAT YOU'LL BUILD */
.builds{background:#f8fafc;}
.builds-header{display:grid;grid-template-columns:1fr 1fr;gap:80px;margin-bottom:72px;align-items:end;}
.builds-sub{font-size:.9rem;color:var(--muted);line-height:1.75;font-weight:400;}
.builds-sub strong{color:var(--white);font-weight:700;}

.builds-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:rgba(0,180,240,.06);}
.build-card{background:#f4f8ff;padding:36px 32px;position:relative;overflow:hidden;cursor:default;transition:background .3s;}
.build-card:hover{background:#fff;}
.build-card::before{content:"";position:absolute;top:0;left:0;width:3px;height:0;background:linear-gradient(180deg,#0284c7,#6d28d9);transition:height .4s cubic-bezier(.23,1,.32,1);}
.build-card:hover::before{height:100%;}
.build-num{font-family:"DM Mono",monospace;font-size:.6rem;color:rgba(0,180,240,.5);letter-spacing:.15em;margin-bottom:24px;}
.build-icon-wrap{width:48px;height:48px;border:1px solid var(--border);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:20px;background:rgba(0,229,255,.04);transition:border-color .3s,background .3s;}
.build-card:hover .build-icon-wrap{border-color:rgba(0,229,255,.3);background:rgba(0,180,240,.08);}
.build-title{font-size:1.1rem;font-weight:800;letter-spacing:-.02em;color:var(--white);margin-bottom:12px;line-height:1.2;}
.build-desc{font-size:.8rem;color:var(--muted);line-height:1.75;font-weight:400;}
.build-stack{display:flex;flex-wrap:wrap;gap:6px;margin-top:20px;}
.stk{font-family:"DM Mono",monospace;font-size:.6rem;color:var(--cyan);border:1px solid rgba(0,180,240,.18);padding:3px 10px;border-radius:4px;background:rgba(0,180,240,.05);}

/* CURRICULUM */
.curriculum{background:#ffffff;}
.curriculum-layout{display:grid;grid-template-columns:1fr 2fr;gap:80px;align-items:start;}
.curr-sticky{position:sticky;top:120px;}
.curr-intro{font-size:.9rem;color:var(--muted);line-height:1.75;margin-top:20px;margin-bottom:32px;}
.curr-cta-note{font-size:.7rem;color:var(--muted);font-family:"DM Mono",monospace;margin-top:12px;opacity:.7;}

.modules{display:flex;flex-direction:column;gap:0;}
.module{border:1px solid rgba(0,180,240,.15);margin-bottom:12px;border-radius:10px;overflow:hidden;cursor:pointer;transition:border-color .3s;background:#fff;box-shadow:0 1px 6px rgba(0,180,240,.05);}
.module:hover,.module.open{border-color:rgba(0,180,240,.4);box-shadow:0 4px 16px rgba(0,180,240,.1);}
.module-header{padding:22px 28px;display:flex;justify-content:space-between;align-items:center;gap:16px;}
.module-meta{display:flex;align-items:center;gap:14px;}
.module-num{font-family:"DM Mono",monospace;font-size:.62rem;color:rgba(0,180,240,.6);letter-spacing:.12em;min-width:32px;}
.module-title{font-size:.95rem;font-weight:800;color:var(--white);letter-spacing:-.01em;}
.module-weeks{font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);background:rgba(255,255,255,.05);padding:4px 10px;border-radius:100px;}
.module-toggle{width:24px;height:24px;border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;color:var(--muted);flex-shrink:0;transition:all .2s;}
.module.open .module-toggle{border-color:var(--cyan);color:var(--cyan);background:rgba(0,180,240,.08);}
.module-body{display:none;padding:0 28px 24px;animation:fadeIn .25s ease;}
.module.open .module-body{display:block;}
@keyframes fadeIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.topic-list{list-style:none;display:flex;flex-direction:column;gap:8px;}
.topic-item{display:flex;align-items:flex-start;gap:12px;font-size:.8rem;color:var(--muted);line-height:1.5;}
.topic-item::before{content:"→";color:var(--cyan);font-size:.75rem;flex-shrink:0;margin-top:1px;}
.module-project{margin-top:16px;padding:14px 16px;background:rgba(0,180,240,.04);border:1px solid rgba(0,180,240,.15);border-radius:8px;font-size:.75rem;color:var(--muted);}
.module-project strong{color:var(--cyan);}

/* COURSES / TRACKS */
.tracks{background:#f0f7ff;}
.tracks-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:64px;}
.track-card{background:#fff;border:1px solid rgba(0,180,240,.15);border-radius:16px;padding:36px 30px;position:relative;overflow:hidden;cursor:default;transition:transform .3s cubic-bezier(.23,1,.32,1),border-color .3s,box-shadow .3s;}
.track-card:hover{transform:translateY(-8px);border-color:rgba(0,180,240,.4);box-shadow:0 16px 48px rgba(0,180,240,.15);}
.track-card.featured{border-color:rgba(0,180,240,.4);background:linear-gradient(160deg,#e0f2fe,#ede9fe);}
.track-card.featured::before{content:"FLAGSHIP";position:absolute;top:20px;right:20px;font-size:.55rem;font-weight:800;letter-spacing:.15em;color:var(--cyan);background:rgba(0,180,240,.1);border:1px solid rgba(0,180,240,.3);padding:3px 10px;border-radius:4px;}
.track-glow{position:absolute;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(0,180,240,.08) 0%,transparent 65%);top:-60px;right:-60px;pointer-events:none;}
.track-icon{font-size:2.2rem;margin-bottom:20px;display:block;}
.track-title{font-size:1.25rem;font-weight:800;letter-spacing:-.02em;color:var(--white);margin-bottom:12px;}
.track-duration{font-family:"DM Mono",monospace;font-size:.65rem;color:var(--cyan);margin-bottom:14px;display:block;}
.track-desc{font-size:.8rem;color:var(--muted);line-height:1.7;}
.track-features{list-style:none;display:flex;flex-direction:column;gap:10px;margin-top:24px;}
.track-features li{display:flex;align-items:center;gap:10px;font-size:.78rem;color:var(--muted);}
.feat-check{width:18px;height:18px;border-radius:50%;background:rgba(0,180,240,.1);border:1px solid rgba(0,180,240,.25);display:flex;align-items:center;justify-content:center;font-size:.55rem;color:var(--cyan);flex-shrink:0;}
.track-price{margin-top:28px;padding-top:20px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}
.price-val{font-size:1.5rem;font-weight:800;color:var(--white);letter-spacing:-.03em;}
.price-val span{font-size:.75rem;color:var(--muted);font-weight:600;}
.btn-track{background:var(--cyan);color:#fff;padding:10px 22px;font-weight:800;font-size:.75rem;border-radius:6px;text-decoration:none;border:none;cursor:pointer;transition:all .2s;letter-spacing:.05em;}
.btn-track:hover{background:#fff;transform:translateY(-1px);}
.btn-track.outline{background:transparent;color:var(--cyan);border:1px solid rgba(0,180,240,.3);}
.btn-track.outline:hover{background:rgba(0,180,240,.08);}

/* INTERNSHIP */
.internship{background:#ffffff;padding:110px 52px;}
.intern-layout{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.intern-visual{position:relative;}
.intern-screen{background:#fff;border:1px solid rgba(0,180,240,.15);border-radius:16px;overflow:hidden;box-shadow:0 8px 40px rgba(0,180,240,.12);}
.intern-screen-bar{background:#f8fafc;padding:14px 18px;display:flex;align-items:center;gap:8px;border-bottom:1px solid rgba(0,180,240,.1);}
.ibar-dot{width:9px;height:9px;border-radius:50%;}
.intern-screen-body{padding:24px;}
.intern-project-card{background:rgba(0,180,240,.04);border:1px solid rgba(0,180,240,.15);border-radius:10px;padding:20px;margin-bottom:14px;}
.ipc-label{font-size:.58rem;font-weight:800;letter-spacing:.15em;text-transform:uppercase;color:var(--cyan);margin-bottom:8px;}
.ipc-title{font-size:.9rem;font-weight:700;color:var(--white);margin-bottom:6px;}
.ipc-meta{font-size:.7rem;color:var(--muted);display:flex;gap:12px;}
.ipc-status{display:inline-flex;align-items:center;gap:5px;font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:3px 10px;border-radius:100px;}
.status-live{background:rgba(22,163,74,.1);color:#16a34a;border:1px solid rgba(22,163,74,.25);}
.status-open{background:rgba(0,180,240,.08);color:var(--cyan);border:1px solid rgba(0,229,255,.2);}
.pipeline-row{display:flex;align-items:center;gap:8px;margin-top:16px;}
.pip-step{flex:1;padding:8px;background:#f8fafc;border:1px solid rgba(0,180,240,.12);border-radius:6px;text-align:center;font-size:.58rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);}
.pip-step.active{background:rgba(0,180,240,.08);border-color:rgba(0,229,255,.3);color:var(--cyan);}
.pip-arr{color:var(--border);font-size:.8rem;}

.intern-content{}
.intern-headline{font-size:clamp(2rem,3.5vw,3rem);font-weight:800;letter-spacing:-.04em;line-height:1.05;color:var(--white);margin-bottom:16px;}
.intern-headline span{color:var(--cyan);}
.intern-desc{font-size:.9rem;color:var(--muted);line-height:1.75;margin-bottom:36px;}
.intern-steps{list-style:none;display:flex;flex-direction:column;gap:20px;}
.intern-step{display:flex;gap:18px;align-items:flex-start;}
.step-num{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,rgba(0,180,240,.12),rgba(0,180,240,.04));border:1px solid rgba(0,180,240,.2);display:flex;align-items:center;justify-content:center;font-family:"DM Mono",monospace;font-size:.7rem;color:var(--cyan);font-weight:500;flex-shrink:0;margin-top:2px;}
.step-text{font-size:.85rem;color:var(--muted);line-height:1.6;}
.step-text strong{color:var(--white);font-weight:700;display:block;margin-bottom:2px;}

/* TESTIMONIALS / SOCIAL PROOF */
.proof-section{background:#f4f8ff;padding:110px 52px;}
.proof-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:64px;}
.proof-card{background:#fff;border:1px solid rgba(0,180,240,.12);border-radius:14px;padding:28px;transition:border-color .3s;box-shadow:0 2px 12px rgba(0,180,240,.06);}
.proof-card:hover{border-color:rgba(0,180,240,.3);box-shadow:0 8px 32px rgba(0,180,240,.1);}
.proof-quote{font-size:.85rem;color:#334155;line-height:1.7;font-style:italic;margin-bottom:20px;}
.proof-author{display:flex;align-items:center;gap:12px;}
.author-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--violet),var(--cyan));display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:800;color:#fff;flex-shrink:0;}
.author-name{font-size:.8rem;font-weight:800;color:#0f172a;}
.author-role{font-size:.7rem;color:var(--muted);}
.proof-stars{color:#f59e0b;font-size:.7rem;margin-bottom:12px;letter-spacing:.1em;}

/* POWERED BY */
/* ── POWERED BY BAND — rich purple section with logo ── */
.powered-band{
  position:relative;overflow:hidden;
  background:linear-gradient(135deg,#3b0764 0%,#4c1d95 35%,#5b21f5 65%,#7c3aed 100%);
  padding:72px 52px;display:flex;justify-content:space-between;align-items:center;gap:48px;
}
/* circuit mesh background */
.powered-band::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px),
    radial-gradient(circle,rgba(255,255,255,.06) 1px,transparent 1px);
  background-size:40px 40px,40px 40px,20px 20px;
  pointer-events:none;
}
/* radial glow blobs */
.powered-band::after{
  content:"";position:absolute;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(167,139,250,.25) 0%,transparent 65%);
  top:-200px;right:-100px;pointer-events:none;
}
.pb-left{position:relative;z-index:1;max-width:520px;}
.pb-eyebrow{font-size:.62rem;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:rgba(196,181,253,.7);margin-bottom:16px;display:flex;align-items:center;gap:10px;}
.pb-eyebrow::before{content:"";display:inline-block;width:20px;height:1.5px;background:rgba(196,181,253,.5);border-radius:2px;}
.pb-headline{font-size:clamp(1.6rem,3vw,2.4rem);font-weight:800;letter-spacing:-.03em;color:#fff;line-height:1.1;margin-bottom:14px;}
.pb-headline span{color:#c4b5fd;}
.pb-desc{font-size:.88rem;color:rgba(196,181,253,.8);line-height:1.75;font-weight:500;}
.pb-right{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;}
/* logo card */
.pb-logo-card{
  background:rgba(255,255,255,.95);
  border-radius:20px;padding:20px 32px;
  box-shadow:0 8px 40px rgba(0,0,0,.3),0 0 0 1px rgba(255,255,255,.2);
  display:flex;flex-direction:column;align-items:center;gap:10px;
  min-width:220px;
}
.pb-logo-img{height:72px;width:auto;}
.pb-logo-sub{font-size:.58rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:#6d28d9;border-top:1px solid rgba(109,40,217,.15);padding-top:8px;width:100%;text-align:center;}
.pb-visit{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.25);
  color:#fff;font-size:.74rem;font-weight:800;letter-spacing:.05em;
  padding:10px 24px;border-radius:100px;text-decoration:none;
  transition:all .2s;backdrop-filter:blur(8px);
  display:inline-block;
}
.pb-visit:hover{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.4);}
/* floating circuit nodes */
.pb-node{position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.15);pointer-events:none;}

/* CTA */
.final-cta{background:linear-gradient(160deg,#e0f2fe,#ede9fe);padding:110px 52px;text-align:center;position:relative;overflow:hidden;}
.final-cta::before{content:"";position:absolute;width:800px;height:800px;border-radius:50%;background:radial-gradient(circle,rgba(0,180,240,.1) 0%,transparent 60%);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;}
.cta-content{position:relative;z-index:1;max-width:640px;margin:0 auto;}
.cta-big{font-size:clamp(3rem,7vw,6.5rem);font-weight:800;line-height:.95;letter-spacing:-.05em;color:#0f172a;margin-bottom:24px;}
.cta-big .cy{color:var(--cyan);}
.cta-big .it{font-family:Fraunces,serif;font-style:italic;font-weight:200;color:rgba(168,85,247,.9);}
.cta-sub-text{font-size:1rem;color:#475569;line-height:1.7;margin-bottom:48px;}
.cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}
.cta-detail{margin-top:20px;font-size:.72rem;color:var(--muted);font-family:"DM Mono",monospace;}

/* FOOTER */
footer{background:#f8fafc;border-top:1px solid rgba(0,180,240,.12);padding:56px 52px 36px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;}
.footer-brand{}
.footer-name{font-size:1.1rem;font-weight:800;letter-spacing:-.02em;color:#0f172a;margin-bottom:4px;}
.footer-name span{color:var(--cyan);}
.footer-domain{font-family:"DM Mono",monospace;font-size:.65rem;color:var(--muted);margin-bottom:16px;}
.footer-tagline{font-size:.8rem;color:var(--muted);line-height:1.65;max-width:240px;}
.footer-powered{margin-top:20px;font-size:.68rem;color:rgba(124,58,237,.6);font-weight:700;letter-spacing:.06em;text-transform:uppercase;}
.footer-powered a{color:rgba(124,58,237,.7);text-decoration:none;}
.footer-powered a:hover{color:var(--violet2);}
.footer-col-title{font-size:.58rem;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--cyan);margin-bottom:20px;}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:11px;}
.footer-links a{color:var(--muted);text-decoration:none;font-size:.8rem;font-weight:600;transition:color .2s;}
.footer-links a:hover{color:var(--white);}
.footer-bottom{grid-column:1/-1;margin-top:40px;padding-top:20px;border-top:1px solid rgba(0,180,240,.1);display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;font-size:.67rem;color:#94a3b8;font-weight:700;}

/* RESPONSIVE */
/* ── TABLET (max 960px) ── */
@media(max-width:960px){
  nav{padding:14px 20px;}
  .nav-links{display:none;}
  .nav-school-sub{display:none;}
  section,.internship,.proof-section,.final-cta{padding:72px 20px;}
  footer{padding:56px 20px 36px;grid-template-columns:1fr 1fr;}
  .hero{padding:100px 20px 60px;grid-template-columns:1fr;}
  .hero-right-panel{display:none;}
  .mobile-workflow{display:block;grid-column:1/-1;}
  .builds-header{grid-template-columns:1fr;gap:24px;}
  .curriculum-layout{grid-template-columns:1fr;}
  .curr-sticky{position:static;}
  .intern-layout{grid-template-columns:1fr;}
  .intern-visual{display:none;}
  .tracks-grid{grid-template-columns:1fr 1fr;}
  .track-card.featured::before{font-size:.5rem;}
  .builds-grid{grid-template-columns:1fr 1fr;background:none;gap:2px;}
  .proof-grid{grid-template-columns:1fr;}
  .stats-bar{flex-wrap:wrap;gap:16px;padding:20px;}
  .stat-divider{display:none;}
  .powered-band{flex-direction:column;text-align:center;padding:48px 20px;}
  .pb-right{text-align:center;}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center;}
  .hero-proof{gap:24px;flex-wrap:wrap;}
  .cta-btns{flex-direction:column;align-items:center;}
}

/* ── MOBILE (max 600px) ── */
@media(max-width:600px){
  .mobile-workflow{display:block;grid-column:1/-1;}

  /* NAV */
  nav{padding:12px 16px;}
  .nav-cta{padding:8px 16px;font-size:.7rem;}

  /* HERO */
  .hero{padding:88px 16px 48px;gap:24px;}
  .hero-headline{font-size:clamp(2.4rem,11vw,3.2rem);letter-spacing:-.03em;line-height:1.0;}
  .hero-sub{font-size:.95rem;}
  .hero-badge{font-size:.65rem;}
  .hero-actions{flex-direction:column;align-items:flex-start;gap:12px;}
  .btn-primary,.btn-outline{width:100%;text-align:center;padding:14px 20px;}
  .hero-proof{gap:16px;margin-top:40px;padding-top:24px;}
  .proof-num{font-size:1.8rem;}

  /* STATS BAR */
  .stats-bar{padding:16px;}
  .stat-val{font-size:1.3rem;}
  .stat-key{font-size:.58rem;}

  /* SECTIONS */
  section,.internship,.proof-section,.final-cta{padding:56px 16px;}
  footer{padding:48px 16px 28px;grid-template-columns:1fr;}
  .sec-headline{font-size:clamp(1.8rem,8vw,2.4rem);}
  .sec-eyebrow{font-size:.58rem;}

  /* BUILDS */
  .builds-grid{grid-template-columns:1fr;}
  .build-card{padding:24px 20px;}
  .builds-header{margin-bottom:40px;}

  /* CURRICULUM */
  .module-header{padding:16px 18px;gap:10px;}
  .module-title{font-size:.88rem;}
  .module-weeks{display:none;}
  .module-body{padding:0 18px 18px;}

  /* TRACKS */
  .tracks-grid{grid-template-columns:1fr;}
  .track-card{padding:28px 22px;}
  .track-card.featured::before{top:16px;right:16px;}

  /* INTERNSHIP STEPS */
  .pipeline-steps{grid-template-columns:1fr 1fr;}

  /* TESTIMONIALS */
  .proof-grid{grid-template-columns:1fr;}
  .proof-card{padding:22px 18px;}

  /* POWERED BAND */
  .powered-band{padding:40px 16px;}
  .pb-headline{font-size:1.4rem;}
  .pb-logo-card{min-width:160px;padding:16px 24px;}
  .pb-logo-img{height:48px;}

  /* CTA */
  .cta-big{font-size:clamp(2.4rem,10vw,3.2rem);}
  .cta-btns{flex-direction:column;align-items:center;gap:12px;}
  .btn-primary,.btn-outline{width:100%;max-width:280px;text-align:center;}

  /* FOOTER */
  .footer-bottom{flex-direction:column;gap:8px;text-align:center;font-size:.62rem;}
  .footer-name{font-size:1rem;}
  .footer-tagline{max-width:100%;}
}

/* ── VERY SMALL (max 380px) ── */
@media(max-width:380px){
  .hero-headline{font-size:2.2rem;}
  nav{padding:10px 12px;}
  .nav-cta{font-size:.65rem;padding:7px 12px;}
  .pipeline-steps{grid-template-columns:1fr;}
}



/* ── MOBILE MINI WORKFLOW ── */
.mobile-workflow{
  display:none; /* hidden by default; shown on mobile via media query */
  margin-top:32px;
  background:#fff;
  border:1px solid rgba(0,180,240,.18);
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 8px 32px rgba(0,180,240,.12);
}
.mwf-bar{
  background:#f4f8ff;
  padding:10px 14px;
  display:flex;align-items:center;gap:7px;
  border-bottom:1px solid rgba(0,180,240,.1);
}
.mwf-dot{width:8px;height:8px;border-radius:50%;}
.mwf-title{font-family:"DM Mono",monospace;font-size:.58rem;color:#64748b;margin-left:4px;flex:1;letter-spacing:.05em;}
.mwf-status{font-family:"DM Mono",monospace;font-size:.56rem;color:#16a34a;display:flex;align-items:center;gap:4px;}
.mwf-status-dot{width:5px;height:5px;border-radius:50%;background:#16a34a;animation:pulse 1.4s infinite;}

.mwf-canvas{padding:20px 16px 16px;position:relative;}

/* the 3-node row */
.mwf-nodes{display:flex;align-items:center;justify-content:space-between;gap:0;position:relative;}

/* connector line behind nodes */
.mwf-connector{
  position:absolute;left:0;right:0;top:50%;
  height:2px;
  background:linear-gradient(90deg,rgba(0,180,240,.15),rgba(0,180,240,.3),rgba(0,180,240,.15));
  transform:translateY(-50%);
  z-index:0;
}

/* individual node */
.mwf-node-m{
  position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:center;gap:8px;
  flex:0 0 auto;
}
.mwf-node-box{
  width:64px;height:64px;
  border-radius:14px;
  border:1.5px solid rgba(0,180,240,.25);
  background:#fff;
  box-shadow:0 4px 16px rgba(0,180,240,.1);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  transition:border-color .3s,box-shadow .3s;
  position:relative;overflow:hidden;
}
.mwf-node-box.active{
  border-color:rgba(0,180,240,.6);
  box-shadow:0 4px 20px rgba(0,180,240,.25);
}
.mwf-node-box::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(0,180,240,.06),transparent);
  opacity:0;transition:opacity .3s;
}
.mwf-node-box.active::after{opacity:1;}
.mwf-node-icon{font-size:1.5rem;line-height:1;}
.mwf-node-label{font-family:"DM Mono",monospace;font-size:.52rem;font-weight:500;color:#475569;letter-spacing:.04em;text-align:center;max-width:64px;line-height:1.3;}

/* arrow between nodes */
.mwf-arrow{
  flex:1;
  display:flex;align-items:center;justify-content:center;
  position:relative;z-index:2;
  padding:0 4px;
}
.mwf-arrow svg{width:28px;height:14px;overflow:visible;}

/* animated packet */
.mwf-packet{
  position:absolute;top:50%;transform:translateY(-50%);
  width:10px;height:10px;border-radius:50%;
  background:var(--cyan);
  box-shadow:0 0 8px rgba(0,180,240,.6);
  z-index:3;
  opacity:0;
  transition:none;
}

/* stats strip below nodes */
.mwf-stats{
  display:flex;justify-content:space-around;
  margin-top:16px;padding-top:14px;
  border-top:1px solid rgba(0,180,240,.1);
}
.mwf-stat{text-align:center;}
.mwf-stat-val{font-size:1.1rem;font-weight:800;color:#1a2b5e;letter-spacing:-.02em;font-family:"Plus Jakarta Sans",sans-serif;}
.mwf-stat-val span{color:var(--cyan);}
.mwf-stat-key{font-family:"DM Mono",monospace;font-size:.52rem;color:#94a3b8;letter-spacing:.08em;margin-top:2px;}

/* active log line */
.mwf-log{
  margin-top:12px;
  padding:8px 12px;
  background:rgba(0,180,240,.04);
  border-radius:8px;
  border:1px solid rgba(0,180,240,.1);
  font-family:"DM Mono",monospace;
  font-size:.58rem;
  color:#475569;
  min-height:26px;
  display:flex;align-items:center;gap:6px;
}
.mwf-log-dot{width:5px;height:5px;border-radius:50%;background:var(--cyan);flex-shrink:0;animation:pulse 1.4s infinite;}


@media(min-width:961px){.mobile-workflow{display:none!important;}}
/* HAMBURGER */
.nav-hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px;z-index:600;}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--white);border-radius:2px;transition:all .25s;}
@media(max-width:960px){.nav-hamburger{display:flex;}}

/* MOBILE DRAWER */
.mobile-drawer{position:fixed;inset:0;z-index:550;pointer-events:none;}
.mobile-drawer.open{pointer-events:all;}
.mobile-drawer::before{content:"";position:absolute;inset:0;background:rgba(15,23,42,.5);opacity:0;transition:opacity .3s;backdrop-filter:blur(4px);}
.mobile-drawer.open::before{opacity:1;}
.mobile-drawer-inner{position:absolute;top:0;right:0;width:min(320px,85vw);height:100%;background:#fff;padding:24px 24px 40px;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .35s cubic-bezier(.23,1,.32,1);box-shadow:-8px 0 40px rgba(0,0,0,.15);}
.mobile-drawer.open .mobile-drawer-inner{transform:translateX(0);}
.drawer-close{align-self:flex-end;background:none;border:1px solid rgba(0,180,240,.2);border-radius:50%;width:36px;height:36px;font-size:1rem;cursor:pointer;color:var(--muted);margin-bottom:32px;transition:all .2s;}
.drawer-close:hover{background:rgba(0,180,240,.08);color:var(--cyan);}
.mobile-nav-links{list-style:none;display:flex;flex-direction:column;gap:4px;}
.mobile-nav-links a{display:block;padding:14px 12px;font-size:1rem;font-weight:700;color:var(--white);text-decoration:none;border-radius:8px;transition:background .2s,color .2s;letter-spacing:-.01em;}
.mobile-nav-links a:hover{background:rgba(0,180,240,.08);color:var(--cyan);}

/* SEO fix: show content immediately if JS hasn't run yet */
body.no-js [style*="opacity:0"],
body.no-js .hero-badge,
body.no-js .hero-headline,
body.no-js .hero-sub,
body.no-js .hero-actions,
body.no-js .hero-proof,
body.no-js .hero-right-panel {
  opacity: 1 !important;
  transform: none !important;
  animation: none !important;
}
/* Respect reduced motion — show everything without animation */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  .hero-badge,.hero-headline,.hero-sub,.hero-actions,.hero-proof,.hero-right-panel {
    opacity: 1 !important;
    transform: none !important;
  }
}


/* ─────────────────────────────── */


/* ── BEEPS DIGITAL REBRAND: Clean consolidated theme ── */

/* 1. CSS variable overrides — purple replaces cyan throughout */
:root {
  --cyan:   #6d28d9;
  --cyan2:  #5b21b6;
  --ink:    #f5f0ff;
  --deep:   #ede8ff;
  --border: rgba(109,40,217,.15);
  --bordv:  rgba(109,40,217,.2);
}

/* 2. Body & page background */
body { background-color: #f5f0ff; }

/* 3. Navigation */
nav {
  background: rgba(255,255,255,.97) !important;
  border-bottom: 1px solid rgba(109,40,217,.1) !important;
}

/* 4. Buttons — fix cursor + colours */
.btn-primary, .nav-cta, .btn-track:not(.outline) {
  cursor: pointer !important;
  background: linear-gradient(135deg,#6d28d9,#7c3aed) !important;
  box-shadow: 0 4px 16px rgba(109,40,217,.3) !important;
}
.btn-primary:hover, .nav-cta:hover { box-shadow: 0 6px 24px rgba(109,40,217,.4) !important; }
a, button { cursor: pointer !important; }

.btn-outline {
  border-color: rgba(109,40,217,.3) !important;
  color: #6d28d9 !important;
}
.btn-outline:hover {
  border-color: #6d28d9 !important;
  color: #6d28d9 !important;
  background: rgba(109,40,217,.06) !important;
}

.btn-track.outline {
  background: transparent !important;
  color: #6d28d9 !important;
  border: 1px solid rgba(109,40,217,.3) !important;
}
.btn-track.outline:hover { background: rgba(109,40,217,.08) !important; }

/* 5. Hero */
.hero {
  background: linear-gradient(160deg,#f5f0ff 0%,#ede8ff 40%,#f0ebff 100%) !important;
}
.hero-grid {
  background-image:
    linear-gradient(rgba(109,40,217,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(109,40,217,.05) 1px,transparent 1px) !important;
}
.hero-blob1 { background: radial-gradient(circle,rgba(109,40,217,.1) 0%,transparent 65%) !important; }
.hero-blob2 { background: radial-gradient(circle,rgba(124,58,237,.1) 0%,transparent 65%) !important; }

/* 6. Section backgrounds */
.builds      { background: #faf8ff !important; }
.tracks      { background: #f5f0ff !important; }
.proof-section { background: #f8f5ff !important; }
.final-cta   { background: linear-gradient(160deg,#f0ebff,#ede8ff) !important; }

/* 7. Track cards */
.track-card.featured {
  border-color: rgba(109,40,217,.35) !important;
  background: linear-gradient(160deg,#ede9fe,#f5f0ff) !important;
}

/* 8. Internship dashboard badges — keep semantic colours */
.status-live {
  background: rgba(22,163,74,.1) !important;
  color: #16a34a !important;
  border: 1px solid rgba(22,163,74,.25) !important;
}
.status-open {
  background: rgba(109,40,217,.08) !important;
  color: #6d28d9 !important;
  border: 1px solid rgba(109,40,217,.2) !important;
}
.pip-step.active {
  background: rgba(109,40,217,.08) !important;
  border-color: rgba(109,40,217,.3) !important;
  color: #6d28d9 !important;
}
.ipc-label { color: #6d28d9 !important; }

/* 9. Module accordion */
.module:hover, .module.open { border-color: rgba(109,40,217,.4) !important; }
.module.open .module-toggle { border-color: #6d28d9 !important; color: #6d28d9 !important; background: rgba(109,40,217,.08) !important; }
.module-project strong { color: #6d28d9 !important; }
.topic-item::before { color: #6d28d9 !important; }

/* 10. Footer — light purple dark theme with readable text */
footer {
  background: #1a0a3d !important;
  border-top: 1px solid rgba(109,40,217,.2) !important;
}
footer .footer-name { color: #f5f0ff !important; }
footer .footer-name span { color: #a78bfa !important; }
footer .footer-domain { color: #a78bfa !important; }
footer .footer-tagline { color: #c4b5fd !important; }
footer .footer-powered { color: rgba(167,139,250,.7) !important; }
footer .footer-powered a { color: #a78bfa !important; }
footer .footer-col-title { color: #a78bfa !important; }
footer .footer-links a { color: #c4b5fd !important; }
footer .footer-links a:hover { color: #fff !important; }
footer .footer-bottom { color: rgba(196,181,253,.5) !important; border-top-color: rgba(109,40,217,.2) !important; }

/* 11. Stats bar */
.stats-bar { background: #fff !important; border-color: rgba(109,40,217,.1) !important; }

/* 12. Scrollbar */
::-webkit-scrollbar-thumb { background: #6d28d9 !important; }

/* 13. Eyebrow/sec-eyebrow lines */
.sec-eyebrow::before { background: #6d28d9 !important; }

/* 14. Build card hover bar */
.build-card::before { background: linear-gradient(180deg,#6d28d9,#7c3aed) !important; }

/* 15. wf-status dot (workflow running indicator) stays green */
.wf-status { color: #16a34a !important; }
.wf-status-dot { background: #16a34a !important; }

/* 16. Mobile workflow arrow strokes */
.mwf-arrow path { stroke: rgba(109,40,217,.4) !important; }
.mwf-packet { background: #6d28d9 !important; box-shadow: 0 0 8px rgba(109,40,217,.6) !important; }
.mwf-log-dot { background: #6d28d9 !important; }
.mwf-status { color: #16a34a !important; }
.mwf-status-dot { background: #16a34a !important; }

/* ============================================================
   HERO CONTRAST LIFT — matches Beeps Digital portal clarity
   ============================================================ */

/* 1. Background — clean near-white instead of heavy purple gradient */
.hero {
  background: #f7f8ff !important;
}
.hero-grid {
  background-image:
    linear-gradient(rgba(109,40,217,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(109,40,217,.025) 1px, transparent 1px) !important;
}
.hero-blob1 {
  background: radial-gradient(circle, rgba(109,40,217,.04) 0%, transparent 65%) !important;
}
.hero-blob2 {
  background: radial-gradient(circle, rgba(124,58,237,.04) 0%, transparent 65%) !important;
}

/* 2. Headline — near-black primary, strong gradient on accent */
.hero-headline .h-white {
  color: #0d0d1f !important;
}
.hero-headline .h-cyan {
  background: linear-gradient(135deg, #4c1d95 0%, #7c3aed 100%) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
}
.hero-headline .h-italic {
  color: #7c3aed !important;
  -webkit-text-fill-color: #7c3aed !important;
}

/* 3. Subheadline — darker for readability */
.hero-sub {
  color: #374151 !important;
}
.hero-sub strong {
  color: #111827 !important;
}

/* 4. Badge — less purple haze */
.hero-badge {
  background: rgba(109,40,217,.04) !important;
  border-color: rgba(109,40,217,.18) !important;
  color: #5b21b6 !important;
}

/* 5. Proof stats — stronger contrast */
.hero-proof {
  border-top-color: rgba(15,23,42,.1) !important;
}
.proof-num {
  color: #0d0d1f !important;
}

/* 6. Workflow canvas — clean white surface, no purple haze */
.workflow-canvas {
  background: #ffffff !important;
  border: 1px solid rgba(15,23,42,.1) !important;
  box-shadow: 0 4px 24px rgba(15,23,42,.07) !important;
}
.wf-bar {
  background: #f9fafb !important;
  border-bottom: 1px solid rgba(15,23,42,.08) !important;
}

/* 7. Terminal — slightly stronger border */
.hero-terminal {
  border-color: rgba(15,23,42,.25) !important;
  box-shadow: 0 4px 24px rgba(15,23,42,.12) !important;
}

/* ═══════════════════════════════════════════════════════════
   NAV LOCKUP — PREMIUM SUB-BRAND REDESIGN
   ═══════════════════════════════════════════════════════════ */

/* 1. Strip the redundant white card — the nav is already white.
      Removing background/border-radius/padding eliminates the
      "box inside a box" that made the lockup look cramped. */
.nav-lockup {
  background: transparent !important;
  border-radius: 0 !important;
  padding: 0 !important;
  height: auto !important;
}

/* 2. Logo — 36px sits optically balanced with the text block */
.nav-beeps-logo    { height: 36px !important; }
.nav-lockup-logo   { padding-right: 18px !important; }

/* 3. Divider — purple-tinted so it reads as brand, not chrome */
.nav-lockup-divider {
  width: 1.5px !important;
  height: 26px !important;
  background: rgba(109,40,217,.28) !important;
}

/* 4. Text block — small gap between the two label lines */
.nav-lockup-text {
  padding-left: 18px !important;
  gap: 4px;
}

/* 5. Primary label — "AI & Automation"
      Heavier weight, near-black so it reads as the brand name */
.nav-school-name {
  font-size: 13px !important;
  font-weight: 800 !important;
  color: #120b29 !important;
  line-height: 1.15 !important;
  letter-spacing: -.01em !important;
}

/* 6. Secondary label — "SCHOOL"
      Wide tracking makes it read as a badge/sub-brand.
      Override the 960px display:none — we want it always visible. */
.nav-school-sub {
  font-size: 8.5px !important;
  font-weight: 800 !important;
  color: #6d28d9 !important;
  letter-spacing: .22em !important;
  text-transform: uppercase !important;
  line-height: 1 !important;
  display: block !important;
}

/* 7. Nav right — replaces the inline style on the CTA wrapper */
.nav-right {
  display: flex;
  align-items: center;
  gap: 14px;
}

/* 9. Nav shadow — match the purple brand (overrides the stale cyan shadow) */
nav {
  box-shadow: 0 2px 20px rgba(109,40,217,.08) !important;
}

/* 10. Portal back link — visible but secondary */
.nav-portal-link {
  font-size: .72rem !important;
  color: #6d28d9 !important;
  font-weight: 700 !important;
  opacity: .65;
  white-space: nowrap;
  border: none !important;
  transition: opacity .2s !important;
}
.nav-portal-link:hover { opacity: 1 !important; }

/* 11. Drawer — purple brand colours */
.drawer-close {
  border-color: rgba(109,40,217,.2) !important;
  color: #6d28d9 !important;
}
.drawer-close:hover { background: rgba(109,40,217,.08) !important; }
.mobile-nav-links a:hover {
  background: rgba(109,40,217,.07) !important;
  color: #6d28d9 !important;
}

/* 12. Drawer footer — CTA + portal link stacked at the bottom */
.drawer-cta-wrap {
  margin-top: auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding-top: 28px;
  border-top: 1px solid rgba(109,40,217,.1);
}
.drawer-cta-btn  { text-align: center; display: block; }
.drawer-portal-link {
  display: block;
  text-align: center;
  font-size: .82rem;
  font-weight: 700;
  color: #6d28d9;
  text-decoration: none;
  padding: 10px 12px;
  border-radius: 8px;
  border: 1px solid rgba(109,40,217,.18);
  transition: background .2s;
}
.drawer-portal-link:hover { background: rgba(109,40,217,.06); }

/* ── TABLET (≤960px)
      nav-links list is hidden but the lockup should still show
      both lines — we already forced display:block on nav-school-sub
      above, so no extra work needed here. Just nudge font-size. */
@media(max-width:960px) {
  .nav-school-name { font-size: 12px !important; }
}

/* ── MOBILE (≤480px)
      Keep the full two-line lockup. Scale text down slightly so
      "AI & Automation / Academy" fits without overflow. */
@media(max-width:480px) {
  .nav-school-name    { font-size: 11px !important; }
  .nav-school-sub     { font-size: 8px !important; letter-spacing: .18em !important; }
  .nav-beeps-logo     { height: 30px !important; }
  .nav-lockup-logo    { padding-right: 12px !important; }
  .nav-lockup-divider { height: 20px !important; }
  .nav-lockup-text    { padding-left: 12px !important; }
}

/* ── VERY SMALL (≤380px) — tightest squeeze, still two lines */
@media(max-width:380px) {
  .nav-school-name    { font-size: 10px !important; }
  .nav-school-sub     { font-size: 7.5px !important; letter-spacing: .15em !important; }
  .nav-beeps-logo     { height: 28px !important; }
  .nav-lockup-logo    { padding-right: 10px !important; }
  .nav-lockup-divider { height: 18px !important; }
  .nav-lockup-text    { padding-left: 10px !important; }
}