*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --blue:#0013A9;--blue-l:#2B3FFF;
  --bg:#03030a;--border:rgba(255,255,255,.07);--border-h:rgba(255,255,255,.18);
  --text:#fff;--muted:#9498ad;--soft:#d4d8ec;--max:1400px;
}
html{scroll-behavior:smooth}
body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img,video{display:block;max-width:100%}
.wrap{width:min(calc(100% - clamp(28px,6vw,80px)),var(--max));margin:0 auto}

.ambient{position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(ellipse 80% 50% at 18% 0%,rgba(43,63,255,.18),transparent),
             radial-gradient(ellipse 60% 40% at 82% 22%,rgba(0,19,169,.12),transparent)}
.shell{position:relative;z-index:1}

/* ── NAV ── */
.nav{position:fixed;top:0;left:0;width:100%;z-index:900;padding:20px 0;transition:padding .35s}
.nav.scrolled{padding:10px 0}
.nav-pill{
  width:min(calc(100% - clamp(28px,6vw,80px)),1360px);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:14px 22px;border-radius:22px;border:1px solid transparent;
  transition:background .35s,backdrop-filter .35s,border-color .35s,box-shadow .35s}
.nav.scrolled .nav-pill{
  background:rgba(3,3,10,.75);border-color:rgba(255,255,255,.10);
  backdrop-filter:blur(20px);box-shadow:0 12px 40px rgba(0,0,0,.40)}
.brand{display:flex;align-items:center;gap:12px;font-weight:700;font-size:.95rem;letter-spacing:.05em}
.brand-icon{width:40px;height:40px;border-radius:11px;flex-shrink:0;
  background:linear-gradient(135deg,var(--blue-l),var(--blue));
  display:grid;place-items:center;font-size:.76rem;font-weight:800;
  box-shadow:0 8px 24px rgba(43,63,255,.38)}
.nav-links{display:flex;align-items:center}
.nav-links .menu{display:flex;align-items:center;gap:28px;list-style:none;margin:0;padding:0;color:rgba(255,255,255,.78);font-size:.9rem}
.nav-links a{transition:color .2s}
.nav-links a:hover,.nav-links .current-menu-item>a,.nav-links .current-menu-ancestor>a,.nav-links .current_page_item>a{color:#fff}
.nav-cta{padding:12px 24px;border-radius:999px;
  background:linear-gradient(135deg,var(--blue-l),var(--blue));
  font-weight:700;font-size:.85rem;
  box-shadow:0 8px 24px rgba(43,63,255,.32);
  transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s;white-space:nowrap}
.nav-cta:hover{transform:translateY(-2px) scale(1.03);box-shadow:0 18px 38px rgba(43,63,255,.45)}

.hamburger{display:none;position:relative;width:36px;height:24px;cursor:pointer;background:none;border:none;padding:0;flex-shrink:0;z-index:1001}
.hamburger span{display:block;position:absolute;left:0;width:100%;height:1.5px;background:#fff;border-radius:2px;transform-origin:center center;transition:transform .4s cubic-bezier(.77,0,.175,1),opacity .25s ease,top .35s ease}
.hamburger span:nth-child(1){top:4px}
.hamburger span:nth-child(2){top:50%;transform:translateY(-50%)}
.hamburger span:nth-child(3){top:calc(100% - 4px)}
.hamburger.open span:nth-child(1){top:50%;transform:translateY(-50%) rotate(35deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:translateY(-50%) scaleX(0)}
.hamburger.open span:nth-child(3){top:50%;transform:translateY(-50%) rotate(-35deg)}

.mobile-menu{position:fixed;inset:0;z-index:800;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;padding:0 clamp(32px,8vw,60px);background:rgba(3,3,10,.97);backdrop-filter:blur(28px);pointer-events:none;clip-path:circle(0% at calc(100% - 48px) 44px);transition:clip-path .65s cubic-bezier(.77,0,.175,1)}
.mobile-menu.open{pointer-events:all;clip-path:circle(150% at calc(100% - 48px) 44px)}
.mobile-menu .menu{display:flex;flex-direction:column;align-items:flex-start;list-style:none;margin:0;padding:0}
.mobile-menu .menu li{opacity:0;transform:translateX(-24px);transition:opacity .35s ease,transform .35s ease,color .2s}
.mobile-menu a{display:block;font-size:clamp(2.4rem,11vw,3.8rem);font-weight:700;letter-spacing:-.04em;color:rgba(255,255,255,.78);padding:10px 0;line-height:1.1;transition:color .2s}
.mobile-menu.open .menu li{opacity:1;transform:translateX(0)}
.mobile-menu.open .menu li:nth-child(1){transition-delay:.20s}
.mobile-menu.open .menu li:nth-child(2){transition-delay:.28s}
.mobile-menu.open .menu li:nth-child(3){transition-delay:.36s}
.mobile-menu.open .menu li:nth-child(4){transition-delay:.44s}
.mobile-menu.open .menu li:nth-child(5){transition-delay:.52s}
.mobile-menu a:hover{color:#fff}
.m-divider{width:40px;height:1px;background:rgba(255,255,255,.18);margin:20px 0;opacity:0;transition:opacity .35s .50s}
.mobile-menu.open .m-divider{opacity:1}
.m-cta{font-size:clamp(1.1rem,4vw,1.3rem) !important;font-weight:600 !important;color:rgba(255,255,255,.55) !important;letter-spacing:.08em !important;text-transform:uppercase}
.m-cta:hover{color:#fff !important}
.mobile-menu:not(.open) .menu li{transition:none}

@media(max-width:768px){.nav-links{display:none}.nav-cta{display:none}.hamburger{display:block}}

/* ── HERO ── */
.page-hero{padding:clamp(130px,18vh,180px) 0 clamp(40px,6vh,70px)}
.page-hero-inner{display:flex;flex-direction:column;gap:12px}
.page-hero-bg{position:absolute;inset:0;z-index:0}
.page-hero-bg video,.page-hero-bg img{width:100%;height:100%;object-fit:cover;display:block}
.page-hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(3,3,10,.32) 0%,rgba(3,3,10,.82) 100%)}
.page-eyebrow{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;border-radius:999px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.10);font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.72);margin-bottom:10px;width:fit-content}
.e-dot{width:6px;height:6px;border-radius:50%;background:var(--blue-l);box-shadow:0 0 8px rgba(43,63,255,.7);flex-shrink:0}
.page-title{font-size:clamp(3rem,7vw,7rem);line-height:.88;letter-spacing:-.07em;font-weight:800}
.page-meta{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-top:clamp(20px,3vw,36px)}
.page-count{color:var(--muted);font-size:.9rem}
.page-count span{color:#fff;font-weight:600}

/* ── FILTER BAR ── */
.filter-bar{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  padding:clamp(20px,3vw,32px) 0;
  border-bottom:1px solid var(--border);
  position:sticky;top:74px;z-index:100;
  background:rgba(3,3,10,.80);backdrop-filter:blur(20px);
  margin:0 calc(-1 * clamp(14px,3vw,40px));
  padding-left:clamp(14px,3vw,40px);
  padding-right:clamp(14px,3vw,40px)}
.filter-btn{
  padding:9px 18px;border-radius:999px;
  border:1px solid var(--border);background:transparent;
  color:rgba(255,255,255,.60);font-family:inherit;font-size:.82rem;
  letter-spacing:.06em;cursor:pointer;white-space:nowrap;
  transition:background .22s,border-color .22s,color .22s,transform .22s cubic-bezier(.34,1.56,.64,1)}
.filter-btn:hover{border-color:var(--border-h);color:#fff;transform:translateY(-1px)}
.filter-btn.active{
  background:linear-gradient(135deg,var(--blue-l),var(--blue));
  border-color:transparent;color:#fff;
  box-shadow:0 6px 20px rgba(43,63,255,.32)}
.filter-count{
  margin-left:auto;
  font-size:.80rem;color:var(--muted);white-space:nowrap;flex-shrink:0}

/* ── PROJECTS GRID ── */
.projects-section{padding:clamp(32px,4vw,56px) 0 clamp(80px,10vw,130px)}
.projects-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:clamp(14px,2vw,24px);
  isolation:isolate}

/* card */
.pcard{
  position:relative;border-radius:20px;overflow:hidden;
  background:#090b15;border:1px solid var(--border);
  cursor:pointer;
  -webkit-transform:translate3d(0,0,0);
  transform:translate3d(0,0,0);
  -webkit-filter:drop-shadow(0 0 0 rgba(0,0,0,0));
  filter:drop-shadow(0 0 0 rgba(0,0,0,0));
  -webkit-backface-visibility:hidden;
  backface-visibility:hidden;
  will-change:transform,filter;
  transition:transform .5s cubic-bezier(.25,.46,.45,.94),filter .5s,border-color .3s;
  animation:fadeUp .5s ease both}
.pcard:hover{-webkit-filter:drop-shadow(0 28px 64px rgba(0,0,0,.55));filter:drop-shadow(0 28px 64px rgba(0,0,0,.55));transform:translate3d(0,-5px,0);border-color:rgba(255,255,255,.14)}
@keyframes fadeUp{from{opacity:0;transform:translate3d(0,28px,0)}to{opacity:1;transform:translate3d(0,0,0)}}

/* image area */
.pcard-img{position:relative;overflow:hidden;aspect-ratio:16/9; display:block}
.pcard-img img{width:100%;height:100%;object-fit:cover;
  -webkit-backface-visibility:hidden;
  backface-visibility:hidden;
  transition:transform .7s cubic-bezier(.25,.46,.45,.94),filter .7s}
.pcard:hover .pcard-img img{transform:scale(1.06);filter:brightness(.75)}
.pcard-img::after{content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(0,0,0,.05) 0%,rgba(0,0,0,.60) 100%)}

/* client logo overlay (center of image) */
.pcard-logo{
  position:absolute;top:50%;left:50%;z-index:3;
  transform:translate(-50%,-50%) scale(.9);
  /*padding:10px 18px;border-radius:12px;
  background:rgba(3,3,10,.52);border:1px solid rgba(255,255,255,.14);
  backdrop-filter:blur(12px);*/
  font-size:.8rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.78);white-space:nowrap;
  opacity:0;transition:opacity .4s ease,transform .4s cubic-bezier(.34,1.56,.64,1)}
.pcard-logo img{display:block;max-width:180px;max-height:70px;width:auto;height:auto;object-fit:contain}
.pcard:hover .pcard-logo{opacity:1;transform:translate(-50%,-50%) scale(1)}

/* play button */
.pcard-play{
  position:absolute;right:18px;bottom:18px;z-index:4;
  transform:translate(0%,-0%) scale(0);
  width:52px;height:52px;border-radius:50%;
  background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);
  backdrop-filter:blur(8px);
  display:grid;place-items:center;
  transition:transform .4s cubic-bezier(.34,1.56,.64,1),background .3s;opacity:0}
.pcard-play svg{width:18px;height:18px;fill:#fff;margin-left:3px}
.pcard:hover .pcard-play{transform:translate(0%,0%) scale(1);opacity:1}
.pcard:hover .pcard-play:hover{background:rgba(43,63,255,.6);transform:translate(-50%,-50%) scale(1.1)}

/* meta row below image */
.pcard-meta{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px 6px;gap:12px}
.pcard-title-row{display:flex;align-items:baseline;gap:10px;flex:1;min-width:0}
.pcard-name{font-size:clamp(.9rem,1.2vw,1.05rem);font-weight:600;letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pcard-year{font-size:.80rem;color:var(--muted);flex-shrink:0}
.pcard-sep{color:rgba(255,255,255,.2);font-size:.8rem}
.pcard-dots{display:flex;gap:3px;flex-shrink:0}
.pcard-dots span{width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.30)}

/* tags row */
.pcard-tags{
  display:flex;flex-wrap:wrap;gap:6px;
  padding:6px 18px 16px}
.pcard-tag{
  padding:5px 11px;border-radius:999px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);
  font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.55)}

/* ── EMPTY STATE ── */
.empty-state{
  grid-column:1/-1;
  display:flex;flex-direction:column;align-items:center;gap:16px;
  padding:80px 20px;color:var(--muted);text-align:center}
.empty-state p{font-size:1rem}
.empty-state button{padding:12px 26px;border-radius:999px;border:1px solid var(--border);
  background:transparent;color:#fff;font-family:inherit;font-size:.88rem;cursor:pointer;
  transition:background .2s,border-color .2s}
.empty-state button:hover{background:rgba(255,255,255,.06);border-color:var(--border-h)}

/* ── FOOTER ── */







/* ── MOBILE ── */
@media(max-width:700px){
  .projects-grid{grid-template-columns:1fr}
  .pcard-img{aspect-ratio:16/9}
  .filter-bar{gap:8px}
}

/* ══════════════════════════════
   FOOTER — LENA STYLE
   ══════════════════════════════ */
.site-footer{
  padding:clamp(56px,8vw,100px) 0 clamp(28px,4vw,40px);
  border-top:1px solid rgba(255,255,255,.07)}
.footer-top{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,80px);
  padding-bottom:clamp(48px,6vw,72px);
  border-bottom:1px solid rgba(255,255,255,.07)}
.footer-headline{
  font-size:clamp(2.8rem,6vw,6.5rem);
  font-weight:800;letter-spacing:-.06em;line-height:.88;color:#fff}
.footer-headline em{
  font-style:italic;font-weight:400;
  font-family:Georgia,'Times New Roman',serif}
.footer-right{
  display:flex;flex-direction:column;justify-content:space-between;gap:32px}
.footer-contact-label{
  font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted,#9498ad);margin-bottom:10px}
.footer-email{
  display:inline-flex;align-items:center;gap:10px;
  font-size:clamp(1rem,1.8vw,1.5rem);font-weight:600;color:#fff;
  text-decoration:none;border-bottom:1px solid rgba(255,255,255,.20);
  padding-bottom:4px;transition:border-color .2s,color .2s}
.footer-email:hover{border-color:#fff;color:rgba(255,255,255,.85)}
.footer-email-icon{
  width:28px;height:28px;border-radius:50%;
  background:linear-gradient(135deg,#2B3FFF,#0013A9);
  display:grid;place-items:center;flex-shrink:0;font-size:.75rem}
.footer-socials{display:flex;gap:14px;flex-wrap:wrap}
.footer-social{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 18px;border-radius:999px;
  border:1px solid rgba(255,255,255,.07);
  font-size:.80rem;letter-spacing:.06em;color:rgba(255,255,255,.65);
  transition:border-color .2s,color .2s,background .2s}
.footer-social:hover{border-color:rgba(255,255,255,.30);color:#fff;background:rgba(255,255,255,.04)}
.footer-social svg{width:14px;height:14px;fill:currentColor;flex-shrink:0}
.footer-cta-btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 32px;border-radius:999px;
  background:linear-gradient(135deg,#2B3FFF,#0013A9);
  font-weight:700;font-size:.9rem;color:#fff;width:fit-content;
  box-shadow:0 10px 28px rgba(43,63,255,.32);
  transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s}
.footer-cta-btn:hover{transform:translateY(-3px) scale(1.03);
  box-shadow:0 18px 40px rgba(43,63,255,.44)}
.footer-bottom-brand{
  display:flex;align-items:center;gap:10px;
  font-weight:700;font-size:.88rem;letter-spacing:.05em}
.footer-bottom-brand .brand-icon{width:32px;height:32px;border-radius:8px;font-size:.66rem;color:#fff}
.footer-nav{display:flex}
.footer-nav .menu{display:flex;gap:20px;flex-wrap:wrap;list-style:none;margin:0;padding:0}
.footer-nav a{font-size:.82rem;color:rgba(255,255,255,.45);transition:color .2s}
.footer-nav a:hover{color:#fff}
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;flex-wrap:wrap;padding-top:clamp(24px,3vw,36px)}
.footer-copy{font-size:.78rem;color:rgba(255,255,255,.30)}
@media(max-width:900px){.footer-top{grid-template-columns:1fr}}
@media(max-width:640px){.footer-bottom{flex-direction:column;align-items:flex-start;gap:12px}}

/* ── WATERMARK ── */
.page-hero{position:relative;overflow:hidden}
.hero-watermark{
  position:absolute;
  right:-2%;top:50%;
  transform:translateY(-55%);
  font-size:clamp(10rem,22vw,22rem);
  font-weight:900;
  letter-spacing:-.06em;
  line-height:1;
  color:transparent;
  -webkit-text-stroke:1px rgba(255,255,255,.06);
  user-select:none;
  pointer-events:none;
  white-space:nowrap;
  z-index:0}
.page-hero-inner{position:relative;z-index:1}

/* ── FEATURED HERO ── */
.featured-hero{
  display:block;
  position:relative;
  width:100%;
  height:clamp(320px,52vw,620px);
  border-radius:24px;
  overflow:hidden;
  margin-bottom:clamp(32px,4vw,56px);
  cursor:pointer;
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 40px 100px rgba(0,0,0,.60)}
.featured-hero img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform 1.2s cubic-bezier(.25,.46,.45,.94),filter 1.2s}
.featured-hero:hover img{transform:scale(1.04);filter:brightness(.65)}
.featured-hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.30) 45%,rgba(0,0,0,.08) 100%);
  display:flex;flex-direction:column;justify-content:space-between;
  padding:clamp(20px,3vw,36px)}
.featured-label{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 16px;border-radius:999px;width:fit-content;
  background:rgba(43,63,255,.25);
  border:1px solid rgba(43,63,255,.50);
  backdrop-filter:blur(8px);
  font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#fff}
.featured-dot{width:6px;height:6px;border-radius:50%;background:#fff;
  animation:fpulse 2s ease-in-out infinite}
@keyframes fpulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}
.featured-bottom{display:flex;align-items:flex-end;justify-content:space-between;gap:20px}
.featured-info{}
.featured-client{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.55);margin-bottom:8px}
.featured-title{font-size:clamp(1.6rem,4vw,3.4rem);font-weight:800;
  letter-spacing:-.04em;line-height:1.05}
.featured-tags{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.featured-tag{
  padding:5px 13px;border-radius:999px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.20);
  backdrop-filter:blur(6px);
  font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.85)}
.featured-play{
  flex-shrink:0;
  width:clamp(52px,6vw,72px);height:clamp(52px,6vw,72px);
  border-radius:50%;
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.30);
  backdrop-filter:blur(10px);
  display:grid;place-items:center;
  transition:transform .4s cubic-bezier(.34,1.56,.64,1),background .3s;
  position:relative}
.featured-play::before{
  content:'';
  position:absolute;inset:-6px;
  border-radius:50%;
  border:1.5px solid rgba(255,255,255,.15);
  animation:playring 2.5s ease-in-out infinite}
@keyframes playring{0%{transform:scale(1);opacity:.6}70%{transform:scale(1.25);opacity:0}100%{transform:scale(1.25);opacity:0}}
.featured-hero:hover .featured-play{transform:scale(1.12);background:rgba(43,63,255,.55)}
.featured-play svg{width:22px;height:22px;fill:#fff;margin-left:4px}

/* ── MASONRY GRID ── */
/*
.projects-grid{
  column-count:2;
  column-gap:clamp(14px,2vw,24px);
  display:block !important}
*/
.pcard{
  break-inside:avoid;
  /*margin-bottom:clamp(14px,2vw,24px);*/
  display:block}

.pcard.featured-card .pcard-img{
  aspect-ratio: 16/7;
}
.pcard:nth-child(6n+1) .pcard-img,
.pcard:nth-child(6n+2) .pcard-img{
  aspect-ratio: 4/3;
}

.pcard:nth-child(6n+3) .pcard-img,
.pcard:nth-child(6n+4) .pcard-img{
  aspect-ratio: 16/9;
}

.pcard:nth-child(6n+5) .pcard-img,
.pcard:nth-child(6n+6) .pcard-img{
  aspect-ratio: 3/4;
}
@media(max-width:700px){
  .projects-grid{column-count:1}
  .pcard .pcard-img{aspect-ratio:16/9 !important}
  .featured-hero{border-radius:16px}
}


/* ── AVAILABLE BADGE ── */
.avail-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 16px 7px 12px;
  border-radius:999px;
  background:rgba(16,185,129,.10);
  border:1px solid rgba(16,185,129,.25);
  font-size:.75rem;letter-spacing:.06em;
  color:rgba(255,255,255,.80);
  white-space:nowrap;
  transition:background .3s,border-color .3s}
.avail-badge:hover{background:rgba(16,185,129,.18);border-color:rgba(16,185,129,.45)}
.avail-dot{
  width:8px;height:8px;border-radius:50%;
  background:#10b981;
  box-shadow:0 0 0 0 rgba(16,185,129,.6);
  flex-shrink:0;
  animation:greenping 2.2s ease-in-out infinite}
@keyframes greenping{
  0%{box-shadow:0 0 0 0 rgba(16,185,129,.6)}
  70%{box-shadow:0 0 0 9px rgba(16,185,129,.0)}
  100%{box-shadow:0 0 0 0 rgba(16,185,129,.0)}}
