:root {
  --blk: #080808; --wht: #f2ede6;
  --pk:  #C17DFF; --bl:  #3d8eff;
  --yl:  #ffe033; --gn:  #00e5a0;
  --or:  #ff8c42; --pu:  #c17dff;
  --m1:  #141414; --m2:  #1c1c1c;
  --mu:  #777;    --bd:  rgba(242,237,230,.09);
  --fd: 'Syne', sans-serif;
  --fb: 'DM Sans', sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--blk);color:var(--wht);font-family:var(--fb);font-size:16px;line-height:1.6;overflow-x:hidden;cursor:none}

/* CURSOR */
.cr,.crr{position:fixed;pointer-events:none;border-radius:50%;transform:translate(-50%,-50%);z-index:9999}
.cr{width:10px;height:10px;background:var(--yl);transition:width .2s,height .2s}
.crr{width:38px;height:38px;border:1px solid rgba(255,224,51,.4);transition:left .12s ease,top .12s ease}
.cr.big{width:18px;height:18px}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:900;display:flex;justify-content:space-between;align-items:center;padding:1.5rem 3rem;background:rgba(8,8,8,.9);backdrop-filter:blur(22px);border-bottom:1px solid var(--bd);transition:padding .3s}
nav.stuck{padding:1rem 3rem}
.logo{display:inline-flex;align-items:center;text-decoration:none}
.logo img{height:38px;width:auto;display:block;transition:opacity .2s,height .3s}
.logo:hover img{opacity:.75}
nav.stuck .logo img{height:30px}
.nl{display:flex;gap:2.5rem;list-style:none}
.nl a{color:var(--mu);text-decoration:none;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;font-weight:500;transition:color .2s}
.nl a:hover{color:var(--wht)}
.ncta{background:var(--yl)!important;color:var(--blk)!important;padding:.55rem 1.3rem;border-radius:2px;font-weight:700!important;transition:background .2s,transform .2s!important}
.ncta:hover{background:var(--wht)!important;transform:translateY(-1px)}
.bur{display:none;flex-direction:column;gap:5px;cursor:pointer}
.bur span{width:24px;height:2px;background:var(--wht);display:block}

/* MOBILE MENU */
.mob{display:none;position:fixed;inset:0;z-index:899;background:var(--blk);padding:6rem 2.5rem;flex-direction:column;gap:1.5rem;justify-content:center}
.mob.open{display:flex}
.mob a{font-family:var(--fd);font-size:2.4rem;font-weight:800;color:var(--wht);text-decoration:none;opacity:.45;transition:opacity .2s,color .2s}
.mob a:hover{opacity:1;color:var(--yl)}

/* HERO */
#hero{min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;padding:0 3rem 5.5rem;position:relative;overflow:hidden}
.hbg{position:absolute;inset:0}
.hbg img{width:100%;height:100%;object-fit:cover;filter:brightness(.3) saturate(1.3)}
.hbg::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,var(--blk) 16%,transparent 65%)}
.hnoise{position:absolute;inset:0;z-index:1;opacity:.03;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 300 300' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:180px}
.hstr{position:absolute;top:0;right:0;bottom:0;width:5px;background:linear-gradient(to bottom,var(--yl),var(--pk),var(--bl),var(--gn));z-index:2}
.hchip{position:relative;z-index:3;display:inline-flex;align-items:center;gap:.6rem;background:rgba(255,224,51,.1);border:1px solid rgba(255,224,51,.32);color:var(--yl);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;padding:.4rem 1rem;border-radius:2px;width:fit-content;margin-bottom:1.8rem;animation:fup .8s .1s both}
.hchip::before{content:'';width:6px;height:6px;background:var(--yl);border-radius:50%;animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}
@keyframes fup{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}
h1.ht{font-family:var(--fd);font-weight:800;line-height:.9;font-size:clamp(3.2rem,9.5vw,10rem);letter-spacing:-.035em;position:relative;z-index:3;animation:fup .8s .3s both}
h1.ht .ol{color:transparent;-webkit-text-stroke:1px rgba(242,237,230,.22)}
h1.ht .yl{color:var(--yl)}
.hbot{display:flex;justify-content:space-between;align-items:flex-end;margin-top:3rem;position:relative;z-index:3;animation:fup .8s .5s both}
.hdesc{max-width:400px;color:rgba(242,237,230,.58);font-size:1.05rem;line-height:1.75}
.hdesc strong{color:var(--wht);font-weight:500}
.hbtns{display:flex;flex-direction:column;align-items:flex-end;gap:.9rem}
.hscrl{position:absolute;bottom:3rem;left:50%;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:.4rem;color:var(--mu);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase}
.hscrl-l{width:1px;height:55px;background:linear-gradient(to bottom,var(--yl),transparent);animation:scrl 2.2s ease-in-out infinite}
@keyframes scrl{0%{transform:scaleY(0);transform-origin:top}49%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* BUTTONS */
.by{display:inline-flex;align-items:center;gap:.7rem;background:var(--yl);color:var(--blk);font-family:var(--fd);font-weight:700;font-size:.9rem;letter-spacing:.05em;padding:.95rem 1.9rem;border-radius:2px;text-decoration:none;transition:background .2s,transform .2s}
.by:hover{background:var(--wht);transform:translateY(-2px)}
.by svg{transition:transform .2s}
.by:hover svg{transform:translate(3px,-3px)}
.bo{display:inline-flex;align-items:center;gap:.6rem;border:1px solid var(--bd);color:var(--wht);font-size:.85rem;letter-spacing:.04em;padding:.75rem 1.5rem;border-radius:2px;text-decoration:none;transition:border-color .2s,background .2s}
.bo:hover{border-color:rgba(242,237,230,.35);background:rgba(242,237,230,.04)}

/* MARQUEE */
.mqw{border-top:1px solid var(--bd);border-bottom:1px solid var(--bd);background:var(--m1);overflow:hidden;padding:1.1rem 0}
.mqt{display:flex;animation:mqa 30s linear infinite;white-space:nowrap}
.mqi{display:inline-flex;align-items:center;gap:1.4rem;padding:0 2.5rem;font-family:var(--fd);font-size:.68rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--mu)}
.dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}
.dy{background:var(--yl)}.dp{background:var(--pk)}.db{background:var(--bl)}.dg{background:var(--gn)}
@keyframes mqa{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* SECTIONS */
section{padding:8rem 3rem}
.sl{display:inline-flex;align-items:center;gap:.9rem;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;font-weight:700;margin-bottom:1.8rem}
.sl::before{content:'';width:28px;height:2px}
.sl.y{color:var(--yl)}.sl.y::before{background:var(--yl)}
.sl.p{color:var(--pk)}.sl.p::before{background:var(--pk)}
.sl.b{color:var(--bl)}.sl.b::before{background:var(--bl)}
.sl.g{color:var(--gn)}.sl.g::before{background:var(--gn)}
.st{font-family:var(--fd);font-weight:800;font-size:clamp(2rem,4.5vw,4.2rem);line-height:1;letter-spacing:-.025em}

/* BRAND INTRO */
#intro{background:var(--m2)}
.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;max-width:1200px;margin:0 auto}
.itxt{color:rgba(242,237,230,.62);font-size:1.05rem;line-height:1.85;margin-bottom:1.4rem}
.itxt:last-child{margin-bottom:0}

/* SERVICES */
#services{background:var(--blk)}
.svh{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:4.5rem;gap:2rem;flex-wrap:wrap}
.svi{max-width:400px;color:rgba(242,237,230,.5);line-height:1.8;margin-top:1rem;font-size:.95rem}
.svg{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--bd);border:1px solid var(--bd)}
.svc{background:var(--blk);padding:2.8rem 2.2rem;position:relative;overflow:hidden;transition:background .3s}
.svc::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;transform:scaleX(0);transform-origin:left;transition:transform .4s}
.svc.cy::after{background:var(--yl)}.svc.cp::after{background:var(--pk)}.svc.cb::after{background:var(--bl)}
.svc.cg::after{background:var(--gn)}.svc.co::after{background:var(--or)}.svc.cm::after{background:var(--pu)}
.svc:hover{background:var(--m1)}.svc:hover::after{transform:scaleX(1)}
.snum{font-family:var(--fd);font-size:.63rem;color:var(--mu);letter-spacing:.2em;margin-bottom:1.8rem}
.sico{width:44px;height:44px;margin-bottom:1.4rem}
.snam{font-family:var(--fd);font-size:1.22rem;font-weight:700;margin-bottom:.85rem}
.sdsc{color:rgba(242,237,230,.5);font-size:.87rem;line-height:1.75}
.stags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1.3rem}
.stag{font-size:.63rem;letter-spacing:.1em;text-transform:uppercase;color:var(--mu);padding:.22rem .6rem;border:1px solid var(--bd);border-radius:1px}

/* GALLERY */
#realisations{background:var(--m1);padding-bottom:0}
.galh{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:2rem;gap:1.5rem;flex-wrap:wrap}
.gal-filters{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:3rem}
.gal-btn{background:none;border:1px solid var(--bd);color:var(--mu);font-family:var(--fb);font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:.5rem 1.2rem;border-radius:2px;cursor:pointer;transition:border-color .2s,color .2s,background .2s}
.gal-btn:hover{border-color:rgba(242,237,230,.28);color:var(--wht)}
.gal-btn.active{background:var(--yl);border-color:var(--yl);color:var(--blk)}
.gal-btn--all{margin-left:.6rem;border-color:rgba(242,237,230,.18)}
.galg{display:flex;flex-wrap:wrap;gap:5px}
.gali{overflow:hidden;position:relative;background:#111;height:240px;cursor:zoom-in;flex-grow:1;min-width:200px}
.gali img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s cubic-bezier(.25,.46,.45,.94),filter .4s;filter:saturate(.85) brightness(1.05)}
.gali:hover img{transform:scale(1.07);filter:saturate(1.1) brightness(1.05)}
.galo{position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,224,51,.5) 0%,transparent 60%);opacity:0;transition:opacity .35s}
.gali:hover .galo{opacity:1}
.gali.hidden{display:none}

/* LIGHTBOX */
.lbx{position:fixed;inset:0;z-index:9000;background:rgba(8,8,8,.96);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s}
.lbx.open{opacity:1;pointer-events:all}
.lbx img{max-width:92vw;max-height:88vh;object-fit:contain;border-radius:2px;box-shadow:0 0 60px rgba(0,0,0,.8);transition:transform .35s cubic-bezier(.25,.46,.45,.94)}
.lbx-close{position:fixed;top:1.4rem;right:1.8rem;background:none;border:none;color:var(--wht);font-size:2rem;cursor:pointer;line-height:1;opacity:.7;transition:opacity .2s;z-index:9001}
.lbx-close:hover{opacity:1}
.lbx-prev,.lbx-next{position:fixed;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.08);border:1px solid var(--bd);color:var(--wht);font-size:1.5rem;cursor:pointer;padding:.6rem .9rem;border-radius:2px;opacity:.7;transition:opacity .2s,background .2s;z-index:9001}
.lbx-prev:hover,.lbx-next:hover{opacity:1;background:rgba(255,255,255,.16)}
.lbx-prev{left:1.2rem}.lbx-next{right:1.2rem}
.lbx-counter{position:fixed;bottom:1.4rem;left:50%;transform:translateX(-50%);font-size:.75rem;letter-spacing:.1em;color:var(--mu);z-index:9001}

/* COLOR BAND */
.cband{height:6px;background:linear-gradient(90deg,var(--yl),var(--pk),var(--bl),var(--gn))}

/* STATS */
#stats{background:var(--m2);padding:6rem 3rem}
.stgr{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
.stbx{padding:2.5rem 2rem;border:1px solid var(--bd);position:relative;overflow:hidden}
.stbx::before{content:'';position:absolute;bottom:0;left:0;right:0;height:3px}
.stbx:nth-child(1)::before{background:var(--yl)}.stbx:nth-child(2)::before{background:var(--pk)}
.stbx:nth-child(3)::before{background:var(--bl)}.stbx:nth-child(4)::before{background:var(--gn)}
.stn{font-family:var(--fd);font-weight:800;line-height:1;letter-spacing:-.03em;font-size:clamp(2.5rem,5vw,4.2rem)}
.stbx:nth-child(1) .stn{color:var(--yl)}.stbx:nth-child(2) .stn{color:var(--pk)}
.stbx:nth-child(3) .stn{color:var(--bl)}.stbx:nth-child(4) .stn{color:var(--gn)}
.stl{color:rgba(242,237,230,.45);font-size:.8rem;margin-top:.55rem;text-transform:uppercase;letter-spacing:.08em}

/* ABOUT */
#about{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center;background:var(--blk)}
.aim{position:relative;aspect-ratio:4/5}
.aim img{width:100%;height:100%;object-fit:cover;display:block}
.aimf{position:absolute;bottom:-18px;right:-18px;width:180px;height:180px;border:2px solid var(--yl);z-index:-1}
.aimt{position:absolute;top:2rem;left:-1.2rem;background:var(--yl);color:var(--blk);font-family:var(--fd);font-weight:800;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;padding:.5rem 1.1rem}
.act .st{margin-bottom:1.4rem}
.atx{color:rgba(242,237,230,.58);line-height:1.85;margin-bottom:.9rem;font-size:.94rem}
.ali{list-style:none;margin:1.8rem 0;display:flex;flex-direction:column;gap:.7rem}
.ali li{display:flex;align-items:center;gap:.75rem;font-size:.9rem;color:rgba(242,237,230,.72)}
.ali li::before{content:'';width:18px;height:2px;background:var(--yl);flex-shrink:0}

/* PROCESS */
#process{background:var(--m2)}
.prh{text-align:center;max-width:540px;margin:0 auto 4rem}
.prh .sl{justify-content:center}
.prg{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--bd)}
.prs{padding:2.8rem 2rem;border-right:1px solid var(--bd)}
.prs:last-child{border-right:none}
.prn{font-family:var(--fd);font-size:3.5rem;font-weight:800;line-height:1;margin-bottom:1.4rem;color:transparent}
.prs:nth-child(1) .prn{-webkit-text-stroke:1px rgba(255,224,51,.3)}
.prs:nth-child(2) .prn{-webkit-text-stroke:1px rgba(255,45,107,.3)}
.prs:nth-child(3) .prn{-webkit-text-stroke:1px rgba(61,142,255,.3)}
.prs:nth-child(4) .prn{-webkit-text-stroke:1px rgba(0,229,160,.3)}
.prt{font-family:var(--fd);font-size:1.05rem;font-weight:700;margin-bottom:.7rem}
.prd{color:rgba(242,237,230,.5);font-size:.86rem;line-height:1.7}

/* TESTIMONIAL */
#testi{background:var(--m1);padding:7rem 3rem;text-align:center;border-top:1px solid var(--bd);border-bottom:1px solid var(--bd);position:relative;overflow:hidden}
.tbd{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--fd);font-size:28vw;font-weight:800;color:transparent;-webkit-text-stroke:1px rgba(255,224,51,.04);pointer-events:none;line-height:1;white-space:nowrap}
.tq{font-family:var(--fd);font-size:clamp(1.5rem,3vw,2.5rem);font-weight:700;line-height:1.3;letter-spacing:-.015em;max-width:860px;margin:0 auto 1.8rem;position:relative;z-index:1}
.tq em{font-style:normal;color:var(--yl)}
.ta{color:rgba(242,237,230,.45);font-size:.83rem;letter-spacing:.05em;position:relative;z-index:1}

/* CONTACT */
#contact{background:var(--blk);padding:10rem 3rem;text-align:center;position:relative;overflow:hidden}
.cgl{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:700px;height:700px;background:radial-gradient(circle,rgba(255,224,51,.08) 0%,transparent 70%);pointer-events:none}
.cti{font-family:var(--fd);font-weight:800;letter-spacing:-.03em;line-height:.9;position:relative;z-index:1;font-size:clamp(2.8rem,8vw,8.5rem);margin-bottom:1.8rem}
.cti .ol{color:transparent;-webkit-text-stroke:1px rgba(242,237,230,.18)}
.cti .yl{color:var(--yl)}
.csub{color:rgba(242,237,230,.42);font-size:1.05rem;margin-bottom:3rem;position:relative;z-index:1}
.cmail{font-family:var(--fd);font-weight:700;letter-spacing:-.01em;font-size:clamp(1rem,2.5vw,1.8rem);color:var(--yl);text-decoration:none;border-bottom:1px solid var(--yl);padding-bottom:.15rem;position:relative;z-index:1;transition:opacity .2s}
.cmail:hover{opacity:.65}
.ctel{color:rgba(242,237,230,.45);font-size:1rem;display:block;margin-top:1.2rem;position:relative;z-index:1;text-decoration:none;transition:color .2s}
.ctel:hover{color:var(--wht)}
.cadr{color:rgba(242,237,230,.3);font-size:.83rem;margin-top:.4rem;position:relative;z-index:1}

/* REFERENCES */
#references{background:var(--m2);text-align:center}
.refh{margin-bottom:3.5rem}
.refg{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:2rem 2.5rem}
.refi{position:relative;flex:0 0 calc(25% - 1.875rem);display:flex;justify-content:center;align-items:center}
.refi img{height:240px;width:auto;display:block;opacity:.35;transition:opacity .3s,filter .3s,drop-shadow .3s}
.refi:hover img{opacity:1;filter:brightness(0) invert(1) drop-shadow(0 0 18px var(--pk))}
.refi::after{content:attr(data-title);position:absolute;bottom:calc(100% + 10px);left:50%;transform:translateX(-50%) scale(.9);background:var(--pk);color:var(--blk);font-family:var(--fd);font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.35rem .8rem;border-radius:2px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s,transform .2s}
.refi::before{content:'';position:absolute;bottom:calc(100% + 4px);left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--pk);opacity:0;pointer-events:none;transition:opacity .2s}
.refi:hover::after{opacity:1;transform:translateX(-50%) scale(1)}
.refi:hover::before{opacity:1}

/* CONTACT MAP */
.cmap{width:100%;margin-top:3.5rem}
#map{width:100%;height:380px;border:none;border-radius:2px;filter:saturate(.7) contrast(1.1)}
.leaflet-control-attribution{background:rgba(8,8,8,.85)!important;color:var(--mu)!important;backdrop-filter:blur(6px)}
.leaflet-control-attribution a{color:rgba(242,237,230,.45)!important}
.fmap-links{display:flex;gap:.75rem;margin-top:1rem;flex-wrap:wrap}
.fmap-btn{display:inline-flex;align-items:center;gap:.5rem;border:1px solid var(--bd);color:var(--mu);font-size:.78rem;letter-spacing:.06em;padding:.5rem 1.1rem;border-radius:2px;text-decoration:none;transition:border-color .2s,color .2s}
.fmap-btn:hover{border-color:var(--yl);color:var(--yl)}

/* FOOTER */
footer{background:var(--m1);border-top:1px solid var(--bd);padding:4rem 3rem 2rem}
.ftp{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid var(--bd);margin-bottom:2rem}
.flo{margin-bottom:0}
.ftg{color:rgba(242,237,230,.35);font-size:.84rem;line-height:1.7;max-width:240px}
.fc h4{font-size:.63rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mu);margin-bottom:1.1rem;font-family:var(--fd)}
.fc ul{list-style:none}
.fc li{margin-bottom:.52rem}
.fc a{color:rgba(242,237,230,.52);text-decoration:none;font-size:.87rem;transition:color .2s}
.fc a:hover{color:var(--wht)}
.fsoc{display:flex;gap:1rem;margin-top:1.2rem}
.fsoc a{color:var(--mu);transition:color .2s}
.fsoc a:hover{color:var(--yl)}
.fbo{display:flex;justify-content:space-between;align-items:center;color:var(--mu);font-size:.76rem;flex-wrap:wrap;gap:1rem}
.fso{display:flex;gap:1.5rem}
.fso a{color:var(--mu);text-decoration:none;font-size:.73rem;letter-spacing:.06em;text-transform:uppercase;transition:color .2s}
.fso a:hover{color:var(--yl)}

/* REVEAL */
.rv{opacity:0;transform:translateY(34px);transition:opacity .7s,transform .7s}
.rv.in{opacity:1;transform:none}
.d1{transition-delay:.12s}.d2{transition-delay:.22s}

/* RESPONSIVE */
@media(max-width:1100px){
  .svg{grid-template-columns:repeat(2,1fr)}
  .refg{gap:3rem 4rem}
  .refi{flex:0 0 calc(33.333% - 2.67rem)}
  .stgr{grid-template-columns:repeat(2,1fr);gap:1px}
  .ftp{grid-template-columns:1fr 1fr}
  #about{grid-template-columns:1fr;gap:3rem;padding:5rem 3rem}
  .aim{max-width:480px}
  .prg{grid-template-columns:repeat(2,1fr)}
  .prs:nth-child(2){border-right:none}
  .prs:nth-child(1),.prs:nth-child(2){border-bottom:1px solid var(--bd)}
  .intro-grid{grid-template-columns:1fr;gap:2.5rem}
}
@media(max-width:768px){
  nav{padding:1.2rem 1.5rem}nav.stuck{padding:1rem 1.5rem}
  .nl{display:none}.bur{display:flex}
  #hero{padding:0 1.5rem 4.5rem}
  section{padding:5rem 1.5rem}
  .svg{grid-template-columns:1fr}
  .svh{flex-direction:column;align-items:flex-start}
  .gali{height:280px}
  .stgr{grid-template-columns:repeat(2,1fr);gap:1px}
  .ftp{grid-template-columns:1fr;gap:2rem}
  .fbo{flex-direction:column;align-items:flex-start}
  .prg{grid-template-columns:1fr}
  .prs{border-right:none!important;border-bottom:1px solid var(--bd)}
  .prs:last-child{border-bottom:none}
  .hbot{flex-direction:column;align-items:flex-start;gap:2rem}
  .hbtns{align-items:flex-start}
  #contact{padding:6rem 1.5rem}
  .galh{flex-direction:column;align-items:flex-start}
  .refg{gap:2.5rem 3rem}
  .refi{flex:0 0 calc(50% - 1.5rem)}
  .intro-grid{grid-template-columns:1fr;gap:2rem}
}
