
:root{--bg:#f5f1ea;--ink:#111;--muted:#666;--line:#ddd5ca;--card:#fffaf2;--dark:#111;--radius:28px;--max:1180px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--ink);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}a{color:inherit;text-decoration:none}img{display:block;width:100%;height:auto}.site-header{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:18px 34px;background:rgba(245,241,234,.82);backdrop-filter:blur(18px);border-bottom:1px solid rgba(17,17,17,.08)}.brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:-.02em}.brand-mark{display:grid;place-items:center;width:38px;height:38px;border:1px solid #111;border-radius:50%;font-size:13px}.nav{display:flex;gap:24px;align-items:center}.nav a{font-size:14px;color:#333}.nav a.active,.nav a:hover{color:#000;font-weight:700}.menu-toggle{display:none;border:1px solid #111;background:transparent;border-radius:999px;padding:10px 16px}.hero,.page-hero,.section{max-width:var(--max);margin:auto;padding:96px 28px}.hero-split,.service-hero,.two-col,.contact-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}.hero h1,.page-hero h1{font-size:clamp(46px,8vw,112px);line-height:.95;letter-spacing:-.065em;margin:16px 0 24px}.section h2,.footer h2{font-size:clamp(32px,5vw,64px);line-height:1;letter-spacing:-.055em;margin:0 0 20px}h3{font-size:26px;line-height:1.08;letter-spacing:-.035em;margin:10px 0}p{font-size:17px;line-height:1.7;color:var(--muted)}.eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:.18em;color:#888;font-weight:800}.hero-media,.service-card,.feature-box,.lead-form,.map-wrap{border-radius:var(--radius);overflow:hidden;background:var(--card);box-shadow:0 24px 80px rgba(0,0,0,.08);border:1px solid rgba(17,17,17,.08)}.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#111;color:#fff;padding:15px 24px;font-weight:800;border:1px solid #111;transition:.25s ease}.btn:hover{transform:translateY(-2px);box-shadow:0 15px 35px rgba(0,0,0,.16)}.btn.ghost{background:transparent;color:#111}.btn-light{background:#fff;color:#111;border-color:#fff}.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}.marquee{display:flex;gap:14px;overflow:hidden;padding:22px 28px;border-block:1px solid var(--line);white-space:nowrap}.marquee span{border:1px solid var(--line);border-radius:999px;padding:12px 18px;background:#fffaf2}.section-head{max-width:850px;margin-bottom:36px}.service-list{border-top:1px solid var(--line)}.service-row{display:grid;grid-template-columns:1fr 1fr;gap:24px;padding:28px 0;border-bottom:1px solid var(--line)}.service-row span{font-size:clamp(28px,4vw,54px);font-weight:800;letter-spacing:-.045em}.service-row small{font-size:17px;color:#666;align-self:center}.card-grid{display:grid;gap:22px}.card-grid.three{grid-template-columns:repeat(3,1fr)}.service-card{padding:14px}.service-card img{border-radius:20px}.service-card h3,.service-card p,.service-card .eyebrow{padding-inline:12px}.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.gallery-grid-large{grid-template-columns:repeat(4,1fr)}.gallery-img{border-radius:24px;border:1px solid rgba(17,17,17,.08);box-shadow:0 18px 50px rgba(0,0,0,.08);aspect-ratio:1.18/1;object-fit:cover}.full-gallery{padding-top:40px}.feature-box{padding:30px}.feature-box li{font-size:17px;line-height:1.7;margin:12px 0}.meta-line{margin-top:20px;border-top:1px solid var(--line);padding-top:18px;color:#777}.seo-copy{background:#fffaf2;border-radius:36px;margin-bottom:90px}.contact-hero{padding-bottom:20px}.lead-form{display:grid;gap:16px;padding:28px}.lead-form label{display:grid;gap:8px;font-weight:700}.lead-form input,.lead-form select,.lead-form textarea{width:100%;border:1px solid var(--line);border-radius:16px;background:#fff;padding:14px;font:inherit}.lead-form textarea{min-height:130px}.map-wrap iframe{width:100%;height:420px;border:0;display:block}.legal h2{font-size:32px;letter-spacing:-.04em}.legal code,.legal pre{background:#fff;border:1px solid var(--line);border-radius:14px;padding:3px 8px}.legal pre{padding:18px;overflow:auto}.footer{background:#111;color:#fff;padding:80px 28px}.footer-grid{max-width:var(--max);margin:auto;display:grid;grid-template-columns:1.2fr .9fr .9fr;gap:38px}.footer p,.footer a{color:#d5d5d5}.footer-links{display:grid;gap:9px}.footer-title{color:#fff;font-weight:800}.scroll-popup{position:fixed;right:24px;bottom:24px;z-index:90;max-width:370px;background:#fff;color:#111;border-radius:28px;padding:26px;box-shadow:0 30px 100px rgba(0,0,0,.25);transform:translateY(140%);transition:.45s cubic-bezier(.2,.8,.2,1)}.scroll-popup.show{transform:translateY(0)}.popup-close{position:absolute;top:12px;right:14px;border:0;background:transparent;font-size:28px;cursor:pointer}.tilt-card{transition:transform .18s ease, box-shadow .18s ease;transform-style:preserve-3d}.reveal{opacity:0;transform:translateY(26px);transition:.7s ease}.reveal.visible{opacity:1;transform:translateY(0)}.progress{position:fixed;top:0;left:0;height:3px;background:#111;z-index:100;width:0}@media(max-width:900px){.menu-toggle{display:block}.nav{position:fixed;inset:74px 16px auto 16px;background:#fff;border-radius:24px;box-shadow:0 30px 80px rgba(0,0,0,.18);padding:22px;display:none;flex-direction:column;align-items:flex-start}.nav.open{display:flex}.hero-split,.service-hero,.two-col,.contact-grid,.footer-grid{grid-template-columns:1fr}.card-grid.three,.gallery-grid,.gallery-grid-large{grid-template-columns:1fr 1fr}.service-row{grid-template-columns:1fr}.hero,.page-hero,.section{padding:70px 20px}.site-header{padding:14px 18px}}@media(max-width:560px){.gallery-grid,.gallery-grid-large{grid-template-columns:1fr}.hero h1,.page-hero h1{font-size:46px}.section h2,.footer h2{font-size:34px}.scroll-popup{left:16px;right:16px;bottom:16px}.hero-actions{display:grid}.btn{width:100%}}


/* Smart Fab refinement overrides */
body::before{content:"";position:fixed;inset:auto auto 10% -12%;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.85),rgba(245,241,234,0));pointer-events:none;z-index:-1;filter:blur(8px)}
.brand-logo{height:38px;width:auto;max-width:160px;object-fit:contain;display:block}.brand-text{display:none}.brand-mark{display:none}.site-header{padding:16px 34px}.hero,.page-hero{padding-top:110px;padding-bottom:88px}.hero h1,.page-hero h1{font-size:clamp(44px,7vw,96px);line-height:.98;letter-spacing:-.035em;font-weight:800}.section h2{font-size:clamp(32px,4.6vw,58px);line-height:1.05;letter-spacing:-.035em}.footer h2{font-size:clamp(30px,4vw,50px);line-height:1.06;letter-spacing:-.035em}.footer .btn-light{background:#fff;color:#111;border-color:#fff}.footer .btn-light:hover{background:#f5f1ea;color:#111}.gallery-grid .section-head h2,.section-head h2{max-width:980px}.gallery-grid{align-items:stretch}.gallery-img:hover{box-shadow:0 28px 80px rgba(0,0,0,.13)}.service-row,.service-card,.feature-box,.gallery-img{will-change:transform}.marquee{display:none}.cursor-aura{position:fixed;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(17,17,17,.08),rgba(17,17,17,0) 65%);pointer-events:none;z-index:2;transform:translate(-50%,-50%);transition:opacity .2s ease;mix-blend-mode:multiply}.image-strip{display:grid;grid-template-columns:1.1fr .9fr;gap:18px;align-items:stretch}.image-strip img:first-child{grid-row:span 2}.image-strip img{height:100%;object-fit:cover}@media(max-width:900px){.brand-logo{height:34px}.hero,.page-hero{padding-top:76px}.hero h1,.page-hero h1{font-size:clamp(42px,13vw,72px)}.footer h2{font-size:34px}}


/* Final requested refinements */
.compact-services{padding-top:78px}.service-tile-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}.service-tile{display:flex;flex-direction:column;gap:12px;padding:12px;border:1px solid rgba(17,17,17,.10);border-radius:26px;background:rgba(255,250,242,.72);box-shadow:0 18px 60px rgba(0,0,0,.055);min-height:255px;position:relative;overflow:hidden}.service-tile::after{content:"";position:absolute;inset:auto 14px 14px auto;width:42px;height:42px;border-radius:50%;background:rgba(17,17,17,.08);transition:.25s ease}.service-tile:hover::after{transform:scale(1.4);background:rgba(17,17,17,.12)}.service-tile img{aspect-ratio:1.15/1;object-fit:cover;border-radius:18px;background:#eee7dc}.service-tile span{font-size:19px;font-weight:850;letter-spacing:-.035em;line-height:1.05}.service-tile small{font-size:13px;line-height:1.45;color:#666;max-width:92%}.contact-panel{align-items:start}.visit-card h2{font-size:clamp(38px,5vw,64px);line-height:1;letter-spacing:-.04em;margin:0 0 18px}.contact-lines{display:grid;gap:12px;margin-top:26px}.contact-lines a{display:flex;justify-content:space-between;gap:18px;border:1px solid var(--line);border-radius:18px;background:#fffaf2;padding:16px 18px}.contact-lines span{color:#777;text-align:right}.map-head{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:end}.map-section .map-wrap{border-radius:30px;box-shadow:0 28px 90px rgba(0,0,0,.10)}.map-section .map-wrap iframe{height:520px}.exit-popup{position:fixed;inset:0;background:rgba(17,17,17,.52);backdrop-filter:blur(10px);z-index:120;display:none;align-items:center;justify-content:center;padding:20px}.exit-popup.show{display:flex}.exit-popup-card{max-width:520px;background:#fffaf2;border-radius:34px;padding:34px;box-shadow:0 40px 120px rgba(0,0,0,.35);position:relative}.exit-popup-card h3{font-size:38px;letter-spacing:-.045em}.exit-popup-card .popup-close{top:16px;right:18px}.interactive-orb{position:fixed;right:8%;top:22%;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#fff,#dfd6c9 52%,rgba(17,17,17,.18));box-shadow:0 40px 80px rgba(0,0,0,.13);z-index:1;pointer-events:none;animation:floatOrb 7s ease-in-out infinite}@keyframes floatOrb{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-24px) rotate(8deg)}}@media(max-width:1100px){.service-tile-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:760px){.service-tile-grid{grid-template-columns:1fr 1fr}.map-head{grid-template-columns:1fr}.contact-lines a{display:grid}.contact-lines span{text-align:left}.interactive-orb{display:none}}@media(max-width:520px){.service-tile-grid{grid-template-columns:1fr}}

/* v3 visual upgrades: larger imagery, carousels and lightbox */
:root{--max:1320px}.hero,.page-hero,.section{max-width:var(--max)}
.hero-carousel,.carousel-shell{position:relative;overflow:hidden;border-radius:32px}.hero-carousel{background:#fffaf2;border:1px solid rgba(17,17,17,.08);box-shadow:0 24px 80px rgba(0,0,0,.08)}
.carousel-track{display:flex;gap:22px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:2px;scrollbar-width:none}.carousel-track::-webkit-scrollbar{display:none}
.hero-carousel .carousel-track{gap:0;padding:0}.hero-slide{min-width:100%;margin:0;position:relative;scroll-snap-align:start}.hero-slide img{aspect-ratio:1.15/1;object-fit:cover;background:#eee7dc}.hero-slide figcaption{position:absolute;left:22px;bottom:22px;background:rgba(255,250,242,.88);backdrop-filter:blur(10px);border:1px solid rgba(17,17,17,.08);border-radius:999px;padding:10px 16px;font-weight:800;font-size:14px}
.carousel-controls{display:flex;gap:10px;justify-content:flex-end;margin-top:18px}.hero-carousel .carousel-controls{position:absolute;right:18px;top:18px;margin:0}.carousel-controls button{width:44px;height:44px;border-radius:50%;border:1px solid rgba(17,17,17,.16);background:#fffaf2;color:#111;font-size:26px;line-height:1;cursor:pointer;box-shadow:0 14px 34px rgba(0,0,0,.10);transition:.2s ease}.carousel-controls button:hover{transform:translateY(-2px);background:#111;color:#fff}
.service-carousel .carousel-track{display:grid;grid-auto-flow:column;grid-auto-columns:calc((100% - 44px)/3);overflow-x:auto}.service-carousel .service-tile{min-height:360px}.service-carousel .service-tile img{aspect-ratio:1.35/1;object-fit:cover}.service-carousel .service-tile span{font-size:24px}.service-carousel .service-tile small{font-size:15px}.visual-carousel .carousel-track{grid-auto-columns:unset}.visual-carousel .gallery-img{min-width:72%;height:520px;object-fit:cover;scroll-snap-align:start;border-radius:32px}.gallery-img{cursor:zoom-in}.gallery-grid{grid-template-columns:repeat(3,1fr);gap:24px}.gallery-grid .gallery-img{aspect-ratio:1.2/1;object-fit:cover;border-radius:28px}.gallery-grid-large{grid-template-columns:repeat(2,1fr);gap:28px}.gallery-grid-large .gallery-img{aspect-ratio:1.35/1;min-height:360px;object-fit:cover}.service-tile-grid{gap:22px}.service-tile{min-height:330px}.service-tile img{aspect-ratio:1.35/1;object-fit:cover}.project-gallery{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:30px}.project-gallery .gallery-img{min-height:420px;aspect-ratio:1.45/1;object-fit:cover;border-radius:34px}.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.86);z-index:200;display:none;align-items:center;justify-content:center;padding:32px}.lightbox.show{display:flex}.lightbox img{max-width:min(94vw,1500px);max-height:88vh;object-fit:contain;border-radius:22px;box-shadow:0 40px 120px rgba(0,0,0,.5);background:#fffaf2}.lightbox-close{position:absolute;top:20px;right:24px;width:48px;height:48px;border-radius:50%;border:1px solid rgba(255,255,255,.35);background:rgba(255,255,255,.12);color:#fff;font-size:34px;cursor:pointer}.lightbox-caption{position:absolute;left:50%;bottom:20px;transform:translateX(-50%);color:#fff;background:rgba(0,0,0,.35);padding:10px 16px;border-radius:999px;font-weight:700;max-width:80vw;text-align:center}.hero-media img{aspect-ratio:1.15/1;object-fit:cover}.section-head h2{max-width:1050px}
@media(max-width:900px){.service-carousel .carousel-track{grid-auto-columns:calc((100% - 18px)/2)}.visual-carousel .gallery-img{min-width:86%;height:420px}.project-gallery,.gallery-grid-large{grid-template-columns:1fr}.project-gallery .gallery-img{min-height:300px}.gallery-grid{grid-template-columns:1fr 1fr}.hero-carousel .carousel-controls{position:static;margin:14px 18px 18px}.hero-slide img{aspect-ratio:1/1}}
@media(max-width:560px){.service-carousel .carousel-track{grid-auto-columns:88%}.visual-carousel .gallery-img{min-width:92%;height:330px}.gallery-grid{grid-template-columns:1fr}.gallery-grid .gallery-img{aspect-ratio:1.25/1}.project-gallery .gallery-img{min-height:260px}.carousel-controls{justify-content:flex-start}.lightbox{padding:16px}.lightbox-close{top:12px;right:12px}}


/* v4 social links, WhatsApp chatbot and 21st.dev-inspired carousel refinements */
.footer-social{display:flex;gap:12px;margin-top:18px;align-items:center}.footer-social a{width:42px;height:42px;border-radius:999px;display:grid;place-items:center;background:#fff;color:#111;border:1px solid rgba(255,255,255,.18);transition:.25s ease}.footer-social a:hover{transform:translateY(-3px) scale(1.04);background:#f5f1ea}.footer-social svg{width:20px;height:20px;fill:currentColor}.wa-chatbot{position:fixed;right:22px;bottom:22px;z-index:160;display:flex;align-items:center;gap:10px;background:#111;color:#fff;border:1px solid rgba(255,255,255,.15);border-radius:999px;padding:13px 16px;box-shadow:0 24px 70px rgba(0,0,0,.28);font-weight:850;letter-spacing:-.02em;transition:.25s ease}.wa-chatbot:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 30px 90px rgba(0,0,0,.34)}.wa-chatbot-icon{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:#fff;color:#111}.wa-chatbot-icon svg{width:20px;height:20px;fill:currentColor}.wa-chatbot small{display:block;color:#cfcfcf;font-size:11px;font-weight:700;line-height:1}.wa-chatbot span{display:block;font-size:14px;line-height:1.15}.scroll-popup{bottom:96px}.exit-popup-card .btn{background:#111;color:#fff}.interface-carousel{padding:14px;background:linear-gradient(135deg,rgba(255,250,242,.96),rgba(255,255,255,.70));box-shadow:0 34px 110px rgba(0,0,0,.12);overflow:hidden}.interface-carousel .carousel-track{gap:18px;padding:0;scroll-snap-type:x mandatory}.interface-carousel .hero-slide{min-width:86%;border-radius:24px;overflow:hidden;opacity:.58;transform:scale(.94);transition:opacity .55s cubic-bezier(.2,.8,.2,1),transform .55s cubic-bezier(.2,.8,.2,1),filter .55s ease;filter:saturate(.86)}.interface-carousel .hero-slide.is-active{opacity:1;transform:scale(1);filter:saturate(1.04)}.interface-carousel .hero-slide img{aspect-ratio:1.22/1;border-radius:24px}.interface-carousel::before,.interface-carousel::after{content:"";position:absolute;top:0;bottom:0;width:70px;z-index:2;pointer-events:none}.interface-carousel::before{left:0;background:linear-gradient(90deg,#fffaf2,rgba(255,250,242,0))}.interface-carousel::after{right:0;background:linear-gradient(270deg,#fffaf2,rgba(255,250,242,0))}.interface-carousel .carousel-controls{z-index:3}.service-carousel{padding:18px 8px 4px}.service-carousel .carousel-track{grid-auto-columns:calc((100% - 44px)/3);gap:22px;padding:4px 2px 18px}.service-carousel .service-tile{border-radius:30px;background:rgba(255,250,242,.88);box-shadow:0 26px 80px rgba(0,0,0,.075);scroll-snap-align:start}.service-carousel .service-tile:hover{box-shadow:0 36px 110px rgba(0,0,0,.13)}.service-carousel .carousel-controls{justify-content:center}.visual-auto-section{max-width:none;padding-left:0;padding-right:0;overflow:hidden}.visual-auto-section .section-head{max-width:1320px;margin-left:auto;margin-right:auto;padding:0 28px}.auto-slider{position:relative;overflow:hidden;padding:34px 0;background:#111;box-shadow:inset 0 1px 0 rgba(255,255,255,.06), inset 0 -1px 0 rgba(255,255,255,.06);mask:linear-gradient(90deg,transparent 0%,#000 8%,#000 92%,transparent 100%);-webkit-mask:linear-gradient(90deg,transparent 0%,#000 8%,#000 92%,transparent 100%)}.auto-slider-track{display:flex;gap:28px;width:max-content;animation:smartfab-scroll 34s linear infinite}.auto-slider:hover .auto-slider-track{animation-play-state:paused}.auto-slide-img{flex:0 0 auto;width:420px;height:360px;object-fit:cover;border-radius:30px;border:1px solid rgba(255,255,255,.12);box-shadow:0 34px 90px rgba(0,0,0,.34);transition:transform .32s ease,filter .32s ease}.auto-slide-img:hover{transform:scale(1.045);filter:brightness(1.08)}@keyframes smartfab-scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@media(max-width:900px){.wa-chatbot{right:16px;bottom:16px;padding:12px}.wa-chatbot small,.wa-chatbot span{display:none}.scroll-popup{bottom:84px}.interface-carousel .hero-slide{min-width:88%}.service-carousel .carousel-track{grid-auto-columns:calc((100% - 18px)/2);gap:18px}.auto-slide-img{width:320px;height:280px}.visual-auto-section .section-head{padding:0 20px}}
@media(max-width:560px){.footer-social{justify-content:flex-start}.service-carousel .carousel-track{grid-auto-columns:88%}.interface-carousel .hero-slide{min-width:92%}.auto-slide-img{width:260px;height:230px}.auto-slider-track{gap:18px;animation-duration:28s}}


/* v5 home page refinements */
.service-carousel{background:#F5F1EA;border-radius:38px;padding:14px 14px 18px;box-shadow:inset 0 0 0 1px rgba(0,0,0,.04)}
.service-carousel .carousel-track{padding:6px 6px 22px;background:#F5F1EA}
.service-carousel .service-tile{background:#fffaf2}
.visual-auto-section .section-head{padding-bottom:8px}
.auto-slider{background:#F5F1EA;box-shadow:inset 0 1px 0 rgba(0,0,0,.05), inset 0 -1px 0 rgba(0,0,0,.05);mask:linear-gradient(90deg,transparent 0%,#000 5%,#000 95%,transparent 100%);-webkit-mask:linear-gradient(90deg,transparent 0%,#000 5%,#000 95%,transparent 100%)}
.auto-slide-img{border:1px solid rgba(0,0,0,.06);box-shadow:0 28px 80px rgba(0,0,0,.12);background:#fff}

/* Codepen-inspired hero overlay carousel */
.hero-overlay-carousel{position:relative;min-height:470px;background:#F5F1EA;border-radius:42px;overflow:hidden;padding:30px;box-shadow:0 30px 80px rgba(0,0,0,.08);isolation:isolate}
.overlay-stage{position:relative;height:100%;min-height:410px}
.overlay-slide{position:absolute;inset:18px 26px 24px 26px;border-radius:34px;overflow:hidden;opacity:0;pointer-events:none;transform:translateX(12%) scale(.92);transition:transform .75s cubic-bezier(.22,.61,.36,1),opacity .55s ease,filter .55s ease;filter:blur(2px);background:#fff;box-shadow:0 30px 90px rgba(0,0,0,.12)}
.overlay-slide img{width:100%;height:100%;object-fit:cover;display:block;background:#fff}
.overlay-slide::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.04) 0%,rgba(0,0,0,.02) 50%,rgba(0,0,0,.42) 100%)}
.overlay-slide.is-active{opacity:1;pointer-events:auto;transform:translateX(0) scale(1);filter:none;z-index:3}
.overlay-slide.is-prev{opacity:.52;transform:translateX(-33%) scale(.86);z-index:1;filter:blur(1px)}
.overlay-slide.is-next{opacity:.52;transform:translateX(33%) scale(.86);z-index:1;filter:blur(1px)}
.overlay-caption{position:absolute;left:24px;right:24px;bottom:20px;z-index:2;color:#fff}
.overlay-caption p{margin:0 0 8px;font-size:.86rem;letter-spacing:.08em;text-transform:uppercase;font-weight:700;opacity:.88}
.overlay-caption h3{margin:0;font-size:1.65rem;line-height:1.1;max-width:12ch;text-shadow:0 8px 30px rgba(0,0,0,.22)}
.overlay-arrow{position:absolute;top:24px;z-index:5;width:48px;height:48px;border-radius:999px;border:1px solid rgba(0,0,0,.12);background:rgba(255,250,242,.92);backdrop-filter:blur(8px);font-size:1.6rem;line-height:1;color:#151515;display:grid;place-items:center;cursor:pointer;transition:transform .25s ease,box-shadow .25s ease,background .25s ease}
.overlay-arrow:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(0,0,0,.1);background:#fff}
.overlay-prev{right:82px}.overlay-next{right:26px}
.overlay-rings{position:absolute;top:50%;transform:translateY(-50%);width:220px;height:220px;pointer-events:none;z-index:0}
.overlay-rings-left{left:-110px}.overlay-rings-right{right:-110px}
.overlay-rings span{position:absolute;inset:50%;transform:translate(-50%,-50%);border-radius:50%;border:1px solid rgba(0,0,0,.07);background:transparent}
.overlay-rings span:nth-child(1){width:56px;height:56px}
.overlay-rings span:nth-child(2){width:112px;height:112px}
.overlay-rings span:nth-child(3){width:168px;height:168px}
.overlay-rings span:nth-child(4){width:224px;height:224px}
.overlay-dots{position:absolute;left:26px;bottom:24px;z-index:6;display:flex;gap:10px}
.overlay-dots button{width:10px;height:10px;padding:0;border:none;border-radius:999px;background:rgba(255,255,255,.45);cursor:pointer;transition:width .25s ease,background .25s ease,transform .25s ease}
.overlay-dots button.is-active{width:30px;background:#fff}
.overlay-dots button:hover{transform:scale(1.08)}

@media(max-width:900px){
  .hero-overlay-carousel{min-height:360px;padding:18px;border-radius:28px}
  .overlay-stage{min-height:308px}
  .overlay-slide{inset:16px 12px 16px 12px;border-radius:24px}
  .overlay-caption h3{font-size:1.25rem}
  .overlay-rings{width:160px;height:160px}.overlay-rings-left{left:-80px}.overlay-rings-right{right:-80px}
  .overlay-prev{right:68px}.overlay-next{right:14px}
}
@media(max-width:560px){
  .service-carousel{padding:10px}
  .hero-overlay-carousel{min-height:320px}
  .overlay-stage{min-height:278px}
  .overlay-caption{left:16px;right:16px;bottom:16px}
  .overlay-caption h3{font-size:1.08rem;max-width:14ch}
  .overlay-arrow{width:42px;height:42px;top:12px}
  .overlay-prev{right:60px}.overlay-next{right:10px}
  .overlay-dots{left:16px;bottom:16px}
}


/* v7 infographic icons and richer content blocks */
.card-top{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px}
.card-badge{display:grid;place-items:center;width:44px;height:44px;border-radius:999px;background:#111;color:#fff;font-weight:850;font-size:21px;line-height:1;flex:0 0 auto}
.card-icon{width:54px;height:54px;border-radius:18px;display:grid;place-items:center;background:#f2ece3;border:1px solid rgba(17,17,17,.08);color:#111;flex:0 0 auto;box-shadow:inset 0 1px 0 rgba(255,255,255,.8)}
.card-icon svg{width:26px;height:26px;display:block;color:currentColor}
.card-icon svg *{stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke}
.info-card p,.proof-card p,.process-step p,.seo-copy p{font-size:18px;line-height:1.6;color:#666;margin:0}
.info-card h3,.proof-card strong,.process-step h3{margin:0 0 10px}
.proof-card strong{display:block}
.seo-list{margin:22px 0 0;padding:0;list-style:none;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px 18px}
.seo-list li{position:relative;padding-left:30px;color:#444;line-height:1.5}
.seo-list li::before{content:"";position:absolute;left:0;top:6px;width:18px;height:18px;border-radius:999px;background:#111;box-shadow:0 0 0 4px #f2ece3 inset}
.wa-chatbot{align-items:center;gap:12px;padding:12px 16px 12px 12px}
.wa-chatbot-icon{width:40px;height:40px;min-width:40px;min-height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;line-height:0}
.wa-chatbot-icon svg{width:24px;height:24px;display:block;fill:currentColor}
.wa-chatbot > span:last-child{display:flex;flex-direction:column;justify-content:center}
@media(max-width:900px){.seo-list{grid-template-columns:1fr}.wa-chatbot-icon{width:38px;height:38px;min-width:38px;min-height:38px}}


/* v7.1 layout corrections */
.infographic-grid,.proof-grid,.process-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px;align-items:stretch}
.info-card,.proof-card,.process-step{position:relative;display:flex;flex-direction:column;justify-content:flex-start;gap:0;min-height:100%;padding:28px;border-radius:30px;background:#fffaf2;border:1px solid rgba(17,17,17,.08);box-shadow:0 22px 60px rgba(0,0,0,.06);overflow:hidden}
.info-card::before,.proof-card::before,.process-step::before{content:"";position:absolute;inset:auto -40px -60px auto;width:140px;height:140px;border-radius:50%;background:radial-gradient(circle,rgba(17,17,17,.06),rgba(17,17,17,0) 68%);pointer-events:none}
.info-card h3,.proof-card strong,.process-step h3{font-size:clamp(24px,2vw,34px);line-height:1.08;letter-spacing:-.03em}
.infographic-grid .info-card p,.proof-grid .proof-card p,.process-grid .process-step p{font-size:16px;line-height:1.65}
.proof-card strong{font-size:clamp(20px,1.7vw,28px);line-height:1.14}
.process-step .card-badge{font-size:18px;width:40px;height:40px}
.usp-infographics .section-head,.process-panel .section-head{max-width:920px}
.card-grid.three{grid-template-columns:repeat(3,minmax(0,1fr));align-items:stretch}
.service-card{height:100%;display:flex;flex-direction:column;justify-content:flex-start;gap:10px;min-height:420px}
.service-card img{aspect-ratio:1.35/1;object-fit:cover}
.service-card h3{margin:6px 0 4px;min-height:56px}
.service-card p:last-child{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;min-height:108px}
.seo-copy p + p{margin-top:14px}
.seo-copy .seo-list{margin:28px 0 34px}
.seo-copy .btn{margin-top:26px}
.wa-chatbot{background:#25D366;border-color:#25D366;color:#fff}
.wa-chatbot:hover{box-shadow:0 30px 90px rgba(37,211,102,.32)}
.wa-chatbot-icon{background:#fff;color:#25D366}
.wa-chatbot small,.wa-chatbot strong,.wa-chatbot span{color:#fff}
@media(max-width:1100px){.infographic-grid,.proof-grid,.process-grid,.card-grid.three{grid-template-columns:repeat(2,minmax(0,1fr))}.service-card{min-height:400px}}
@media(max-width:700px){.infographic-grid,.proof-grid,.process-grid,.card-grid.three{grid-template-columns:1fr}.service-card{min-height:auto}.service-card h3,.service-card p:last-child{min-height:0}}

.footer-bottom{max-width:var(--max);margin:34px auto 0;padding-top:26px;border-top:1px solid rgba(255,255,255,.14);color:#fff;font-size:16px;line-height:1.6}.footer-bottom a{color:#fff;font-weight:800}.footer-bottom a:hover{text-decoration:underline}.footer-grid{align-items:start}.footer .btn-light{padding:15px 26px}.footer-social{margin-top:18px;margin-bottom:8px}


.footer{padding:78px 28px 36px}
.footer-grid{max-width:1320px;grid-template-columns:1.25fr .95fr .95fr;gap:44px}
.footer h2{font-size:clamp(34px,4vw,58px);line-height:1.02;letter-spacing:-.04em;max-width:10ch}
.footer-links a{line-height:1.75}
.wa-chatbot{background:#25D366;border-color:#25D366;color:#fff;padding:12px 16px 12px 12px}
.wa-chatbot-icon{background:#fff;color:#25D366;box-shadow:inset 0 0 0 1px rgba(0,0,0,.03)}
.wa-chatbot-icon svg{width:22px;height:22px;display:block;fill:#25D366}
@media(max-width:900px){.footer-bottom{margin-top:26px;padding-top:22px;font-size:15px}.footer{padding:64px 20px 28px}}


/* v7.3 WhatsApp icon image fix */
.wa-chatbot{display:flex;align-items:center;gap:12px;background:#25D366;border-color:#25D366;color:#fff}
.wa-chatbot-icon{width:42px;height:42px;min-width:42px;min-height:42px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:0}
.wa-chatbot-icon img{width:100%;height:100%;display:block;object-fit:cover;border-radius:50%}
.wa-chatbot-label{display:flex;flex-direction:column;justify-content:center;line-height:1.1}
.wa-chatbot-label small{display:block;color:#fff;font-size:11px;font-weight:700;margin-bottom:2px}
.wa-chatbot-label strong{display:block;color:#fff;font-size:16px;font-weight:800}


/* v7.4 mobile footer and WhatsApp fixes */
html, body{
  max-width:100%;
  overflow-x:hidden;
}

@media(max-width:700px){
  .footer{
    width:100%;
    overflow:hidden;
    padding:56px 24px 32px;
  }

  .footer-grid{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:34px !important;
    max-width:100% !important;
    width:100% !important;
    margin:0 !important;
  }

  .footer h2{
    max-width:100% !important;
    font-size:clamp(34px,11vw,48px) !important;
    line-height:1.05 !important;
  }

  .footer .btn-light{
    width:auto !important;
    max-width:210px;
    padding:15px 26px;
  }

  .footer-social{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
  }

  .footer-links{
    max-width:100%;
  }

  .footer-links a,
  .footer p,
  .footer a{
    overflow-wrap:anywhere;
    word-break:normal;
  }

  .footer-bottom{
    max-width:100% !important;
    margin:34px 0 0 !important;
    padding-top:24px;
    font-size:15px;
  }

  .wa-chatbot{
    width:64px !important;
    height:64px !important;
    min-width:64px !important;
    min-height:64px !important;
    padding:0 !important;
    border-radius:50% !important;
    right:18px !important;
    bottom:18px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    gap:0 !important;
    background:transparent !important;
    border:0 !important;
    box-shadow:0 18px 48px rgba(37,211,102,.28) !important;
  }

  .wa-chatbot-label,
  .wa-chatbot small,
  .wa-chatbot strong{
    display:none !important;
  }

  .wa-chatbot-icon{
    width:64px !important;
    height:64px !important;
    min-width:64px !important;
    min-height:64px !important;
    background:transparent !important;
    padding:0 !important;
    border-radius:50% !important;
  }

  .wa-chatbot-icon img{
    width:64px !important;
    height:64px !important;
    object-fit:cover !important;
    border-radius:50% !important;
  }
}


/* v7.5 guaranteed whatsapp icon visibility */
.wa-chatbot{overflow:visible}
.wa-chatbot-icon{display:flex !important;align-items:center !important;justify-content:center !important;overflow:hidden !important}
.wa-chatbot-icon img{display:block !important;opacity:1 !important;visibility:visible !important}
@media(max-width:700px){
  .wa-chatbot{background:transparent !important;box-shadow:none !important}
  .wa-chatbot-icon{box-shadow:0 16px 38px rgba(37,211,102,.34) !important}
}
