/* Wojtek Klemm — shared stylesheet */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
:root{
  --bg:#ffffff;
  --fg:#111111;
  --muted:#6b6b6b;
  --line:#e6e6e6;
  --accent:#1a4a6e;
  --maxw:1400px;
}
html{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Helvetica Neue',Arial,sans-serif;color:var(--fg);background:var(--bg);-webkit-font-smoothing:antialiased;font-size:16px;line-height:1.5}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
a:hover{color:var(--accent)}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.95);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--line)}
.site-header .bar{max-width:var(--maxw);margin:0 auto;padding:18px 28px;display:flex;align-items:center;justify-content:space-between;gap:24px;position:relative}
.site-header .brand{font-size:15px;letter-spacing:.06em;text-transform:uppercase;font-weight:600}
.site-header nav > ul{list-style:none;display:flex;flex-wrap:wrap;gap:14px 20px;margin:0;padding:0;align-items:center;justify-content:flex-end}
.site-header nav a,.site-header nav .nav-trigger{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg);background:none;border:0;padding:0;cursor:pointer;font:inherit;font-size:12px;letter-spacing:.14em;text-transform:uppercase}
.site-header nav .nav-trigger:hover{color:var(--accent)}
.site-header nav a.cross{color:var(--muted)}
.site-header nav a.cross:hover{color:var(--accent)}
.site-header nav li.has-sub{position:relative}
.site-header nav .subnav{list-style:none;margin:0;padding:0;display:none}
.site-header nav .subnav.open{display:flex;position:absolute;top:100%;left:0;background:#fff;border:1px solid var(--line);border-top:0;padding:14px 22px;gap:26px;white-space:nowrap;box-shadow:0 6px 18px rgba(0,0,0,.06);margin-top:18px}
.site-header nav .subnav a{display:inline-block;padding:4px 0}
.hamburger{display:none;background:none;border:0;font-size:22px;cursor:pointer;padding:4px 8px}
@media(max-width:520px){
  .site-header .bar{padding:14px 18px;gap:12px}
  .site-header nav{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);max-height:calc(100vh - 60px);overflow-y:auto}
  .site-header nav.open{display:block}
  .site-header nav > ul{flex-direction:column;gap:0;padding:8px 0;align-items:stretch}
  .site-header nav a,.site-header nav .nav-trigger{display:block;padding:14px 22px;width:100%;text-align:left}
  .site-header nav .subnav.open{position:static;display:block;border:0;box-shadow:none;padding:0 0 8px;margin:0;background:#fafafa}
  .site-header nav .subnav a{padding:12px 36px}
  .hamburger{display:block}
}

/* Layout helpers */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{padding:80px 0}
.section h2{font-size:22px;letter-spacing:-.005em;margin:0 0 32px;color:var(--fg);font-weight:500;line-height:1.2}
.section h2.eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:600}
.review-source-link{display:inline-block;margin-top:10px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg);border-bottom:1px solid var(--fg);padding-bottom:2px}
.review-source-link:hover{color:var(--accent);border-color:var(--accent)}
.collab-links{display:flex;flex-wrap:wrap;gap:14px 22px;margin:24px 0 0;font-size:14px}
.collab-links a{border-bottom:1px solid var(--line);padding-bottom:2px}
.collab-links a:hover{border-color:var(--accent)}

/* Hero */
/* Hero carousel — horizontal scroll-snap */
.hero{position:relative;background:#000;overflow:hidden}
.hero .slider{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none}
.hero .slider::-webkit-scrollbar{display:none}
.hero .slide{position:relative;flex:0 0 100%;scroll-snap-align:start;height:78vh;min-height:480px}
.hero .slide-link{display:block;width:100%;height:100%}
.hero .slide img{width:100%;height:100%;object-fit:cover;display:block}
.hero .slide::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.55) 0%,rgba(0,0,0,0) 45%);pointer-events:none}
.hero .slide-text{position:absolute;left:24px;right:24px;bottom:36px;color:#fff;max-width:520px;text-shadow:0 1px 10px rgba(0,0,0,.5);z-index:2}
.hero .slide-kicker{font-size:10px;letter-spacing:.16em;text-transform:uppercase;opacity:.85;margin-bottom:6px}
.hero .slide-text h2{font-size:clamp(18px,2vw,26px);line-height:1.2;font-weight:400;letter-spacing:-.005em;margin:0 0 4px}
.hero .slide-text h2 a{color:#fff}
.hero .slide-text h2 a:hover{color:var(--accent)}
.hero .slide-sub{font-size:12px;opacity:.9;margin:0;max-width:60ch;line-height:1.35}
.hero .slide-review{font-size:12px;font-style:italic;opacity:.95;margin:8px 0 0;max-width:60ch;line-height:1.4}
.hero .slide-review-source{display:block;margin-top:3px;font-style:normal;font-size:11px;opacity:.8;letter-spacing:.04em}
.hero .slide-review-source a{color:#fff;text-decoration:underline;text-underline-offset:2px}
.hero .slide-review-source a:hover{color:var(--accent)}
.hero .slide-credit{position:absolute;right:14px;bottom:14px;font-size:10px;letter-spacing:.06em;color:rgba(255,255,255,.75);background:rgba(0,0,0,.45);padding:4px 8px;border-radius:2px;z-index:3}
.hero .slide-credit a{color:#fff;text-decoration:underline;text-underline-offset:2px}
.slider-arrow{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border:0;border-radius:50%;background:rgba(0,0,0,.45);color:#fff;font-size:28px;line-height:1;cursor:pointer;z-index:4;display:flex;align-items:center;justify-content:center;transition:background .2s}
.slider-arrow:hover{background:rgba(0,0,0,.75)}
.slider-arrow.prev{left:18px}
.slider-arrow.next{right:18px}
.slider-dots{position:absolute;left:0;right:0;bottom:14px;display:flex;justify-content:center;gap:8px;z-index:4}
.slider-dots button{width:7px;height:7px;border-radius:50%;border:0;background:rgba(255,255,255,.45);padding:0;cursor:pointer;transition:background .2s,transform .2s}
.slider-dots button.active{background:#fff;transform:scale(1.3)}
@media(max-width:680px){.hero .slide-text{bottom:64px}.slider-arrow{width:38px;height:38px;font-size:22px}}

/* Productions grid */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px 28px}
@media(max-width:980px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.grid{grid-template-columns:1fr}}
.card{display:block}
.card .cover{aspect-ratio:4/3;overflow:hidden;background:#f3f3f3}
.card .cover img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.card:hover .cover img{transform:scale(1.03)}
.card .meta{margin-top:12px;display:flex;align-items:baseline;justify-content:space-between;gap:12px}
.card .tag{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.card h3{font-size:18px;margin:6px 0 2px;font-weight:500;letter-spacing:-.005em}
.card .sub{font-size:13px;color:var(--muted)}

/* Profile mini */
.profile{display:grid;grid-template-columns:280px 1fr;gap:40px;align-items:start}
.profile img{aspect-ratio:4/5;object-fit:cover;width:100%}
.profile p{max-width:60ch;font-size:16px;line-height:1.65}
@media(max-width:680px){.profile{grid-template-columns:1fr}.profile img{max-width:220px}}

/* Footer */
.site-footer{border-top:1px solid var(--line);padding:40px 0;margin-top:60px;font-size:15px;color:var(--fg);letter-spacing:.02em;font-weight:500}
.site-footer .wrap{display:flex;flex-wrap:wrap;gap:18px 28px;justify-content:space-between;align-items:center}
.site-footer a{color:var(--fg);border-bottom:1px solid transparent;transition:border-color .2s}
.site-footer a:hover{color:var(--accent);border-bottom-color:var(--accent)}

/* Production / Story pages */
.page-head{padding:64px 0 32px}
.page-head .kicker{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.page-head h1{font-size:clamp(32px,4.4vw,56px);line-height:1.05;margin:0 0 18px;font-weight:400;letter-spacing:-.015em}
.page-head .sub{color:var(--muted);font-size:15px}
.intro{max-width:62ch;font-size:18px;line-height:1.65;margin:24px 0 48px}

.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
@media(max-width:680px){.gallery{grid-template-columns:1fr}}
.gallery figure{margin:0}
.gallery figure img{width:100%;height:100%;object-fit:cover;aspect-ratio:3/2;cursor:zoom-in}
.gallery figcaption{font-size:11px;color:var(--muted);margin-top:6px;letter-spacing:.04em}

.video{margin:48px 0}
.video iframe,.video video{width:100%;aspect-ratio:16/9;border:0;background:#000;display:block}
.video figcaption{font-size:11px;color:var(--muted);margin-top:6px}

.reviews{display:grid;gap:36px;margin:48px 0}
.reviews blockquote{margin:0;border-left:2px solid var(--fg);padding:8px 0 8px 22px;font-size:clamp(18px,2.1vw,24px);font-weight:300;line-height:1.4;letter-spacing:-.005em}
.reviews cite{display:block;margin-top:10px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-style:normal}

.credits{border-top:1px solid var(--line);padding-top:32px;margin-top:64px;display:grid;grid-template-columns:200px 1fr;gap:18px 40px;font-size:13px;line-height:1.6}
.credits dt{color:var(--fg);text-transform:uppercase;font-size:13px;letter-spacing:.1em;font-weight:600}
.credits dd{margin:0;font-size:15px;color:var(--fg)}
@media(max-width:620px){.credits{grid-template-columns:1fr}}

.pagernav{display:flex;justify-content:space-between;gap:18px;border-top:1px solid var(--line);padding:32px 0;margin-top:48px;font-size:12px;letter-spacing:.14em;text-transform:uppercase}
.pagernav a:hover{color:var(--accent)}

/* Coaching */
.coach-intro{max-width:62ch;font-size:22px;line-height:1.5;font-weight:300;margin:32px 0 0;letter-spacing:-.005em}
.experience{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:24px}
@media(max-width:760px){.experience{grid-template-columns:1fr}}
.experience .stat{border-top:1px solid var(--line);padding-top:18px}
.experience .num{font-size:36px;font-weight:300;letter-spacing:-.02em}
.experience .lbl{font-size:12px;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;margin-top:6px}

.offers{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
@media(max-width:880px){.offers{grid-template-columns:1fr}}
.offer{border-top:1px solid var(--fg);padding-top:18px}
.offer h3{font-size:18px;margin:0 0 10px;font-weight:500}
.offer p{font-size:14px;line-height:1.6;color:#333;margin:0 0 12px}
.offer .more{font-size:11px;letter-spacing:.16em;text-transform:uppercase}

.stories{display:grid;grid-template-columns:repeat(3,1fr);gap:36px 28px}
@media(max-width:980px){.stories{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.stories{grid-template-columns:1fr}}
.story{display:block}
.story .cover{aspect-ratio:4/3;overflow:hidden;background:#f3f3f3}
.story .cover img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.story:hover .cover img{transform:scale(1.03)}
.story .tag{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-top:12px;display:block}
.story h3{font-size:18px;margin:6px 0 6px;font-weight:500;letter-spacing:-.005em}
.story p{font-size:14px;color:#444;margin:0 0 8px;line-height:1.5}
.story .credit{font-size:11px;color:var(--muted)}

details.inline-story{border-top:1px solid var(--line);padding:16px 0}
details.inline-story summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:18px;font-size:15px}
details.inline-story summary::after{content:"+";color:var(--muted)}
details.inline-story[open] summary::after{content:"–"}
details.inline-story .body{padding-top:14px;font-size:15px;line-height:1.6;color:#333;max-width:62ch}

.clients{display:flex;flex-wrap:wrap;gap:28px 40px;font-size:13px;color:var(--muted);letter-spacing:.06em}
.contact-cta{padding:48px 0 0;font-size:18px}
.contact-cta a{border-bottom:1px solid var(--fg);padding-bottom:2px}

/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.92);display:none;align-items:center;justify-content:center;z-index:100;padding:24px;cursor:zoom-out}
.lightbox.open{display:flex}
.lightbox img{max-width:100%;max-height:90vh;object-fit:contain}
.lightbox .lb-cap{position:absolute;bottom:18px;left:0;right:0;text-align:center;color:#bbb;font-size:11px;letter-spacing:.1em}

/* Section head with link */
.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:18px;margin-bottom:32px;flex-wrap:wrap}
.section-head h2{margin:0}
.section-head .more{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--fg);border-bottom:1px solid var(--fg);padding-bottom:2px}

/* Vita page */
.vita{padding:24px 0 80px}
.vita-grid{display:grid;grid-template-columns:320px 1fr;gap:56px;align-items:start}
@media(max-width:880px){.vita-grid{grid-template-columns:1fr}}
.vita-grid .caption{font-size:11px;color:var(--muted);margin:8px 0 0;letter-spacing:.04em}
.vita .prose h2{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin:28px 0 10px;font-weight:600}
.vita .prose h2:first-child{margin-top:0}
.vita .prose p,.vita .prose ul{font-size:16px;line-height:1.7;max-width:64ch;color:#222}
.vita .prose ul{padding-left:20px}
.vita .prose li{margin:6px 0}
.source{font-size:11px;color:var(--muted);margin-top:36px;letter-spacing:.04em}

/* Chronological productions */
.chrono{padding:24px 0 80px}
.chrono .year{font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin:40px 0 14px;border-top:1px solid var(--line);padding-top:18px;font-weight:600}
.chrono .year:first-of-type{margin-top:16px;border-top:0;padding-top:0}
.chrono ul.works{list-style:none;margin:0;padding:0}
.chrono ul.works li{display:grid;grid-template-columns:1.4fr 1fr 1.2fr;gap:18px;padding:10px 0;border-bottom:1px solid var(--line);font-size:15px;line-height:1.45}
.chrono .t{font-weight:500}
.chrono .a{color:#444;font-style:italic}
.chrono .v{color:var(--muted);font-size:13px;text-align:right}
@media(max-width:760px){.chrono ul.works li{grid-template-columns:1fr;gap:2px;padding:14px 0}.chrono .v{text-align:left}}

/* Photo credits */
.gallery figure{position:relative}
.gallery figcaption{display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.gallery figcaption a{color:var(--muted);border-bottom:1px dotted var(--muted)}
.gallery figcaption a:hover{color:var(--accent);border-color:var(--accent)}
.credit-overlay{position:absolute;right:8px;bottom:8px;background:rgba(0,0,0,.55);color:#fff;font-size:10px;letter-spacing:.06em;padding:3px 7px;border-radius:2px;pointer-events:auto;z-index:2}
.credit-overlay a{color:#fff;text-decoration:underline;text-underline-offset:2px}
