/* ============================================================
   KOPFKINO — Website  ·  Sections  (sections.css)
   ============================================================ */

.sec{ padding:clamp(88px,12vw,180px) 0; }
.sec-head{ max-width:var(--maxw); margin:0 auto; padding:0 var(--pad); }
.sec-num{ font-family:var(--mono); font-size:11px; letter-spacing:.2em; color:var(--dim); }

/* full-bleed image block */
.bleed{ position:relative; width:100%; overflow:hidden; }
.bleed img{ width:100%; height:100%; object-fit:cover; }
.bleed .cap{ position:absolute; left:var(--pad); bottom:22px; font-family:var(--mono); font-size:10px;
  letter-spacing:.18em; text-transform:uppercase; color:rgba(245,244,240,.8); display:flex; gap:10px; align-items:center; }
.bleed .cap::before{ content:""; width:18px; height:1px; background:var(--red); }

/* ---------- SCENE 2: CINEMA FOR LIVE ---------- */
.s-cinema .top{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,80px); align-items:end; }
@media(max-width:860px){ .s-cinema .top{ grid-template-columns:1fr; gap:40px; } }
.s-cinema h2{ font-size:clamp(46px,9vw,150px); line-height:.86; }
.s-cinema h2 em{ font-style:normal; color:var(--red); }
.s-cinema .top .right{ padding-bottom:10px; }
.s-cinema .promise{ font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--red); margin-bottom:18px; }
.s-cinema .big-img{ height:clamp(320px,68vh,760px); margin-top:clamp(40px,6vw,90px); border-radius:4px; }
.s-cinema .stat-row{ display:flex; gap:clamp(24px,5vw,80px); flex-wrap:wrap; margin-top:clamp(40px,6vw,80px); }
.s-cinema .stat .n{ font-weight:800; font-size:clamp(34px,5vw,68px); letter-spacing:-.03em; line-height:1; }
.s-cinema .stat .n em{ color:var(--red); font-style:normal; }
.s-cinema .stat .l{ font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--mid); margin-top:10px; }

/* ---------- SCENE 3: VALUE CHAIN ---------- */
.s-chain h2{ font-size:clamp(40px,7vw,108px); line-height:.9; margin-top:22px; }
.s-chain h2 em{ font-style:normal; color:var(--red); }
.chain-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:clamp(48px,6vw,86px); }
@media(max-width:860px){ .chain-grid{ grid-template-columns:1fr; } }
.phase{ background:var(--ink-2); border:1px solid var(--line); border-radius:6px; overflow:hidden;
  display:flex; flex-direction:column; transition:.4s; }
.phase:hover{ border-color:rgba(232,89,60,.5); transform:translateY(-6px); }
.phase .ph-img{ height:230px; overflow:hidden; position:relative; }
.phase .ph-img img{ width:100%; height:100%; object-fit:cover; filter:brightness(.8); transition:transform 1s; }
.phase:hover .ph-img img{ transform:scale(1.06); }
.phase .ph-img .tag{ position:absolute; top:14px; left:14px; font-family:var(--mono); font-size:10px;
  letter-spacing:.14em; text-transform:uppercase; color:var(--red); background:rgba(5,5,5,.7); padding:5px 10px; border-radius:999px; }
.phase .ph-body{ padding:26px 24px 30px; display:flex; flex-direction:column; flex:1; }
.phase h3{ font-size:26px; letter-spacing:-.01em; }
.phase h3 em{ font-style:normal; color:var(--red); }
.phase .role{ font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--mid); margin:0 0 18px; }
.phase ul{ list-style:none; margin-top:auto; }
.phase li{ font-size:14px; color:var(--mid); padding:9px 0; border-top:1px solid var(--line-2); display:flex; gap:10px; }
.phase li::before{ content:"+"; color:var(--red); }
.chain-foot{ margin-top:34px; font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--mid); }
.chain-foot b{ color:var(--white); font-weight:500; }

/* ---------- SCENE 4: USP ---------- */
.s-usp{ background:var(--black); }
.s-usp h2{ font-size:clamp(44px,8.5vw,140px); line-height:.86; }
.s-usp h2 em{ font-style:normal; color:var(--red); }
.usp-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); margin-top:clamp(48px,6vw,90px); border-radius:6px; overflow:hidden; }
@media(max-width:860px){ .usp-grid{ grid-template-columns:1fr; } }
.usp{ background:var(--ink); padding:clamp(30px,4vw,52px); min-height:300px; display:flex; flex-direction:column; transition:.4s; }
.usp:hover{ background:var(--ink-2); }
.usp .n{ font-family:var(--mono); font-size:11px; letter-spacing:.18em; color:var(--red); }
.usp h3{ font-size:clamp(24px,2.4vw,34px); margin:auto 0 16px; letter-spacing:-.01em; }
.usp p{ color:var(--mid); font-size:15px; line-height:1.65; }

/* ---------- SCENE 5: WORK ---------- */
.work-grid{ display:grid; grid-template-columns:repeat(12,1fr); grid-auto-rows:clamp(140px,18vh,205px); gap:14px; margin-top:clamp(44px,5vw,80px); }
.work-item{ position:relative; overflow:hidden; border-radius:6px; display:block; }
.work-item:nth-child(1){ grid-column:span 7; grid-row:span 2; }
.work-item:nth-child(2){ grid-column:span 5; grid-row:span 1; }
.work-item:nth-child(3){ grid-column:span 5; grid-row:span 1; }
.work-item:nth-child(4){ grid-column:span 6; grid-row:span 1; }
.work-item:nth-child(5){ grid-column:span 6; grid-row:span 1; }
@media(max-width:760px){ .work-grid{ grid-template-columns:1fr 1fr; grid-auto-rows:150px; }
  .work-item:nth-child(1){ grid-column:span 2; grid-row:span 2; } .work-item:nth-child(n+2){ grid-column:span 1; grid-row:span 1; } }
.work-item img{ width:100%; height:100%; object-fit:cover; filter:brightness(.7); transition:transform 1.1s cubic-bezier(.2,.7,.2,1),filter .5s; }
.work-item:hover img{ transform:scale(1.07); filter:brightness(.85); }
.work-item .meta{ position:absolute; inset:auto 0 0 0; padding:20px; background:linear-gradient(transparent,rgba(5,5,5,.9));
  transform:translateY(8px); opacity:.9; transition:.45s; }
.work-item:hover .meta{ transform:none; opacity:1; }
.work-item .tag{ font-family:var(--mono); font-size:9.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--red); display:flex; align-items:center; gap:7px; }
.work-item .tag .dot{ width:6px; height:6px; border-radius:50%; background:var(--red); }
.work-item h3{ font-size:clamp(17px,1.6vw,23px); margin-top:8px; letter-spacing:-.01em; }
.work-item .yr{ font-family:var(--mono); font-size:10px; color:var(--mid); margin-top:3px; }
.work-foot{ display:flex; justify-content:space-between; align-items:baseline; gap:20px; flex-wrap:wrap; margin-top:34px; }
.work-foot .big{ font-weight:800; font-size:clamp(20px,2.4vw,32px); letter-spacing:-.02em; }
.work-foot .big em{ font-style:normal; color:var(--red); }

/* ---------- SCENE 6: STUDIO TOUR (pinned) ---------- */
.s-tour{ height:340vh; }
.tour-sticky{ position:sticky; top:0; height:100vh; overflow:hidden; display:flex; flex-direction:column; justify-content:center; }
.tour-top{ max-width:var(--maxw); margin:0 auto; width:100%; padding:0 var(--pad);
  display:flex; justify-content:space-between; align-items:flex-end; gap:20px; margin-bottom:30px; }
.tour-top h2{ font-size:clamp(32px,5vw,72px); line-height:.92; }
.tour-top h2 em{ font-style:normal; color:var(--red); }
.tour-lede{ color:var(--mid); font-size:clamp(13px,1.3vw,17px); line-height:1.6; max-width:48ch; margin-top:16px; }
.tour-lede b{ color:var(--white); font-weight:600; }
.tour-hint{ font-family:var(--mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--mid); }
.tour-track{ display:flex; gap:20px; padding:0 var(--pad); will-change:transform; }
.tour-card{ flex:0 0 clamp(260px,30vw,400px); height:60vh; position:relative; border-radius:6px; overflow:hidden; }
.tour-card img{ width:100%; height:100%; object-fit:cover; filter:brightness(.72); }
.tour-card .ov{ position:absolute; inset:0; padding:24px; display:flex; flex-direction:column; justify-content:space-between;
  background:linear-gradient(180deg,rgba(5,5,5,.5),transparent 35%,rgba(5,5,5,.85)); }
.tour-card .n{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; color:var(--red); }
.tour-card h3{ font-size:clamp(22px,2.2vw,30px); letter-spacing:-.01em; }
.tour-card .m{ font-family:var(--mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--mid); margin-top:8px; }
.tour-progress{ max-width:var(--maxw); margin:30px auto 0; width:100%; padding:0 var(--pad); }
.tour-progress .track{ height:2px; background:var(--line); position:relative; }
.tour-progress .bar{ position:absolute; left:0; top:0; height:100%; width:10%; background:var(--red); }

/* ---------- SCENE 7: EVENTTECHNIK ---------- */
.s-event{ display:grid; grid-template-columns:1fr 1fr; min-height:80vh; }
@media(max-width:860px){ .s-event{ grid-template-columns:1fr; } }
.s-event .img{ position:relative; overflow:hidden; min-height:340px; }
.s-event .img img{ width:100%; height:100%; object-fit:cover; filter:brightness(.85); }
.s-event .content{ padding:clamp(50px,7vw,120px) var(--pad); display:flex; flex-direction:column; justify-content:center; }
.s-event h2{ font-size:clamp(38px,5.5vw,92px); line-height:.9; margin:22px 0; }
.s-event h2 em{ font-style:normal; color:var(--red); }

/* ---------- SCENE 8: MANIFEST (parallax) ---------- */
.s-manifest{ height:130vh; position:relative; overflow:hidden; display:flex; align-items:center; justify-content:center; background:var(--black); }
.s-manifest .layer{ position:absolute; inset:-10% -5%; }
.s-manifest .layer img{ width:100%; height:100%; object-fit:cover; }
.s-manifest .l1{ filter:brightness(.4) contrast(1.1); }
.s-manifest .l2 img{ filter:brightness(.5); object-position:center; }
.s-manifest::after{ content:""; position:absolute; inset:0; background:radial-gradient(circle at center,rgba(5,5,5,.4),rgba(5,5,5,.86)); }
.s-manifest .mani{ position:relative; z-index:2; text-align:center; padding:0 var(--pad); }
.s-manifest h2{ font-size:clamp(44px,8vw,150px); line-height:.86; }
.s-manifest h2 em{ font-style:normal; color:var(--red); }
.s-manifest p{ margin-top:26px; color:rgba(245,244,240,.8); font-size:clamp(15px,1.5vw,20px); max-width:40ch; margin-left:auto; margin-right:auto; line-height:1.6; }

/* ---------- MARQUEE wrapper ---------- */
.s-clients{ padding-top:clamp(60px,7vw,90px); }
.s-clients .eyebrow{ display:flex; justify-content:center; margin-bottom:clamp(30px,4vw,46px); }

/* ---------- SCENE 10: CREW ---------- */
.s-crew{ position:relative; min-height:92vh; display:flex; align-items:flex-end; overflow:hidden; }
.s-crew .bg{ position:absolute; inset:0; } .s-crew .bg img{ width:100%; height:100%; object-fit:cover; object-position:center 22%; filter:brightness(.55); }
.s-crew .bg image-slot{ display:block; width:100%; height:100%; filter:brightness(.55); }
.s-crew::after{ content:""; position:absolute; inset:0; pointer-events:none; background:linear-gradient(180deg,rgba(5,5,5,.5),transparent 40%,rgba(5,5,5,.92)); }
.s-crew .content{ position:relative; z-index:2; pointer-events:none; padding-bottom:clamp(50px,7vw,100px); }
.s-crew h2{ font-size:clamp(46px,9vw,160px); line-height:.84; }
.s-crew h2 em{ font-style:normal; color:var(--red); }
.s-crew .tags{ display:flex; gap:14px; flex-wrap:wrap; margin-top:30px; }
.s-crew .tags span{ font-family:var(--mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:rgba(245,244,240,.8);
  border:1px solid var(--line); border-radius:999px; padding:9px 16px; }

/* ---------- SCENE 11: CTA ---------- */
.s-cta{ position:relative; overflow:hidden; padding:clamp(90px,14vw,220px) 0; text-align:center; background:var(--black); }
.s-cta .bg{ position:absolute; inset:0; opacity:.3; } .s-cta .bg img{ width:100%; height:100%; object-fit:cover; filter:brightness(.5) grayscale(.2); }
.s-cta::after{ content:""; position:absolute; inset:0; background:radial-gradient(circle at center,transparent,rgba(5,5,5,.85)); }
.s-cta .inner{ position:relative; z-index:2; }
.s-cta .eyebrow{ display:inline-flex; margin-bottom:26px; }
.s-cta h2{ font-size:clamp(52px,11vw,190px); line-height:.84; }
.s-cta h2 em{ font-style:normal; color:var(--red); }
.s-cta p{ color:var(--mid); margin:30px auto 40px; max-width:46ch; font-size:clamp(15px,1.5vw,19px); line-height:1.6; }

/* ---------- SCENE: INSTAGRAM ---------- */
.s-insta{ background:var(--black); }
.insta-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:24px; flex-wrap:wrap; margin-bottom:clamp(34px,5vw,60px); }
.insta-head h2{ font-size:clamp(36px,6.5vw,96px); line-height:.9; margin-top:16px; }
.insta-head h2 em{ font-style:normal; color:var(--red); }
.insta-follow{ white-space:nowrap; }

.insta-layout{ display:grid; grid-template-columns:1fr minmax(300px,348px) 1fr; gap:clamp(12px,2.5vw,40px); align-items:center; justify-items:center; }
@media(max-width:760px){ .insta-layout{ grid-template-columns:1fr; gap:30px; } }

/* iPhone — präsenter, mittig */
.ig-phone{ display:block; position:relative; width:100%; max-width:348px; aspect-ratio:9/19.3;
  background:linear-gradient(180deg,#1d1d1d,#0b0b0b); border-radius:46px; padding:9px;
  box-shadow:0 0 0 1px rgba(245,244,240,.09), 0 40px 90px -30px rgba(0,0,0,.9);
  transition:transform .5s cubic-bezier(.2,.7,.2,1); z-index:2; }
.ig-phone:hover{ transform:translateY(-4px); }
.ig-phone .screen{ position:relative; width:100%; height:100%; border-radius:38px; overflow:hidden; background:#000; }
.ig-reel{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
.ig-phone .island{ position:absolute; top:11px; left:50%; transform:translateX(-50%);
  width:80px; height:22px; background:#000; border-radius:13px; z-index:4; }
.reel-ui{ position:absolute; inset:0; z-index:3; pointer-events:none;
  background:linear-gradient(180deg, rgba(0,0,0,.4) 0%, transparent 20%, transparent 60%, rgba(0,0,0,.65) 100%); }
.reel-top{ position:absolute; top:18px; left:16px; right:16px; display:flex; justify-content:space-between; align-items:center; }
.reel-tag{ font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:#fff; }
.reel-mute{ font-family:var(--mono); font-size:8px; letter-spacing:.16em; text-transform:uppercase; color:rgba(245,244,240,.9);
  border:1px solid rgba(245,244,240,.45); border-radius:999px; padding:3px 8px; }
.reel-bot{ position:absolute; left:16px; right:16px; bottom:18px; }
.reel-handle{ display:flex; align-items:center; gap:9px; font-family:var(--mono); font-size:11px; letter-spacing:.03em; color:#fff; }
.reel-av{ width:24px; height:24px; border-radius:50%; flex:none; border:1px solid rgba(245,244,240,.55);
  background:#000 url('kopfkino-mark-white.png') center/64% no-repeat; }

/* schwebende Kachel-Spalten links & rechts */
.ig-col{ display:flex; flex-direction:column; gap:clamp(14px,2vw,26px); width:100%; max-width:210px; }
.ig-col-left{ align-items:flex-end; }
.ig-col-right{ align-items:flex-start; }
@media(max-width:760px){
  .ig-col{ flex-direction:row; max-width:none; justify-content:center; flex-wrap:wrap; }
  .ig-col-left,.ig-col-right{ align-items:center; }
}
.ig-tile{ display:block; width:clamp(104px,12vw,148px); aspect-ratio:1/1; border-radius:8px; overflow:hidden;
  position:relative; box-shadow:0 18px 40px -16px rgba(0,0,0,.8);
  --tx:0%; --rot:0deg; will-change:transform; }
.ig-tile img{ display:block; width:100%; height:100%; object-fit:cover;
  filter:brightness(.92); transition:filter .4s, transform .6s cubic-bezier(.2,.7,.2,1); }
.ig-tile:hover img{ filter:brightness(1.05); transform:scale(1.06); }

/* wilde Versätze + Rotation */
.ig-col-left  .t1{ --tx:-12%; --rot:-4deg; }
.ig-col-left  .t2{ --tx:16%;  --rot:3deg;  }
.ig-col-left  .t3{ --tx:-6%;  --rot:-2deg; }
.ig-col-right .t4{ --tx:12%;  --rot:4deg;  }
.ig-col-right .t5{ --tx:-16%; --rot:-3deg; }
.ig-col-right .t6{ --tx:6%;   --rot:2deg;  }
.ig-tile{ transform:translate(var(--tx),0) rotate(var(--rot)); }

@media (prefers-reduced-motion:no-preference){
  .ig-tile{ animation:igFloat 6.5s ease-in-out infinite; }
  .ig-col-left  .t1{ animation-delay:-0.4s; } .ig-col-left  .t2{ animation-delay:-2.6s; }
  .ig-col-left  .t3{ animation-delay:-4.1s; } .ig-col-right .t4{ animation-delay:-1.3s; }
  .ig-col-right .t5{ animation-delay:-3.4s; } .ig-col-right .t6{ animation-delay:-5.2s; }
  .ig-tile:hover{ animation-play-state:paused; }
}
@keyframes igFloat{
  0%,100%{ transform:translate(var(--tx),0) rotate(var(--rot)); }
  50%    { transform:translate(var(--tx),-12px) rotate(var(--rot)); }
}

.insta-foot{ margin-top:clamp(28px,4vw,52px); justify-content:center; font-family:var(--mono); font-size:11px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--mid); display:flex; align-items:center; gap:10px; }
.insta-foot .rec{ width:7px; height:7px; border-radius:50%; background:var(--red); box-shadow:0 0 10px var(--red); animation:pulse 1.3s infinite; }
