*{box-sizing:border-box} html{scroll-behavior:smooth} body{margin:0;font-family:Inter,Arial,sans-serif;background:radial-gradient(circle at 50% 0%,rgba(255,255,255,.05),transparent 22%),var(--bg);color:var(--text);overflow-x:hidden} a{text-decoration:none;color:inherit}
    .container{width:min(calc(100% - 40px),var(--max));margin:0 auto}.header{position:fixed;inset:16px 0 auto;z-index:100;transition:transform .35s ease}.nav{display:grid;grid-template-columns:auto 1fr auto;gap:20px;align-items:center;padding:14px 18px;border:1px solid var(--line);background:rgba(8,8,8,.5);backdrop-filter:blur(16px);border-radius:999px;box-shadow:var(--shadow)}body[data-theme="light"] .nav{background:rgba(255,255,255,.78)}.brand{display:inline-flex;align-items:center;gap:12px;font-size:20px;font-weight:900}.brand-mark{width:48px;height:48px;border-radius:0;background:transparent!important;background-image:none!important;box-shadow:none!important;border:0!important;outline:0!important;display:grid;place-items:center;color:#fff;font-size:12px;font-weight:900;overflow:visible;padding:0;flex:0 0 48px}.brand-logo{width:100%;height:100%;display:block;object-fit:contain}.brand-text{font-weight:900;text-transform:uppercase;letter-spacing:.02em}.nav-links{display:flex;gap:26px;justify-self:center;color:var(--muted);font-size:14px}.nav-links a{position:relative;display:inline-flex;align-items:center;padding:4px 0;transition:color .25s ease}.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:left center;transition:transform .32s cubic-bezier(.22,.61,.36,1),opacity .25s ease;opacity:.9}.nav-links a:hover{color:var(--text)}.nav-links a:hover::after,.nav-links a:focus-visible::after{transform:scaleX(1)}.nav-actions{display:inline-flex;gap:10px;align-items:center}.lang-switcher,.theme-toggle{display:inline-flex;gap:4px;border:1px solid var(--line);background:rgba(255,255,255,.04);border-radius:999px;padding:4px}.lang-btn,.theme-btn{border:0;background:transparent;color:var(--muted);padding:6px 8px;border-radius:999px;font-size:11px;cursor:pointer;position:relative;min-width:44px}.theme-btn{min-width:50px}.lang-btn.active,.theme-btn.active{background:rgba(255,255,255,.14);color:var(--text)}.lang-text,.lang-flag,.theme-label,.theme-icon{position:absolute;inset:0;display:inline-flex;align-items:center;justify-content:center;transition:opacity .28s cubic-bezier(.22,.61,.36,1),transform .28s cubic-bezier(.22,.61,.36,1)}.lang-text,.theme-label{opacity:1;transform:translateY(0)}.lang-flag,.theme-icon{opacity:0;transform:translateY(6px) scale(.9)}.lang-btn:hover .lang-text,.theme-btn:hover .theme-label{opacity:0;transform:translateY(-6px) scale(.92)}.lang-btn:hover .lang-flag,.theme-btn:hover .theme-icon{opacity:1;transform:translateY(0) scale(1)}.lang-flag svg{width:18px;height:12px;border-radius:2px}.menu-btn{border:0;background:transparent;color:var(--text);font-size:22px;cursor:pointer}
    [data-lang-content]{display:none} body[data-lang="en"] [data-lang-content="en"],body[data-lang="de"] [data-lang-content="de"],body[data-lang="fa"] [data-lang-content="fa"]{display:inline}
    body[data-lang="fa"]{direction:rtl}
    .hero{min-height:100vh;padding:124px 0 34px;position:relative}.hero-grid{display:grid;grid-template-columns:1fr;min-height:calc(100vh - 158px);border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06);position:relative;overflow:visible}.hero-bottom{position:relative;display:grid;align-items:start;justify-items:center;padding:52px 24px 24px;border-left:0;text-align:center;gap:28px;min-height:calc(100vh - 158px);overflow:visible}.massive-title{font-size:clamp(88px,13.5vw,260px);line-height:.83;letter-spacing:-.09em;font-weight:900;margin:0;position:relative;text-align:center;justify-self:center;width:100%;overflow:visible}.massive-title>span{display:block;position:relative;overflow:visible;transition:transform 1.05s cubic-bezier(.22,.61,.36,1),opacity .95s ease;will-change:transform,opacity}.massive-title>span:nth-child(1){transform:translateX(-160px);opacity:0}.massive-title>span:nth-child(2){transform:translateY(22px);opacity:0}.massive-title>span:nth-child(3){transform:translateX(160px);opacity:0}.massive-title.active>span{transform:translateX(0) translateY(0);opacity:1}.massive-title.active>span:nth-child(2){transition-delay:.08s}.massive-title.active>span:nth-child(3){transition-delay:.04s}.massive-title>span>span{position:relative;color:transparent;-webkit-text-fill-color:transparent;background-image:radial-gradient(circle at 18% 48%,rgba(255,255,255,.95) 0 4%,transparent 5%),radial-gradient(circle at 42% 64%,rgba(255,255,255,.75) 0 3.5%,transparent 4.5%),radial-gradient(circle at 72% 34%,rgba(255,255,255,.88) 0 4%,transparent 5%),radial-gradient(circle at 88% 68%,rgba(255,255,255,.68) 0 3%,transparent 4%),linear-gradient(115deg,#8f8f8f 0%,#fff 12%,#bdbdbd 24%,#f7f7f7 38%,#8d8d8d 52%,#fff 66%,#c9c9c9 80%,#f3f3f3 100%);background-size:140% 140%,160% 160%,150% 150%,145% 145%,240% 240%;background-position:0 50%,25% 75%,80% 25%,100% 70%,0 50%;-webkit-background-clip:text;background-clip:text;animation:liquidTextFlow 7s linear infinite;filter:drop-shadow(0 0 10px rgba(255,255,255,.08))}.massive-title>span>span{display:none}body[data-lang="en"] .massive-title>span>span[data-lang-content="en"],body[data-lang="de"] .massive-title>span>span[data-lang-content="de"],body[data-lang="fa"] .massive-title>span>span[data-lang-content="fa"]{display:block}.services-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:22px;padding:26px 0 10px;margin-top:10px}.service-chip{border-top:1px solid rgba(255,255,255,.16);padding-top:12px;min-width:0}.service-chip small{display:block;color:var(--muted);font-size:12px;letter-spacing:.14em;margin-bottom:10px}.service-chip strong{display:block;font-size:clamp(18px,2vw,28px);line-height:1;letter-spacing:-.04em;font-weight:500}
    section{padding:70px 0 40px;position:relative}.selected-head,.services-head,.about-head{display:flex;justify-content:space-between;gap:20px;align-items:end;margin-bottom:24px}.selected-head small,.services-head small,.about-head small,.about-copy small{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.18em;margin-bottom:14px}.projects{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.project{display:grid;gap:10px;transform:translateY(60px) scale(.98);opacity:0;transition:opacity .9s ease,transform .9s cubic-bezier(.2,.7,.2,1)}.project.visible{opacity:1;transform:translateY(0) scale(1)}.thumb{position:relative;overflow:hidden;background:radial-gradient(circle at 25% 25%,rgba(255,255,255,.08),transparent 16%),linear-gradient(135deg,#171717,#090909);aspect-ratio:1.7/1;border:1px solid rgba(255,255,255,.06)}.thumb::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.14),rgba(0,0,0,0))}.thumb img{width:100%;height:100%;object-fit:cover;display:block}.play-btn{position:absolute;inset:0;margin:auto;width:64px;height:64px;border-radius:50%;border:1px solid rgba(255,255,255,.28);background:rgba(0,0,0,.48);backdrop-filter:blur(10px);display:grid;place-items:center;color:#fff;z-index:3;cursor:pointer;transition:transform .25s ease,background .25s ease}.play-btn:hover{transform:scale(1.08);background:rgba(255,255,255,.16)}.play-btn svg{width:22px;height:22px;margin-left:3px}.video-modal{position:fixed;inset:0;background:rgba(0,0,0,.86);display:none;align-items:center;justify-content:center;padding:24px;z-index:999}.video-modal.open{display:flex}.video-frame{width:min(1100px,94vw);background:#050505;border:1px solid rgba(255,255,255,.16);border-radius:20px;overflow:hidden;box-shadow:0 40px 120px rgba(0,0,0,.55)}.video-frame video{width:100%;display:block;max-height:78vh;background:#000}.video-close{position:fixed;top:22px;right:22px;width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.08);color:#fff;font-size:26px;cursor:pointer}.project h3{margin:0;font-size:clamp(24px,2.6vw,42px);line-height:.96;letter-spacing:-.06em;font-weight:500}.project p{margin:0;color:var(--muted);font-size:15px}.roll-title{display:inline-flex;flex-wrap:wrap;gap:0}.roll-title .char{position:relative;display:inline-block;overflow:hidden;height:1em;line-height:1em;vertical-align:top}.roll-title .char-inner{display:flex;flex-direction:column;transform:translateY(0);transition:transform .28s cubic-bezier(.2,.8,.2,1)}.roll-title .char-inner span{display:block;height:1em;line-height:1em}.roll-title:hover .char-inner{transform:translateY(-50%)}
    .services-showcase{display:grid;grid-template-columns:.95fr 1.05fr;gap:18px}.service-wall{border:1px solid rgba(255,255,255,.06);background:rgba(255,255,255,.02);min-height:580px;position:relative;overflow:hidden}.service-wall::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:44px 44px;opacity:.42;mask-image:linear-gradient(to bottom,rgba(0,0,0,.9),rgba(0,0,0,.35))}.service-stack{position:relative;z-index:1;padding:24px;display:grid;gap:18px}.service-panel{padding:20px 18px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.035);backdrop-filter:blur(8px);transform:translateX(-30px);opacity:0;transition:opacity .8s ease,transform .8s ease,background .25s ease}.service-panel:nth-child(1){transition-delay:0s}.service-panel:nth-child(2){transition-delay:.12s}.service-panel:nth-child(3){transition-delay:.24s}.service-panel h3,.service-panel p{opacity:0;transform:translateX(-20px);transition:opacity .55s ease,transform .55s cubic-bezier(.22,.61,.36,1)}.service-panel:nth-child(1).visible h3{transition-delay:.05s}.service-panel:nth-child(1).visible p{transition-delay:.12s}.service-panel:nth-child(2).visible h3{transition-delay:.17s}.service-panel:nth-child(2).visible p{transition-delay:.24s}.service-panel:nth-child(3).visible h3{transition-delay:.29s}.service-panel:nth-child(3).visible p{transition-delay:.36s}.service-panel.visible{opacity:1;transform:translateX(0);animation:cardPop .5s cubic-bezier(.22,.61,.36,1) both}.service-panel.visible h3,.service-panel.visible p{opacity:1;transform:translateX(0)}@keyframes cardPop{0%{transform:translateX(0) scale(.98)}60%{transform:translateX(0) scale(1.02)}100%{transform:translateX(0) scale(1)}}.service-panel h3{margin:0 0 10px;font-size:clamp(34px,4vw,66px);line-height:.9;letter-spacing:-.07em;font-weight:700;max-width:8ch}.service-panel p{margin:0;max-width:40ch;color:var(--muted)}
    .service-media{display:grid;gap:18px}.float-card,.stat-panel,.about-copy,.footer-card{border:1px solid rgba(255,255,255,.06);background:rgba(255,255,255,.025);overflow:hidden}.float-card,.stat-panel{transform:translateY(50px);opacity:0;transition:opacity .85s ease,transform .85s ease}.float-card.visible,.stat-panel.visible{opacity:1;transform:translateY(0)}.float-card{min-height:420px;background:radial-gradient(circle at 30% 25%,rgba(255,255,255,.08),transparent 18%),linear-gradient(135deg,#1b1b1b,#090909)}.stat-panel{padding:22px;display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.stat-box{padding:12px 0;border-top:1px solid rgba(255,255,255,.1)}.stat-box strong{display:block;font-size:clamp(32px,4vw,58px);line-height:.95;letter-spacing:-.06em;margin-bottom:6px;font-weight:700;transform:translateY(20px) scale(.98);opacity:0;transition:transform .8s cubic-bezier(.22,.61,.36,1),opacity .8s ease}.stat-box.visible strong{transform:translateY(0) scale(1);opacity:1}.stat-box strong.counting{transform:translateY(0) scale(1.04);transition:transform .2s ease}.stat-box span{color:var(--muted);font-size:13px;opacity:0;transform:translateY(10px);transition:transform .8s cubic-bezier(.22,.61,.36,1),opacity .8s ease;transition-delay:.1s}.stat-box.visible span{opacity:1;transform:translateY(0)}
    .about-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:center}.about-visual{width:min(100%,430px);aspect-ratio:1/1;min-height:0;justify-self:center;align-self:center;background:linear-gradient(135deg,#161616,#090909);transform:translateY(40px);opacity:0;transition:opacity .85s ease,transform .85s ease;position:relative;overflow:hidden}.about-visual::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 60% 35%,rgba(255,255,255,.08),transparent 18%),linear-gradient(120deg,rgba(255,255,255,.06),transparent 44%);z-index:1;pointer-events:none}.about-visual.has-media::before{background:linear-gradient(120deg,rgba(255,255,255,.08),transparent 42%)}.about-visual img,.about-visual video{width:100%;height:100%;min-height:0;display:block;object-fit:cover;position:relative;z-index:0}.about-visual.visible,.about-copy.visible{opacity:1;transform:translateY(0)}.about-copy{padding:28px;display:grid;align-content:space-between;transform:translateY(40px);opacity:0;transition:opacity .85s ease,transform .85s ease}.about-copy h2{margin:0 0 16px;font-size:clamp(44px,6vw,94px);line-height:.9;letter-spacing:-.08em;font-weight:700;max-width:8ch}.about-copy p{margin:0;max-width:40ch;color:var(--muted);font-size:16px;line-height:1.5}.about-link{margin-top:24px;display:inline-flex;gap:8px;color:#d2d2d2}
    .footer{padding:80px 0 26px}.footer-card{padding:30px;display:grid;grid-template-columns:1.2fr .8fr;gap:20px;transform:translateX(-140px);opacity:0;transition:opacity 1.15s cubic-bezier(.22,.61,.36,1),transform 1.35s cubic-bezier(.22,.61,.36,1)}.footer-card.visible{opacity:1;transform:translateX(0)}.footer-card h2{margin:0;font-size:clamp(46px,7vw,110px);line-height:.9;letter-spacing:-.08em;font-weight:800;max-width:9ch}.footer-actions{display:grid;gap:14px;align-content:end;justify-items:start}.contact-link{display:inline-flex;align-items:center;gap:10px}.contact-link svg{width:16px;height:16px;flex:0 0 16px}.footer-actions a{padding:12px 16px;border:1px solid rgba(255,255,255,.1);color:#e7e7e7;background:rgba(255,255,255,.03)}.footer-meta{margin-top:20px;padding-top:18px;border-top:1px solid rgba(255,255,255,.07);display:flex;justify-content:space-between;gap:18px;color:var(--muted);font-size:13px}
    .reveal{opacity:0;transform:translateY(40px);transition:opacity .95s ease,transform .95s cubic-bezier(.2,.7,.2,1)}.reveal.visible{opacity:1;transform:translateY(0)}
    .scroll-top{position:fixed;right:24px;bottom:24px;width:44px;height:44px;display:grid;place-items:center;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.12);color:var(--text);border-radius:50%;box-shadow:0 10px 30px rgba(0,0,0,.25);backdrop-filter:blur(18px) saturate(160%);cursor:pointer;z-index:120;transition:all .35s cubic-bezier(.22,.61,.36,1);overflow:hidden}.scroll-top::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.14),rgba(255,255,255,.03));opacity:.9}.scroll-top:hover{transform:translateY(-4px) scale(1.06)}.scroll-top .icon-wrap{position:relative;width:22px;height:22px}.scroll-top .icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:38px;font-weight:900}.scroll-top .icon-up{opacity:0}.scroll-top.is-up .icon-down{transform:translateY(-14px);opacity:0}.scroll-top.is-up .icon-up{opacity:1}.scroll-top.pulse{animation:scrollBtnPulse 1.8s ease-in-out infinite}
    .mobile-menu{position:fixed;top:82px;right:20px;width:min(320px,calc(100vw - 40px));padding:14px;border:1px solid var(--line);background:rgba(10,10,10,.88);backdrop-filter:blur(18px);box-shadow:var(--shadow);z-index:110;opacity:0;visibility:hidden;transform:translateY(-10px) scale(.98);transition:opacity .25s ease,transform .25s ease,visibility .25s ease}.mobile-menu.open{opacity:1;visibility:visible;transform:translateY(0) scale(1)}.mobile-menu-links{display:grid;gap:8px}.mobile-menu a{display:block;padding:12px 10px;border-radius:12px;color:var(--text);background:rgba(255,255,255,.03)}
    @keyframes liquidTextFlow{0%{background-position:0 50%,25% 75%,80% 25%,100% 70%,0 50%}50%{background-position:85% 45%,60% 20%,22% 78%,45% 30%,100% 50%}100%{background-position:0 50%,25% 75%,80% 25%,100% 70%,0 50%}}@keyframes scrollBtnPulse{0%,100%{box-shadow:var(--shadow)}50%{box-shadow:0 24px 90px rgba(255,255,255,.08)}}
    @media (max-width:1150px){.services-showcase,.about-grid,.footer-card,.projects{grid-template-columns:1fr}.about-visual{width:min(100%,390px)}.services-strip,.stat-panel{grid-template-columns:repeat(2,1fr)}} @media (max-width:780px){.container{width:min(calc(100% - 24px),var(--max))}.nav-links{display:none}.hero{padding-top:102px}.about-visual{width:min(86vw,320px)}.services-strip,.stat-panel{grid-template-columns:1fr}.footer-meta{flex-direction:column}.massive-title{font-size:clamp(62px,18vw,128px)}}

/* Dynamic project masonry: original ratio, no crop, no stretch */
.projects.masonry-projects{display:block;column-count:3;column-gap:18px;}
.projects.masonry-projects .project{break-inside:avoid;page-break-inside:avoid;margin:0 0 22px;display:grid;gap:10px;transform:translateY(60px) scale(.98);}
.projects.masonry-projects .thumb{aspect-ratio:auto;min-height:0;display:block;border:1px solid rgba(255,255,255,.06);background:radial-gradient(circle at 25% 25%,rgba(255,255,255,.08),transparent 16%),linear-gradient(135deg,#171717,#090909);}
.projects.masonry-projects .thumb.empty{min-height:240px;}
.projects.masonry-projects .thumb img,.projects.masonry-projects .thumb video{width:100%;height:auto;max-width:100%;display:block;object-fit:contain;}
.projects.masonry-projects .thumb::after{pointer-events:none;}
@media (max-width:1150px){.projects.masonry-projects{column-count:2;}}
@media (max-width:780px){.projects.masonry-projects{column-count:1;}}

/* Mobile/tablet header fix: logo + hamburger only; controls inside menu */
.mobile-menu-controls{display:none;gap:10px;margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}
.mobile-control-label{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.14em;margin:6px 0 2px}
.mobile-lang-switcher,.mobile-theme-toggle{display:flex;width:100%;justify-content:flex-start;gap:6px;padding:6px;border-radius:18px;background:rgba(255,255,255,.04);border:1px solid var(--line)}
.mobile-menu .lang-btn,.mobile-menu .theme-btn{min-width:56px;height:36px;position:relative}
.mobile-menu .theme-btn{min-width:74px}
.mobile-menu .lang-text,.mobile-menu .theme-label{position:relative;opacity:1;transform:none}
.mobile-menu .lang-flag,.mobile-menu .theme-icon{display:none}
.mobile-menu .lang-btn:hover .lang-text,.mobile-menu .theme-btn:hover .theme-label{opacity:1;transform:none}
@media (max-width:1024px){
  .header{inset:10px 0 auto}
  .container{width:min(calc(100% - 24px),var(--max))}
  .nav{grid-template-columns:auto auto;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:22px;width:100%;overflow:hidden}
  .brand{min-width:0;gap:10px;font-size:16px;line-height:1;max-width:calc(100vw - 92px);overflow:hidden}
  .brand .brand-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .brand-mark{width:42px;height:42px;border-radius:0;background:transparent!important;background-image:none!important;box-shadow:none!important;border:0!important;outline:0!important;flex:0 0 42px}
  .nav-links{display:none!important}
  .nav-actions{display:flex;justify-content:flex-end;gap:0;min-width:auto}
  .nav-actions>.lang-switcher,.nav-actions>.theme-toggle{display:none!important}
  .menu-btn{display:grid;place-items:center;width:42px;height:42px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.05);font-size:24px;line-height:1;flex:0 0 42px}
  .mobile-menu{top:76px;left:12px;right:12px;width:auto;max-height:calc(100vh - 94px);overflow:auto;border-radius:22px;padding:14px;background:rgba(10,10,10,.94)}
  body[data-theme="light"] .mobile-menu{background:rgba(245,245,243,.94)}
  .mobile-menu-links{gap:8px}
  .mobile-menu a{font-size:16px;padding:14px 12px;border-radius:14px}
  .mobile-menu-controls{display:grid}
  .hero{padding-top:100px}
}
@media (min-width:1025px){.menu-btn{display:none}.mobile-menu{display:none}}

/* Project preview update: homepage shows three square cards; all projects stay original-ratio. */
.view-all-link{font-weight:900;letter-spacing:.02em;color:var(--text);display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border:1px solid rgba(255,255,255,.12);border-radius:999px;background:rgba(255,255,255,.045);transition:transform .25s ease,background .25s ease,border-color .25s ease;}
.view-all-link:hover{transform:translateY(-2px);background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.22);}
.home-projects{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:start;}
.home-projects .project{display:grid;gap:12px;}
.home-projects .thumb.square-preview{aspect-ratio:1/1;width:100%;min-height:0;border-radius:0;overflow:hidden;background:radial-gradient(circle at 25% 25%,rgba(255,255,255,.08),transparent 16%),linear-gradient(135deg,#171717,#090909);border:1px solid rgba(255,255,255,.07);}
.home-projects .thumb.square-preview img,.home-projects .thumb.square-preview video{width:100%;height:100%;display:block;object-fit:cover;}
.home-projects .project h3{font-size:clamp(24px,2.2vw,38px);}
.media-badge{position:absolute;left:12px;top:12px;z-index:4;display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border-radius:999px;background:rgba(0,0,0,.58);border:1px solid rgba(255,255,255,.16);color:#fff;font-size:11px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;backdrop-filter:blur(10px);}
.media-badge.is-video::before{content:'';width:0;height:0;border-top:5px solid transparent;border-bottom:5px solid transparent;border-left:8px solid currentColor;display:inline-block;}
.media-badge.is-image::before{content:'';width:9px;height:9px;border:1px solid currentColor;border-radius:2px;display:inline-block;}
.thumb video{display:block;background:#050505;}
.thumb:has(video)::before{content:'';position:absolute;inset:0;z-index:2;pointer-events:none;background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.08) 45%,transparent 62%);transform:translateX(-120%);animation:videoPreviewSheen 3.2s ease-in-out infinite;}
@keyframes videoPreviewSheen{0%,45%{transform:translateX(-120%)}75%,100%{transform:translateX(120%)}}
.projects-page-main{padding-top:112px;}
.all-projects-hero{padding:70px 0 20px;}
.all-projects-head{display:flex;justify-content:space-between;gap:24px;align-items:end;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:24px;}
.all-projects-head small{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.18em;margin-bottom:14px;}
.all-projects-head h1{margin:0;font-size:clamp(52px,8vw,128px);line-height:.9;letter-spacing:-.08em;font-weight:900;}
.all-projects-section{padding-top:28px;}
.back-home-link{white-space:nowrap;}
.all-projects-grid .thumb.original-ratio img,.all-projects-grid .thumb.original-ratio video{width:100%;height:auto;max-width:100%;object-fit:contain;display:block;}
@media (max-width:1150px){.home-projects{grid-template-columns:repeat(3,1fr);gap:16px}.selected-head{align-items:start}.all-projects-head{align-items:start;flex-direction:column}.projects-page-main{padding-top:96px}}
@media (max-width:780px){.home-projects{grid-template-columns:1fr;gap:22px}.home-projects .thumb.square-preview{aspect-ratio:1/1}.view-all-link{width:100%;justify-content:center}.selected-head{display:grid;gap:14px}.projects-page-main{padding-top:88px}.all-projects-hero{padding-top:42px}.all-projects-head h1{font-size:clamp(42px,16vw,82px)}}

/* Image lightbox modal */
.thumb.has-image-lightbox{cursor:zoom-in;}
.thumb.has-image-lightbox img{transition:transform .45s cubic-bezier(.22,.61,.36,1),filter .45s ease;}
.thumb.has-image-lightbox:hover img{transform:scale(1.025);filter:brightness(1.04);}
.image-modal{position:fixed;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);display:none;align-items:center;justify-content:center;padding:28px;z-index:1000;}
.image-modal.open{display:flex;}
.image-frame{width:auto;max-width:min(1180px,94vw);max-height:86vh;border:1px solid rgba(255,255,255,.18);border-radius:24px;overflow:hidden;background:rgba(255,255,255,.04);box-shadow:0 44px 140px rgba(0,0,0,.62), inset 0 1px 0 rgba(255,255,255,.08);}
.image-frame img{display:block;width:auto;height:auto;max-width:94vw;max-height:86vh;object-fit:contain;background:#050505;}
.image-close{position:fixed;top:22px;right:22px;width:46px;height:46px;border-radius:50%;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.10);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);color:#fff;font-size:28px;line-height:1;cursor:pointer;z-index:1001;transition:transform .22s ease,background .22s ease;}
.image-close:hover{transform:scale(1.06);background:rgba(255,255,255,.18);}
@media (max-width:780px){.image-modal{padding:16px}.image-frame{max-width:96vw;max-height:82vh;border-radius:18px}.image-frame img{max-width:96vw;max-height:82vh}.image-close{top:14px;right:14px;width:42px;height:42px}}


/* Scroll jitter fix: keep hero service chips stable while scrolling */
.services-strip,
.service-chip,
.service-chip strong,
.service-chip small{
  backface-visibility:hidden;
  -webkit-font-smoothing:antialiased;
  transform:translateZ(0);
}

/* Remove the empty decorative visual box in the Services section */
.service-media .float-card{
  display:none !important;
}
.service-media{
  align-content:start;
}
.service-media .stat-panel{
  margin-top:0;
}

/* Services stats layout fix: desktop stats move under service cards; mobile/tablet stats stay in one compact row */
@media (min-width:1151px){
  .services-showcase{
    grid-template-columns:.95fr 1.05fr;
    align-items:start;
  }
  .service-wall{
    grid-column:1;
    grid-row:1;
  }
  .service-media{
    grid-column:1;
    grid-row:2;
    display:block;
    width:100%;
  }
  .service-media .stat-panel{
    width:100%;
    margin-top:18px;
  }
}

@media (max-width:1150px){
  .service-media .stat-panel{
    grid-template-columns:repeat(3,minmax(0,1fr)) !important;
    gap:10px;
    padding:18px;
  }
  .stat-box{
    min-width:0;
    padding:10px 0;
  }
  .stat-box strong{
    font-size:clamp(28px,8vw,52px);
    white-space:nowrap;
  }
  .stat-box span{
    display:block;
    font-size:clamp(10px,2.7vw,13px);
    line-height:1.25;
    max-width:100%;
  }
}

@media (max-width:520px){
  .service-media .stat-panel{
    gap:8px;
    padding:16px 14px;
  }
  .stat-box strong{
    font-size:clamp(26px,9vw,42px);
  }
  .stat-box span{
    font-size:10px;
  }
}

/* Mobile/tablet stats language fix: keep only the selected language visible inside stats labels */
.stat-box span [data-lang-content]{
  display:none !important;
}
body[data-lang="en"] .stat-box span [data-lang-content="en"],
body[data-lang="de"] .stat-box span [data-lang-content="de"],
body[data-lang="fa"] .stat-box span [data-lang-content="fa"]{
  display:inline !important;
}

/* Hero spacing compact fix: reduce only the empty space between headline, service strip, and Selected Projects */
.hero{
  min-height:auto !important;
  padding-bottom:8px !important;
}
.hero-grid{
  min-height:auto !important;
}
.hero-bottom{
  min-height:auto !important;
  gap:16px !important;
  padding-bottom:8px !important;
}
.massive-title{
  margin-bottom:0 !important;
}
.services-strip{
  margin-top:0 !important;
  padding-top:8px !important;
  padding-bottom:0 !important;
}
#work{
  padding-top:34px !important;
}
@media (min-width:1151px){
  .hero{
    padding-top:112px !important;
  }
  .hero-bottom{
    padding-top:34px !important;
  }
  #work{
    padding-top:28px !important;
  }
}
@media (max-width:780px){
  .hero{
    min-height:auto !important;
    padding-top:96px !important;
    padding-bottom:4px !important;
  }
  .hero-grid{
    min-height:auto !important;
  }
  .hero-bottom{
    min-height:auto !important;
    gap:12px !important;
    padding:24px 14px 4px !important;
  }
  .services-strip{
    margin-top:0 !important;
    padding-top:6px !important;
    padding-bottom:0 !important;
    gap:12px !important;
  }
  #work{
    padding-top:24px !important;
  }
}

/* Desktop-only spacing balance: add a small breathing room back on large screens only. Mobile stays unchanged. */
@media (min-width:1025px){
  .hero-bottom{
    gap:24px !important;
    padding-bottom:16px !important;
  }
  .services-strip{
    padding-top:18px !important;
    padding-bottom:8px !important;
  }
  #work{
    padding-top:52px !important;
  }
}

/* Desktop-only title to services breathing room: increase distance between main headline and service list. Mobile/tablet untouched. */
@media (min-width:1025px){
  .massive-title{
    margin-bottom:22px !important;
  }
  .services-strip{
    padding-top:24px !important;
  }
}

/* Category gallery page */
.project-categories-section{padding:34px 0 90px}
.category-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.category-card{display:grid;gap:12px;color:var(--text);border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.025);padding:12px;min-height:260px;transition:transform .28s ease,border-color .28s ease,background .28s ease}
.category-card:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.2);background:rgba(255,255,255,.045)}
.category-card-media{position:relative;aspect-ratio:1/1;background:radial-gradient(circle at 35% 25%,rgba(255,255,255,.08),transparent 18%),linear-gradient(135deg,#181818,#070707);overflow:hidden;border:1px solid rgba(255,255,255,.06)}
.category-card-media img,.category-card-media video{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(.9) contrast(1.04)}
.category-card-media::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.38),transparent 55%);pointer-events:none}
.category-count{position:absolute;left:10px;bottom:10px;z-index:2;padding:7px 10px;border-radius:999px;background:rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.16);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:#fff}
.category-card-title{font-size:clamp(25px,2.4vw,42px);line-height:.95;letter-spacing:-.055em;font-weight:900}
.category-card-arrow{font-size:14px;color:var(--muted);font-weight:800}
.empty-category-message{border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);padding:28px;color:var(--muted);font-size:18px}
@media(max-width:1150px){.category-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.project-categories-section{padding-top:20px}.category-grid{grid-template-columns:1fr;gap:14px}.category-card{min-height:auto}.category-card-title{font-size:34px}}
