/* ZOC_AGENCY_STUDIO_PRO_STAGE4E */
.asp-root{--asp-primary:#1f3f6d;--asp-contrast:#fff;--asp-icon:#fff;--asp-accent:#ef6b61;--asp-surface:#17345d;--asp-muted:#d8e4f5;--asp-radius:28px;--asp-font:Tahoma,Arial,sans-serif;--asp-heading-weight:900;direction:rtl;background:var(--asp-bg,var(--asp-primary));color:var(--asp-contrast);font-family:var(--asp-font);min-height:100vh;overflow:hidden}.asp-root *{box-sizing:border-box}.asp-root a{color:inherit;text-decoration:none}.asp-container{width:min(1180px,calc(100% - 34px));margin:0 auto}.asp-section{padding:76px 0}.asp-topbar{position:sticky;top:0;z-index:30;background:color-mix(in srgb,var(--asp-primary) 86%,#000 14%);border-bottom:1px solid color-mix(in srgb,var(--asp-contrast) 18%,transparent);backdrop-filter:blur(14px)}.asp-nav{height:74px;display:flex;align-items:center;justify-content:space-between;gap:20px}.asp-logo{display:flex;align-items:center;gap:10px;font-weight:900}.asp-logo img{max-height:42px;max-width:160px;object-fit:contain}.asp-logo-mark{width:48px;height:48px;display:grid;place-items:center;background:var(--asp-accent);color:var(--asp-contrast);border-radius:14px;font-weight:900}.asp-logo small{display:block;opacity:.72;font-size:11px;letter-spacing:.08em}.asp-menu{display:flex;align-items:center;gap:22px;font-weight:800}.asp-phone{background:var(--asp-accent);padding:13px 18px;border-radius:999px;font-weight:900}.asp-hero{position:relative;padding-top:90px}.asp-hero:before,.asp-services:before,.asp-packages:before{content:"";position:absolute;inset:auto -12% 0 auto;width:50vw;height:50vw;border-radius:50%;border:2px solid color-mix(in srgb,var(--asp-contrast) 14%,transparent);opacity:.35;pointer-events:none}.asp-hero-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,.9fr);gap:60px;align-items:center}.asp-kicker{display:inline-flex;align-items:center;gap:10px;color:var(--asp-muted);font-weight:900;letter-spacing:.12em;text-transform:uppercase}.asp-kicker:before{content:"";width:42px;height:8px;border-radius:999px;background:var(--asp-accent)}.asp-hero h1{font-size:clamp(48px,8vw,116px);line-height:.92;margin:24px 0 22px;font-weight:var(--asp-heading-weight);letter-spacing:-.04em}.asp-hero p{font-size:19px;line-height:2;color:var(--asp-muted);max-width:700px}.asp-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px}.asp-btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;border-radius:999px;padding:12px 22px;font-weight:900;border:2px solid color-mix(in srgb,var(--asp-contrast) 26%,transparent)}.asp-btn-fill{background:var(--asp-accent);border-color:var(--asp-accent);color:var(--asp-contrast)}.asp-btn-line{background:transparent}.asp-hero-art{min-height:470px;position:relative;border-radius:var(--asp-radius);background:linear-gradient(150deg,color-mix(in srgb,var(--asp-surface) 78%,#000 22%),color-mix(in srgb,var(--asp-primary) 78%,#fff 22%));overflow:hidden;padding:28px}.asp-big-number{font-size:clamp(150px,20vw,280px);font-weight:900;line-height:.75;color:color-mix(in srgb,var(--asp-contrast) 20%,transparent);letter-spacing:-.08em}.asp-art-ball{position:absolute;border-radius:50%;background:radial-gradient(circle at 35% 30%,var(--asp-accent),color-mix(in srgb,var(--asp-primary) 75%,#000 25%) 62%,transparent 63%);filter:drop-shadow(0 30px 70px rgba(0,0,0,.25))}.asp-art-ball-a{width:230px;height:230px;left:14%;top:19%}.asp-art-ball-b{width:170px;height:170px;right:13%;bottom:16%;background:radial-gradient(circle at 35% 30%,var(--asp-contrast),color-mix(in srgb,var(--asp-primary) 78%,#000 22%) 66%)}.asp-art-lines{position:absolute;inset:0;background:repeating-linear-gradient(70deg,transparent 0 34px,color-mix(in srgb,var(--asp-contrast) 12%,transparent) 35px 37px,transparent 38px 82px);opacity:.8}.asp-hero-image{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(1.05) contrast(1.05);opacity:.82}.asp-stat-card{position:absolute;right:24px;bottom:24px;background:var(--asp-primary);border:1px solid color-mix(in srgb,var(--asp-contrast) 22%,transparent);border-radius:22px;padding:16px 18px;box-shadow:0 24px 60px rgba(0,0,0,.22)}.asp-stat-card.second{right:auto;left:24px}.asp-stat-card strong{display:block;font-size:36px}.asp-stat-card span{color:var(--asp-muted);font-weight:800}.asp-title-row{display:flex;align-items:end;justify-content:space-between;gap:24px;margin-bottom:34px}.asp-title-row h2{font-size:clamp(32px,5vw,72px);line-height:.95;margin:0;font-weight:var(--asp-heading-weight)}.asp-title-row b{font-size:clamp(42px,8vw,100px);line-height:.8;color:color-mix(in srgb,var(--asp-contrast) 18%,transparent);font-weight:900;letter-spacing:-.06em}.asp-title-row.compact b{font-size:clamp(36px,6vw,82px)}.asp-section-line{width:7px;height:80px;background:var(--asp-accent);border-radius:999px}.asp-service-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.asp-service-card{background:var(--asp-surface);border:1px solid color-mix(in srgb,var(--asp-contrast) 18%,transparent);border-radius:var(--asp-radius);padding:26px;min-height:235px;transition:transform .25s ease,background .25s ease}.asp-service-card:hover{transform:translateY(-7px);background:color-mix(in srgb,var(--asp-surface) 86%,var(--asp-accent) 14%)}.asp-service-icon{width:88px;height:88px;border-radius:28px;display:grid;place-items:center;color:var(--asp-icon);font-size:62px;font-weight:900;margin-bottom:26px}.asp-service-card h3{font-size:24px;margin:0 0 12px;font-weight:900}.asp-service-card p,.asp-portfolio p,.asp-blog-card p,.asp-process p{color:var(--asp-muted);line-height:1.9}.asp-stats{padding:28px 0}.asp-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.asp-stats-grid div{background:color-mix(in srgb,var(--asp-surface) 84%,#fff 16%);border-radius:var(--asp-radius);padding:24px;text-align:center;border:1px solid color-mix(in srgb,var(--asp-contrast) 18%,transparent)}.asp-stats-grid strong{display:block;font-size:48px;line-height:1;font-weight:900}.asp-stats-grid span{display:block;margin-top:10px;color:var(--asp-muted);font-weight:900}.asp-price-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.asp-price-card{background:var(--asp-surface);border:1px solid color-mix(in srgb,var(--asp-contrast) 18%,transparent);border-radius:var(--asp-radius);padding:26px;position:relative;overflow:hidden}.asp-price-card.is-featured{background:var(--asp-accent);color:var(--asp-contrast);transform:translateY(-10px)}.asp-price-card:before{content:"";position:absolute;left:-60px;top:-60px;width:150px;height:150px;border:24px solid color-mix(in srgb,var(--asp-contrast) 16%,transparent);border-radius:50%}.asp-badge{display:inline-flex;padding:7px 13px;border-radius:999px;background:color-mix(in srgb,var(--asp-contrast) 15%,transparent);font-size:12px;font-weight:900}.asp-price-card h3{font-size:28px;margin:22px 0 10px}.asp-price{font-size:32px;font-weight:900;margin-bottom:20px}.asp-price-card ul{padding:0;margin:0 0 22px;list-style:none}.asp-price-card li{display:flex;gap:9px;margin:10px 0;color:var(--asp-muted)}.asp-price-card li span{color:var(--asp-icon);font-weight:900}.asp-price-card.is-featured li{color:var(--asp-contrast)}.asp-process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.asp-process-grid article{background:color-mix(in srgb,var(--asp-primary) 80%,#fff 20%);border:1px solid color-mix(in srgb,var(--asp-contrast) 18%,transparent);border-radius:var(--asp-radius);padding:24px}.asp-process-grid span{font-size:42px;color:var(--asp-accent);font-weight:900}.asp-process-grid h3{font-size:24px}.asp-work-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.asp-work-card{display:block;min-height:250px;background:var(--asp-surface);border-radius:var(--asp-radius);overflow:hidden;border:1px solid color-mix(in srgb,var(--asp-contrast) 16%,transparent);position:relative;padding:18px}.asp-work-card img,.asp-work-ph{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.52}.asp-work-ph{background:linear-gradient(135deg,color-mix(in srgb,var(--asp-accent) 58%,var(--asp-primary) 42%),color-mix(in srgb,var(--asp-surface) 72%,#000 28%))}.asp-work-card span,.asp-work-card h3{position:relative;z-index:1}.asp-work-card span{display:inline-flex;background:var(--asp-accent);border-radius:999px;padding:7px 12px;font-size:12px;font-weight:900}.asp-work-card h3{font-size:28px;margin-top:140px}.asp-blog{background:color-mix(in srgb,var(--asp-primary) 86%,#fff 14%)}.asp-blog-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.asp-blog-card{background:color-mix(in srgb,var(--asp-contrast) 96%,var(--asp-primary) 4%);color:var(--asp-primary);border-radius:var(--asp-radius);padding:26px;min-height:210px}.asp-blog-card h3{font-size:24px}.asp-blog-card p{color:color-mix(in srgb,var(--asp-primary) 70%,#777 30%)}.asp-blog-card a{color:var(--asp-accent);font-weight:900}.asp-extra-content{background:color-mix(in srgb,var(--asp-contrast) 96%,var(--asp-primary) 4%);color:#172033;border-radius:var(--asp-radius);padding:28px}.asp-cta-box{background:var(--asp-surface);border-radius:calc(var(--asp-radius) + 8px);padding:48px;border:1px solid color-mix(in srgb,var(--asp-contrast) 18%,transparent);text-align:center}.asp-cta-box h2{font-size:clamp(34px,5vw,76px);margin:0 0 14px;font-weight:900}.asp-cta-box p{max-width:720px;margin:0 auto 22px;color:var(--asp-muted);line-height:1.9}.asp-footer{padding:28px 0;background:color-mix(in srgb,var(--asp-primary) 80%,#000 20%)}.asp-footer .asp-container{display:flex;justify-content:space-between;gap:14px;color:var(--asp-muted)}
@media(max-width:1100px){.asp-service-grid,.asp-price-grid{grid-template-columns:repeat(2,1fr)}.asp-hero-grid{grid-template-columns:1fr}.asp-hero-art{min-height:380px}.asp-work-grid,.asp-blog-grid{grid-template-columns:1fr 1fr}.asp-process-grid,.asp-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:760px){.asp-container{width:min(100% - 24px,1180px)}.asp-section{padding:46px 0}.asp-nav{height:auto;min-height:72px;flex-wrap:wrap;padding:10px 0}.asp-menu{order:3;width:100%;overflow-x:auto;gap:14px;padding-bottom:8px}.asp-phone{padding:10px 13px}.asp-hero{padding-top:44px}.asp-title-row{display:block}.asp-title-row b{display:block;margin-top:12px}.asp-section-line{height:8px;width:80px;margin-bottom:16px}.asp-service-grid,.asp-price-grid,.asp-work-grid,.asp-blog-grid,.asp-process-grid,.asp-stats-grid{grid-template-columns:1fr}.asp-price-card.is-featured{transform:none}.asp-footer .asp-container{display:block;text-align:center}.asp-logo strong{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}

/* ZOC_AGENCY_STUDIO_PRO_STAGE4D_STICKY_MOBILE_MENU */
.asp-root{padding-top:0!important}.asp-topbar{position:fixed!important;top:0!important;left:0!important;right:0!important;width:100%!important;z-index:9999!important;box-shadow:0 12px 34px rgba(0,0,0,.12)}.asp-menu-toggle,.asp-menu-close,.asp-menu-title,.asp-mobile-phone,.asp-menu-overlay{display:none}.asp-menu-toggle{width:46px;height:46px;border:1px solid color-mix(in srgb,var(--asp-contrast) 24%,transparent);border-radius:14px;background:color-mix(in srgb,var(--asp-surface) 86%,#000 14%);color:var(--asp-contrast);cursor:pointer;place-items:center;padding:9px}.asp-menu-toggle span{display:block;width:23px;height:3px;border-radius:999px;background:var(--asp-contrast);margin:3px auto;transition:transform .22s ease,opacity .22s ease}.asp-menu-close{border:0;background:var(--asp-accent);color:var(--asp-contrast);width:42px;height:42px;border-radius:14px;font-size:30px;line-height:1;cursor:pointer;font-weight:900}.asp-menu-title{font-size:18px;font-weight:900;margin:4px 0 12px;color:var(--asp-contrast)}
@media(max-width:760px){.asp-root{padding-top:0!important;overflow-x:hidden}.asp-nav{height:72px!important;min-height:72px!important;flex-wrap:nowrap!important;padding:0!important}.asp-logo{min-width:0}.asp-logo img{max-width:116px;max-height:38px}.asp-logo-mark{width:40px;height:40px;border-radius:12px}.asp-logo strong{max-width:155px}.asp-logo small{display:none}.asp-menu-toggle{display:block;order:3;flex:0 0 auto}.asp-phone{display:none!important}.asp-menu-overlay{display:block;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:9998;opacity:0;visibility:hidden;transition:opacity .22s ease,visibility .22s ease}.asp-menu{position:fixed!important;top:0!important;right:0!important;bottom:0!important;width:min(340px,88vw)!important;height:100vh!important;z-index:9999!important;background:linear-gradient(180deg,color-mix(in srgb,var(--asp-surface) 92%,#000 8%),color-mix(in srgb,var(--asp-primary) 86%,#000 14%))!important;border-left:1px solid color-mix(in srgb,var(--asp-contrast) 20%,transparent);box-shadow:-24px 0 60px rgba(0,0,0,.32);display:flex!important;flex-direction:column!important;align-items:stretch!important;gap:8px!important;overflow-y:auto!important;overflow-x:hidden!important;padding:18px!important;transform:translateX(112%);visibility:hidden;transition:transform .28s ease,visibility .28s ease}.asp-menu-close,.asp-menu-title,.asp-mobile-phone{display:inline-flex}.asp-menu a{width:100%;min-height:48px;align-items:center;display:flex;padding:12px 14px;border-radius:16px;background:color-mix(in srgb,var(--asp-contrast) 8%,transparent);font-weight:900}.asp-menu a:hover{background:color-mix(in srgb,var(--asp-accent) 78%,transparent)}.asp-mobile-phone{margin-top:10px;background:var(--asp-accent)!important;justify-content:center;color:var(--asp-contrast)!important}.asp-menu-open .asp-menu{transform:translateX(0);visibility:visible}.asp-menu-open .asp-menu-overlay{opacity:1;visibility:visible}.asp-menu-open .asp-menu-toggle span:nth-child(1){transform:translateY(6px) rotate(45deg)}.asp-menu-open .asp-menu-toggle span:nth-child(2){opacity:0}.asp-menu-open .asp-menu-toggle span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}}
@media(min-width:761px){.asp-menu{position:static!important;transform:none!important;visibility:visible!important}.asp-menu-overlay{display:none!important}}


/* ZOC_AGENCY_STUDIO_PRO_STAGE4E_BLOG_FONT_SCOPE */
.asp-root h1,.asp-root h2,.asp-root h3,.asp-title-row b{font-family:var(--asp-heading-font,var(--asp-font))!important}.asp-topbar,.asp-menu,.asp-logo,.asp-phone{font-family:var(--asp-nav-font,var(--asp-font))!important}.asp-service-card,.asp-price-card,.asp-work-card,.asp-blog-card,.asp-stat-card{font-family:var(--asp-card-font,var(--asp-font))!important}.asp-article,.asp-article-body,.asp-blog-list{font-family:var(--asp-article-font,var(--asp-font))!important}.asp-inner{background:var(--asp-bg,var(--asp-primary));min-height:100vh}.asp-blog-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.asp-blog-list .asp-blog-card{min-height:240px}.asp-blog-card time{display:block;color:color-mix(in srgb,var(--asp-primary) 58%,#777 42%);font-size:12px;font-weight:900;margin-bottom:8px}.asp-pagination{display:flex;gap:8px;justify-content:center;margin-top:28px;flex-wrap:wrap}.asp-pagination a,.asp-pagination span{min-width:42px;height:42px;border-radius:999px;display:grid;place-items:center;background:var(--asp-surface);border:1px solid color-mix(in srgb,var(--asp-contrast) 18%,transparent);font-weight:900}.asp-pagination .is-active{background:var(--asp-accent);color:var(--asp-contrast)}.asp-article{background:color-mix(in srgb,var(--asp-contrast) 96%,var(--asp-primary) 4%);color:#172033;border-radius:var(--asp-radius);padding:clamp(24px,4vw,54px);line-height:2.1}.asp-article h1{font-size:clamp(36px,6vw,82px);line-height:1.08;margin:0 0 24px;color:var(--asp-primary)}.asp-article-body{font-size:18px}.asp-article-body img{max-width:100%;height:auto;border-radius:22px}.asp-article-meta{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px;color:color-mix(in srgb,var(--asp-primary) 70%,#777 30%);font-weight:900}.asp-empty{border:1px dashed color-mix(in srgb,var(--asp-contrast) 35%,transparent);border-radius:var(--asp-radius);padding:40px;text-align:center;color:var(--asp-muted)}
@media(max-width:900px){.asp-blog-list{grid-template-columns:1fr}}

/* ZOC_AGENCY_STAGE4F_STRONG_BACKGROUND */
html:has(.asp-root),body:has(.asp-root),.asp-root,.asp-inner{background:var(--asp-bg,var(--asp-primary))!important;}
.asp-root{isolation:isolate;}


/* ZOC_AGENCY_STAGE4H_BG_LINK_FIX */
.asp-root[data-template="agency_studio_pro"]{background:var(--asp-bg,var(--asp-primary))!important;background-color:var(--asp-bg,var(--asp-primary))!important;}
.asp-root[data-template="agency_studio_pro"] .asp-inner,
.asp-root[data-template="agency_studio_pro"] .asp-section,
.asp-root[data-template="agency_studio_pro"] .asp-hero,
.asp-root[data-template="agency_studio_pro"] .asp-services,
.asp-root[data-template="agency_studio_pro"] .asp-stats,
.asp-root[data-template="agency_studio_pro"] .asp-packages,
.asp-root[data-template="agency_studio_pro"] .asp-process,
.asp-root[data-template="agency_studio_pro"] .asp-portfolio,
.asp-root[data-template="agency_studio_pro"] .asp-cta{background:var(--asp-bg,var(--asp-primary))!important;background-color:var(--asp-bg,var(--asp-primary))!important;}

/* ZOC_AGENCY_STAGE4L_CSS_ONLY_BG_FIX
   Safe color fix: uses the --asp-bg already printed by home.php/section.php/post.php.
   Does not replace any template view and does not change header markup. */
html:has(.asp-root[data-template="agency_studio_pro"]),
body:has(.asp-root[data-template="agency_studio_pro"]){
  background: var(--asp-bg, var(--asp-primary)) !important;
  background-color: var(--asp-bg, var(--asp-primary)) !important;
}
.asp-root[data-template="agency_studio_pro"]{
  background: var(--asp-bg, var(--asp-primary)) !important;
  background-color: var(--asp-bg, var(--asp-primary)) !important;
}
.asp-root[data-template="agency_studio_pro"] .asp-hero,
.asp-root[data-template="agency_studio_pro"] .asp-services,
.asp-root[data-template="agency_studio_pro"] .asp-stats,
.asp-root[data-template="agency_studio_pro"] .asp-packages,
.asp-root[data-template="agency_studio_pro"] .asp-process,
.asp-root[data-template="agency_studio_pro"] .asp-portfolio,
.asp-root[data-template="agency_studio_pro"] .asp-blog,
.asp-root[data-template="agency_studio_pro"] .asp-cta{
  background: var(--asp-bg, var(--asp-primary)) !important;
  background-color: var(--asp-bg, var(--asp-primary)) !important;
}
/* keep header designed from primary, but allow it to follow chosen color if primary is same as bg */
.asp-root[data-template="agency_studio_pro"] .asp-footer{
  background: color-mix(in srgb, var(--asp-bg, var(--asp-primary)) 82%, #000 18%) !important;
}


/* ZOC_AGENCY_STAGE4O_STRIP_FIX: remove stale blue TemplateLayout/root strip without changing the header design */
html:has(.asp-root[data-template="agency_studio_pro"]),
body:has(.asp-root[data-template="agency_studio_pro"]){background:var(--asp-bg,#800d41)!important;background-color:var(--asp-bg,#800d41)!important;}
.asp-root[data-template="agency_studio_pro"]{background:var(--asp-bg,var(--asp-primary,#800d41))!important;background-color:var(--asp-bg,var(--asp-primary,#800d41))!important;}
.asp-root[data-template="agency_studio_pro"] > .asp-root[data-template="agency_studio_pro"]{margin-top:0!important;}
.asp-root[data-template="agency_studio_pro"] > .asp-topbar + .asp-root,
.asp-root[data-template="agency_studio_pro"] > header + main,
.asp-root[data-template="agency_studio_pro"] > .asp-topbar + main{background:var(--asp-bg,var(--asp-primary,#800d41))!important;background-color:var(--asp-bg,var(--asp-primary,#800d41))!important;}
.asp-root[data-template="agency_studio_pro"] .asp-hero,
.asp-root[data-template="agency_studio_pro"] .asp-services,
.asp-root[data-template="agency_studio_pro"] .asp-stats,
.asp-root[data-template="agency_studio_pro"] .asp-packages,
.asp-root[data-template="agency_studio_pro"] .asp-process,
.asp-root[data-template="agency_studio_pro"] .asp-portfolio,
.asp-root[data-template="agency_studio_pro"] .asp-cta{background-color:var(--asp-bg,var(--asp-primary,#800d41))!important;}
/* Blue/old-primary bars created by stale outer roots are forced to current tenant background. */
.asp-root[data-template="agency_studio_pro"] [style*="#1f3f6d"],
.asp-root[data-template="agency_studio_pro"] [style*="31,63,109"]{background-color:var(--asp-bg,var(--asp-primary,#800d41))!important;}
/* ZOC_AGENCY_STAGE4P_REMOVE_TOP_GAP
   The fixed header already reserves its own height visually. The old .asp-root{padding-top:0!important}
   created a fake strip under the menu, especially with nested TemplateLayout roots. Remove only that strip. */
.asp-root[data-template="agency_studio_pro"]{padding-top:0!important;}
.asp-root[data-template="agency_studio_pro"] > .asp-root[data-template="agency_studio_pro"]{padding-top:0!important;margin-top:0!important;}
.asp-root[data-template="agency_studio_pro"] .asp-root[data-template="agency_studio_pro"]{padding-top:0!important;margin-top:0!important;}
.asp-root[data-template="agency_studio_pro"] > header.asp-topbar + main.asp-root,
.asp-root[data-template="agency_studio_pro"] > header.asp-topbar + .asp-root,
.asp-root[data-template="agency_studio_pro"] > .asp-topbar + main,
.asp-root[data-template="agency_studio_pro"] > .asp-topbar + .asp-root{margin-top:0!important;padding-top:0!important;}
.asp-root[data-template="agency_studio_pro"] .asp-hero{margin-top:0!important;}
@supports selector(:has(*)){
  body:has(.asp-root[data-template="agency_studio_pro"]) .asp-root[data-template="agency_studio_pro"]{padding-top:0!important;}
}
/* ZOC_AGENCY_STAGE4Q_REMOVE_ROOT_GAP
   The header is fixed/sticky; the old root padding created a fake strip under the menu. */
.asp-root[data-template="agency_studio_pro"]{padding-top:0!important;margin-top:0!important;}
.asp-root[data-template="agency_studio_pro"] > .asp-root[data-template="agency_studio_pro"]{padding-top:0!important;margin-top:0!important;}
body:has(.asp-root[data-template="agency_studio_pro"]) .asp-root[data-template="agency_studio_pro"]{padding-top:0!important;}
@media(max-width:760px){.asp-root[data-template="agency_studio_pro"]{padding-top:0!important;}}
/* ZOC_AGENCY_STAGE4S_GAP_ZERO */
.asp-root[data-template="agency_studio_pro"]{padding-top:0!important;margin-top:0!important;}
.asp-root[data-template="agency_studio_pro"] .asp-root[data-template="agency_studio_pro"]{padding-top:0!important;margin-top:0!important;}
body:has(.asp-root[data-template="agency_studio_pro"]) .asp-root[data-template="agency_studio_pro"]{padding-top:0!important;}

/* ZOC_AGENCY_STAGE4AE_SITE_MEDIA_CSS */
.asp-hero-media, .asp-hero-art video.asp-hero-image{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(1.05) contrast(1.05);opacity:.88;background:#000;z-index:1}.asp-hero-art video.asp-hero-image{pointer-events:auto}.asp-hero-art .asp-stat-card{z-index:3}.asp-work-card .asp-work-media,.asp-work-card video.asp-work-media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.72;background:#000}.asp-work-card video.asp-work-media{pointer-events:auto}.asp-work-card:has(video.asp-work-media){cursor:default}.am-image-preview video{width:100%;max-height:220px;object-fit:contain;background:#000;border-radius:12px}

/* ZOC_AGENCY_STAGE4AN_CSS_ONLY_PORTFOLIO_FIX_START
   CSS-only fix. Do not modify PHP/view/layout/menu.
*/
html body .asp-root[data-template="agency_studio_pro"] .asp-work-card{
  position:relative!important;
  overflow:hidden!important;
  isolation:isolate!important;
  background-size:cover!important;
  background-position:center!important;
  background-repeat:no-repeat!important;
}
html body .asp-root[data-template="agency_studio_pro"] .asp-work-card[data-asp-work-media="image"]{
  background-image:var(--asp-work-media-url)!important;
  background-size:cover!important;
  background-position:center!important;
  background-repeat:no-repeat!important;
}
html body .asp-root[data-template="agency_studio_pro"] .asp-work-card[data-asp-work-media] > .asp-work-ph,
html body .asp-root[data-template="agency_studio_pro"] .asp-work-card[data-asp-work-media] > img:not(.asp-stage4al-video):not(.asp-work-video-bg),
html body .asp-root[data-template="agency_studio_pro"] .asp-work-card[data-asp-work-media] > .asp-work-media,
html body .asp-root[data-template="agency_studio_pro"] .asp-work-card[data-asp-work-media] > .asp-stage4ah-media,
html body .asp-root[data-template="agency_studio_pro"] .asp-work-card[data-asp-work-media] > video.asp-work-media,
html body .asp-root[data-template="agency_studio_pro"] .asp-work-card[data-asp-work-media] > video.asp-work-uploaded-media{
  display:none!important;
  opacity:0!important;
  visibility:hidden!important;
  pointer-events:none!important;
}
html body .asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-video-shade,
html body .asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-stage4al-video + .asp-work-video-shade{
  display:none!important;
  background:none!important;
}
html body .asp-root[data-template="agency_studio_pro"] .asp-work-card[data-asp-work-media]::before,
html body .asp-root[data-template="agency_studio_pro"] .asp-work-card[data-asp-work-media]::after{
  content:none!important;
  display:none!important;
  background:none!important;
  opacity:0!important;
}
html body .asp-root[data-template="agency_studio_pro"] .asp-work-card[data-asp-work-media] > *:not(.asp-stage4al-video):not(.asp-work-video-bg):not(.asp-work-ph){
  position:relative!important;
  z-index:2!important;
}
html body .asp-root[data-template="agency_studio_pro"] .asp-work-card h3{
  position:absolute!important;
  right:18px!important;
  left:18px!important;
  bottom:56px!important;
  margin:0!important;
  z-index:4!important;
  max-width:calc(100% - 36px)!important;
  font-size:24px!important;
  line-height:1.35!important;
  color:#fff!important;
  text-shadow:0 4px 18px rgba(0,0,0,.50)!important;
}
html body .asp-root[data-template="agency_studio_pro"] .asp-work-card span{
  position:absolute!important;
  right:18px!important;
  bottom:18px!important;
  z-index:5!important;
  margin:0!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  max-width:calc(100% - 36px)!important;
  min-height:32px!important;
  padding:8px 14px!important;
  border-radius:999px!important;
  background:var(--asp-accent)!important;
  color:var(--asp-contrast)!important;
  font-size:12px!important;
  font-weight:900!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  box-shadow:0 10px 24px rgba(0,0,0,.24)!important;
}
html body .asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-btn,
html body .asp-root[data-template="agency_studio_pro"] .asp-work-card button,
html body .asp-root[data-template="agency_studio_pro"] .asp-work-card [class*="work-btn"],
html body .asp-root[data-template="agency_studio_pro"] .asp-work-card [class*="portfolio-btn"]{
  position:absolute!important;
  left:18px!important;
  bottom:18px!important;
  z-index:5!important;
  margin:0!important;
}
@media(max-width:760px){
  html body .asp-root[data-template="agency_studio_pro"] .asp-work-card h3{right:14px!important;left:14px!important;bottom:50px!important;font-size:20px!important;}
  html body .asp-root[data-template="agency_studio_pro"] .asp-work-card span{right:14px!important;bottom:14px!important;max-width:calc(100% - 28px)!important;}
  html body .asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-btn,
  html body .asp-root[data-template="agency_studio_pro"] .asp-work-card button,
  html body .asp-root[data-template="agency_studio_pro"] .asp-work-card [class*="work-btn"],
  html body .asp-root[data-template="agency_studio_pro"] .asp-work-card [class*="portfolio-btn"]{left:14px!important;bottom:14px!important;}
}
/* ZOC_AGENCY_STAGE4AN_CSS_ONLY_PORTFOLIO_FIX_END */

/* ZOC_AGENCY_STAGE4AX_PORTFOLIO_TRUE_SINGLE_FRAME_START */
/* Final single-frame portfolio rendering. The card itself is NOT the image. */
.asp-root[data-template="agency_studio_pro"] .asp-work-grid{
  align-items:start!important;
  row-gap:26px!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-card{
  position:relative!important;
  display:flex!important;
  flex-direction:column!important;
  gap:9px!important;
  height:auto!important;
  min-height:0!important;
  padding:0!important;
  margin:0!important;
  overflow:visible!important;
  border:none!important;
  box-shadow:none!important;
  background:none!important;
  background-image:none!important;
  background-color:transparent!important;
  background-size:auto!important;
  background-position:initial!important;
  background-repeat:no-repeat!important;
  transform:none!important;
  cursor:default!important;
}
/* Disable every older pseudo/media duplication layer. */
.asp-root[data-template="agency_studio_pro"] .asp-work-card::before,
.asp-root[data-template="agency_studio_pro"] .asp-work-card::after{
  content:none!important;
  display:none!important;
  background:none!important;
}
/* Real single image frame, injected by JS. */
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-media-frame{
  order:0!important;
  position:relative!important;
  display:block!important;
  width:100%!important;
  height:clamp(165px,17vw,215px)!important;
  min-height:165px!important;
  max-height:215px!important;
  border-radius:28px!important;
  overflow:hidden!important;
  background-size:cover!important;
  background-position:center center!important;
  background-repeat:no-repeat!important;
  background-color:color-mix(in srgb,var(--asp-primary) 72%,#000 28%)!important;
  box-shadow:0 20px 44px rgba(0,0,0,.20)!important;
  border:1px solid rgba(255,255,255,.08)!important;
  isolation:isolate!important;
  transition:filter .72s ease, box-shadow .72s ease, transform .72s ease!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-media-frame::before{
  content:""!important;
  position:absolute!important;
  inset:0!important;
  z-index:2!important;
  pointer-events:none!important;
  background:
    linear-gradient(45deg, rgba(255,255,255,.18) 25%, transparent 25% 75%, rgba(255,255,255,.18) 75%),
    linear-gradient(45deg, rgba(0,0,0,.18) 25%, transparent 25% 75%, rgba(0,0,0,.18) 75%)!important;
  background-position:0 0, 14px 14px!important;
  background-size:28px 28px!important;
  opacity:.62!important;
  mix-blend-mode:multiply!important;
  transition:opacity .95s ease, background-size .95s ease!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-card:hover .asp-work-media-frame::before,
.asp-root[data-template="agency_studio_pro"] .asp-work-card.is-asp-unmosaic .asp-work-media-frame::before,
.asp-root[data-template="agency_studio_pro"] .asp-work-card[data-asp-unmosaic="1"] .asp-work-media-frame::before{
  opacity:0!important;
  background-size:42px 42px!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-card:hover .asp-work-media-frame,
.asp-root[data-template="agency_studio_pro"] .asp-work-card.is-asp-unmosaic .asp-work-media-frame,
.asp-root[data-template="agency_studio_pro"] .asp-work-card[data-asp-unmosaic="1"] .asp-work-media-frame{
  filter:saturate(1.05) contrast(1.03)!important;
  box-shadow:0 24px 54px rgba(0,0,0,.25)!important;
  transform:translateY(-3px)!important;
}
/* Hide legacy internal media/placeholder elements. */
.asp-root[data-template="agency_studio_pro"] .asp-work-card > .asp-work-ph,
.asp-root[data-template="agency_studio_pro"] .asp-work-card > img,
.asp-root[data-template="agency_studio_pro"] .asp-work-card > picture,
.asp-root[data-template="agency_studio_pro"] .asp-work-card > video,
.asp-root[data-template="agency_studio_pro"] .asp-work-card > .asp-stage4al-video,
.asp-root[data-template="agency_studio_pro"] .asp-work-card > .asp-work-video-bg,
.asp-root[data-template="agency_studio_pro"] .asp-work-card > .asp-work-video-shade,
.asp-root[data-template="agency_studio_pro"] .asp-work-card > .asp-stage4ah-media,
.asp-root[data-template="agency_studio_pro"] .asp-work-card > .asp-work-media{
  display:none!important;
}
/* Category/tag is no longer displayed. */
.asp-root[data-template="agency_studio_pro"] .asp-work-card > span{
  display:none!important;
}
/* Title below the media only. */
.asp-root[data-template="agency_studio_pro"] .asp-work-card h3{
  order:1!important;
  position:static!important;
  display:block!important;
  width:auto!important;
  max-width:100%!important;
  margin:4px 0 0!important;
  padding:0 18px 0 0!important;
  color:var(--asp-contrast)!important;
  text-align:right!important;
  font-size:clamp(19px,2vw,28px)!important;
  line-height:1.25!important;
  text-shadow:none!important;
  white-space:normal!important;
  overflow:visible!important;
  overflow-wrap:anywhere!important;
  z-index:1!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-card h3::before{
  content:""!important;
  display:inline-block!important;
  width:10px!important;
  height:10px!important;
  margin-left:9px!important;
  border-radius:999px!important;
  background:var(--asp-accent)!important;
  box-shadow:0 0 0 6px color-mix(in srgb,var(--asp-accent) 18%,transparent)!important;
  vertical-align:.08em!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-card h3 a.asp-work-title-link{
  color:inherit!important;
  text-decoration:none!important;
  border-bottom:1px solid color-mix(in srgb,var(--asp-accent) 48%,transparent)!important;
  transition:color .25s ease,border-color .25s ease!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-card h3 a.asp-work-title-link:hover{
  color:color-mix(in srgb,var(--asp-accent) 65%,#fff 35%)!important;
  border-color:var(--asp-accent)!important;
}
@media (max-width:760px){
  .asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-media-frame{
    height:clamp(155px,42vw,210px)!important;
    min-height:155px!important;
    max-height:210px!important;
    border-radius:24px!important;
  }
  .asp-root[data-template="agency_studio_pro"] .asp-work-card h3{
    font-size:19px!important;
    padding-right:15px!important;
  }
}
/* ZOC_AGENCY_STAGE4AX_PORTFOLIO_TRUE_SINGLE_FRAME_END */

/* ZOC_AGENCY_STAGE4AY_PORTFOLIO_CAPTION_BAR_START */
/* Caption bar under portfolio media: {title}/{category}, same font size, no rounded corners. */
.asp-root[data-template="agency_studio_pro"] .asp-work-card{
  gap:0!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-card > h3,
.asp-root[data-template="agency_studio_pro"] .asp-work-card > span:not(.asp-work-caption-bar):not(.asp-work-caption-title):not(.asp-work-caption-category):not(.asp-work-caption-separator){
  display:none!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-caption-bar{
  position:static!important;
  order:50!important;
  direction:rtl!important;
  box-sizing:border-box!important;
  width:100%!important;
  min-width:0!important;
  max-width:100%!important;
  display:flex!important;
  flex-wrap:nowrap!important;
  align-items:center!important;
  justify-content:flex-start!important;
  gap:6px!important;
  margin:0!important;
  padding:12px 16px!important;
  border-radius:0!important;
  background:color-mix(in srgb,var(--asp-bg) 78%,transparent 22%)!important;
  background-color:color-mix(in srgb,var(--asp-bg) 86%,#fff 14%)!important;
  -webkit-backdrop-filter:blur(14px) saturate(1.05)!important;
  backdrop-filter:blur(14px) saturate(1.05)!important;
  border-top:1px solid color-mix(in srgb,var(--asp-contrast) 15%,transparent 85%)!important;
  color:var(--asp-contrast)!important;
  box-shadow:none!important;
  overflow:hidden!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-caption-title,
.asp-root[data-template="agency_studio_pro"] .asp-work-caption-title a,
.asp-root[data-template="agency_studio_pro"] .asp-work-caption-category,
.asp-root[data-template="agency_studio_pro"] .asp-work-caption-separator,
.asp-root[data-template="agency_studio_pro"] .asp-work-caption-brace{
  font-family:inherit!important;
  font-size:14px!important;
  font-weight:850!important;
  line-height:1.55!important;
  color:var(--asp-contrast)!important;
  text-decoration:none!important;
  white-space:nowrap!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-caption-title,
.asp-root[data-template="agency_studio_pro"] .asp-work-caption-category{
  min-width:0!important;
  max-width:46%!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  display:inline-block!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-caption-title a:hover{
  color:color-mix(in srgb,var(--asp-accent) 70%,var(--asp-contrast) 30%)!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-caption-separator,
.asp-root[data-template="agency_studio_pro"] .asp-work-caption-brace{
  flex:0 0 auto!important;
  opacity:.92!important;
}
@media (max-width:760px){
  .asp-root[data-template="agency_studio_pro"] .asp-work-caption-bar{padding:10px 12px!important;gap:4px!important;}
  .asp-root[data-template="agency_studio_pro"] .asp-work-caption-title,
  .asp-root[data-template="agency_studio_pro"] .asp-work-caption-title a,
  .asp-root[data-template="agency_studio_pro"] .asp-work-caption-category,
  .asp-root[data-template="agency_studio_pro"] .asp-work-caption-separator,
  .asp-root[data-template="agency_studio_pro"] .asp-work-caption-brace{font-size:13px!important;}
}
/* ZOC_AGENCY_STAGE4AY_PORTFOLIO_CAPTION_BAR_END */

/* ZOC_AGENCY_STAGE4AZ_PORTFOLIO_SQUARE_CAPTION_VISIBLE_START */
/* Square all portfolio corners and force the caption bar to be visible under the media frame. */
.asp-root[data-template="agency_studio_pro"] .asp-work-card,
.asp-root[data-template="agency_studio_pro"] .asp-work-card *,
.asp-root[data-template="agency_studio_pro"] .asp-work-card::before,
.asp-root[data-template="agency_studio_pro"] .asp-work-card::after{
  border-radius:0!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-card{
  position:relative!important;
  display:flex!important;
  flex-direction:column!important;
  gap:0!important;
  overflow:visible!important;
  height:auto!important;
  min-height:0!important;
  max-height:none!important;
  background:none!important;
  background-image:none!important;
  background-color:transparent!important;
  box-shadow:none!important;
  border:none!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-media-frame{
  order:0!important;
  position:relative!important;
  z-index:1!important;
  display:block!important;
  width:100%!important;
  height:clamp(165px,17vw,215px)!important;
  min-height:165px!important;
  max-height:215px!important;
  margin:0!important;
  padding:0!important;
  overflow:hidden!important;
  border-radius:0!important;
  background-size:cover!important;
  background-position:center center!important;
  background-repeat:no-repeat!important;
  box-sizing:border-box!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-media-frame::before,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-media-frame::after{
  border-radius:0!important;
}
/* Old text elements must not compete with the final caption bar. */
.asp-root[data-template="agency_studio_pro"] .asp-work-card > h3,
.asp-root[data-template="agency_studio_pro"] .asp-work-card > span:not(.asp-work-caption-bar):not(.asp-work-caption-title):not(.asp-work-caption-category):not(.asp-work-caption-separator):not(.asp-work-caption-brace){
  display:none!important;
}
/* Visible final caption bar: {title}/{category}; same font size, square corners, background-matched. */
.asp-root[data-template="agency_studio_pro"] .asp-work-card > .asp-work-caption-bar{
  order:1!important;
  position:relative!important;
  z-index:20!important;
  inset:auto!important;
  transform:none!important;
  direction:rtl!important;
  box-sizing:border-box!important;
  width:100%!important;
  min-height:44px!important;
  display:flex!important;
  flex-wrap:nowrap!important;
  align-items:center!important;
  justify-content:flex-start!important;
  gap:6px!important;
  margin:0!important;
  padding:11px 14px!important;
  border-radius:0!important;
  background:var(--asp-bg)!important;
  background-color:var(--asp-bg)!important;
  color:var(--asp-contrast)!important;
  border:0!important;
  border-top:1px solid color-mix(in srgb,var(--asp-contrast) 14%,transparent 86%)!important;
  box-shadow:none!important;
  overflow:hidden!important;
  opacity:1!important;
  visibility:visible!important;
  pointer-events:auto!important;
  -webkit-backdrop-filter:blur(12px) saturate(1.05)!important;
  backdrop-filter:blur(12px) saturate(1.05)!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption-title,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption-title a,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption-category,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption-separator,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption-brace{
  font-family:inherit!important;
  font-size:14px!important;
  font-weight:850!important;
  line-height:1.45!important;
  color:var(--asp-contrast)!important;
  text-decoration:none!important;
  white-space:nowrap!important;
  border-radius:0!important;
  background:transparent!important;
  box-shadow:none!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption-title,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption-category{
  display:inline-block!important;
  min-width:0!important;
  max-width:46%!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption-separator,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption-brace{
  flex:0 0 auto!important;
  opacity:.96!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption-title a:hover{
  color:color-mix(in srgb,var(--asp-accent) 70%,var(--asp-contrast) 30%)!important;
}
@media (max-width:760px){
  .asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-media-frame{
    height:clamp(155px,42vw,205px)!important;
    min-height:155px!important;
    max-height:205px!important;
  }
  .asp-root[data-template="agency_studio_pro"] .asp-work-card > .asp-work-caption-bar{min-height:40px!important;padding:9px 11px!important;gap:4px!important;}
  .asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption-title,
  .asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption-title a,
  .asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption-category,
  .asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption-separator,
  .asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption-brace{font-size:13px!important;}
}
/* ZOC_AGENCY_STAGE4AZ_PORTFOLIO_SQUARE_CAPTION_VISIBLE_END */

/* ZOC_AGENCY_STAGE4BA_CAPTION_INLINE_BLUR_START */
/* Keep the current Stage 4-AZ/AX layout. Only fix caption collision and replace mosaic with heavy blur. */
.asp-root[data-template="agency_studio_pro"] .asp-work-card,
.asp-root[data-template="agency_studio_pro"] .asp-work-card *{
  border-radius:0!important;
}
/* The caption bar must stay visible under the media, not absolute/overlapped. */
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption-bar,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-stage4ay-caption,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-stage4az-caption,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-meta,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-title-row{
  position:relative!important;
  inset:auto!important;
  top:auto!important;
  right:auto!important;
  bottom:auto!important;
  left:auto!important;
  z-index:8!important;
  display:flex!important;
  flex-direction:row!important;
  align-items:center!important;
  justify-content:flex-start!important;
  gap:0!important;
  flex-wrap:nowrap!important;
  width:100%!important;
  min-height:42px!important;
  height:auto!important;
  margin:0!important;
  padding:9px 12px!important;
  box-sizing:border-box!important;
  background:color-mix(in srgb,var(--asp-bg) 84%,#fff 16%)!important;
  color:var(--asp-contrast)!important;
  border-radius:0!important;
  overflow:hidden!important;
  line-height:1.65!important;
  white-space:nowrap!important;
  clear:both!important;
}
/* Force all caption children to sit inline and use the same font size. */
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption *,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption-bar *,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-stage4ay-caption *,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-stage4az-caption *,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-meta *,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-title-row *{
  position:static!important;
  display:inline!important;
  width:auto!important;
  max-width:none!important;
  min-width:0!important;
  margin:0!important;
  padding:0!important;
  background:transparent!important;
  box-shadow:none!important;
  border:0!important;
  border-radius:0!important;
  color:inherit!important;
  font-size:14px!important;
  font-weight:800!important;
  line-height:1.65!important;
  text-shadow:none!important;
  white-space:nowrap!important;
  overflow:visible!important;
  text-overflow:clip!important;
  vertical-align:baseline!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption a,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption-bar a,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-stage4ay-caption a,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-stage4az-caption a,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-title-link{
  text-decoration:none!important;
}
/* Legacy title/tag elements: keep them inline if the current patch still uses h3/span directly. */
.asp-root[data-template="agency_studio_pro"] .asp-work-card > h3,
.asp-root[data-template="agency_studio_pro"] .asp-work-card > span{
  position:static!important;
  display:inline!important;
  width:auto!important;
  max-width:none!important;
  margin:0!important;
  padding:0!important;
  background:transparent!important;
  box-shadow:none!important;
  border:0!important;
  border-radius:0!important;
  font-size:14px!important;
  font-weight:800!important;
  line-height:1.65!important;
  color:var(--asp-contrast)!important;
  text-shadow:none!important;
  white-space:nowrap!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-card > h3::before,
.asp-root[data-template="agency_studio_pro"] .asp-work-card > span::before,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption *::before,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption-bar *::before,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-stage4ay-caption *::before,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-stage4az-caption *::before{
  display:none!important;
  content:none!important;
}
/* Media frame: no repeated background and no rounded corners. */
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-media-frame,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-portfolio-media-frame,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-stage4ax-media-frame,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-media-frame,
.asp-root[data-template="agency_studio_pro"] .asp-work-card[data-asp-work-media="image"]::before{
  border-radius:0!important;
  background-size:cover!important;
  background-position:center center!important;
  background-repeat:no-repeat!important;
  overflow:hidden!important;
}
/* Remove every checker/mosaic overlay from prior patches. */
.asp-root[data-template="agency_studio_pro"] .asp-work-card::after,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-media-frame::after,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-portfolio-media-frame::after,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-stage4ax-media-frame::after,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-media-frame::after,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-mosaic-layer,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-checker-layer{
  display:none!important;
  opacity:0!important;
  content:none!important;
  background:none!important;
}
/* Heavy blur by default; smooth reveal on hover or click/toggle. */
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-media-frame,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-portfolio-media-frame,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-stage4ax-media-frame,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-media-frame,
.asp-root[data-template="agency_studio_pro"] .asp-work-card[data-asp-work-media="image"]::before,
.asp-root[data-template="agency_studio_pro"] .asp-work-card img,
.asp-root[data-template="agency_studio_pro"] .asp-work-card video{
  filter:blur(10px) saturate(.78) brightness(.82)!important;
  transform:translateZ(0) scale(1.035)!important;
  transition:filter .95s cubic-bezier(.2,.8,.2,1), transform .95s cubic-bezier(.2,.8,.2,1), opacity .95s ease!important;
  will-change:filter,transform!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-card:hover .asp-work-media-frame,
.asp-root[data-template="agency_studio_pro"] .asp-work-card:hover .asp-portfolio-media-frame,
.asp-root[data-template="agency_studio_pro"] .asp-work-card:hover .asp-stage4ax-media-frame,
.asp-root[data-template="agency_studio_pro"] .asp-work-card:hover .asp-media-frame,
.asp-root[data-template="agency_studio_pro"] .asp-work-card:hover[data-asp-work-media="image"]::before,
.asp-root[data-template="agency_studio_pro"] .asp-work-card:hover img,
.asp-root[data-template="agency_studio_pro"] .asp-work-card:hover video,
.asp-root[data-template="agency_studio_pro"] .asp-work-card.is-asp-clear .asp-work-media-frame,
.asp-root[data-template="agency_studio_pro"] .asp-work-card.is-asp-clear .asp-portfolio-media-frame,
.asp-root[data-template="agency_studio_pro"] .asp-work-card.is-asp-clear .asp-stage4ax-media-frame,
.asp-root[data-template="agency_studio_pro"] .asp-work-card.is-asp-clear .asp-media-frame,
.asp-root[data-template="agency_studio_pro"] .asp-work-card.is-asp-clear[data-asp-work-media="image"]::before,
.asp-root[data-template="agency_studio_pro"] .asp-work-card.is-asp-clear img,
.asp-root[data-template="agency_studio_pro"] .asp-work-card.is-asp-clear video,
.asp-root[data-template="agency_studio_pro"] .asp-work-card[data-asp-clear="1"] .asp-work-media-frame,
.asp-root[data-template="agency_studio_pro"] .asp-work-card[data-asp-clear="1"] .asp-portfolio-media-frame,
.asp-root[data-template="agency_studio_pro"] .asp-work-card[data-asp-clear="1"] .asp-stage4ax-media-frame,
.asp-root[data-template="agency_studio_pro"] .asp-work-card[data-asp-clear="1"] .asp-media-frame,
.asp-root[data-template="agency_studio_pro"] .asp-work-card[data-asp-clear="1"][data-asp-work-media="image"]::before,
.asp-root[data-template="agency_studio_pro"] .asp-work-card[data-asp-clear="1"] img,
.asp-root[data-template="agency_studio_pro"] .asp-work-card[data-asp-clear="1"] video{
  filter:blur(0) saturate(1) brightness(1)!important;
  transform:translateZ(0) scale(1)!important;
}
@media (max-width:760px){
  .asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption,
  .asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption-bar,
  .asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-stage4ay-caption,
  .asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-stage4az-caption,
  .asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-meta,
  .asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-title-row{
    padding:8px 10px!important;
    min-height:38px!important;
    overflow-x:auto!important;
  }
  .asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption *,
  .asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption-bar *,
  .asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-stage4ay-caption *,
  .asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-stage4az-caption *,
  .asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-meta *,
  .asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-title-row *,
  .asp-root[data-template="agency_studio_pro"] .asp-work-card > h3,
  .asp-root[data-template="agency_studio_pro"] .asp-work-card > span{
    font-size:13px!important;
  }
}
/* ZOC_AGENCY_STAGE4BA_CAPTION_INLINE_BLUR_END */

/* ZOC_AGENCY_STAGE4BB_CAPTION_BOLD_HIDE_OVERLAY_TITLE_START */
/* Only requested change: make {title}/{category} larger and boldest, and remove duplicate title from image box. */
.asp-root[data-template="agency_studio_pro"] .asp-work-card > h3:not(.asp-work-caption):not(.asp-work-caption-title):not(.asp-work-title-link),
.asp-root[data-template="agency_studio_pro"] .asp-work-card > .asp-work-title:not(.asp-work-caption-title),
.asp-root[data-template="agency_studio_pro"] .asp-work-card > .asp-work-title-link:not(.asp-work-caption-title):not(.asp-work-caption-link){
  display:none!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-caption,
.asp-root[data-template="agency_studio_pro"] .asp-work-caption-bar,
.asp-root[data-template="agency_studio_pro"] .asp-work-meta-bar,
.asp-root[data-template="agency_studio_pro"] .asp-work-info-bar{
  font-size:clamp(18px,1.55vw,23px)!important;
  font-weight:1000!important;
  line-height:1.45!important;
}
.asp-root[data-template="agency_studio_pro"] .asp-work-caption *,
.asp-root[data-template="agency_studio_pro"] .asp-work-caption-bar *,
.asp-root[data-template="agency_studio_pro"] .asp-work-meta-bar *,
.asp-root[data-template="agency_studio_pro"] .asp-work-info-bar *{
  font-size:inherit!important;
  font-weight:1000!important;
  line-height:inherit!important;
}
/* Fallback for current structure where caption is rendered from h3/span below the frame. */
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-media-frame ~ h3,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-media-frame ~ span,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-media-frame ~ a,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-frame ~ h3,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-frame ~ span,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-frame ~ a{
  font-size:clamp(18px,1.55vw,23px)!important;
  font-weight:1000!important;
  line-height:1.45!important;
}
/* ZOC_AGENCY_STAGE4BB_CAPTION_BOLD_HIDE_OVERLAY_TITLE_END */

/* ZOC_AGENCY_STAGE4BC_CAPTION_BIGGER_BOLD_ONLY_START */
/* Only requested change: bigger/boldest {عنوان}/{دسته} caption + remove duplicate title over image. */
.asp-root[data-template="agency_studio_pro"] .asp-work-caption,
.asp-root[data-template="agency_studio_pro"] .asp-work-caption *,
.asp-root[data-template="agency_studio_pro"] .asp-work-title-link,
.asp-root[data-template="agency_studio_pro"] .asp-work-title-link *,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-caption,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-title-link{
  font-size:calc(1em + 4px)!important;
  font-weight:1000!important;
  font-variation-settings:"wght" 1000!important;
  line-height:1.35!important;
}
/* fallback selectors for captions built from original h3/span */
.asp-root[data-template="agency_studio_pro"] .asp-work-card[data-asp-stage4caption="1"] h3,
.asp-root[data-template="agency_studio_pro"] .asp-work-card[data-asp-stage4caption="1"] span,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-meta,
.asp-root[data-template="agency_studio_pro"] .asp-work-card .asp-work-meta *{
  font-size:calc(1em + 4px)!important;
  font-weight:1000!important;
  font-variation-settings:"wght" 1000!important;
  line-height:1.35!important;
}
/* remove duplicated overlay title that appears on the image; keep the caption below. */
.asp-root[data-template="agency_studio_pro"] .asp-work-card > h3:not(.asp-work-caption):not(.asp-work-title-link),
.asp-root[data-template="agency_studio_pro"] .asp-work-card > .asp-overlay-title,
.asp-root[data-template="agency_studio_pro"] .asp-work-card > .asp-media-title{
  display:none!important;
}
/* ZOC_AGENCY_STAGE4BC_CAPTION_BIGGER_BOLD_ONLY_END */
