  :root{
    --bg:#0A0A0A; --surface:#111111; --surface-2:#161616;
    --line:#1f1f1f; --text:#FFFFFF; --muted:#B5B5B5; --dim:#6f6f6f;
    --display:"Bebas Neue", Impact, sans-serif;
    --body:"Inter", system-ui, sans-serif;
    --ease:cubic-bezier(0.22,1,0.36,1);
    --container:1280px;
  }
  *{ box-sizing:border-box; margin:0; padding:0; -webkit-font-smoothing:antialiased; }
  html{ scroll-behavior:smooth; }
  body{ background:var(--bg); color:var(--text); font-family:var(--body); font-weight:300; line-height:1.6; overflow-x:hidden; }
  ::selection{ background:#fff; color:#000; }
  a{ color:inherit; text-decoration:none; }
  img{ display:block; max-width:100%; }
  ::-webkit-scrollbar{ width:9px; height:9px; } ::-webkit-scrollbar-track{ background:var(--bg); } ::-webkit-scrollbar-thumb{ background:#2a2a2a; }

  .container{ max-width:var(--container); margin:0 auto; padding:0 clamp(20px,5vw,64px); }
  .section{ padding:clamp(72px,11vw,150px) 0; }

  /* ---- type ---- */
  .display{ font-family:var(--display); font-weight:400; letter-spacing:.01em; line-height:.92; }
  .eyebrow{ font-family:var(--body); font-size:11px; font-weight:600; letter-spacing:.36em; text-transform:uppercase; color:var(--dim); }
  h1,h2,h3{ font-family:var(--display); font-weight:400; letter-spacing:.015em; line-height:.92; }
  .h-sec{ font-size:clamp(2.8rem,8vw,6.5rem); }
  .lead{ color:var(--muted); font-weight:300; }

  /* ---- buttons ---- */
  .btn{ display:inline-flex; align-items:center; justify-content:center; gap:.6em;
    font-family:var(--body); font-size:12px; font-weight:600; letter-spacing:.2em; text-transform:uppercase;
    padding:1.05em 2.2em; border:1px solid #fff; background:#fff; color:#000; cursor:pointer;
    transition:background .35s var(--ease), color .35s var(--ease), transform .15s var(--ease); }
  .btn:hover{ background:transparent; color:#fff; }
  .btn:active{ transform:scale(.97); }
  .btn--ghost{ background:transparent; color:#fff; border-color:#3a3a3a; }
  .btn--ghost:hover{ background:#fff; color:#000; border-color:#fff; }

  /* ---- image frame + skeleton ---- */
  .frame{ position:relative; overflow:hidden; background:var(--surface); }
  .frame::before{ /* skeleton shimmer, visible until image loads */
    content:""; position:absolute; inset:0; z-index:0;
    background:linear-gradient(100deg,#0f0f0f 30%,#191919 50%,#0f0f0f 70%);
    background-size:200% 100%; animation:shimmer 1.6s linear infinite;
  }
  .frame.loaded::before, .frame.failed::before{ animation:none; }
  .frame.loaded::before{ opacity:0; }
  .frame.failed::before{ background:var(--surface); }
  .frame img{ position:relative; z-index:1; width:100%; height:100%; object-fit:cover; opacity:0; transition:opacity .6s var(--ease); }
  .frame.loaded img{ opacity:1; }
  .frame.failed img{ display:none; }
  @keyframes shimmer{ to{ background-position:-200% 0; } }
  @media (prefers-reduced-motion:reduce){ .frame::before{ animation:none; } }

  /* ---- reveals (only hidden when JS active) ---- */
  .js .reveal{ opacity:0; transform:translateY(24px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
  .reveal.in{ opacity:1; transform:none; }
  @media (prefers-reduced-motion:reduce){ .js .reveal{ opacity:1; transform:none; transition:none; } }

  /* ---- nav ---- */
  .nav{ position:fixed; top:0; left:0; right:0; z-index:50; transition:background .4s var(--ease), backdrop-filter .4s, border-color .4s; border-bottom:1px solid transparent; }
  .nav.scrolled{ background:rgba(10,10,10,.78); backdrop-filter:blur(14px); border-bottom-color:var(--line); }
  .nav__inner{ display:flex; align-items:center; justify-content:space-between; gap:16px; padding:20px 0; }
  .brand{ font-family:var(--display); font-size:26px; letter-spacing:.06em; white-space:nowrap; }
  .brand span{ color:var(--dim); }
  .nav__links{ display:flex; gap:34px; align-items:center; }
  .nav__links a{ font-size:12px; font-weight:500; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); position:relative; transition:color .3s; }
  .nav__links a::after{ content:""; position:absolute; left:0; bottom:-6px; height:1px; width:0; background:#fff; transition:width .35s var(--ease); }
  .nav__links a:hover{ color:#fff; } .nav__links a:hover::after{ width:100%; }
  .nav__cta{ display:inline-flex; }
  .burger{ display:none; width:30px; height:16px; position:relative; background:none; border:none; cursor:pointer; }
  .burger span{ position:absolute; left:0; width:100%; height:1.6px; background:#fff; transition:transform .4s var(--ease), opacity .3s; }
  .burger span:nth-child(1){ top:0; } .burger span:nth-child(2){ bottom:0; }
  .burger.open span:nth-child(1){ top:7px; transform:rotate(45deg); }
  .burger.open span:nth-child(2){ bottom:7px; transform:rotate(-45deg); }

  .mobile{ position:fixed; inset:0; z-index:49; background:var(--bg); display:flex; flex-direction:column; justify-content:center; gap:6px; padding:0 clamp(24px,8vw,48px); transform:translateY(-102%); transition:transform .55s var(--ease); }
  .mobile.open{ transform:translateY(0); }
  .mobile a{ font-family:var(--display); font-size:clamp(2.4rem,11vw,4rem); letter-spacing:.03em; padding:.2em 0; border-bottom:1px solid var(--line); }

  /* ---- hero ---- */
  .hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end; padding-bottom:clamp(48px,9vh,110px); }
  .hero__bg{ position:absolute; inset:0; z-index:0; }
  .hero__bg img{ width:100%; height:100%; object-fit:cover; }
  .hero__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(to top, var(--bg) 3%, rgba(10,10,10,.35) 50%, rgba(10,10,10,.6) 100%); }
  .hero__content{ position:relative; z-index:2; width:100%; }
  .hero h1{ font-size:clamp(3.4rem,14vw,11rem); margin:.1em 0 .12em; line-height:.86; }
  .hero .sub{ font-family:var(--display); font-size:clamp(1.4rem,4.2vw,2.6rem); letter-spacing:.08em; color:#eee; }
  .hero__cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:36px; }
  .scrollcue{ position:absolute; bottom:26px; left:50%; transform:translateX(-50%); z-index:2; display:flex; flex-direction:column; align-items:center; gap:10px; }
  .scrollcue .eyebrow{ font-size:9px; }
  .scrollcue .bar{ width:1px; height:46px; background:linear-gradient(to bottom,#777,transparent); position:relative; overflow:hidden; }
  .scrollcue .bar::after{ content:""; position:absolute; top:0; left:0; width:100%; height:14px; background:#fff; animation:cue 2.2s var(--ease) infinite; }
  @keyframes cue{ 0%{ transform:translateY(-100%);} 60%,100%{ transform:translateY(330%);} }

  /* ---- intro / positioning ---- */
  .intro{ text-align:center; }
  .intro .big{ font-size:clamp(2.4rem,6.5vw,5rem); max-width:16ch; margin:18px auto 22px; }
  .intro .lead{ max-width:54ch; margin:0 auto; font-size:1.05rem; }

  /* ---- services ---- */
  .head-row{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; flex-wrap:wrap; margin-bottom:48px; }
  .grid-svc{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
  .card{ position:relative; overflow:hidden; aspect-ratio:4/5; background:var(--surface); border:1px solid var(--surface-2); }
  .card .frame{ position:absolute; inset:0; }
  .card .frame img{ transition:transform 1s var(--ease), opacity .6s var(--ease); }
  .card__body{ position:absolute; inset:0; z-index:3; display:flex; flex-direction:column; justify-content:flex-end; padding:clamp(18px,2.4vw,30px);
    background:linear-gradient(to top, rgba(10,10,10,.94) 0%, rgba(10,10,10,.25) 55%, transparent 100%); }
  .card__num{ position:absolute; top:18px; right:22px; z-index:3; font-family:var(--display); font-size:15px; color:var(--dim); letter-spacing:.1em; }
  .card h3{ font-size:clamp(1.9rem,3vw,2.6rem); margin-bottom:6px; }
  .card p{ color:var(--muted); font-size:.9rem; max-width:32ch; }
  .card .more{ margin-top:14px; font-size:11px; font-weight:600; letter-spacing:.22em; text-transform:uppercase; color:var(--dim); transition:color .3s; }
  @media (hover:hover){
    .card:hover .frame img{ transform:scale(1.07); }
    .card:hover .more{ color:#fff; }
  }

  /* ---- gallery ---- */
  .masonry{ column-count:3; column-gap:16px; }
  .masonry .g{ break-inside:avoid; margin-bottom:16px; position:relative; cursor:pointer; overflow:hidden; }
  .masonry .g .frame{ position:relative; }
  .masonry .g .frame img{ transition:transform 1s var(--ease), opacity .6s var(--ease); }
  .masonry .g .plus{ position:absolute; inset:0; z-index:3; display:flex; align-items:center; justify-content:center; opacity:0; transition:opacity .4s var(--ease); }
  .masonry .g .plus i{ width:48px; height:48px; border:1px solid #fff; border-radius:50%; display:grid; place-items:center; font-style:normal; font-size:22px; font-weight:300; }
  @media (hover:hover){ .masonry .g:hover .frame img{ transform:scale(1.06); } .masonry .g:hover .plus{ opacity:1; } }

  /* ---- artist ---- */
  .split{ display:grid; grid-template-columns:5fr 7fr; gap:clamp(28px,5vw,72px); align-items:center; }
  .split .frame{ aspect-ratio:4/5; }
  .artist-stats{ display:flex; gap:40px; margin-top:34px; }
  .artist-stats .n{ font-family:var(--display); font-size:clamp(2.6rem,4vw,3.6rem); }
  .artist-stats .l{ font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--dim); margin-top:2px; }

  /* ---- reviews ---- */
  .rev-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; flex-wrap:wrap; margin-bottom:40px; }
  .rev-track{ display:flex; gap:18px; overflow-x:auto; scroll-snap-type:x mandatory; scroll-behavior:smooth; padding-bottom:6px; -ms-overflow-style:none; scrollbar-width:none; }
  .rev-track::-webkit-scrollbar{ display:none; }
  .rev{ scroll-snap-align:start; flex:0 0 clamp(300px,33%,420px); background:var(--surface); border:1px solid var(--surface-2); padding:clamp(22px,2.6vw,34px); }
  .rev .stars{ letter-spacing:.25em; font-size:13px; }
  .rev p{ color:#e4e4e4; font-weight:300; margin:18px 0 24px; }
  .rev .who{ display:flex; align-items:center; gap:14px; }
  .rev .who .frame{ width:50px; height:50px; border-radius:50%; flex:none; }
  .rev .who .name{ font-weight:500; font-size:.95rem; }
  .rev .who .role{ font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--dim); margin-top:2px; }
  .rev-nav{ display:flex; gap:10px; }
  .rev-nav button{ width:46px; height:46px; border:1px solid #2c2c2c; background:none; color:#fff; cursor:pointer; font-size:18px; transition:background .3s, color .3s; }
  .rev-nav button:hover{ background:#fff; color:#000; }

  /* ---- studio ---- */
  .studio{ position:relative; }
  .studio .frame{ aspect-ratio:21/9; }
  @media (max-width:760px){ .studio .frame{ aspect-ratio:4/3; } }
  .studio__overlay{ position:absolute; inset:0; z-index:3; display:flex; flex-direction:column; justify-content:center; align-items:flex-start; padding:0 clamp(28px,7vw,90px);
    background:linear-gradient(to right, rgba(10,10,10,.8) 0%, rgba(10,10,10,.25) 70%, transparent 100%); }
  .studio__overlay h2{ font-size:clamp(2.6rem,7vw,5.5rem); }
  .studio__overlay p{ color:var(--muted); max-width:42ch; margin-top:16px; }

  /* ---- contact ---- */
  .contact-grid{ display:grid; grid-template-columns:5fr 7fr; gap:clamp(32px,5vw,72px); }
  .field{ margin-bottom:26px; }
  .field label{ display:block; font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--dim); margin-bottom:9px; }
  .field input, .field textarea{ width:100%; background:transparent; border:none; border-bottom:1px solid #2a2a2a; color:#fff; font-family:var(--body); font-size:15px; padding:11px 0; outline:none; transition:border-color .35s var(--ease); }
  .field input::placeholder, .field textarea::placeholder{ color:#444; }
  .field input:focus, .field textarea:focus{ border-color:#fff; }
  .field.err input, .field.err textarea{ border-color:#a33; }
  .field .msg{ color:#c66; font-size:11px; letter-spacing:.04em; margin-top:7px; display:none; }
  .field.err .msg{ display:block; }
  .form-ok{ display:none; padding:34px; border:1px solid var(--surface-2); background:var(--surface); }
  .form-ok.show{ display:block; }
  .form-ok h3{ font-size:2.2rem; margin-bottom:8px; }
  .info-block{ margin-bottom:26px; }
  .info-block .t{ font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--dim); margin-bottom:6px; }
  .info-block .v{ color:#ddd; font-weight:300; }

  /* ---- footer ---- */
  footer{ border-top:1px solid var(--line); padding:72px 0 40px; }
  .foot-grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:40px; margin-bottom:54px; }
  .foot-grid .brand{ font-size:32px; }
  .foot-grid p{ color:var(--muted); max-width:34ch; margin-top:16px; font-size:.92rem; }
  .foot-col .t{ font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--dim); margin-bottom:18px; }
  .foot-col a{ display:block; color:var(--muted); font-size:.92rem; padding:6px 0; transition:color .3s; }
  .foot-col a:hover{ color:#fff; }
  .foot-bottom{ display:flex; justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap; padding-top:30px; border-top:1px solid var(--line); }
  .foot-bottom small{ color:var(--dim); font-size:12px; letter-spacing:.04em; }
  .foot-bottom .links{ display:flex; gap:24px; } .foot-bottom .links a{ color:var(--dim); font-size:12px; }
  .foot-bottom .links a:hover{ color:#fff; }

  /* ---- lightbox ---- */
  .lb{ position:fixed; inset:0; z-index:200; background:rgba(5,5,5,.96); backdrop-filter:blur(4px); display:flex; align-items:center; justify-content:center; padding:5vw; opacity:0; visibility:hidden; transition:opacity .35s var(--ease), visibility .35s; }
  .lb.open{ opacity:1; visibility:visible; }
  .lb img{ max-width:92vw; max-height:86vh; object-fit:contain; transform:scale(.97); transition:transform .4s var(--ease); }
  .lb.open img{ transform:scale(1); }
  .lb .x{ position:absolute; top:24px; right:28px; background:none; border:none; color:#fff; font-size:12px; letter-spacing:.2em; cursor:pointer; }

  /* ---- responsive ---- */
  @media (max-width:1000px){
    .grid-svc{ grid-template-columns:repeat(2,1fr); }
    .masonry{ column-count:2; }
    .split, .contact-grid{ grid-template-columns:1fr; }
    .split .order-img{ order:-1; }
    .foot-grid{ grid-template-columns:1fr 1fr; }
  }
  @media (max-width:760px){
    .nav__links, .nav__cta{ display:none; }
    .burger{ display:block; }
    .section{ padding:clamp(52px,12vw,80px) 0; }
    .grid-svc{ grid-template-columns:repeat(2,1fr); gap:10px; }
    .masonry{ column-count:3; column-gap:8px; }
    .masonry .g{ margin-bottom:8px; }
    .foot-grid{ grid-template-columns:1fr; }
    .artist-stats{ gap:28px; }
  }
  @media (max-width:560px){
    .nav__inner{ padding:16px 0; }
    .brand{ font-size:20px; letter-spacing:.03em; }
    /* keep small service tiles clean & readable: image + title only */
    .card{ aspect-ratio:3/4; }
    .card p, .card .more{ display:none; }
    .card h3{ font-size:1.35rem; }
    .card__num{ top:12px; right:14px; font-size:12px; }
    .card__body{ padding:14px; }
    .h-sec{ font-size:clamp(2.4rem,12vw,3.2rem); }
    .rev{ flex-basis:84%; }
  }
  @media (max-width:380px){
    .masonry{ column-count:2; }
    .brand{ font-size:17px; }
  }

  /* ===== multi-page additions ===== */
  .nav__links a.active{ color:#fff; }
  .nav__links a.active::after{ width:100%; }

  /* page header (top of each subpage) */
  .page-header{ padding:clamp(120px,20vh,200px) 0 clamp(40px,6vw,72px); border-bottom:1px solid var(--line); }
  .page-header .h-sec{ margin:14px 0 18px; }
  .page-header .lead{ max-width:60ch; }

  /* home teaser cards -> link to each subpage */
  .teasers{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
  .teaser{ position:relative; display:block; overflow:hidden; aspect-ratio:4/5; background:var(--surface); border:1px solid var(--surface-2); }
  .teaser .frame{ position:absolute; inset:0; }
  .teaser .frame img{ transition:transform 1s var(--ease), opacity .6s var(--ease); filter:grayscale(.1); object-position:50% 28%; }
  .teaser__body{ position:absolute; inset:0; z-index:3; display:flex; flex-direction:column; justify-content:flex-end; padding:clamp(18px,2.4vw,30px);
    background:linear-gradient(to top, rgba(10,10,10,.92) 0%, rgba(10,10,10,.2) 60%, transparent 100%); }
  .teaser h3{ font-size:clamp(1.9rem,3vw,2.8rem); }
  .teaser .go{ margin-top:10px; font-size:11px; font-weight:600; letter-spacing:.22em; text-transform:uppercase; color:var(--dim); transition:color .3s; }
  @media (hover:hover){ .teaser:hover .frame img{ transform:scale(1.07); } .teaser:hover .go{ color:#fff; } }

  /* CTA band */
  .cta-band{ border-top:1px solid var(--line); text-align:center; }
  .cta-band h2{ font-size:clamp(2.4rem,7vw,5rem); margin-bottom:24px; }
  .cta-band .lead{ max-width:48ch; margin:0 auto 30px; }

  /* reviews shown as static grid (reviews page) */
  .rev-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
  .rev-grid .rev{ flex:none; }

  /* studio detail points */
  .studio-points{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:54px; }
  .studio-points .p{ border:1px solid var(--surface-2); background:var(--surface); padding:clamp(20px,2.6vw,32px); }
  .studio-points .p .n{ font-family:var(--display); font-size:1.6rem; color:var(--dim); }
  .studio-points .p h3{ font-size:1.7rem; margin:10px 0 8px; }
  .studio-points .p p{ color:var(--muted); font-size:.92rem; }

  @media (max-width:1000px){
    .teasers, .rev-grid, .studio-points{ grid-template-columns:repeat(2,1fr); }
  }
  @media (max-width:640px){
    .teasers{ grid-template-columns:1fr; }
    .rev-grid, .studio-points{ grid-template-columns:1fr; }
    .teaser{ aspect-ratio:16/10; }
  }

/* ===== Zurück-zu-KJC sticky button (portfolio demo) ===== */
.kjc-back{position:fixed;top:16px;left:16px;z-index:99999;display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px;border-radius:999px;background:rgba(10,10,10,.72);color:#fff;
  border:1px solid rgba(255,255,255,.28);font-size:13px;font-weight:600;letter-spacing:.01em;
  text-decoration:none;line-height:1;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  box-shadow:0 4px 18px rgba(0,0,0,.28);transition:transform .25s ease,background .25s ease,box-shadow .25s ease,border-color .25s ease;}
.kjc-back svg{transition:transform .25s ease;}
.kjc-back:hover{transform:translateY(-1px);background:rgba(10,10,10,.92);border-color:rgba(255,255,255,.5);box-shadow:0 8px 26px rgba(0,0,0,.4);}
.kjc-back:hover svg{transform:translateX(-3px);}
.kjc-back:focus-visible{outline:2px solid #fff;outline-offset:2px;}
@media(max-width:560px){.kjc-back{top:10px;left:10px;padding:8px 13px;font-size:12px;}.kjc-back svg{width:14px;height:14px;}}

/* ===== form error ===== */
.form-err{ display:none; margin-top:18px; padding:18px 22px; border:1px solid #5a2b2b; background:#1a0f0f; color:#e8b8b8; font-size:.95rem; }
.form-err.show{ display:block; }
.form-err a{ text-decoration:underline; color:#fff; }

/* ===== FAQ ===== */
.faq-list{ max-width:760px; }
.faq{ border-bottom:1px solid var(--line); }
.faq summary{ cursor:pointer; list-style:none; display:flex; justify-content:space-between; align-items:center; gap:18px;
  padding:20px 0; font-family:var(--body); font-weight:600; font-size:1.02rem; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; font-family:var(--display); font-size:1.5rem; color:var(--dim); transition:transform .3s var(--ease); }
.faq[open] summary::after{ transform:rotate(45deg); }
.faq p{ color:var(--muted); padding:0 0 22px; max-width:62ch; }
.faq summary:focus-visible{ outline:2px solid #fff; outline-offset:2px; }

/* ===== sticky mobile booking bar ===== */
.book-bar{ display:none; }
@media (max-width:760px){
  .book-bar{ position:fixed; left:12px; right:12px; bottom:12px; z-index:60; display:flex; align-items:center; justify-content:center;
    font-family:var(--body); font-size:12px; font-weight:600; letter-spacing:.18em; text-transform:uppercase;
    padding:1.1em 1.2em; background:#fff; color:#000; border:1px solid #fff; box-shadow:0 10px 34px rgba(0,0,0,.55); }
  .book-bar:active{ transform:scale(.98); }
  body:has(.book-bar) footer{ padding-bottom:76px; }
}
