:root{
  --ink:#15130f;
  --ink-soft:#5b564d;
  --paper:#f6f3ee;
  --paper-2:#efeae2;
  --line:#dcd5c9;
  --white:#ffffff;
  /* Niminal corner: top-right rounder than the rest (tl tr br bl) */
  --corner-sm:2px 16px 2px 2px;
  --corner:4px 40px 4px 4px;
  --corner-xl:6px 78px 6px 6px;
  --pad:clamp(20px,5vw,72px);
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
/* paper background on <html> too, so iOS Safari's bottom toolbar + overscroll never
   reveal a white/black gap behind the page (keeps top and bottom chrome the same tone) */
html{scroll-behavior:smooth;background:var(--paper)}
body{background:var(--paper);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.5}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.eyebrow{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);font-weight:600}

/* header */
header{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  padding:14px var(--pad);padding-top:calc(14px + env(safe-area-inset-top));
  background:rgba(246,243,238,.45);backdrop-filter:blur(22px) saturate(180%);-webkit-backdrop-filter:blur(22px) saturate(180%);
  box-shadow:inset 0 -1px 0 rgba(10,9,7,.06);transition:background .3s,box-shadow .3s,padding .3s}
header.scrolled{background:rgba(246,243,238,.62);backdrop-filter:blur(26px) saturate(180%);-webkit-backdrop-filter:blur(26px) saturate(180%);
  box-shadow:inset 0 -1px 0 rgba(10,9,7,.08),0 8px 24px rgba(10,9,7,.05);
  padding:11px var(--pad);padding-top:calc(11px + env(safe-area-inset-top))}
/* during the full-bleed opening the real header is hidden; JS removes .intro as the frame forms */
header.intro{opacity:0;transform:translateY(-8px);pointer-events:none;transition:opacity .5s ease,transform .5s ease}
header .logo{height:34px;width:auto}
header nav{display:flex;gap:clamp(16px,3vw,40px);align-items:center}
header nav a{font-size:13px;letter-spacing:.06em;font-weight:500;color:var(--ink);opacity:.8;transition:opacity .2s}
header nav a:hover{opacity:1}
/* language toggle (EN/SQ) */
.lang-toggle{display:inline-flex;align-items:center;gap:2px;border:1px solid var(--line);
  border-radius:0 12px 4px 4px;padding:3px;background:rgba(255,255,255,.4)}
.lang-toggle button{background:none;border:none;cursor:pointer;font:inherit;font-size:11.5px;font-weight:600;
  letter-spacing:.04em;color:var(--ink);opacity:.6;padding:4px 8px;border-radius:0 9px 3px 3px;transition:opacity .2s,background .2s,color .2s}
.lang-toggle button:hover{opacity:.9}
.lang-toggle button.active{opacity:1;background:var(--ink);color:var(--paper)}

/* hero - opens full-bleed, falls into a frame as you scroll.
   --p is scroll progress 0..1 (0 = full-bleed opening, 1 = framed), set by JS. */
.hero-stage{--p:0;height:200vh;position:relative}
.hero-sticky{position:sticky;top:0;height:100vh;height:100dvh;display:flex;align-items:flex-start;
  /* inset around the frame grows from 0 (full-bleed) to the framed margins */
  padding:calc(var(--p) * 128px) calc(var(--p) * var(--pad)) 0}
.hero-frame{position:relative;overflow:hidden;width:100%;
  height:calc(100vh - var(--p) * (10vh + 128px));height:calc(100dvh - var(--p) * (10dvh + 128px));min-height:460px;
  /* corners round in as the frame forms, keeping Niminal's rounder top-right */
  border-top-right-radius:calc(6px + var(--p) * 72px);
  border-top-left-radius:calc(var(--p) * 6px);border-bottom-right-radius:calc(var(--p) * 6px);
  border-bottom-left-radius:calc(var(--p) * 6px)}
.hero-slides{position:absolute;inset:0;z-index:0}
.hero-slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;
  transition:opacity 2.2s cubic-bezier(.4,0,.2,1);will-change:opacity,transform;
  /* every slide drifts continuously, so the one fading out keeps moving instead of snapping back */
  animation:kenburns 22s linear infinite alternate}
.hero-slide.active{opacity:1}
@keyframes kenburns{from{transform:scale(1.06)}to{transform:scale(1.14)}}
.hero-frame::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,rgba(10,9,7,.18) 0%,rgba(10,9,7,0) 32%,rgba(10,9,7,.55) 100%)}

/* intro overlay: centered logo + scroll cue, visible at p=0, gone by the time the frame forms */
.hero-intro{position:absolute;inset:0;z-index:3;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:0;opacity:calc(1 - var(--p) * 2.2);pointer-events:none}
.hero-intro-logo{height:clamp(34px,5vw,58px);width:auto;filter:drop-shadow(0 2px 24px rgba(0,0,0,.35));
  transform:translateY(calc(var(--p) * -24px))}
.scroll-cue{position:absolute;bottom:clamp(26px,5vh,54px);left:50%;transform:translateX(-50%);
  width:24px;height:38px;border:2px solid rgba(255,255,255,.7);border-radius:13px;display:flex;justify-content:center}
.scroll-cue span{display:block;width:3px;height:7px;margin-top:7px;border-radius:2px;background:rgba(255,255,255,.9);
  animation:cue 1.6s ease-in-out infinite}
@keyframes cue{0%{transform:translateY(0);opacity:0}30%{opacity:1}70%{transform:translateY(11px);opacity:1}100%{transform:translateY(13px);opacity:0}}

/* scroll reveal */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .9s ease,transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
/* cards are the main event: they rise a touch more, a touch slower, than supporting text.
   The render itself is never scaled/blurred on reveal - it stays pixel-crisp at all times;
   only the card's position/opacity animates in. */
.card.reveal{transform:translateY(34px)}
.card.reveal{transition:opacity 1.05s ease,transform 1.05s cubic-bezier(.2,.7,.2,1)}
/* process steps: the node (number/✓) must stay solid and in place - only the step's
   content fades in. So the reveal effect lives on .step-inner, not the whole step. */
.step.reveal{opacity:1;transform:none;transition:none}
.step.reveal .step-inner{opacity:0;transform:translateY(20px);
  transition:opacity .9s ease,transform .9s cubic-bezier(.2,.7,.2,1)}
.step.reveal.in .step-inner{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .step.reveal .step-inner{opacity:1;transform:none;transition:none}
  .hero-slide{animation:none!important;transition:none}
  .scroll-cue span{animation:none}
  /* skip the full-bleed opening: render the framed hero statically, no dead scroll */
  .hero-stage{--p:1;height:auto}
  .hero-sticky{position:static;height:auto}
  .hero-frame{height:min(82vh,760px)}
  .hero-intro{display:none}
  .hero-copy{opacity:1;transform:none}
  header.intro{opacity:1;transform:none;pointer-events:auto}
}
.hero-copy{position:absolute;z-index:2;left:clamp(22px,4vw,54px);right:clamp(22px,4vw,54px);bottom:clamp(26px,4vw,52px);color:#fff;
  /* rises and fades in as the frame forms (second half of the scroll) */
  opacity:calc((var(--p) - .45) * 2.6);transform:translateY(calc((1 - var(--p)) * 26px));pointer-events:none}
.hero-copy a{pointer-events:auto}
.hero-copy h1{font-size:clamp(34px,6vw,76px);font-weight:600;letter-spacing:-.02em;line-height:1.02;max-width:14ch}
.hero-copy p{margin-top:16px;font-size:clamp(15px,1.6vw,20px);max-width:46ch;color:rgba(255,255,255,.9);font-weight:400}
.hero-cta{display:inline-flex;align-items:center;gap:10px;margin-top:26px;background:#fff;color:var(--ink);
  padding:13px 22px;border-radius:var(--corner-sm);font-size:13px;font-weight:600;letter-spacing:.04em;transition:transform .2s,background .2s}
.hero-cta:hover{transform:translateY(-2px);background:#fff}
.hero-cta span{font-size:15px}

/* sections */
section{padding:clamp(64px,9vw,128px) var(--pad)}
.sec-head{display:flex;align-items:baseline;justify-content:space-between;gap:24px;margin-bottom:clamp(30px,4vw,54px);flex-wrap:wrap}
.sec-head h2{font-size:clamp(26px,3.4vw,44px);font-weight:600;letter-spacing:-.02em}
.sec-head .count{font-size:clamp(15px,1.5vw,18px);color:var(--ink-soft);font-weight:500;letter-spacing:-.01em;
  display:inline-flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.sec-head .count b{font-weight:700;color:var(--ink);font-size:1.5em;letter-spacing:-.02em;margin-right:1px}
.sec-head .count i{color:var(--line);font-style:normal;font-weight:400;margin:0 2px}

/* work grid */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:clamp(18px,2.4vw,34px)}
.card{cursor:pointer;background:none;border:none;text-align:left;padding:0;font:inherit;color:inherit;display:flex;flex-direction:column;gap:14px}
/* no lingering focus box after a mouse/touch click; keep a ring for keyboard users only */
.card:focus,a:focus,button:focus{outline:none}
.card:focus-visible,a:focus-visible,button:focus-visible{outline:2px solid var(--ink);outline-offset:3px;border-radius:2px}
.card .img{position:relative;border-radius:var(--corner);overflow:hidden;aspect-ratio:4/3;background:var(--paper-2);
  transform:translateZ(0);-webkit-mask-image:-webkit-radial-gradient(white,black)}
.card .img img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.2,.7,.2,1)}
.card:hover .img img{transform:scale(1.05)}
.card .img .badge{position:absolute;left:0;bottom:0;background:rgba(21,19,15,.72);backdrop-filter:blur(6px);
  color:#fff;font-size:11px;letter-spacing:.04em;font-weight:500;padding:7px 14px;border-radius:0 16px 0 4px}
.card h3{font-size:18px;font-weight:600;letter-spacing:-.01em}
.card .meta{font-size:13px;color:var(--ink-soft);margin-top:2px}
.card .meta b{font-weight:500;color:var(--ink)}

/* view-all link under the featured grid */
.grid-foot{display:flex;justify-content:center;margin-top:clamp(52px,7vw,84px)}
.view-all{display:inline-flex;align-items:center;gap:12px;padding:14px 26px;border-radius:var(--corner-sm);
  border:1px solid var(--ink);font-size:13px;font-weight:600;letter-spacing:.04em;color:var(--ink);
  transition:transform .2s,background .2s,color .2s}
.view-all:hover{transform:translateY(-2px);background:var(--ink);color:var(--paper)}
.view-all span{font-size:15px}

/* process - paper-2 gives a tonal beat between Work (paper) and Contact (dark) */
.process{background:var(--paper-2)}
/* the note sits in the heading band on the right, wrapping to its own column */
/* note sits in the heading band, right-aligned; width tuned so it breaks to two balanced rows */
.proc-note{text-align:right;text-wrap:balance;font-size:14px;line-height:1.55;color:var(--ink-soft);
  max-width:50ch;margin:0;align-self:flex-end}
.proc{position:relative;max-width:940px;margin:0 auto;clear:both}
@media (max-width:980px){
  /* stack under the heading, left-aligned, full width */
  .proc-note{text-align:left;max-width:none;align-self:stretch;margin-top:6px}
}
.proc-line{position:absolute;left:21px;top:14px;bottom:14px;width:2px;background:var(--line);border-radius:2px;z-index:0}
.proc-fill{position:absolute;left:0;top:0;width:100%;height:0;background:var(--ink);border-radius:2px}
.proc-arrow{position:absolute;left:50%;bottom:-7px;transform:translateX(-50%);color:var(--ink);font-size:15px;line-height:1;transition:opacity .3s ease}
.step{position:relative;padding:clamp(20px,3.4vw,40px) 0 clamp(20px,3.4vw,40px) clamp(62px,9vw,104px)}
.step .node{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:24px;height:24px;
  border-radius:0 11px 4px 4px;background:var(--paper-2);border:2px solid var(--ink);z-index:2;
  display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--ink);
  transition:background .35s ease,color .35s ease,transform .35s ease}
.step .node.done{background:var(--ink);color:var(--paper)}
.step.goal .node{width:28px;height:28px;border-radius:0 13px 4px 4px}
.step-inner{display:grid;grid-template-columns:136px 1fr;gap:clamp(18px,3vw,42px);align-items:center}
.sketch{aspect-ratio:1;background:var(--paper);border:1px solid var(--line);border-radius:var(--corner);
  display:flex;align-items:center;justify-content:center;padding:20px;color:var(--ink)}
.sketch svg{width:100%;height:100%;display:block;opacity:.85}
.step .num{font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);font-weight:600}
.step h3{font-size:clamp(19px,2.2vw,24px);font-weight:600;letter-spacing:-.01em;margin:7px 0 8px}
.step p{color:var(--ink-soft);font-size:15.5px;line-height:1.62;max-width:50ch}
.step.optional .node{border-style:dashed}
.step.optional .num{color:var(--ink)}
.step.goal h3{font-size:clamp(24px,3.4vw,40px)}
.step.goal .sketch{background:var(--ink);color:var(--paper);border-color:var(--ink)}
@media(max-width:560px){
  .step-inner{grid-template-columns:104px 1fr;gap:16px}
  .step{padding-left:56px}
  .proc-line{left:17px}.step .node{left:6px}
}

/* contact */
.contact-box{background:var(--ink);color:var(--paper);border-radius:var(--corner-xl);padding:clamp(34px,6vw,84px);
  display:grid;grid-template-columns:1.2fr 1fr;gap:clamp(28px,4vw,60px);align-items:end}
.contact-box h2{font-size:clamp(28px,4vw,52px);font-weight:600;letter-spacing:-.02em;line-height:1.05;color:#fff}
.contact-box .lead{margin-top:16px;color:rgba(246,243,238,.72);font-size:16px;max-width:42ch}
.contact-actions{display:flex;flex-direction:column;gap:12px}
.btn{display:inline-flex;align-items:center;justify-content:space-between;gap:14px;padding:15px 20px;border-radius:var(--corner-sm);
  font-size:14px;font-weight:500;transition:transform .2s,background .2s,color .2s}
.btn-primary{background:var(--paper);color:var(--ink)}
.btn-ghost{background:rgba(255,255,255,.06);color:#fff;border:1px solid rgba(255,255,255,.16)}
.btn:hover{transform:translateY(-2px)}
.btn .ar{opacity:.5;font-size:15px}
.btn .btn-l{display:inline-flex;align-items:center;gap:11px;min-width:0}
.btn .btn-l>span{min-width:0;display:inline-block}
.btn .btn-ico{width:18px;height:18px;flex:0 0 18px;display:block;vertical-align:middle;align-self:center}
/* footer */
footer{padding:40px var(--pad) 56px;
  /* a little safe-area room on notched iPhones, nothing more */
  padding-bottom:calc(56px + env(safe-area-inset-bottom));
  display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;border-top:1px solid var(--line)}
footer img{height:30px;opacity:.9}
footer .copy{font-size:12.5px;color:var(--ink-soft)}

/* Invisible bottom-fixed sliver. Its only job: pages without a real bottom
   dock (home, work) still trigger iOS Safari's compact floating toolbar,
   matching the prishtina-towers page. No visual footprint. Phones only. */
.safari-floatbar-trigger{display:none}
@media(hover:none) and (max-width:860px){
  .safari-floatbar-trigger{display:block;position:fixed;left:0;
    bottom:env(safe-area-inset-bottom);width:1px;height:1px;
    pointer-events:none;opacity:0}
}

/* work page: simple intro band instead of the slideshow hero */
.page-head{padding:clamp(120px,16vw,180px) var(--pad) 0}
.page-head .eyebrow{margin-bottom:14px}
.page-head h1{font-size:clamp(34px,5vw,64px);font-weight:600;letter-spacing:-.02em;line-height:1.04;max-width:18ch}
.page-head p{margin-top:18px;font-size:clamp(16px,1.7vw,20px);color:var(--ink-soft);max-width:52ch}
.work-section{padding-top:clamp(40px,6vw,72px)}

/* lightbox */
.lb{position:fixed;inset:0;z-index:100;background:rgba(15,13,10,.96);display:none;flex-direction:column;
  opacity:0;transition:opacity .25s}
.lb.open{display:flex;opacity:1}
.lb-top{display:flex;align-items:center;justify-content:space-between;padding:18px clamp(16px,4vw,40px);
  padding-top:calc(18px + env(safe-area-inset-top));color:#fff;gap:16px}
.lb-top .t{font-size:15px;font-weight:600}
.lb-top .t small{display:block;font-weight:400;font-size:12.5px;color:rgba(255,255,255,.6);letter-spacing:.02em;margin-top:3px;max-width:60ch}
.lb-close{background:rgba(255,255,255,.1);color:#fff;border:none;width:40px;height:40px;border-radius:0 16px 6px 6px;
  font-size:20px;cursor:pointer;flex:none;transition:background .2s}
.lb-close:hover{background:rgba(255,255,255,.22)}
.lb-stage{flex:1;display:flex;align-items:center;justify-content:center;padding:0 clamp(10px,3vw,28px);position:relative;min-height:0;overflow:hidden;touch-action:none}
.lb-stage img{max-width:100%;max-height:100%;object-fit:contain;border-radius:var(--corner);
  cursor:zoom-in;will-change:transform;user-select:none;-webkit-user-drag:none}
.lb-stage.zoomed img{cursor:grab;border-radius:0}
.lb-stage.zoomed.grabbing img{cursor:grabbing}
.lb-stage.zoomed img{transition:none}
/* arrows + caption fade back when you're inspecting up close */
.lb-stage.zoomed .lb-nav{opacity:0;pointer-events:none}
.lb-nav{transition:background .2s,opacity .2s}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.1);color:#fff;border:none;
  width:48px;height:48px;border-radius:50%;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.lb-nav:hover{background:rgba(255,255,255,.25)}
.lb-prev{left:clamp(10px,3vw,28px)}.lb-next{right:clamp(10px,3vw,28px)}
.lb-counter{text-align:center;color:rgba(255,255,255,.66);font-size:13px;padding:14px 0 8px;letter-spacing:.08em}
.lb-strip{display:flex;gap:8px;overflow-x:auto;padding:6px clamp(16px,4vw,40px) 22px;scrollbar-width:thin}
.lb-strip img{height:56px;width:auto;border-radius:0 12px 3px 3px;opacity:.45;cursor:pointer;flex:none;transition:opacity .2s}
.lb-strip img.active{opacity:1;outline:2px solid #fff}

@media(max-width:860px){
  .contact-box{grid-template-columns:1fr}
  /* shorter pin on tablet/phone so the opening doesn't overstay; frame margins tighten too */
  .hero-stage{height:175vh}
  .hero-sticky{padding:calc(var(--p) * 88px) calc(var(--p) * var(--pad)) 0}
  .hero-frame{height:calc(100vh - var(--p) * (8vh + 88px));height:calc(100dvh - var(--p) * (8dvh + 88px))}
}
@media(max-width:520px){
  header .logo{height:28px}
  /* keep the nav links on one tidy line on small phones */
  header nav{gap:14px}
  header nav a{font-size:12px;letter-spacing:.02em}
  .grid{grid-template-columns:1fr}
  .lb-strip{display:none}
  .lb-counter{padding-bottom:calc(8px + env(safe-area-inset-bottom))}
  .hero-stage{height:160vh}
}
@media(max-width:380px){
  header{padding-left:16px;padding-right:16px}
  header nav{gap:11px}
  header nav a{font-size:11.5px}
}
