body.elementor-page-21070201 header.page-header{display:none;}#content, #wrapper, #wrapper .container{min-width:100%;margin:0 !important;padding:0 !important;background:inherit !important;color:inherit !important;font:inherit !important;box-shadow:none !important;}@media(min-width:768px){.elementor-21070201 .elementor-element.elementor-element-0c818ed{width:100%;}}/* Start custom CSS for html, class: .elementor-element-3408c6d */*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --white:#FFFFFF;
  --bg:#FAFAF8;
  --cream:#F2EFE8;
  --cream2:#E8E4DC;
  --text:#0D0F14;
  --text-mid:#484C57;
  --text-muted:#8C90A0;
  --brick:#CC1A0A;
  --brick-d:#A2150A;
  --border:rgba(0,0,0,0.08);
  --sh:0 6px 32px rgba(0,0,0,0.09);
  --sh-lg:0 20px 64px rgba(0,0,0,0.13);
  --r:14px;
  --rl:22px;
}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--white);color:var(--text);overflow-x:hidden}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--brick);border-radius:2px}


/* ── SCROLL REVEAL ── */
.rv{opacity:0;transform:translateY(30px);transition:opacity .65s ease,transform .65s ease}
.rv.on{opacity:1;transform:translateY(0)}
.rl{opacity:0;transform:translateX(-30px);transition:opacity .7s ease,transform .7s ease}
.rl.on{opacity:1;transform:translateX(0)}
.rr{opacity:0;transform:translateX(30px);transition:opacity .7s ease,transform .7s ease}
.rr.on{opacity:1;transform:translateX(0)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

/* ── TYPE ── */
h1,h2,h3,h4{font-family:'Outfit',sans-serif;font-weight:800;line-height:1.08}
.tH{font-size:clamp(3rem,8vw,7.2rem);font-weight:900;letter-spacing:-.04em;line-height:1.0}
.tS{font-size:clamp(2rem,4.5vw,3.8rem);font-weight:800;letter-spacing:-.03em}
.tC{font-size:clamp(1.4rem,2.5vw,1.9rem);font-weight:700;letter-spacing:-.02em}
.ey{font-family:'Outfit',sans-serif;font-size:.68rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--brick)}
.lead{font-size:clamp(.92rem,1.5vw,1.1rem);color:var(--text-mid);line-height:1.82}

/* ── LAYOUT ── */
.w{max-width:1200px;margin:0 auto;padding:0 2rem}
.wW{max-width:1440px;margin:0 auto;padding:0 2.5rem}
.sec{padding:8rem 0;position:relative;overflow:hidden}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.88rem 1.9rem;border-radius:9px;font-family:'Outfit',sans-serif;font-weight:700;font-size:.9rem;text-decoration:none;transition:all .22s;cursor:pointer;border:none}
.bP{background:var(--brick);color:#fff;box-shadow:0 4px 18px rgba(204,26,10,.28)}
.bP:hover{background:var(--brick-d);transform:translateY(-2px);box-shadow:0 8px 26px rgba(204,26,10,.42)}
.bD{background:var(--text);color:#fff}
.bD:hover{background:#1e2230;transform:translateY(-2px)}
.bO{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.25)}
.bO:hover{border-color:rgba(255,255,255,.6);transform:translateY(-2px)}
.bLg{padding:1.05rem 2.4rem;font-size:.98rem}

/* ── STUD ROW ── */
.sRow{display:flex;gap:7px;margin-bottom:1.1rem}
.sRow.c{justify-content:center}
.sd{width:16px;height:16px;background:var(--brick);border-radius:50%;position:relative;opacity:.65}
.sd::after{content:'';position:absolute;inset:4px;background:rgba(0,0,0,.2);border-radius:50%}

/* ── HERO ── */
.hero{min-height:100vh;display:flex;align-items:center;padding:8rem 0 4rem;background:var(--white);position:relative;overflow:hidden;isolation:isolate}
.hDots{position:absolute;inset:0;background-image:radial-gradient(circle at 2px 2px,rgba(0,0,0,.055) 2px,transparent 0);background-size:44px 44px}
.hGrid{position:relative;z-index:3;display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;width:100%}
.hEy{display:inline-flex;align-items:center;gap:.7rem;margin-bottom:1.2rem;opacity:0;animation:fU .7s ease .1s forwards}
.hEy-line{width:20px;height:2px;background:var(--brick)}
.hH1{opacity:0;animation:fU .75s ease .25s forwards;margin-bottom:1.2rem}
.hH1 .ac{color:var(--brick);display:block}
.hH1 .ol{-webkit-text-stroke:2.5px rgba(13,15,20,.18);color:transparent;display:block}
.hLd{opacity:0;animation:fU .75s ease .4s forwards;margin-bottom:2rem}
.hCta{display:flex;gap:.9rem;flex-wrap:wrap;opacity:0;animation:fU .75s ease .55s forwards}
.hR{position:relative;height:640px;opacity:0;animation:fRi .85s ease .35s forwards}
.hC{position:absolute}
.hC img{width:100%;height:100%;object-fit:contain;display:block;filter:drop-shadow(0 28px 44px rgba(0,0,0,.13))}
.hC.m{width:100%;height:100%;top:0;right:0;animation:hFl 6s ease-in-out infinite}
.hBadge{position:absolute;top:-4px;left:-12px;background:var(--brick);color:#fff;border-radius:10px;padding:.55rem .95rem;font-family:'Outfit',sans-serif;font-weight:800;font-size:.76rem;box-shadow:0 6px 22px rgba(204,26,10,.4);animation:bPulse 2.5s ease-in-out infinite;z-index:5}
@keyframes hFl{0%,100%{transform:translateY(0)}50%{transform:translateY(-13px)}}
@keyframes bPulse{0%,100%{box-shadow:0 6px 22px rgba(204,26,10,.4)}50%{box-shadow:0 6px 32px rgba(204,26,10,.65)}}
@keyframes fU{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fRi{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}
.scrollHint{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.45rem;color:var(--text-muted);font-size:.66rem;letter-spacing:.15em;text-transform:uppercase;z-index:3;opacity:0;animation:fU 1s ease 1.3s forwards}
.sMouse{width:20px;height:34px;border:2px solid rgba(0,0,0,.16);border-radius:10px;display:flex;justify-content:center;padding-top:5px}
.sDot{width:3px;height:6px;background:var(--brick);border-radius:2px;animation:sd 1.6s ease-in-out infinite}
@keyframes sd{0%,100%{transform:translateY(0);opacity:1}50%{transform:translateY(5px);opacity:.3}}

/* ── MARQUEE ── */
.mBar{padding:1.25rem 0;background:var(--cream);border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden}
.mTrk{display:flex;gap:3rem;white-space:nowrap;animation:mq 26s linear infinite}
.mi{flex-shrink:0;font-family:'Outfit',sans-serif;font-weight:700;font-size:.76rem;color:var(--text-muted);letter-spacing:.14em;text-transform:uppercase;display:flex;align-items:center;gap:.85rem}
.miDot{width:5px;height:5px;background:var(--brick);border-radius:50%;flex-shrink:0}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── PRODUCT CARDS ── */
.prG{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:3.5rem;margin-bottom:2.5rem}
.prC{background:var(--white);border-radius:var(--rl);overflow:hidden;border:1px solid var(--border);transition:transform .3s,box-shadow .3s;box-shadow:var(--sh)}
.prC:hover{transform:translateY(-5px);box-shadow:var(--sh-lg)}
.prImg{background:var(--cream);padding:8% 10%;display:flex;align-items:center;justify-content:center;min-height:300px;overflow:hidden}
.prImg img{max-width:100%;max-height:280px;object-fit:contain;display:block;filter:drop-shadow(0 16px 36px rgba(0,0,0,.16));transition:transform .45s}
.prC:hover .prImg img{transform:scale(1.06)}
.prFt{padding:2rem 2.2rem 2.4rem;border-top:3px solid var(--brick)}
.prFt h3{font-family:'Outfit',sans-serif;font-size:1.55rem;font-weight:800;letter-spacing:-.02em;margin:.55rem 0 .65rem}
.prFt p{font-size:.9rem;color:var(--text-mid);line-height:1.72;margin-bottom:1.1rem}
.prTag{display:inline-block;padding:.3rem .78rem;background:rgba(204,26,10,.08);border-radius:20px;font-size:.7rem;font-weight:700;color:var(--brick);font-family:'Outfit',sans-serif;letter-spacing:.08em;text-transform:uppercase}
.prUl{list-style:none;display:flex;flex-direction:column;gap:.38rem}
.prUl li{font-size:.82rem;color:var(--text-muted);padding-left:1.1rem;position:relative}
.prUl li::before{content:'✦';position:absolute;left:0;color:var(--brick);font-size:.6rem;top:2px}

/* ── PHOTO SPLIT ── */
.pSplit{display:grid;grid-template-columns:1fr 1fr;border-radius:var(--rl);overflow:hidden;margin-top:2.5rem;border:1px solid var(--border)}
.pPh{position:relative;aspect-ratio:16/10;overflow:hidden}
.pPh img{width:100%;height:100%;object-fit:cover;transition:transform .55s}
.pPh:hover img{transform:scale(1.04)}
.pLbl{position:absolute;bottom:.9rem;left:.9rem;background:rgba(0,0,0,.52);backdrop-filter:blur(8px);padding:.38rem .75rem;border-radius:5px;font-family:'Outfit',sans-serif;font-weight:700;font-size:.74rem;color:#fff}

/* ── SHOWCASE ── */
.shG{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.siW{position:relative;padding-right:2.5rem;padding-bottom:2.5rem}
.siM img{width:100%;display:block;filter:drop-shadow(0 22px 48px rgba(0,0,0,.14))}
.siF{position:absolute;bottom:0;right:0;width:46%}
.siF img{width:100%;display:block;filter:drop-shadow(0 14px 30px rgba(0,0,0,.15))}
.fList{margin-top:1.8rem;display:flex;flex-direction:column;gap:.8rem}
.fi{display:flex;align-items:flex-start;gap:.85rem;padding:.82rem 1rem;background:var(--cream);border:1px solid var(--border);border-radius:var(--r);transition:background .2s,border-color .2s}
.fi:hover{background:var(--cream2)}
.fiDot{width:7px;height:7px;background:var(--brick);border-radius:50%;margin-top:7px;flex-shrink:0}
.fi h4{font-size:.88rem;font-weight:600;margin-bottom:.18rem}
.fi p{font-size:.78rem;color:var(--text-muted)}

/* ── PROCESS ── */
.psG{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:4rem;position:relative}
.psG::after{content:'';position:absolute;top:52px;left:calc(16.66%+1.5rem);right:calc(16.66%+1.5rem);height:1px;background:linear-gradient(90deg,transparent,var(--brick) 30%,var(--brick) 70%,transparent)}
.ps{position:relative;z-index:1}
.psN{width:44px;height:44px;background:var(--brick);border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:'Outfit',sans-serif;font-weight:900;font-size:.96rem;color:#fff;margin-bottom:1.3rem;position:relative}
.psN::after{content:'';position:absolute;inset:-4px;border-radius:13px;border:1.5px solid rgba(204,26,10,.22)}
.psImg{position:relative;aspect-ratio:4/3;margin-bottom:1.2rem}
.psImg img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 8px 22px rgba(0,0,0,.13));display:block}
.ps h3{font-size:1.12rem;margin-bottom:.42rem}
.ps p{font-size:.86rem;color:var(--text-mid);line-height:1.65}
.craft{aspect-ratio:4/3;margin-bottom:1.2rem;background:var(--cream);border:1px solid var(--border);border-radius:var(--r);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.1rem;position:relative;overflow:hidden}
.craft::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 2px 2px,rgba(204,26,10,.14) 2px,transparent 0);background-size:20px 20px}
.cBricks{position:relative;z-index:1;display:flex;flex-direction:column;gap:5px;align-items:flex-start}
.cRow{display:flex;gap:5px}
.cb{width:16px;height:13px;border-radius:3px;position:relative}
.cb::before{content:'';position:absolute;top:-6px;left:50%;transform:translateX(-50%);width:10px;height:6px;border-radius:50% 50% 20% 20%/60% 60% 40% 40%;filter:brightness(1.18)}
.cbA{background:#CC1A0A}.cbA::before{background:#CC1A0A}
.cbB{background:#F5C132}.cbB::before{background:#F5C132}
.cbC{background:#1D70C9}.cbC::before{background:#1D70C9}
.cbD{background:#2FA52D}.cbD::before{background:#2FA52D}
.cbO{background:#DDD8CE}.cbO::before{background:#DDD8CE}
.cLbl{position:relative;z-index:1;font-family:'Outfit',sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--brick)}

/* ── COMPARISON ── */
.cmpW{margin-top:5rem;border-radius:var(--rl);overflow:hidden;background:var(--cream);border:1px solid var(--border)}
.cmp{position:relative;user-select:none;cursor:ew-resize}
.cmpBef img{display:block;width:100%;max-height:500px;object-fit:contain;background:var(--cream)}
.cmpAft{position:absolute;inset:0;clip-path:inset(0 50% 0 0)}
.cmpAft img{display:block;width:100%;max-height:500px;object-fit:contain;background:#E8E4DC}
.cmpLine{position:absolute;top:0;bottom:0;left:50%;width:3px;background:var(--text);transform:translateX(-50%);z-index:10}
.cmpHand{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:42px;height:42px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,0,0,.22);font-size:.92rem;color:var(--text)}
.cmpLbl{position:absolute;bottom:1rem;padding:.38rem .82rem;border-radius:5px;font-family:'Outfit',sans-serif;font-weight:700;font-size:.76rem}
.cmpLbl.a{left:1rem;background:rgba(0,0,0,.5);color:#fff;backdrop-filter:blur(8px)}
.cmpLbl.b{right:1rem;background:rgba(204,26,10,.1);border:1px solid rgba(204,26,10,.28);color:var(--brick)}
.cmpHint{text-align:center;padding:.85rem;background:var(--cream);font-size:.76rem;color:var(--text-muted);font-family:'Outfit',sans-serif;border-top:1px solid var(--border)}

/* ── GALLERY ── */
.galG{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:2.5rem}
.gI{border-radius:var(--r);overflow:hidden;background:var(--cream);border:1px solid var(--border);position:relative;cursor:pointer;aspect-ratio:1}
.gI.sp{grid-column:span 2;grid-row:span 2;aspect-ratio:auto}
.gI img{width:100%;height:100%;object-fit:contain;transition:transform .45s;padding:6%}
.gI:hover img{transform:scale(1.06)}
.gIO{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.76) 100%);opacity:0;transition:opacity .3s;display:flex;align-items:flex-end;padding:1.1rem}
.gI:hover .gIO{opacity:1}
.gIL{font-family:'Outfit',sans-serif;font-weight:700;font-size:.78rem;color:#fff}


/* ── STATS ── */
.statS{background:var(--brick);padding:5rem 0}
.statG{display:grid;grid-template-columns:repeat(4,1fr)}
.statI{padding:2rem;border-right:1px solid rgba(255,255,255,.18);text-align:center}
.statI:last-child{border-right:none}
.statN{font-family:'Outfit',sans-serif;font-weight:900;font-size:clamp(2.2rem,4vw,3.5rem);color:#fff;line-height:1;margin-bottom:.3rem}
.statL{font-size:.83rem;color:rgba(255,255,255,.7);font-weight:500}

/* ── CLIENTS ── */
.cliBar{margin-top:2.5rem;background:var(--cream);border-radius:var(--rl);padding:2.5rem 3rem;border:1px solid var(--border)}
.cliBar img{max-width:100%;display:block;filter:grayscale(1) brightness(.58);transition:filter .3s}
.cliBar:hover img{filter:grayscale(.4) brightness(.8)}

/* ── PHOTO ROW ── */
.phRow{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.phI{border-radius:var(--r);overflow:hidden;aspect-ratio:3/2;position:relative}
.phI img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.phI:hover img{transform:scale(1.04)}
.phL{position:absolute;bottom:.85rem;left:.85rem;background:rgba(0,0,0,.5);backdrop-filter:blur(8px);padding:.33rem .72rem;border-radius:5px;font-family:'Outfit',sans-serif;font-weight:700;font-size:.72rem;color:#fff}

/* ── CTA (dark) ── */
.ctaS{background:var(--text);padding:9rem 0;position:relative;overflow:hidden}
.ctaGlow{position:absolute;inset:0;background:radial-gradient(ellipse 70% 60% at 50% 110%,rgba(204,26,10,.2) 0%,transparent 55%)}
.ctaDots{position:absolute;inset:0;background-image:radial-gradient(circle at 2px 2px,rgba(255,255,255,.045) 2px,transparent 0);background-size:44px 44px}
.ctaIn{position:relative;z-index:2;text-align:center;max-width:660px;margin:0 auto}
.ctaIn .ey{color:var(--brick);display:flex;justify-content:center;margin-bottom:.9rem}
.ctaIn h2{color:#fff;margin-bottom:1.2rem}
.ctaIn p{color:rgba(255,255,255,.58);font-size:1.02rem;margin-bottom:2.8rem;line-height:1.75}
.ctaBtns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.ctaMeta{margin-top:2.5rem;display:flex;justify-content:center;gap:2rem;flex-wrap:wrap}
.ctaMI{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:rgba(255,255,255,.42)}
.ctaMI svg{color:var(--brick)}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .hGrid,.shG{grid-template-columns:1fr}
  .hR{display:none}
  .prG{grid-template-columns:1fr}
  .psG{grid-template-columns:1fr}
  .psG::after{display:none}
  .statG{grid-template-columns:repeat(2,1fr)}
  .galG{grid-template-columns:repeat(3,1fr)}
  .pSplit{grid-template-columns:1fr}
  .phRow{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .sec{padding:5rem 0}
  .statG{grid-template-columns:1fr}
  .statI{border-right:none;border-bottom:1px solid rgba(255,255,255,.18)}
  .statI:last-child{border-bottom:none}
  .galG{grid-template-columns:repeat(2,1fr)}
  .phRow{grid-template-columns:1fr}
}/* End custom CSS */