:root{
  --blue:#2A7DE1;--blue-mid:#3B8FF0;
  --blue-light:rgba(42,125,225,.13);--blue-glow:rgba(42,125,225,.22);
  --ink:#EDF3FC;--ink-2:#93AECB;--ink-3:#4A6480;
  --paper:#06111F;--paper-2:#0B1826;--paper-3:#0E1D32;
  --line:#1A2E46;--white:#0C1828;
  --wa:#25D366;--orange:#FF6B35;--orange-light:rgba(255,107,53,.12);
  --r:cubic-bezier(.25,.46,.45,.94);--spring:cubic-bezier(.34,1.56,.64,1);
}
[data-theme="light"]{
  --blue:#1A5FAA;--blue-mid:#2874C8;--blue-light:#EBF3FF;--blue-glow:rgba(26,95,170,.18);
  --ink:#09121E;--ink-2:#354558;--ink-3:#7A94AE;
  --paper:#F9FAFD;--paper-2:#EFF3F9;--paper-3:#E4EDF8;--line:#DDE6F2;--white:#FFFFFF;
  --orange:#E85D25;--orange-light:rgba(232,93,37,.1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:17px;-webkit-text-size-adjust:100%}
body{background:var(--paper);color:var(--ink);font-family:'Lato',sans-serif;-webkit-font-smoothing:antialiased;font-weight:400;overflow-x:hidden;transition:background .35s,color .35s;display:flex;flex-direction:column;min-height:100vh}
main{flex:1}
::-webkit-scrollbar{width:2px}::-webkit-scrollbar-thumb{background:var(--blue);border-radius:2px}
::selection{background:var(--blue);color:#fff}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
.container{max-width:1100px;margin:0 auto;padding:0 clamp(16px,3.5vw,36px)}
section{padding:72px 0}
.rv{opacity:1;transform:none;transition:opacity .75s var(--r),transform .75s var(--r)}
.rv.before-in{opacity:0;transform:translateY(26px)}
.rv.in{opacity:1;transform:none}
/* Ensure LANEFORGE section always fully visible */
#landorge .landorge-wrap,
#landorge .landorge-top,
#landorge .landorge-bottom,
#landorge .landorge-badge,
#landorge .landorge-title,
#landorge .landorge-desc,
#landorge .landorge-feats,
#landorge .wl-box,
#landorge .wl-avatars{opacity:1!important;transform:none!important;visibility:visible!important}
.d1{transition-delay:.07s}.d2{transition-delay:.14s}.d3{transition-delay:.21s}.d4{transition-delay:.28s}

/* NAVBAR */
nav{position:fixed;top:0;left:0;right:0;z-index:600;padding:0 clamp(20px,5vw,56px);height:68px;display:flex;align-items:center;justify-content:space-between;transition:background .3s,box-shadow .3s}
nav.solid{background:rgba(7,14,26,.94);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);box-shadow:0 1px 0 var(--line)}
[data-theme="light"] nav.solid{background:rgba(249,250,253,.94)}
.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none;flex-shrink:0}
.nav-logo-img{height:44px;width:44px;object-fit:contain;display:block}
.nav-logo-text{font-family:'Poppins',sans-serif;font-size:1.1rem;font-weight:800;letter-spacing:.12em;color:var(--ink);text-transform:uppercase;line-height:1}
.nav-links{display:flex;align-items:center;gap:2px;list-style:none}
.nav-links a{padding:7px 14px;border-radius:8px;font-size:.95rem;font-weight:500;color:var(--ink-2);letter-spacing:.01em;transition:color .2s,background .2s}
.nav-links a:hover{color:var(--blue);background:var(--blue-light)}
.nav-right{display:flex;align-items:center;gap:8px}
.theme-btn{width:36px;height:36px;border-radius:9px;border:1px solid var(--line);background:transparent;cursor:pointer;color:var(--ink-3);font-size:.88rem;display:flex;align-items:center;justify-content:center;transition:all .2s}
.theme-btn:hover{border-color:var(--blue);color:var(--blue)}
.nav-cta{display:inline-flex;align-items:center;gap:7px;padding:10px 22px;border-radius:9px;background:var(--blue);color:#fff;font-family:'Lato',sans-serif;font-size:.95rem;font-weight:700;letter-spacing:.04em;letter-spacing:.03em;transition:all .25s var(--spring);box-shadow:0 3px 14px var(--blue-glow);white-space:nowrap}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 6px 22px rgba(42,125,225,.45)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;border:1px solid var(--line);background:transparent;padding:8px;border-radius:9px}
.hamburger span{display:block;width:20px;height:1.5px;background:var(--ink);border-radius:2px;transition:all .3s var(--r)}
.hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* MOBILE DRAWER */
.mob-drawer{position:fixed;inset:0;z-index:590;background:var(--paper);display:flex;flex-direction:column;padding:86px 28px 40px;transform:translateX(100%);transition:transform .42s var(--r);overflow-y:auto}
.mob-drawer.open{transform:none}
.mob-drawer-link{font-family:'Poppins',sans-serif;font-size:2.1rem;font-weight:600;color:var(--ink);padding:14px 0;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;text-decoration:none;transition:color .2s}
.mob-drawer-link::after{content:'↗';font-size:1rem;font-family:'Lato',sans-serif;color:var(--ink-3)}
.mob-drawer-link:hover{color:var(--blue)}
.mob-lang-row{margin-top:auto;padding-top:28px;display:flex;gap:8px;flex-wrap:wrap;border-top:1px solid var(--line)}
.mob-lang-divider{width:100%;font-size:.68rem;font-family:'Inconsolata',monospace;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin-bottom:6px;padding-top:20px}
.lang-pill{padding:6px 14px;border-radius:100px;border:1px solid var(--line);background:transparent;font-size:.78rem;font-weight:600;color:var(--ink-2);cursor:pointer;font-family:'Inconsolata',monospace;transition:all .2s}
.lang-pill.active,.lang-pill:hover{background:var(--blue);color:#fff;border-color:var(--blue)}

/* HERO */
#hero{min-height:100vh;display:flex;align-items:center;padding-top:68px;position:relative;overflow:hidden}
#hero::before{content:'';position:absolute;top:-20%;right:-8%;width:700px;height:700px;border-radius:50%;background:radial-gradient(ellipse,rgba(42,125,225,.08) 0%,transparent 65%);pointer-events:none}
#hero::after{content:'';position:absolute;bottom:-18%;left:-6%;width:500px;height:500px;border-radius:50%;background:radial-gradient(ellipse,rgba(42,125,225,.05) 0%,transparent 65%);pointer-events:none}
.hero-inner{padding:60px 0 52px;display:grid;grid-template-columns:1.2fr 1fr;gap:52px;align-items:center;position:relative;z-index:1}
.hero-kicker{font-family:'Inconsolata',monospace;font-size:.75rem;font-weight:600;color:var(--blue);letter-spacing:.15em;text-transform:uppercase;margin-bottom:16px;display:inline-flex;align-items:center;gap:8px;padding:5px 12px;border-radius:100px;border:1px solid rgba(42,125,225,.25);background:var(--blue-light)}
.hero-h1{font-family:'Poppins',sans-serif;font-size:clamp(3rem,6vw,5.6rem);font-weight:900;color:var(--ink);margin-bottom:18px;line-height:1.0;letter-spacing:-.02em}
.hero-h1 em{color:var(--blue);font-style:normal;font-weight:900}
.hero-p{font-size:1.1rem;line-height:1.9;color:var(--ink-2);max-width:500px;margin-bottom:32px;font-weight:400}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:14px 30px;border-radius:10px;background:var(--blue);color:#fff;font-family:'Lato',sans-serif;font-size:1rem;font-weight:700;letter-spacing:.05em;transition:all .3s var(--spring);box-shadow:0 4px 20px var(--blue-glow);border:none;cursor:pointer}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(42,125,225,.5)}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:10px;border:1px solid var(--line);color:var(--ink-2);font-size:1rem;font-weight:700;background:transparent;transition:all .25s;cursor:pointer}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-light)}
.hero-visual{display:flex;flex-direction:column;gap:14px}
.hero-panel{background:var(--paper-2);border:1px solid var(--line);border-radius:14px;padding:20px 22px;transition:border-color .3s}
.hero-panel:hover{border-color:rgba(42,125,225,.3)}
.hero-panel-icon{font-size:1.6rem;color:var(--blue);margin-bottom:12px;opacity:.8}
.hero-panel-title{font-family:'Poppins',sans-serif;font-size:1.15rem;font-weight:600;color:var(--ink);margin-bottom:6px}
.hero-panel-text{font-size:1rem;color:var(--ink-2);line-height:1.75}
.hero-panel-split{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* TICKER */
.ticker-wrap{border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;padding:12px 0;background:var(--paper-2)}
.ticker-track{display:flex;animation:ticker 28s linear infinite;width:max-content}
.ticker-item{font-family:'Inconsolata',monospace;font-size:.68rem;font-weight:500;letter-spacing:.14em;color:var(--ink-3);text-transform:uppercase;padding:0 28px;white-space:nowrap}
.ticker-item::before{content:'·';margin-right:28px;color:var(--blue)}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ticker-wrap:hover .ticker-track{animation-play-state:paused}

/* SECTION HEADERS */
.sec-eyebrow{font-family:'Inconsolata',monospace;font-size:.78rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--blue);margin-bottom:10px;display:inline-flex;align-items:center;gap:8px}
.sec-eyebrow::before{content:'';width:16px;height:1px;background:var(--blue);flex-shrink:0}
.sec-h2{font-family:'Poppins',sans-serif;font-size:clamp(2rem,3.4vw,3rem);font-weight:800;color:var(--ink);margin-bottom:14px;letter-spacing:-.02em;line-height:1.08}
.sec-h2 em{color:var(--blue);font-style:normal;font-weight:900}
.sec-p{font-size:1.05rem;line-height:1.9;color:var(--ink-2);max-width:520px;font-weight:400}

/* ABOUT */
#about{background:var(--paper-2)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:center}
.about-pillars{margin-top:24px;display:flex;flex-direction:column}
.pillar{display:flex;align-items:flex-start;gap:14px;padding:14px 0;border-bottom:1px solid var(--line)}
.pillar:last-child{border-bottom:none}
.pillar-num{font-family:'Inconsolata',monospace;font-size:.65rem;color:var(--ink-3);flex-shrink:0;padding-top:3px;width:22px}
.pillar strong{font-family:'Poppins',sans-serif;font-size:1.05rem;font-weight:600;color:var(--ink);display:block;margin-bottom:4px}
.pillar span{font-size:1rem;color:var(--ink-2);line-height:1.75}
.about-card{border:1px solid var(--line);border-radius:18px;overflow:hidden;background:var(--paper)}
.about-logo-zone{display:flex;justify-content:center;align-items:center;padding:24px 20px;border-bottom:1px solid var(--line)}
.about-logo-zone img{height:88px;width:auto;object-fit:contain}
.about-info-grid{display:grid;grid-template-columns:1fr 1fr}
.ai{padding:20px;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.ai:nth-child(even){border-right:none}
.ai:nth-last-child(-n+2){border-bottom:none}
.ai-label{font-family:'Inconsolata',monospace;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);margin-bottom:5px}
.ai-val{font-family:'Poppins',sans-serif;font-size:1.1rem;font-weight:600;color:var(--ink)}
.tech-tags{display:flex;gap:6px;flex-wrap:wrap;padding:18px 20px}
.ttag{font-size:.7rem;font-weight:500;padding:4px 12px;border-radius:100px;border:1px solid var(--line);color:var(--ink-2);background:transparent;transition:all .2s;cursor:default}
.ttag:hover{border-color:var(--blue);color:var(--blue)}

/* TEAM */
#team{background:var(--paper)}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:36px}
.team-card{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--paper-2);transition:all .3s var(--spring)}
.team-card:hover{transform:translateY(-5px);box-shadow:0 18px 50px var(--blue-glow);border-color:rgba(42,125,225,.35)}
.team-avatar{aspect-ratio:1;background:var(--paper-3);overflow:hidden;border-bottom:1px solid var(--line);position:relative}
.team-initials{width:64px;height:64px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;font-family:'Poppins',sans-serif;font-size:1.3rem;font-weight:600;color:#fff}
.team-avatar img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.team-body{padding:14px 16px}
.team-name{font-family:'Poppins',sans-serif;font-size:1.05rem;font-weight:600;color:var(--ink);margin-bottom:3px}
.team-role{font-size:.9rem;color:var(--blue);font-weight:500;letter-spacing:.02em;margin-bottom:10px}
.team-bio{font-size:.97rem;color:var(--ink-2);line-height:1.75;margin-bottom:14px}
.team-socials{display:flex;gap:7px}
.team-socials a{width:30px;height:30px;border-radius:7px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink-3);font-size:.72rem;transition:all .2s}
.team-socials a:hover{border-color:var(--blue);color:var(--blue)}

/* PROGRAMS */
#services{background:var(--paper-2)}
.services-top{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-bottom:32px}
.serv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:16px;overflow:hidden}
.srv-card{padding:22px 20px;background:var(--paper);transition:background .25s}
.srv-card:hover{background:var(--blue-light)}
[data-theme="dark"] .srv-card{background:var(--paper-2)}
[data-theme="dark"] .srv-card:hover{background:rgba(42,125,225,.1)}
.srv-icon{font-size:1.3rem;color:var(--blue);margin-bottom:14px}
.srv-title{font-family:'Poppins',sans-serif;font-size:1.1rem;font-weight:600;color:var(--ink);margin-bottom:10px}
.srv-desc{font-size:1rem;color:var(--ink-2);line-height:1.85}

/* PROJECTS */
#projects{background:var(--paper)}
.proj-header{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:16px;margin-bottom:32px}
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.proj-card{border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;background:var(--paper-2);transition:all .3s var(--spring)}
.proj-card:hover{transform:translateY(-4px);box-shadow:0 18px 50px var(--blue-glow);border-color:rgba(42,125,225,.3)}
.proj-card.feat{grid-row:span 1}
.proj-thumb{height:160px;overflow:hidden;border-bottom:1px solid var(--line);position:relative;background:var(--paper-3)}
.proj-thumb img{width:100%;height:100%;object-fit:cover;display:block}

.proj-card.feat .proj-thumb{height:240px}
.proj-body{padding:16px 18px;flex:1;display:flex;flex-direction:column}
.ptags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.ptag{font-size:.63rem;font-family:'Inconsolata',monospace;padding:3px 9px;border-radius:4px;background:var(--blue-light);color:var(--blue);border:1px solid rgba(42,125,225,.18);font-weight:500;letter-spacing:.04em}
.proj-name{font-family:'Poppins',sans-serif;font-size:1.15rem;font-weight:600;color:var(--ink);margin-bottom:8px}
.proj-desc{font-size:1rem;color:var(--ink-2);line-height:1.85;flex:1}
.proj-foot{padding:10px 18px;border-top:1px solid var(--line);display:flex;align-items:center;justify-content:flex-end}
.proj-link{font-size:.9rem;font-weight:700;color:var(--blue);display:inline-flex;align-items:center;gap:5px;transition:gap .2s}
.proj-link:hover{gap:9px}

/* LANEFORGE */
#landorge{background:var(--paper-2);position:relative;overflow:hidden;padding:52px 0}
#landorge::before{content:'';position:absolute;top:-30%;right:-10%;width:600px;height:600px;border-radius:50%;background:radial-gradient(ellipse,rgba(255,107,53,.07) 0%,transparent 65%);pointer-events:none}
.landorge-wrap{border:1px solid var(--line);border-radius:22px;overflow:visible;background:var(--paper);position:relative;z-index:1;width:100%}
.landorge-top{padding:24px 28px;background:linear-gradient(135deg,var(--paper-3) 0%,var(--paper) 100%);border-bottom:1px solid var(--line);border-radius:22px 22px 0 0;display:grid;grid-template-columns:1.2fr 1fr;gap:24px;align-items:flex-start;box-sizing:border-box}
.landorge-badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:100px;border:1px solid rgba(255,107,53,.3);background:var(--orange-light);font-family:'Inconsolata',monospace;font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--orange);margin-bottom:10px}
.ldot{width:6px;height:6px;border-radius:50%;background:var(--orange);animation:pulse-o 2s ease-in-out infinite}
@keyframes pulse-o{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}
.landorge-title{font-family:'Poppins',sans-serif;font-size:clamp(1.5rem,2.8vw,2.2rem);font-weight:700;letter-spacing:-.01em;color:var(--ink);line-height:1.05;margin-bottom:8px}
.landorge-title span{color:var(--orange)}
.landorge-desc{font-size:.88rem;color:var(--ink-2);line-height:1.65;max-width:440px;margin-bottom:12px}
.landorge-feats{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px;margin-bottom:4px}
.lf{display:flex;align-items:center;gap:5px;font-size:.82rem;color:var(--ink-2);font-weight:500}
.lf i{color:var(--orange);font-size:.8rem}
/* Waitlist form */
.wl-box{background:var(--paper-2);border:1px solid var(--line);border-radius:12px;padding:14px;width:100%;box-sizing:border-box}
.wl-title{font-family:'Poppins',sans-serif;font-size:.95rem;font-weight:600;color:var(--ink);margin-bottom:2px}
.wl-sub{font-size:.78rem;color:var(--ink-2);margin-bottom:10px}
.wf-f{display:flex;flex-direction:column;gap:2px;margin-bottom:6px}
.wf-f label{font-family:'Inconsolata',monospace;font-size:.6rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-3)}
.wf-f input,.wf-f select{background:var(--paper);border:1px solid var(--line);border-radius:7px;padding:7px 9px;font-size:.84rem;color:var(--ink);font-family:'Lato',sans-serif;outline:none;transition:border-color .2s,box-shadow .2s;-webkit-appearance:none}
.wf-f input:focus,.wf-f select:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,107,53,.1)}
.wf-f input::placeholder{color:var(--ink-3)}
.phone-row{display:flex;gap:8px}
.phone-cc{background:var(--paper);border:1px solid var(--line);border-radius:7px;padding:7px 24px 7px 9px;font-size:.8rem;color:var(--ink);font-family:'Lato',sans-serif;outline:none;min-width:108px;-webkit-appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%238BA5C2'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 9px center;transition:border-color .2s}
.phone-cc:focus{border-color:var(--orange)}
.phone-in{flex:1}
.btn-wl{width:100%;padding:9px 14px;border-radius:8px;background:var(--orange);color:#fff;border:none;cursor:pointer;font-family:'Lato',sans-serif;font-size:.88rem;font-weight:700;letter-spacing:.04em;display:flex;align-items:center;justify-content:center;gap:7px;transition:all .3s var(--spring);box-shadow:0 4px 16px rgba(255,107,53,.3);margin-top:3px}
.btn-wl:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(255,107,53,.5)}
.wl-note{font-size:.62rem;color:var(--ink-3);text-align:center;margin-top:5px}
.landorge-bottom{padding:10px 28px;background:var(--paper-3);display:flex;align-items:center;gap:10px;font-size:.82rem;color:var(--ink-2);border-radius:0 0 22px 22px;border-top:1px solid var(--line)}
.wl-avatars{display:flex}
.wla{width:28px;height:28px;border-radius:50%;border:2px solid var(--paper-3);display:flex;align-items:center;justify-content:center;font-size:.52rem;font-weight:700;color:#fff;font-family:'Poppins',sans-serif;margin-left:-7px}
.wla:first-child{margin-left:0;background:var(--blue)}
.wla:nth-child(2){background:#4a9f7e}
.wla:nth-child(3){background:#9B59B6}
.wla:nth-child(4){background:var(--orange)}

/* COMMUNITY CTA */
#community{background:var(--paper)}
.join-block{border-radius:18px;overflow:hidden;background:linear-gradient(140deg,var(--blue) 0%,#04193A 100%);padding:60px 44px;text-align:center;position:relative}
.join-block::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 50% at 50% -10%,rgba(255,255,255,.08) 0%,transparent 60%)}
.join-eyebrow{font-family:'Inconsolata',monospace;font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:16px;position:relative;z-index:1;display:block}
.join-h2{font-family:'Poppins',sans-serif;font-size:clamp(2.4rem,5vw,3.8rem);font-weight:700;letter-spacing:-.01em;color:#fff;margin-bottom:16px;position:relative;z-index:1;line-height:1.05}
.join-h2 em{font-style:italic;color:rgba(255,255,255,.6)}
.join-p{font-size:1.1rem;color:rgba(255,255,255,.75);line-height:1.9;max-width:460px;margin:0 auto 36px;position:relative;z-index:1}
.join-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}
.btn-white{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:10px;background:#fff;color:var(--blue);font-family:'Lato',sans-serif;font-size:1rem;font-weight:700;letter-spacing:.04em;transition:all .3s var(--spring);box-shadow:0 4px 20px rgba(0,0,0,.2)}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,.3)}
.btn-wa{display:inline-flex;align-items:center;gap:8px;padding:14px 26px;border-radius:10px;background:var(--wa);color:#fff;font-family:'Lato',sans-serif;font-size:1rem;font-weight:700;letter-spacing:.04em;transition:all .3s var(--spring);box-shadow:0 4px 18px rgba(37,211,102,.3)}
.btn-wa:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(37,211,102,.5)}

/* CONTACT */
#contact{background:var(--paper-2)}
.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:52px;align-items:start;margin-top:36px}
.ci h3{font-family:'Poppins',sans-serif;font-size:1.65rem;font-weight:600;color:var(--ink);margin-bottom:12px}
.ci p{font-size:1.05rem;color:var(--ink-2);line-height:1.95;margin-bottom:26px}
.c-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line);font-size:1rem;color:var(--ink-2)}
.c-item:last-of-type{border-bottom:none}
.c-item i{color:var(--blue);width:16px;text-align:center;flex-shrink:0}
.c-socials{display:flex;gap:8px;margin-top:22px}
.csb{width:38px;height:38px;border-radius:9px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink-3);font-size:.82rem;transition:all .25s}
.csb:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-light)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-full{grid-column:span 2}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:.75rem;font-weight:600;color:var(--ink-2);letter-spacing:.07em;text-transform:uppercase;font-family:'Inconsolata',monospace}
.field input,.field textarea,.field select{background:var(--paper);border:1px solid var(--line);border-radius:9px;padding:13px 15px;font-size:1rem;color:var(--ink);font-family:'Lato',sans-serif;outline:none;transition:border-color .2s,box-shadow .2s;-webkit-appearance:none}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(42,125,225,.1)}
.field textarea{resize:vertical;min-height:120px;line-height:1.65}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-3)}
.contact-phone-row{display:flex;gap:8px}
.cpfx{background:var(--paper);border:1px solid var(--line);border-radius:9px;padding:11px 28px 11px 13px;font-size:.85rem;color:var(--ink);font-family:'Lato',sans-serif;outline:none;min-width:115px;cursor:pointer;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%238BA5C2'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;transition:border-color .2s}
.cpfx:focus{border-color:var(--blue)}
.contact-phone-row .field input{flex:1}

/* FOOTER */
footer{background:#040a14;color:#fff;padding:48px 0 0}
[data-theme="light"] footer{background:var(--ink)}
.ft-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px}
.ft-logo{display:flex;align-items:center;gap:11px;margin-bottom:18px}
.ft-logo img{height:36px;width:36px;object-fit:contain}
.ft-logo-text{font-family:'Poppins',sans-serif;font-size:1rem;font-weight:800;letter-spacing:.12em;color:#fff;text-transform:uppercase}
.ft-about{font-size:1rem;color:rgba(255,255,255,.5);line-height:1.9;max-width:270px;margin-bottom:22px}
.ft-social{display:flex;gap:8px}
.ftsb{width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.32);font-size:.78rem;transition:all .2s}
.ftsb:hover{background:rgba(255,255,255,.13);color:#fff}
.ft-col h4{font-family:'Inconsolata',monospace;font-size:.7rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:16px}
.ft-col a{display:block;font-size:1rem;color:rgba(255,255,255,.48);padding:5px 0;transition:color .2s}
.ft-col a:hover{color:#fff}
.ft-bottom{margin-top:36px;padding:16px 0;border-top:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.ft-bottom p,.ft-bottom a{font-size:.72rem;color:rgba(255,255,255,.25);font-family:'Inconsolata',monospace;letter-spacing:.04em}
.ft-bottom a:hover{color:rgba(255,255,255,.65)}

/* WHATSAPP FLOAT */
.wa-float{position:fixed;bottom:26px;right:26px;z-index:800;display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.wa-bubble{background:var(--paper-2);color:var(--ink);border:1px solid var(--line);padding:12px 16px;border-radius:14px 14px 0 14px;font-size:.8rem;line-height:1.55;max-width:230px;text-align:right;box-shadow:0 4px 20px rgba(0,0,0,.3);opacity:0;transform:translateY(8px) scale(.95);pointer-events:none;transition:all .3s var(--spring)}
.wa-float:hover .wa-bubble{opacity:1;transform:none;pointer-events:auto}
.wa-btn{width:56px;height:56px;border-radius:50%;background:var(--wa);border:none;cursor:pointer;color:#fff;font-size:1.45rem;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 22px rgba(37,211,102,.5);transition:transform .3s var(--spring),box-shadow .3s;text-decoration:none}
.wa-btn:hover{transform:scale(1.08);box-shadow:0 8px 30px rgba(37,211,102,.65)}

/* SUCCESS MODAL */
.modal-overlay{position:fixed;inset:0;z-index:900;background:rgba(0,0,0,.7);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .3s}
.modal-overlay.open{opacity:1;pointer-events:auto}
.modal-box{background:var(--paper-2);border:1px solid var(--line);border-radius:20px;padding:40px 36px;max-width:420px;width:100%;text-align:center;transform:scale(.95) translateY(12px);transition:transform .35s var(--spring)}
.modal-overlay.open .modal-box{transform:none}
.modal-icon{font-size:2.8rem;color:var(--orange);margin-bottom:16px}
.modal-title{font-family:'Poppins',sans-serif;font-size:1.6rem;font-weight:600;color:var(--ink);margin-bottom:10px}
.modal-text{font-size:1rem;color:var(--ink-2);line-height:1.85;margin-bottom:24px}
.modal-close-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 26px;border-radius:10px;background:var(--blue);color:#fff;font-family:'Lato',sans-serif;font-size:1rem;font-weight:700;letter-spacing:.04em;border:none;cursor:pointer;transition:all .25s}
.modal-close-btn:hover{background:var(--blue-mid)}

/* BOOTCAMP TIMER MODAL */
.modal-overlay#bootcampModal .modal-box{max-width:480px}
#bootcamp-timer{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:22px}
#bootcamp-timer div{background:var(--paper-3);border-radius:10px;padding:14px;text-align:center}
#bootcamp-timer .label{font-size:.7rem;color:var(--ink-3);font-family:'Inconsolata',monospace;letter-spacing:.08em;text-transform:uppercase;margin-bottom:5px}
#bootcamp-timer .value{font-size:1.8rem;font-weight:700;color:var(--ink);font-family:'Poppins',sans-serif}

/* HACKATHON INFO MODAL */
.modal-overlay#hackathonModal .modal-box{max-width:460px}

/* RESPONSIVE */
@media(max-width:1100px){
  .hero-inner{grid-template-columns:1fr;gap:32px}
  .about-grid{grid-template-columns:1fr;gap:36px}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .services-top{grid-template-columns:1fr;gap:16px}
  .proj-grid{grid-template-columns:1fr 1fr}
  .proj-card.feat{grid-column:span 2;grid-row:span 1}
  .proj-card.feat .proj-thumb{height:200px}
  .contact-grid{grid-template-columns:1fr;gap:36px}
  .ft-grid{grid-template-columns:1fr 1fr;row-gap:28px}
  .landorge-top{grid-template-columns:1fr;gap:20px;padding:24px}
  .wl-box{width:100%}
}
@media(max-width:768px){
  section{padding:52px 0}
  .nav-links,.nav-cta{display:none}
  .hamburger{display:flex}
  #pill-en,#pill-fr{display:none!important}
  .hero-h1{font-size:clamp(2.4rem,9vw,3.4rem)}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .serv-grid{grid-template-columns:1fr 1fr}
  .proj-grid{grid-template-columns:1fr}
  .proj-card.feat{grid-column:span 1}
  .ft-grid{grid-template-columns:1fr}
  .contact-grid{margin-top:22px}
  .form-grid{grid-template-columns:1fr}
  .form-full{grid-column:span 1}
  .landorge-top{padding:18px}
  .landorge-bottom{padding:10px 18px;flex-wrap:wrap;border-radius:0 0 22px 22px}
}
@media(max-width:480px){
  .hero-actions{flex-direction:column;align-items:flex-start}
  .hero-panel-split{grid-template-columns:1fr}
  .serv-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .ft-bottom{flex-direction:column;text-align:center}
  .wa-float{bottom:16px;right:16px}
}

/* ═══════════════════════════════════════════
   MORE SQUAD SECTION
═══════════════════════════════════════════ */
#more-squad{background:var(--paper);padding:64px 0}
.squad-header{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:36px}
.squad-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.squad-card{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--paper-2);transition:all .3s var(--spring);display:flex;flex-direction:row;align-items:center;gap:0}
.squad-card:hover{transform:translateY(-4px);box-shadow:0 14px 40px var(--blue-glow);border-color:rgba(42,125,225,.35)}
.squad-photo{width:80px;height:80px;flex-shrink:0;overflow:hidden;background:var(--paper-3);display:flex;align-items:center;justify-content:center;margin:14px 0 14px 14px;border-radius:50%;border:2px solid var(--line)}
.squad-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;border-radius:50%}
.squad-initials{width:100%;height:100%;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Poppins',sans-serif;font-size:1.3rem;font-weight:700;color:#fff}
.squad-body{padding:14px 14px 14px 12px;flex:1;min-width:0}
.squad-name{font-family:'Poppins',sans-serif;font-size:.92rem;font-weight:600;color:var(--ink);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.squad-role{font-size:.78rem;color:var(--blue);font-weight:500;letter-spacing:.02em;margin-bottom:8px}
.squad-links{display:flex;gap:6px}
.squad-links a{width:26px;height:26px;border-radius:7px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink-3);font-size:.66rem;transition:all .2s;text-decoration:none}
.squad-links a:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-light)}
.team-see-more{display:flex;justify-content:center;align-items:center;margin-top:48px;padding:32px 0 0}
.team-see-more-btn{display:inline-flex;align-items:center;gap:10px;padding:16px 32px;border-radius:12px;border:2px solid var(--blue);background:var(--blue-light);color:var(--blue);font-family:'Lato',sans-serif;font-size:1rem;font-weight:700;letter-spacing:.05em;text-decoration:none;transition:all .3s var(--spring);cursor:pointer}
.team-see-more-btn:hover{transform:translateY(-3px);background:var(--blue);color:#fff;box-shadow:0 8px 32px var(--blue-glow)}
.team-see-more-btn i{font-size:1.2rem;transition:transform .3s var(--spring)}
.team-see-more-btn:hover i{transform:translateX(4px)}
@media(max-width:1100px){.squad-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:768px){.squad-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.squad-grid{grid-template-columns:1fr}}

/* ═══════════════════════════════════════════
   COOKIE CONSENT BANNER
═══════════════════════════════════════════ */
#cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:var(--paper-2);border-top:1px solid var(--line);backdrop-filter:blur(16px);padding:18px clamp(20px,5vw,56px);display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;box-shadow:0 -8px 40px rgba(0,0,0,.45);transform:translateY(110%);transition:transform .5s cubic-bezier(.34,1.56,.64,1)}
#cookie-banner.show{transform:translateY(0)}
.ck-text{flex:1;min-width:240px}
.ck-text p{font-size:.88rem;color:var(--ink-2);margin:0;line-height:1.6}
.ck-text p a{color:var(--blue)}
.ck-text strong{color:var(--ink)}
.ck-actions{display:flex;gap:9px;flex-shrink:0;flex-wrap:wrap}
.ck-accept{padding:10px 22px;border-radius:9px;background:var(--blue);color:#fff;border:none;cursor:pointer;font-family:'Lato',sans-serif;font-size:.88rem;font-weight:700;letter-spacing:.04em;transition:all .25s;box-shadow:0 4px 16px rgba(42,125,225,.35)}
.ck-accept:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(42,125,225,.5)}
.ck-decline{padding:10px 18px;border-radius:9px;border:1px solid var(--line);background:transparent;color:var(--ink-2);cursor:pointer;font-family:'Lato',sans-serif;font-size:.88rem;font-weight:700;transition:all .22s}
.ck-decline:hover{border-color:var(--ink-3);color:var(--ink)}

/* ═══════════════════════════════════════════
   SQUAD MOMENTS
═══════════════════════════════════════════ */
#moments{background:var(--paper-2);padding:72px 0;overflow:hidden}
.moments-header{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:44px}
.moments-eyebrow{font-family:'Inconsolata',monospace;font-size:.72rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--blue);display:inline-flex;align-items:center;gap:8px}
.moments-eyebrow::before{content:'';width:16px;height:1px;background:var(--blue);flex-shrink:0}

/* MASONRY GRID */
.moments-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.moment-item{position:relative;overflow:hidden;border-radius:12px;background:var(--paper-3);border:1px solid var(--line);aspect-ratio:4/3}
.moment-item img{width:100%;height:100%;object-fit:cover;display:block}

/* HOVER OVERLAY - removed for always visible */
.moment-overlay{display:none}

/* ANIMATED ENTRY */
.moment-item{opacity:0;transform:translateY(24px);transition:opacity .55s ease,transform .55s ease,box-shadow .3s,border-color .3s}
.moment-item.vis{opacity:1;transform:translateY(0)}
.moment-item:hover{box-shadow:0 12px 32px rgba(0,0,0,.3);border-color:rgba(42,125,225,.3)}

@media(max-width:900px){
  .moments-grid{grid-template-columns:repeat(2,1fr);gap:10px}
}
@media(max-width:480px){
  .moments-grid{grid-template-columns:1fr;gap:8px}
  .moment-item{aspect-ratio:1}
}