/* header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(8,5,5,.82);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.site-header .bar{display:flex;align-items:center;justify-content:space-between;height:72px}
.site-header .logo img{height:34px}
.nav{display:flex;gap:28px}
.nav a{font-family:var(--font-head);text-transform:uppercase;font-size:14px;letter-spacing:.08em;color:var(--muted);transition:color .2s}
.nav a:hover,.nav a[aria-current="page"]{color:var(--paper)}
.nav a[aria-current="page"]{border-bottom:2px solid var(--blood)}
.nav-toggle{display:none;background:none;border:0;color:#fff;font-size:26px;cursor:pointer;line-height:1}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.08em;
  font-size:14px;font-weight:700;padding:14px 22px;border:2px solid var(--paper);color:var(--paper);transition:.2s;cursor:pointer;background:none}
.btn:hover{background:var(--paper);color:var(--ink)}
.btn--blood{border-color:var(--blood);background:var(--blood);box-shadow:0 0 0 0 var(--blood-glow)}
.btn--blood:hover{background:#e11d2a;box-shadow:0 0 26px var(--blood-glow);color:#fff}

/* signature case tiles */
.cases{display:flex;flex-wrap:wrap;gap:0}
.case-tile{position:relative;flex:1 1 280px;min-height:340px;overflow:hidden;cursor:pointer;
  clip-path:polygon(7% 0,100% 0,93% 100%,0 100%);margin-left:-26px;transition:flex .3s ease,transform .3s ease}
.case-tile:first-child{margin-left:0;clip-path:polygon(0 0,100% 0,93% 100%,0 100%)}
.case-tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:grayscale(1) contrast(1.1) brightness(.75);transition:filter .35s ease,transform .35s ease}
.case-tile .cap{position:absolute;left:34px;bottom:24px;z-index:2}
.case-tile .cap h3{font-size:26px}
.case-tile .cap .role{color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:.12em}
.case-tile::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(8,5,5,.85));z-index:1}
.case-tile:hover{flex-grow:2;transform:translateY(-6px);z-index:3}
.case-tile:hover img{filter:grayscale(0) contrast(1.05);transform:scale(1.05)}
.case-tile:hover .cap h3{text-shadow:0 0 20px var(--blood-glow)}

/* footer */
.site-footer{border-top:1px solid var(--line);padding-block:48px;color:var(--muted);font-size:14px}
.site-footer a:hover{color:#fff}
.site-footer .vari{color:#fff}
.site-footer .vari b{color:var(--blood)}

/* cookie banner */
.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:1000;background:var(--ink-2);
  border:1px solid var(--line);padding:20px;display:flex;gap:16px;flex-wrap:wrap;align-items:center;justify-content:space-between}
.cookie-banner.hidden{display:none}
.spotify-placeholder{display:flex;align-items:center;justify-content:center;min-height:152px;border:1px dashed var(--line);
  color:var(--muted);text-align:center;padding:20px;cursor:pointer;border-radius:12px}
.spotify-placeholder:hover{border-color:var(--blood);color:#fff}

/* mobile nav */
@media(max-width:760px){
  .nav{display:none;position:absolute;top:72px;left:0;right:0;flex-direction:column;background:var(--ink-2);
    padding:20px;border-bottom:1px solid var(--line);gap:18px}
  .nav.open{display:flex}
  .nav-toggle{display:block}
  .case-tile{clip-path:none;margin-left:0;flex-basis:100%;min-height:240px}
  /* compact, less intrusive cookie banner */
  .cookie-banner{flex-direction:column;align-items:stretch;gap:12px;padding:14px;left:8px;right:8px;bottom:8px}
  .cookie-banner > div:first-child{font-size:13px}
  .cookie-banner > div:last-child{display:flex;gap:8px}
  .cookie-banner .btn{flex:1;padding:11px 8px;font-size:12px;justify-content:center;text-align:center}
}

/* loading states */
.progressbar{position:fixed;top:0;left:0;height:3px;width:0;background:var(--blood);
  box-shadow:0 0 10px var(--blood-glow);z-index:10000;opacity:0;transition:width .2s ease,opacity .3s ease;pointer-events:none}
.btn.is-loading{opacity:.7;cursor:progress}
/* image skeleton: animated shimmer until the photo paints over it */
.case-tile{background:linear-gradient(100deg,#120c0d 30%,#1c1314 50%,#120c0d 70%);background-size:200% 100%;animation:ajs-shimmer 1.5s linear infinite}
.case-tile.loaded{animation:none;background:#120c0d}
.case-gallery img{background:#120c0d}
@keyframes ajs-shimmer{to{background-position:-200% 0}}
@media (prefers-reduced-motion:reduce){.case-tile{animation:none}}
