/* IBWebdesign Theme — main.css (webdesign mode) v2.1 */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Plus Jakarta Sans',sans-serif;background:#f5f6f8;color:#1a1d23;line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
ul{list-style:none;}
::-webkit-scrollbar{width:4px;}
::-webkit-scrollbar-track{background:#f0f1f4;}
::-webkit-scrollbar-thumb{background:#3b82f6;border-radius:2px;}

:root{
  --blue:#3b82f6;--blue-dark:#2563eb;--blue-light:#60a5fa;
  --blue-xlight:#eff6ff;--blue-glow:rgba(59,130,246,.14);
  --dark:#0f1117;--dark2:#1a1d23;--mid:#6b7280;
  --light:#f5f6f8;--white:#fff;--border:#e5e7eb;
  --radius:14px;--radius-lg:22px;--nav-h:70px;--max:1160px;
  --ff:'Plus Jakarta Sans',sans-serif;--fd:'Syne',sans-serif;
  --shadow:0 4px 24px rgba(15,17,23,.07);
  --shadow-blue:0 8px 32px rgba(59,130,246,.28);
}

.container{max-width:var(--max);margin:0 auto;padding:0 28px;}
.pill{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);background:var(--blue-xlight);border:1px solid rgba(59,130,246,.2);padding:5px 14px;border-radius:100px;margin-bottom:18px;}
.pill::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--blue);}
.section-title{font-family:var(--fd);font-size:clamp(2rem,4.5vw,3.2rem);font-weight:700;line-height:1.15;color:var(--dark);margin-bottom:14px;}
.section-title .hl{color:var(--blue);}
.section-sub{font-size:1rem;color:var(--mid);max-width:540px;line-height:1.85;}
.btn-blue{display:inline-flex;align-items:center;gap:8px;background:var(--blue);color:#fff;font-weight:600;font-size:.9rem;padding:13px 24px;border-radius:10px;font-family:var(--ff);transition:background .2s,transform .15s,box-shadow .2s;}
.btn-blue:hover{background:var(--blue-dark);transform:translateY(-2px);box-shadow:var(--shadow-blue);}
.btn-outline{display:inline-flex;align-items:center;gap:8px;color:var(--dark2);font-size:.9rem;font-weight:500;padding:13px 24px;border-radius:10px;border:1.5px solid var(--border);transition:border-color .2s,background .2s,color .2s;font-family:var(--ff);}
.btn-outline:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-xlight);}

/* === NAV === */
nav#navbar{position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:900;transition:background .3s,box-shadow .3s;}
nav#navbar.scrolled{background:rgba(255,255,255,.93);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);box-shadow:0 1px 0 var(--border),0 4px 20px rgba(15,17,23,.05);}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:var(--nav-h);}
.nav-logo{display:flex;align-items:center;}
.nav-logo img{height:36px;width:auto;transition:filter .3s,opacity .2s;}
.nav-logo:hover img{opacity:.75;}
.nav-logo-text{font-family:var(--fd);font-size:1.25rem;font-weight:700;color:#fff;}
.nav-logo-text span{color:var(--blue-light);}
nav#navbar.scrolled .nav-logo-text{color:var(--dark);}
nav#navbar.scrolled .nav-logo-text span{color:var(--blue);}
.nav-links{display:flex;gap:2px;align-items:center;}
.nav-links a{font-size:.875rem;font-weight:500;color:rgba(255,255,255,.8);padding:8px 13px;border-radius:8px;transition:color .2s,background .2s;}
nav#navbar.scrolled .nav-links a{color:var(--mid);}
.nav-links a:hover{color:#fff;background:rgba(255,255,255,.15);}
nav#navbar.scrolled .nav-links a:hover{color:var(--dark);background:#f0f1f4;}
.nav-links a.active{color:#fff!important;background:rgba(255,255,255,.2);}
nav#navbar.scrolled .nav-links a.active{color:var(--dark)!important;background:#e8eaf0;}
.nav-cta{background:var(--blue)!important;color:#fff!important;font-weight:600!important;border-radius:9px!important;padding:9px 20px!important;transition:background .2s,box-shadow .2s!important;}
.nav-cta:hover{background:var(--blue-dark)!important;box-shadow:var(--shadow-blue)!important;}
nav#navbar.scrolled .nav-cta{color:#fff!important;}

/* === HAMBURGER === */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;border:none;background:none;z-index:1001;}
.hamburger span{display:block;width:24px;height:2px;background:#fff;border-radius:2px;transition:all .3s;}
nav#navbar.scrolled .hamburger span{background:var(--dark);}
.hamburger.open span{background:var(--dark)!important;}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* === MOBILE MENU — high contrast, visible active === */
.mobile-menu{
  display:none;position:fixed;inset:0;
  background:#0f1117;  /* dark background = max contrast */
  z-index:800;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  opacity:0;pointer-events:none;transition:opacity .3s;
}
.mobile-menu.open{opacity:1;pointer-events:all;}
.mobile-menu-close{
  position:absolute;top:24px;right:24px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);
  color:#fff;width:44px;height:44px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  transition:background .2s;
}
.mobile-menu-close:hover{background:rgba(255,255,255,.18);}
.mobile-menu a{
  font-family:var(--fd);font-size:2.4rem;font-weight:700;
  color:#ffffff;   /* fully white — WCAG AAA on #0f1117 */
  padding:10px 32px;transition:color .2s,transform .2s;
  border-radius:12px;
}
.mobile-menu a:hover{color:var(--blue-light);transform:translateX(6px);}
.mobile-menu a.active{color:var(--blue-light);}
.mobile-menu .mobile-cta{
  margin-top:8px;
  background:var(--blue);color:#fff!important;
  font-size:1.2rem;padding:14px 40px;border-radius:12px;
  display:inline-block;
}
.mobile-menu .mobile-cta:hover{background:var(--blue-dark);transform:none;}

/* === HERO SLIDER === */
#section-home{position:relative;height:100vh;min-height:600px;overflow:hidden;}
.slides-wrap{position:absolute;inset:0;}
.slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.4s ease;}
.slide.active{opacity:1;}
.slide::after{content:'';position:absolute;inset:0;background:linear-gradient(130deg,rgba(8,12,24,.72) 0%,rgba(8,12,24,.38) 65%,rgba(8,12,24,.15) 100%);}
.hero-ui{position:absolute;inset:0;z-index:10;display:flex;align-items:center;padding-top:var(--nav-h);}
.slide-text{position:absolute;inset:0;display:flex;align-items:center;opacity:0;pointer-events:none;transition:opacity .5s .2s;}
.slide-text.active{opacity:1;pointer-events:all;}
.hero-inner{padding:0 28px;margin-left:calc((100vw - var(--max))/2);max-width:660px;}
@media(max-width:1216px){.hero-inner{margin-left:28px;}}
.hero-eye{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--blue-light);margin-bottom:20px;}
.hero-dot{width:6px;height:6px;border-radius:50%;background:var(--blue-light);}
.hero-h1{font-family:var(--fd);font-size:clamp(2.8rem,7.5vw,5.8rem);font-weight:800;color:#fff;line-height:1.05;margin-bottom:20px;letter-spacing:-.015em;}
.hero-h1 em{font-style:normal;color:var(--blue-light);}
.hero-p{font-size:1.1rem;color:rgba(255,255,255,.7);line-height:1.8;max-width:460px;margin-bottom:34px;}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;}
.hero-btns .btn-blue{box-shadow:var(--shadow-blue);}
.slider-dots{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;gap:10px;z-index:20;}
.sdot{width:8px;height:8px;border-radius:100px;background:rgba(255,255,255,.3);border:none;cursor:pointer;transition:width .4s,background .3s;padding:0;}
.sdot.active{width:28px;background:var(--blue-light);}
.sarrow{position:absolute;top:50%;transform:translateY(-50%);z-index:20;background:rgba(255,255,255,.1);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.18);color:#fff;width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s;font-size:18px;line-height:1;}
.sarrow:hover{background:rgba(59,130,246,.55);}
.sarrow.prev{left:24px;}.sarrow.next{right:24px;}
.scroll-ind{position:absolute;bottom:38px;right:44px;z-index:20;display:flex;flex-direction:column;align-items:center;gap:8px;}
.scroll-ind span{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.35);writing-mode:vertical-rl;}
.scroll-line{width:1px;height:48px;background:linear-gradient(to bottom,rgba(96,165,250,.8),transparent);animation:scPulse 2s ease-in-out infinite;}

/* === INTRO === */
#section-about{padding:110px 0;background:#fff;}
.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.intro-visual{position:relative;}
.intro-img{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);border:1.5px solid var(--border);aspect-ratio:4/5;}
.intro-img img{width:100%;height:100%;object-fit:cover;display:block;}
.intro-badge{position:absolute;bottom:-18px;right:-18px;background:#fff;border:1.5px solid var(--border);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow);display:flex;align-items:center;gap:14px;}
.badge-ic{width:42px;height:42px;border-radius:11px;background:var(--blue-xlight);display:flex;align-items:center;justify-content:center;color:var(--blue);flex-shrink:0;}
.badge-tx strong{display:block;font-size:.98rem;font-weight:700;color:var(--dark);}
.badge-tx span{font-size:.76rem;color:var(--mid);}
.feats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:32px;}
.feat{background:var(--light);border:1.5px solid var(--border);border-radius:var(--radius);padding:20px;transition:border-color .25s,transform .25s,box-shadow .25s;}
.feat:hover{border-color:var(--blue);transform:translateY(-2px);box-shadow:0 0 0 3px var(--blue-glow);}
.feat-ic{width:36px;height:36px;border-radius:9px;background:var(--blue-xlight);display:flex;align-items:center;justify-content:center;margin-bottom:11px;color:var(--blue);}
.feat h4{font-size:.88rem;font-weight:700;color:var(--dark);margin-bottom:4px;}
.feat p{font-size:.8rem;color:var(--mid);line-height:1.65;}

/* === SERVICES === */
#section-services{padding:110px 0;background:linear-gradient(155deg,#f5f6f8 0%,#eef2ff 55%,#f5f6f8 100%);}
.svc-hd{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:50px;gap:32px;flex-wrap:wrap;}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}
.svc{background:#fff;border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:26px;transition:border-color .25s,transform .25s,box-shadow .25s;}
.svc:hover{border-color:var(--blue);transform:translateY(-3px);box-shadow:0 8px 32px rgba(59,130,246,.1);}
.svc-n{font-size:10px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--blue);opacity:.6;margin-bottom:16px;font-family:var(--fd);}
.svc-ic{width:42px;height:42px;border-radius:11px;background:var(--blue-xlight);display:flex;align-items:center;justify-content:center;margin-bottom:14px;font-size:18px;}
.svc h3{font-size:.93rem;font-weight:700;color:var(--dark);margin-bottom:7px;}
.svc p{font-size:.81rem;color:var(--mid);line-height:1.7;}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);border-radius:var(--radius-lg);overflow:hidden;border:1.5px solid var(--border);background:#fff;box-shadow:var(--shadow);margin-top:56px;}
.stat{padding:34px 18px;text-align:center;border-right:1px solid var(--border);}
.stat:last-child{border-right:none;}
.stat-n{font-family:var(--fd);font-size:2.6rem;font-weight:800;color:var(--blue);line-height:1;margin-bottom:5px;display:block;}
.stat-l{font-size:.73rem;color:var(--mid);letter-spacing:.08em;text-transform:uppercase;font-weight:600;}

/* === WORKS === */
#section-works{padding:110px 0;background:#fff;}
.works-hd{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:38px;gap:20px;flex-wrap:wrap;}
.ftabs{display:flex;gap:7px;flex-wrap:wrap;}
.ftab{font-size:.79rem;font-weight:600;padding:7px 17px;border-radius:100px;border:1.5px solid var(--border);color:var(--mid);cursor:pointer;transition:all .2s;background:none;font-family:var(--ff);}
.ftab:hover,.ftab.active{color:#fff;background:var(--blue);border-color:var(--blue);}
.works-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.wcard{border-radius:var(--radius);overflow:hidden;background:var(--light);border:1.5px solid var(--border);transition:transform .3s,box-shadow .3s,border-color .3s;}
.wcard:hover{transform:translateY(-4px);border-color:var(--blue);box-shadow:0 12px 36px rgba(59,130,246,.11);}
.wimg{aspect-ratio:4/3;overflow:hidden;position:relative;}
.wimg img{width:100%;height:100%;object-fit:cover;transition:transform .5s;display:block;}
.wcard:hover .wimg img{transform:scale(1.05);}
.wov{position:absolute;inset:0;background:rgba(59,130,246,.78);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s;}
.wcard:hover .wov{opacity:1;}
.wov-ic{width:44px;height:44px;border:2px solid #fff;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;transform:scale(.7);transition:transform .3s;}
.wcard:hover .wov-ic{transform:scale(1);}
.winfo{padding:13px 15px;}
.wcat{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);margin-bottom:3px;}
.winfo h4{font-size:.83rem;font-weight:600;color:var(--dark);line-height:1.4;}

/* === QUOTES === */
.quotes-s{padding:90px 0;background:var(--dark);}
.quotes-s .section-title{color:#fff;}
.quotes-g{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:44px;}
.qcard{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:32px;transition:border-color .3s,background .3s;}
.qcard:hover{border-color:var(--blue);background:rgba(59,130,246,.07);}
.qmark{font-family:var(--fd);font-size:4rem;color:var(--blue);line-height:.8;margin-bottom:14px;display:block;opacity:.65;}
.qtext{font-size:.93rem;color:rgba(255,255,255,.8);line-height:1.8;font-style:italic;margin-bottom:18px;}
.qauth{font-size:.76rem;font-weight:700;color:var(--blue-light);letter-spacing:.1em;text-transform:uppercase;}

/* === ABOUT === */
#section-team{padding:110px 0;background:#fff;}
.about-layout{display:grid;grid-template-columns:350px 1fr;gap:80px;align-items:start;}
.about-photo{border-radius:var(--radius-lg);overflow:hidden;border:1.5px solid var(--border);box-shadow:var(--shadow);position:sticky;top:calc(var(--nav-h) + 24px);}
.about-photo img{width:100%;display:block;}
.aname{font-family:var(--fd);font-size:2.5rem;font-weight:800;color:var(--dark);line-height:1.1;margin-bottom:5px;}
.arole{font-size:.83rem;color:var(--blue);letter-spacing:.1em;text-transform:uppercase;font-weight:700;margin-bottom:20px;}
.atags{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:26px;}
.atag{font-size:.73rem;color:var(--mid);background:var(--light);border:1px solid var(--border);padding:4px 11px;border-radius:100px;}
.abio{font-size:.96rem;color:var(--mid);line-height:1.85;margin-bottom:22px;}
.aquote{font-family:var(--fd);font-size:1.08rem;font-style:italic;color:var(--dark);border-left:3px solid var(--blue);padding-left:17px;margin-bottom:32px;line-height:1.65;}
.sk-hd{font-size:.77rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--mid);margin-bottom:16px;}
.skills{display:flex;flex-direction:column;gap:13px;margin-bottom:34px;}
.sk-row{display:flex;flex-direction:column;gap:6px;}
.sk-meta{display:flex;justify-content:space-between;}
.sk-meta span:first-child{font-size:.84rem;font-weight:600;color:var(--dark);}
.sk-meta span:last-child{font-size:.76rem;color:var(--mid);}
.sk-bar{height:4px;background:var(--light);border-radius:2px;overflow:hidden;border:1px solid var(--border);}
.sk-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--blue),var(--blue-light));transform:scaleX(0);transform-origin:left;transition:transform 1.1s cubic-bezier(.4,0,.2,1);}
.sk-fill.go{transform:scaleX(1);}
.alinks{display:flex;gap:9px;flex-wrap:wrap;}
.alink{display:inline-flex;align-items:center;gap:7px;font-size:.81rem;color:var(--mid);border:1.5px solid var(--border);padding:9px 15px;border-radius:9px;transition:all .2s;font-weight:500;}
.alink:hover{color:var(--blue);border-color:var(--blue);background:var(--blue-xlight);}

/* === CONTACT === */
#section-contact{padding:110px 0;background:var(--light);}
.ct-layout{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;}
/* When form is hidden: info column expands to a centred single column */
.ct-layout--no-form{grid-template-columns:1fr;max-width:600px;}
.ct-title{font-family:var(--fd);font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:800;color:var(--dark);line-height:1.2;margin-bottom:14px;}
.ct-sub{font-size:.97rem;color:var(--mid);line-height:1.8;margin-bottom:34px;}
.ct-items{display:flex;flex-direction:column;gap:11px;}
.ci{display:flex;align-items:center;gap:13px;padding:15px 17px;background:#fff;border:1.5px solid var(--border);border-radius:var(--radius);transition:border-color .2s;}
.ci:hover{border-color:var(--blue);}
.ci-ic{width:38px;height:38px;background:var(--blue-xlight);border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--blue);}
.ci-tx small{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--mid);display:block;margin-bottom:1px;}
.ci-tx span{font-size:.87rem;color:var(--dark);font-weight:500;}
.form-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:34px;box-shadow:var(--shadow);}
.form-card h3{font-family:var(--fd);font-size:1.35rem;font-weight:700;color:var(--dark);margin-bottom:22px;}
.cf{display:flex;flex-direction:column;gap:13px;}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:13px;}
.fg{display:flex;flex-direction:column;gap:6px;}
.fg label{font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--mid);}
.fg input,.fg textarea{background:var(--light);border:1.5px solid var(--border);border-radius:9px;color:var(--dark);font-family:var(--ff);font-size:.88rem;padding:12px 14px;outline:none;transition:border-color .2s,box-shadow .2s;resize:none;width:100%;}
.fg input:focus,.fg textarea:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px var(--blue-glow);}
.fg textarea{min-height:108px;}
.btn-sub{display:flex;align-items:center;justify-content:center;gap:9px;background:var(--blue);color:#fff;font-family:var(--ff);font-weight:700;font-size:.88rem;padding:14px 26px;border-radius:9px;border:none;cursor:pointer;transition:background .2s,transform .15s,box-shadow .2s;width:100%;}
.btn-sub:hover{background:var(--blue-dark);transform:translateY(-1px);box-shadow:var(--shadow-blue);}
.recaptcha-notice a{color:var(--blue);text-decoration:underline;}

/* CF7 overrides */
.wpcf7-form .frow{display:grid;grid-template-columns:1fr 1fr;gap:13px;}
.wpcf7-form p{margin-bottom:0;}
.wpcf7-form .wpcf7-submit{display:flex;align-items:center;justify-content:center;gap:9px;background:var(--blue);color:#fff;font-family:var(--ff);font-weight:700;font-size:.88rem;padding:14px 26px;border-radius:9px;border:none;cursor:pointer;transition:background .2s,box-shadow .2s;width:100%;}
.wpcf7-form .wpcf7-submit:hover{background:var(--blue-dark);box-shadow:var(--shadow-blue);}
.wpcf7-not-valid-tip{font-size:.75rem;color:#ef4444;margin-top:4px;}
.wpcf7-response-output{margin-top:12px!important;padding:12px 16px!important;border-radius:9px!important;font-size:.85rem!important;border:none!important;background:var(--blue-xlight)!important;color:var(--blue-dark)!important;}

/* === FOOTER === */
footer{background:var(--dark);padding:50px 0;}
.ft{display:flex;align-items:center;justify-content:space-between;gap:22px;padding-bottom:32px;border-bottom:1px solid rgba(255,255,255,.07);flex-wrap:wrap;}
.ft-logo img{height:28px;opacity:.65;filter:brightness(0) invert(1);transition:opacity .2s;}
.ft-logo:hover img{opacity:1;}
.ft-logo-fb{font-family:var(--fd);font-size:1.1rem;font-weight:700;color:rgba(255,255,255,.65);}
.ft-logo-fb span{color:var(--blue-light);}
.ft-links{display:flex;gap:16px;flex-wrap:wrap;}
.ft-links a{font-size:.8rem;color:rgba(255,255,255,.45);transition:color .2s;font-weight:500;}
.ft-links a:hover{color:var(--blue-light);}
.fb{display:flex;justify-content:space-between;align-items:center;padding-top:22px;flex-wrap:wrap;gap:12px;}
.fb-copy{font-size:.77rem;color:rgba(255,255,255,.3);}
.fb-soc{display:flex;gap:10px;}
.soc-btn{width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.5);transition:background .2s,color .2s;}
.soc-btn:hover{background:var(--blue);color:#fff;border-color:var(--blue);}

/* === ANIMATIONS === */
@keyframes scPulse{0%,100%{opacity:.3;}50%{opacity:1;}}
.reveal{opacity:0;transform:translateY(26px);transition:opacity .65s ease,transform .65s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}
.d1{transition-delay:.1s;}.d2{transition-delay:.2s;}.d3{transition-delay:.3s;}.d4{transition-delay:.4s;}

/* === RESPONSIVE === */
@media(max-width:1024px){.works-grid{grid-template-columns:repeat(3,1fr);}.svc-grid{grid-template-columns:repeat(2,1fr);}.about-layout{grid-template-columns:1fr;gap:44px;}.about-photo{position:static;max-width:320px;}.intro-grid{grid-template-columns:1fr;gap:48px;}.intro-visual{max-width:400px;}}
@media(max-width:768px){.nav-links{display:none;}.hamburger{display:flex;}.mobile-menu{display:flex;}.works-grid{grid-template-columns:repeat(2,1fr);}.svc-grid{grid-template-columns:1fr;}.stats-row{grid-template-columns:repeat(2,1fr);}.ct-layout{grid-template-columns:1fr;gap:44px;}.frow{grid-template-columns:1fr;}.wpcf7-form .frow{grid-template-columns:1fr;}.quotes-g{grid-template-columns:1fr;}.ft{flex-direction:column;text-align:center;}.ft-links{justify-content:center;}.fb{justify-content:center;}.feats{grid-template-columns:1fr;}.sarrow{display:none;}}
@media(max-width:480px){.works-grid{grid-template-columns:1fr;}.hero-btns{flex-direction:column;}.btn-blue,.btn-outline{justify-content:center;}.stats-row{grid-template-columns:1fr 1fr;}}
