:root {
  /* ═══ TYPOGRAPHY ═══ */
  --fs-base: clamp(0.75rem, 2.4vh, 1.125rem);
  --fs-lg:   calc(var(--fs-base) * 2.5);
  --fs-md:   calc(var(--fs-base) * 1.25);
  --fs-sm:   calc(var(--fs-base) * .75);

  /* ═══ COLORS ═══ */
  --accent: #fe5000;
  --a-d:    rgba(254,80,0,.06);
  --a-r:    rgba(254,80,0,.12);
  --a-i:    rgba(254,80,0,.25);

  /* ═══ MEDIA ═══ */
  --sec-img-h: 45vh;
  --side-pad:  clamp(0px, calc(50vw - 50vh), calc(100vw / 6));

  /* ═══ BAND OVERLAY ═══ */
  --band-w:         100vw;
  --band-item-w:    20vw;
  --trigger-w:      48vw;
  --bar-w:          0.5vw;
  --band-close-ms:  300ms;

  /* ═══ SPACING SCALE (derived from --fs-base) ═══ */
  --sp-03:  calc(var(--fs-base) * 0.3);
  --sp-04:  calc(var(--fs-base) * 0.4);
  --sp-05:  calc(var(--fs-base) * 0.5);
  --sp-07:  calc(var(--fs-base) * 0.7);   /* was 0.8rem */
  --sp-085: calc(var(--fs-base) * 0.85);  /* was 0.85rem */
  --sp-1:   var(--fs-base);               /* was 1rem */
  --sp-15:  calc(var(--fs-base) * 1.5);   /* was 1.5rem */
  --sp-2:   calc(var(--fs-base) * 2);     /* was 2rem */
  --sp-25:  calc(var(--fs-base) * 2.5);   /* was 2.5rem */
  --sp-4:   calc(var(--fs-base) * 4);     /* was 4rem */
  --sp-5:   calc(var(--fs-base) * 5);     /* was 5rem */
  --sp-6:   calc(var(--fs-base) * 6);     /* was 6rem */

  /* ═══ GRID — COLUMNS ═══ */
  --grid-2col: 1fr 1fr;
  --grid-3col: repeat(3, 1fr);
  --grid-icon: 56px 1fr;

  /* ═══ GRID — GAPS ═══ */
  --gap-row:     var(--sp-05);
  --gap-gallery: 0;  /* TEMP */
  --gap-pano:    0;
  --gap-section: 0;  /* TEMP */
  --gap-card:    0;  /* TEMP */
  --gap-icon:    var(--sp-05);

  /* ═══ PADDING ═══ */
  --pad-x:     0;  /* TEMP experiment */
  --pad-sec-y: var(--sp-6);

  /* ═══ MAX-WIDTHS ═══ */
  --txt-max-w:     none;  /* TEMP */
  --block-max-w:   none;  /* TEMP */
  --proj-inner-w:  100%;  /* TEMP */
  --canvas-max-w:  none;  /* TEMP */
  --intro-w:       none;  /* TEMP */
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:var(--sp-5);overflow-x:hidden}
body{font-family:'Noto Sans',sans-serif;color:#2c2c2c;background:#fff;line-height:1;font-weight:300;font-size:var(--fs-base);-webkit-font-smoothing:antialiased;padding:0 var(--side-pad)}
/* body::before — dot pattern removed */
/* body::after — gradient removed */
img{max-width:100%;height:auto;display:block}
::selection{background:var(--accent);color:#fff}

h1{font-size:var(--fs-lg);font-weight:300;letter-spacing:.02em;line-height:1}
h2{font-size:var(--fs-md);font-weight:300;letter-spacing:.1em;line-height:1;margin-bottom:0}

h3{font-weight:400;line-height:1;margin-bottom:0}
p{color:#555;font-weight:300;line-height:1;margin:0}
a{color:inherit;text-decoration:none}

nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:var(--sp-15) 0;background:#fff;border-bottom:1px solid rgba(44,44,44,.06);transition:background .3s,backdrop-filter .3s}
nav.blur{background:rgba(255,255,255,.5);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
nav .nav-inner{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-2);padding:0}
.nav-logo{color:#2c2c2c;font-weight:400;letter-spacing:.15em;text-transform:uppercase;line-height:1;font-size:1.5vh}
.nav-logo .hl{color:var(--accent)}
.nav-links{list-style:none;display:flex;align-items:center;flex:1;justify-content:space-evenly}
.nav-links a{font-size:1.5vh;color:rgba(44,44,44,.65);font-weight:300;letter-spacing:.2em;text-transform:uppercase;transition:opacity .3s,color .15s}
.nav-links a:hover,.nav-links a.active{opacity:1;color:var(--accent)}
.nav-links .nav-dropdown:hover .nav-group{color:var(--accent);opacity:1}
.nav-links .nav-dropdown{position:relative}
.nav-links .nav-group{font-size:var(--fs-sm);color:rgba(44,44,44,.35);font-weight:300;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;padding:0;transition:color .3s,opacity .3s}
.nav-links .dropdown-content{display:block;visibility:hidden;opacity:0;position:absolute;top:100%;left:0;min-width:100px;z-index:101;padding-top:.6rem;transition:opacity .35s ease,visibility .35s ease}
.nav-links .nav-dropdown:hover .dropdown-content{visibility:visible;opacity:1}
.nav-links .dropdown-content a{display:block;padding:.3rem 0;white-space:nowrap;font-size:var(--fs-sm);color:rgba(44,44,44,.65);letter-spacing:.2em;text-transform:uppercase}
.nav-links .dropdown-content a:hover{color:var(--accent)}

/* Sub-Dropdown (industrial → lamps/audio/furniture) */
.nav-sub{position:relative}
.nav-sub .sub-dropdown{display:flex;visibility:hidden;opacity:0;position:absolute;top:0;right:100%;z-index:102;flex-direction:row;gap:.25rem;padding-right:.3rem;transition:opacity .35s ease,visibility .35s ease}
.nav-sub:hover .sub-dropdown{visibility:visible;opacity:1}
.sub-dropdown a{display:inline-block;padding:.3rem .35rem;font-size:var(--fs-sm);color:rgba(44,44,44,.65);letter-spacing:.2em;text-transform:uppercase}
.sub-dropdown a:hover{color:var(--accent)}

.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 30%,rgba(254,80,0,.1),transparent 60%);pointer-events:none;z-index:1;mix-blend-mode:overlay}

footer{text-align:center;padding:var(--sp-4) 0;position:relative;z-index:1;font-size:var(--fs-sm);color:#999;letter-spacing:.15em;text-transform:uppercase}
footer .hl{color:var(--accent)}
footer::before{content:'';display:block;width:40px;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);margin:0 auto var(--sp-15)}
footer::after{content:'';position:absolute;bottom:0;right:0;width:50%;height:100%;background:radial-gradient(ellipse at bottom right,var(--a-r),transparent 70%);pointer-events:none}

/* ===== from inline <style> (externalized 2026-06-05) ===== */
/* === SECTION RHYTHM === */
.sec{padding:var(--pad-sec-y) 0;position:relative;z-index:1;background:#fff}
.sec:last-of-type{border-bottom:none}
.sec .inner{max-width:100%;padding:0 var(--pad-x)}
.sec-label{font-size:var(--fs-sm);color:var(--accent);letter-spacing:.18em;text-transform:uppercase;margin-bottom:0;font-weight:300;position:relative;padding-bottom:.5vh}
.sec-label::after{content:'';position:absolute;bottom:0;left:calc(0px - var(--side-pad));width:100vw;height:1px;background:var(--accent)}
.sec-title{font-size:var(--fs-lg);font-weight:300;letter-spacing:.04em;margin:0;color:#2c2c2c}
/* Flush-left headers */
.sec-label,.sec-title{margin-left:calc(-1 * var(--pad-x))}

/* === HERO BYLINE === */
.hero-byline{display:flex;flex-direction:column;align-items:center;gap:.3rem;margin-top:var(--sp-2);text-align:center}
.hero-location{font-size:var(--fs-sm);color:#999;letter-spacing:.2em;text-transform:uppercase;font-weight:300}
.hero-disciplines{font-size:var(--fs-sm);color:#888;letter-spacing:.15em;text-transform:uppercase;font-weight:300}

/* === HERO === */
.hero{margin-top:var(--sp-5);margin-bottom:3%;position:relative;z-index:1;background:#fff;display:block;min-height:55vh;overflow:visible}
/* === PROJECT ROWS === */
.proj{margin-bottom:5%;position:relative;z-index:1}
.proj .inner{max-width:var(--proj-inner-w);margin:0 auto}
.proj img{display:block;width:100%;height:auto;max-height:50vh;object-fit:cover}
.proj .txt{padding:0}
.proj .txt p{color:#555;font-weight:300;line-height:1;margin-bottom:0;max-width:var(--txt-max-w)}
.proj .txt .title{font-size:var(--fs-lg);font-weight:300;letter-spacing:.04em;margin:0;color:#2c2c2c}
.proj .txt .title small{display:block;font-size:var(--fs-sm);color:var(--accent);letter-spacing:.18em;text-transform:uppercase;margin-bottom:0;font-weight:300}
.proj .txt .hl-row{color:var(--accent);font-size:var(--fs-md);font-weight:400;letter-spacing:.08em;margin-bottom:0}
.proj .txt .caps-title{font-size:var(--fs-lg);font-weight:300;letter-spacing:.08em;margin:0;color:#2c2c2c}

/* === TWO-COLUMN === */
.row-2col{display:grid;grid-template-columns:var(--grid-2col);gap:var(--gap-row);align-items:start}
.row-2col .txt{padding:0}
/* text clings to image */
.txt-left{text-align:right;justify-self:end}
.txt-left .title small{display:inline}
.txt-right{text-align:left;justify-self:start}
.row-2col img{width:100%;height:auto;display:block}

/* === THREE-COLUMN GALLERY === */
.gal-3{display:grid;grid-template-columns:var(--grid-3col);gap:var(--gap-gallery);padding:0 var(--pad-x)}
.gal-3 img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:1px}

/* === PANORAMA === */
/* ── Pano Container ── */
.pano-2col {
  display: block;
  margin: 0;
}

/* ── Pano loading state ── */
.pano-loading a-scene{opacity:0;transition:opacity .4s}
.pano-active a-scene{opacity:1}
[data-drag="true"]::before{content:'';position:absolute;inset:0;z-index:1;background:rgba(0,0,0,.03);pointer-events:none;opacity:0;transition:opacity .3s}
.pano-loading::before{opacity:1}

.a-enter-vr,.a-orientation-modal{display:none!important}

/* === SERVICE BLOCK (new capacities) === */
.cap-block{padding:0 var(--pad-x);max-width:var(--block-max-w);margin:0 auto}
.cap-block .subhead{font-size:var(--fs-sm);color:var(--accent);letter-spacing:.15em;text-transform:uppercase;margin:0 0 1em;font-weight:300}
.cap-block p{color:#555;font-weight:300;line-height:1;margin-bottom:0}
.cap-block strong{font-weight:400;color:#2c2c2c}
.cap-block .xref{display:inline-block;font-size:var(--fs-sm);color:var(--accent);letter-spacing:.08em;border-bottom:1px solid var(--a-r);margin:var(--sp-15) 0;text-decoration:none}
.cap-block .xref:hover{border-bottom-color:var(--accent)}
.cap-block .metric-row{display:grid;grid-template-columns:var(--grid-3col);gap:var(--gap-card);margin:var(--sp-15) 0;padding:var(--sp-15) 0;border-top:1px solid #e8e6e0;border-bottom:1px solid #e8e6e0}
.cap-block .metric-row .m-num{font-size:var(--fs-lg);font-weight:300;color:var(--accent);line-height:1}
.cap-block .metric-row .m-label{font-size:var(--fs-sm);color:#999;letter-spacing:.1em;text-transform:uppercase}

/* === ABOUT & CONTACT GRID === */
.grid-2{display:grid;grid-template-columns:var(--grid-2col);gap:var(--gap-section);align-items:start;padding:0 var(--pad-x)}
.grid-2 h4{font-size:var(--fs-sm);font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:#999;margin:0}
.grid-2 p{color:#555;line-height:1;margin-bottom:0}
.grid-2 .info-line{color:#777;line-height:1;letter-spacing:.05em}
.grid-2 .tools-line{font-size:var(--fs-sm);color:#888;line-height:1;letter-spacing:.03em;font-weight:300}
.grid-2 .tools-line .hl{color:var(--accent)}
.contact-email{font-size:var(--fs-base);color:var(--accent);letter-spacing:.03em;margin-top:var(--sp-05);display:inline-block}

/* === INFERENCE POINTS === */
.inf-grid{display:grid;grid-template-columns:var(--grid-2col);gap:var(--gap-card);padding:0 var(--pad-x);margin-top:var(--sp-2)}
.inf-card{border:1px solid #e8e6e0;padding:var(--sp-15);background:rgba(255,255,255,.5);transition:border-color .3s}
.inf-card:hover{border-color:var(--accent)}
.inf-card .inf-cat{font-size:var(--fs-sm);color:var(--accent);letter-spacing:.18em;text-transform:uppercase;margin-bottom:0;font-weight:300}
.inf-card h3{font-weight:400;margin:0}
.inf-card .inf-note{display:inline-block;margin-top:0;font-size:var(--fs-sm);color:#999;letter-spacing:.06em}

/* === BUTTONS (in body context) === */
.btn-inline{display:inline-block;padding:var(--sp-07) var(--sp-2);border:1px solid #c8c3b8;color:#2c2c2c;text-decoration:none;letter-spacing:.2em;text-transform:uppercase;transition:all .3s;font-weight:300;font-size:var(--fs-sm)}
.btn-inline:hover{background:#2c2c2c;color:#fff;border-color:#2c2c2c}
.btn-accent{display:inline-block;padding:var(--sp-07) var(--sp-2);background:var(--accent);border:1px solid var(--accent);color:#fff;text-decoration:none;letter-spacing:.2em;text-transform:uppercase;transition:all .3s;font-weight:300;font-size:var(--fs-sm)}
.btn-accent:hover{background:#2c2c2c;border-color:#2c2c2c}

/* Coming Soon badge variant */
.btn-coming {
  cursor: default;
  opacity: 0.55;
}
.btn-coming::after {
  content: 'in Kürze';
  display: inline-block;
  margin-left: 0.6em;
  padding: 0.15em 0.5em;
  font-size: 0.6em;
  font-weight: 400;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  background: var(--accent);
  color: #fff;
  border-radius: 2px;
  vertical-align: 0.15em;
  line-height: 1.4;
}

/* Button spacing */
.btn-row{display:inline-flex;flex-wrap:wrap;gap:var(--sp-15);margin-top:var(--sp-1)}

/* === CAPABILITY ICONS === */
.cap-icon-row{display:grid;grid-template-columns:var(--grid-icon);gap:var(--gap-icon);align-items:center;padding:var(--sp-085) 0}
.cap-icon-row strong{font-weight:400;color:#2c2c2c}
.cap-icon-row p{margin-bottom:0}
.icn{width:56px;height:56px;border-radius:50%;position:relative;overflow:hidden;flex-shrink:0;background:linear-gradient(135deg,#f7f6f4 0%,#ece8df 100%)}
/* FEA — Heat Deformation */
.icn-fea::before{content:'';position:absolute;inset:5px;border-radius:50%;background:radial-gradient(circle at 30% 40%,rgba(254,80,0,.35) 0%,rgba(254,80,0,.18) 30%,rgba(254,80,0,.08) 60%,transparent 100%)}
.icn-fea::after{content:'';position:absolute;inset:12px;border-radius:50%;border:1px dashed rgba(254,80,0,.25)}
/* AM — Stacked Layers */
.icn-am-layers i{position:absolute;left:10px;right:10px;height:3px;border-radius:1.5px;background:var(--accent)}
.icn-am-layers i:nth-child(1){top:10px;opacity:.15}
.icn-am-layers i:nth-child(2){top:18px;opacity:.2}
.icn-am-layers i:nth-child(3){top:26px;opacity:.3;height:4px}
.icn-am-layers i:nth-child(4){top:34px;opacity:.35;height:4px}
.icn-am-layers i:nth-child(5){top:40px;opacity:.4;height:4px}
.icn-am-layers i:nth-child(6){top:46px;opacity:.25}
/* AM — Honeycomb */
.icn-am-hex::before{content:'';position:absolute;inset:0;border-radius:50%;background:repeating-linear-gradient(60deg,rgba(254,80,0,.12) 0px,rgba(254,80,0,.12) 1px,transparent 1px,transparent 8px),repeating-linear-gradient(-60deg,rgba(254,80,0,.12) 0px,rgba(254,80,0,.12) 1px,transparent 1px,transparent 8px),repeating-linear-gradient(0deg,rgba(254,80,0,.08) 0px,rgba(254,80,0,.08) 1px,transparent 1px,transparent 8px);mask:radial-gradient(circle,black 55%,transparent 58%);-webkit-mask:radial-gradient(circle,black 55%,transparent 58%)}
.icn-am-hex::after{content:'';position:absolute;inset:12px;border-radius:50%;border:1px solid rgba(254,80,0,.25)}
/* macOS — App Window */
.icn-mac::before{content:'';position:absolute;top:11px;left:9px;right:9px;bottom:11px;border-radius:5px;background:rgba(254,80,0,.05);border:1.5px solid rgba(254,80,0,.2)}
.icn-mac::after{content:'';position:absolute;top:15px;left:14px;width:5px;height:5px;border-radius:50%;background:rgba(254,80,0,.35);box-shadow:9px 0 0 rgba(254,80,0,.12),18px 0 0 rgba(254,80,0,.12)}
.icn-mac c{position:absolute;left:15px;height:2.5px;border-radius:1.5px;background:rgba(254,80,0,.18)}
.icn-mac c:nth-child(1){top:24px;right:12px}
.icn-mac c:nth-child(2){top:30px;right:14px;width:8px}
/* CI/CD — Continuous Loop */
.icn-ci::before{content:'';position:absolute;inset:11px;border-radius:50%;border:1.5px solid rgba(254,80,0,.25);border-top-color:transparent;border-right-color:transparent;animation:icn-spin 3s linear infinite}
.icn-ci::after{content:'';position:absolute;inset:17px;border-radius:50%;border:1px solid rgba(254,80,0,.18);border-bottom-color:transparent;border-left-color:transparent;animation:icn-spin 4s linear infinite reverse}
.icn-ci r{position:absolute;top:50%;left:50%;width:5px;height:5px;border-radius:50%;background:var(--accent);opacity:.4;transform:translate(-50%,-50%)}
@keyframes icn-spin{to{transform:rotate(360deg)}}

/* individual concept icons */
.rx-ex::before{content:'';position:absolute;top:15px;left:50%;width:13px;height:10px;border:1.5px solid rgba(254,80,0,.35);border-radius:2px 2px 0 0;transform:translateX(-50%)}
.rx-ex::after{content:'';position:absolute;top:30px;left:50%;width:1.5px;height:7px;background:var(--accent);opacity:.4;transform:translateX(-50%)}
.rx-ex a{position:absolute;top:33px;left:50%;width:0;height:0;border-left:3.5px solid transparent;border-right:3.5px solid transparent;border-top:4px solid var(--accent);opacity:.5;transform:translateX(-50%)}
.rx-ex d{position:absolute;top:23px;left:5px;width:3px;height:1.5px;background:var(--accent);border-radius:1px}
.rx-ex d:nth-child(4){left:10px;opacity:.35;width:5px}
.rx-ex d:nth-child(5){left:17px;opacity:.2}
.rx-pa::before{content:'';position:absolute;inset:7px;border-radius:50%;background:radial-gradient(circle,rgba(254,80,0,.08) 1px,transparent 1px) 12px 10px,radial-gradient(circle,rgba(254,80,0,.08) 1px,transparent 1px) 20px 10px,radial-gradient(circle,rgba(254,80,0,.08) 1px,transparent 1px) 28px 10px,radial-gradient(circle,rgba(254,80,0,.35) 2.5px,transparent 2.5px) 12px 20px,radial-gradient(circle,rgba(254,80,0,.08) 1px,transparent 1px) 20px 20px,radial-gradient(circle,rgba(254,80,0,.08) 1px,transparent 1px) 28px 20px,radial-gradient(circle,rgba(254,80,0,.08) 1px,transparent 1px) 12px 30px,radial-gradient(circle,rgba(254,80,0,.35) 2.5px,transparent 2.5px) 28px 30px,radial-gradient(circle,rgba(254,80,0,.08) 1px,transparent 1px) 20px 30px;background-size:100% 100%}
.rx-pa::after{content:'';position:absolute;inset:8px;border-radius:50%;border:1px solid rgba(254,80,0,.18)}
.rx-ed::before{content:'';position:absolute;top:12px;left:15px;width:15px;height:17px;border-radius:2px;border:1.5px solid rgba(254,80,0,.25);background:rgba(254,80,0,.08);transform:rotate(-2deg)}
.rx-ed::after{content:'';position:absolute;top:15px;left:18px;width:15px;height:17px;border-radius:2px;border:1.5px solid rgba(254,80,0,.35);background:rgba(254,80,0,.12);transform:rotate(2deg)}
.rx-ed s{position:absolute;top:18px;left:23px;width:6px;height:6px;border-radius:50%;border:1.5px solid var(--accent);opacity:.45;transform:rotate(2deg)}
.rx-ed c{position:absolute;top:28px;left:22px;width:7px;height:1.5px;border-radius:1px;background:var(--accent);opacity:.25;transform:rotate(2deg)}
.rx-ed c:nth-child(3){top:31px;width:4px}
.rx-es::before{content:'';position:absolute;top:8px;left:10px;width:1.5px;height:10px;background:rgba(254,80,0,.35)}
.rx-es::after{content:'';position:absolute;top:23px;left:34px;width:1.5px;height:11px;background:rgba(254,80,0,.5)}
.rx-es z{position:absolute;height:1.5px;background:var(--accent);border-radius:1px}
.rx-es z:nth-child(1){top:18px;left:10px;width:17px;opacity:.35}
.rx-es z:nth-child(2){top:32px;left:25px;width:10px;opacity:.45}
.rx-es a{position:absolute;top:5px;right:8px;width:0;height:0;border-left:3px solid transparent;border-right:3px solid transparent;border-bottom:5px solid var(--accent);opacity:.55}
.rx-es a:nth-child(4){top:34px;left:27px;border-left:3px solid transparent;border-right:3px solid transparent;border-top:5px solid var(--accent);border-bottom:none;opacity:.45}
.rx-pp::before{content:'';position:absolute;top:8px;left:12px;width:8px;height:12px;border:1.5px solid rgba(254,80,0,.35);transform:skewY(-10deg)}
.rx-pp::after{content:'';position:absolute;top:8px;left:12px;width:12px;height:8px;border:1.5px solid rgba(254,80,0,.25);transform:skewX(-15deg) translate(4px,8px)}
.rx-pp p{position:absolute;bottom:10px;left:50%;width:17px;height:5px;border:1.5px solid rgba(254,80,0,.35);background:rgba(254,80,0,.08);transform:translateX(-50%)}
.rx-pp a{position:absolute;top:25px;left:50%;width:0;height:0;border-left:2.5px solid transparent;border-right:2.5px solid transparent;border-top:4px solid var(--accent);opacity:.3;transform:translateX(-50%)}
.rx-ma::before{content:'';position:absolute;top:10px;left:20px;width:1.5px;height:8px;background:rgba(254,80,0,.18);transform:rotate(-30deg)}
.rx-ma::after{content:'';position:absolute;top:28px;left:20px;width:1.5px;height:8px;background:rgba(254,80,0,.18);transform:rotate(30deg)}
.rx-ma n{position:absolute;width:6px;height:6px;border-radius:50%;border:1.5px solid var(--accent)}
.rx-ma n:nth-child(1){top:8px;left:14px;background:var(--accent);opacity:.35}
.rx-ma n:nth-child(2){top:30px;left:14px;opacity:.35}
.rx-ma n:nth-child(3){top:19px;left:34px;background:var(--accent);opacity:.5}
.rx-ma d{position:absolute;top:19px;left:20px;width:14px;height:1.5px;background:rgba(254,80,0,.18)}
.rx-ma d:nth-child(5){width:1.5px;height:12px;left:auto;right:24px}
.rx-ll::before{content:'';position:absolute;top:12px;left:50%;width:14px;height:15px;border-radius:2px;border:1.5px solid rgba(254,80,0,.25);background:rgba(254,80,0,.08);transform:translateX(-50%)}
.rx-ll::after{content:'';position:absolute;top:17px;left:50%;width:6px;height:4px;border-radius:0 0 3px 3px;border:1.5px solid rgba(254,80,0,.35);background:rgba(254,80,0,.12);transform:translateX(-50%)}
.rx-ll l{position:absolute;bottom:7px;left:7px;width:3px;height:3px;border-radius:1px;background:var(--accent);opacity:.3}
.rx-ll l:nth-child(2){left:15px;width:4px;opacity:.4}
.rx-ll l:nth-child(3){left:23px;opacity:.25}
.rx-ll s{position:absolute;top:28px;left:50%;width:8px;height:1px;background:rgba(254,80,0,.18);transform:translateX(-50%)}
.rx-ll s:nth-child(5){top:31px;width:12px;opacity:.3}
.rx-dw::before{content:'';position:absolute;bottom:12px;left:10px;right:10px;height:1.5px;background:rgba(254,80,0,.18);border-radius:1px}
.rx-dw c{position:absolute;bottom:15px;width:7px;height:7px;border-radius:50%;border:1.5px solid rgba(254,80,0,.25);background:rgba(254,80,0,.08)}
.rx-dw c:nth-child(1){left:11px}
.rx-dw c:nth-child(2){left:25px;border-color:rgba(254,80,0,.35);background:rgba(254,80,0,.12)}
.rx-dw c:nth-child(3){left:39px;border-color:rgba(254,80,0,.25);background:rgba(254,80,0,.08)}
.rx-id::before{content:'';position:absolute;top:12px;left:50%;width:12px;height:12px;border-radius:50%;border:1.5px solid rgba(254,80,0,.35);background:radial-gradient(circle at 50% 50%,rgba(254,80,0,.18) 0%,transparent 60%);transform:translateX(-50%)}
.rx-id::after{content:'';position:absolute;top:24px;left:50%;width:7px;height:5px;border-radius:0 0 2.5px 2.5px;border:1.5px solid rgba(254,80,0,.25);border-top:none;transform:translateX(-50%)}
.rx-id f{position:absolute;top:16px;left:50%;width:1.5px;height:3px;background:var(--accent);opacity:.4;transform:translateX(-50%)}
.rx-id f:nth-child(2){transform:translateX(-50%) rotate(60deg)}
.rx-id f:nth-child(3){transform:translateX(-50%) rotate(-60deg)}
.rx-id f:nth-child(4){top:42px;left:12px;width:2.5px;height:1.5px;background:rgba(254,80,0,.12);border-radius:1px;opacity:.5;transform:none}
.rx-id f:nth-child(5){top:42px;left:18px;transform:none}
.rx-id f:nth-child(6){top:42px;left:25px;opacity:.3;transform:none}
.rx-st::before{content:'';position:absolute;left:50%;width:1.5px;top:17px;bottom:17px;background:rgba(254,80,0,.18);transform:translateX(-50%)}
.rx-st b{position:absolute;left:50%;transform:translateX(-50%);background:rgba(254,80,0,.08);border:1.5px solid rgba(254,80,0,.25);border-radius:2px}
.rx-st b:nth-child(1){top:17px;width:8px;height:5px;border-color:var(--accent);background:rgba(254,80,0,.12)}
.rx-st b:nth-child(2){top:25px;width:12px;height:5px;border-color:rgba(254,80,0,.35)}
.rx-st b:nth-child(3){top:33px;width:15px;height:5px;border-color:rgba(254,80,0,.25)}
.rx-st v{position:absolute;left:50%;width:1.5px;height:3px;background:rgba(254,80,0,.18);transform:translateX(-50%)}
.rx-st v:nth-child(4){top:22px}
.rx-st v:nth-child(5){top:30px}
.rx-rm::before{content:'';position:absolute;left:12px;width:1.5px;top:7px;bottom:7px;background:linear-gradient(180deg,rgba(254,80,0,.35),rgba(254,80,0,.18),rgba(254,80,0,.18))}
.rx-rm d{position:absolute;left:12px;width:7px;height:7px;border-radius:50%;border:1.5px solid var(--accent);transform:translateX(-50%)}
.rx-rm d:nth-child(1){top:8px;background:var(--accent);opacity:.5}
.rx-rm d:nth-child(2){top:22px;opacity:.4;background:rgba(254,80,0,.08)}
.rx-rm d:nth-child(3){top:36px;opacity:.35;background:rgba(254,80,0,.08)}
.rx-rm r{position:absolute;left:22px;height:1.5px;background:var(--accent);border-radius:1px}
.rx-rm r:nth-child(4){top:7px;width:15px;opacity:.25}
.rx-rm r:nth-child(5){top:21px;width:10px;opacity:.2}
.rx-rm r:nth-child(6){top:35px;width:13px;opacity:.2}

/* === FULL-BLEED === */
.proj.full img{width:100vw;margin-left:calc(-50vw + 50%)}

/* ═══════ BAND (fixed am rechten Viewport-Rand) ═══════ */

/* Projekt-Bilder in #industrial & #lamps — rein vh */
#lamps .stack-wrap .proj-img,
#industrial .stack-wrap .proj-img,
#social .stack-wrap .proj-img{
  display:block;
  width:100%;
  height:var(--sec-img-h);
  object-fit:cover;
}

/* Band — fixed am rechten Viewport-Rand */
.img-band{
  position:fixed;
  right:0;
  top:0;
  height:var(--sec-img-h);
  width:calc(var(--bar-w) + var(--band-w));
  z-index:100;
  display:flex;
  flex-direction:row;
  pointer-events:auto;
  transform:translateX(calc(100% - var(--bar-w)));
  transition:transform .45s cubic-bezier(.4,0,.2,1);
}
.img-band.preview{
  transform:translateX(calc(100% - (var(--band-w) + var(--bar-w))));
}

/* Orange Bar */
.img-band::before{
  content:'';
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:var(--bar-w);
  background:var(--accent);
  opacity:.1;
  transition:opacity .15s ease;
  z-index:3;
  flex-shrink:0;
}
.img-band:hover::before,
.img-band.bar-hot::before{
  opacity:1;
}

/* Band von links (Tria) */
.img-band.band-left{
  left:0;
  right:auto;
  transform:translateX(calc(-100% + var(--bar-w)));
}
.img-band.band-left.preview{
  transform:translateX(0);
}
.img-band.band-left::before{
  display:none;
}
.img-band.band-left::after{
  content:'';
  position:absolute;
  right:0;
  top:0;
  bottom:0;
  width:var(--bar-w);
  background:var(--accent);
  opacity:.1;
  transition:opacity 1s ease;
  z-index:3;
}
.img-band.band-left:hover::after,
.img-band.band-left.bar-hot::after{
  opacity:1;
}
.img-band.band-left .band-inner{
  margin-left:0;
  margin-right:var(--bar-w);
}

/* Proximity-Trigger */
.band-trigger{
  position:fixed;
  right:0;
  top:0;
  width:var(--trigger-w);
  height:var(--sec-img-h);
  z-index:99;
  cursor:pointer;
}
.band-trigger.left{
  left:0;
  right:auto;
}

/* Inner: 3 Bilder */
.band-inner{
  display:flex;
  height:100%;
  margin-left:var(--bar-w);
  flex:1;
  min-width:0;
}
.band-item{
  flex:1;
  height:100%;
  overflow:hidden;
  cursor:pointer;
  position:relative;
  border-right:.5px solid rgba(254,80,0,.3);
}
.band-item:last-child{border-right:none}
.band-item img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

/* Selected: native Breite */
.band-item.selected{
  flex:0 0 auto;
}
.band-item.selected img{
  width:auto;
  height:100%;
  object-fit:contain;
}

/* Master-Band (industrial: 8 Hero-Bilder) */
#industrialBand{
  width:calc(0.5vw + 100vw);
}
#industrialBand.preview{
  transform:translateX(calc(100% - 100.5vw));
}

/* ═══════ LAYER BREAKS ═══════ */
.lb-canvas-wrap{max-width:var(--canvas-max-w);margin:0 auto 1.5rem;border:1px solid #e0ddd6;border-radius:4px;overflow:hidden;background:#fff;position:relative}
.lb-canvas-wrap::before{content:'';position:absolute;inset:-2px;z-index:0;background-image:var(--lb-ambient);background-size:cover;background-position:center;filter:blur(20px) brightness(2) contrast(.5);transform:scaleX(-1)}
.lb-canvas{position:relative;z-index:1;width:calc(100vw/3);height:calc(100vw/3);margin:0 auto}
.lb-canvas img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain}
.lb-canvas .ly{opacity:0;pointer-events:none;transition:opacity .3s}
.lb-canvas .ly.on{opacity:1}
.lb-canvas .ly.ana-depth.on{mix-blend-mode:screen}
.lb-canvas .ly.ana-norm.on{mix-blend-mode:overlay}
.lb-canvas .ly.ana-objs.on{mix-blend-mode:screen}
#lb2Canvas{width:calc(100vw*.75);height:calc(100vw/4)}
#lb2Canvas .ly{object-fit:cover}
.ctrl-section{margin-bottom:var(--sp-07)}
.ctrl-label{font-size:var(--fs-sm);color:#aaa;letter-spacing:.08em;text-transform:uppercase;margin-bottom:var(--sp-04)}
.ctrl-row{display:flex;gap:.35rem;flex-wrap:wrap}
.ctrl-btn{display:inline-flex;align-items:center;gap:.25rem;padding:var(--sp-04) var(--sp-07);border:1px solid #e0ddd6;border-radius:3px;font-size:var(--fs-sm);letter-spacing:.04em;color:#888;background:none;cursor:pointer;transition:all .2s;font-family:inherit}
.ctrl-btn:hover{border-color:var(--accent);color:#555}
.ctrl-btn.on{border-color:var(--accent);color:var(--accent);background:var(--a-d)}
.ctrl-btn .dot{width:5px;height:5px;border-radius:50%;background:#ccc;flex-shrink:0}
.ctrl-btn.on .dot{background:var(--accent)}

/* ═══════ SCHATTENZENSUS ═══════ */
.schatten-typewriter{
  background:#fe5000;
  color:#fff;
  height:4.5vw;
  width:100vw;
  margin-left:calc(-50vw + 50%);
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:'Courier New',monospace;
  font-size:3vw;
  white-space:nowrap;
  margin-top:2%;
  margin-bottom:2%;
}

/* Gallery — Filmstrip */
.gallery{position:relative;overflow:hidden;height:30vh;width:100vw;margin-left:calc(-50vw + 50%);margin-top:2%;margin-bottom:2%}
.gallery .carousel-track{display:flex;height:100%;gap:0;position:relative;z-index:0}
.gallery .carousel-slide{flex-shrink:0;height:100%}
.gallery .carousel-slide img{height:100%;width:auto;display:block}
.gallery::before,.gallery::after{content:'';position:absolute;top:0;bottom:0;width:1vw;background:var(--accent);opacity:.15;pointer-events:none;z-index:5;transition:opacity .2s}
.gallery::before{left:0}.gallery::after{right:0}
.gallery.hover-left::before,
.gallery.hover-right::after{opacity:1}
.gallery.at-start::before{opacity:0!important}
.gallery.at-end::after{opacity:0!important}
.carousel-track{
  display:flex;
  transition:transform .2s ease;
  height:100%;
  gap:0;
}

.carousel-slide img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.carousel-dots{
  position:absolute;
  bottom:var(--sp-1);
  left:50%;
  transform:translateX(-50%);
  display:flex;
  gap:var(--sp-05);
  z-index:2;
}
.carousel-dot{
  width:8px;height:8px;
  border-radius:50%;
  background:rgba(255,255,255,.4);
  border:none;cursor:pointer;padding:0;
  transition:background .2s;
}
.carousel-dot.active,.carousel-dot:hover{background:var(--accent,#fe5000)}

/* ═══════ LAYER DISSECTION ═══════ */
.stack-container{position:relative;overflow:hidden;background:#f8f7f5;cursor:ew-resize;perspective:800px;perspective-origin:50% 50%}
.stack-container::before{content:'';position:absolute;inset:-2px;z-index:0;background-image:var(--ambient);background-size:cover;background-position:center;filter:blur(30px) brightness(1.8) contrast(.4);transform:scaleX(-1)}
.stack-layer{position:absolute;inset:0;z-index:1;will-change:transform;backface-visibility:hidden}
.stack-layer img{width:100%;height:100%;object-fit:cover;object-position:center 38%;display:block}
#stack-dissect{height:25vh;width:100vw;margin-left:calc(-50vw + 50%)}
.ly-label{position:absolute;bottom:.6rem;left:0;right:0;text-align:center;color:rgba(255,255,255,.9);font-size:var(--fs-sm);letter-spacing:.1em;text-transform:uppercase;text-shadow:0 1px 4px rgba(0,0,0,.5);opacity:0;pointer-events:none}
.stack-hint{text-align:center;font-size:var(--fs-sm);color:#999;letter-spacing:.08em;padding:0 0 1rem}

/* ═══════ STACK SWITCHER ═══════ */
.stack-switcher {
  display: flex;
  gap: var(--sp-15);
  margin-bottom: var(--sp-15);
  justify-content: center;
}
.stack-set-btn {
  background: none;
  border: 1px solid var(--accent);
  color: var(--accent);
  padding: var(--sp-05) var(--sp-1);
  font-size: var(--fs-sm);
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-family: inherit;
}
.stack-set-btn.active {
  background: var(--accent);
  color: #000;
}

/* ── Project Details Dropdown ── */
.proj-details {
  margin-top: var(--sp-1);
  background: transparent;
}
.proj-details summary {
  cursor: pointer;
  list-style: none;
  color: var(--accent);
  font-size: var(--fs-sm);
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: var(--sp-05) 0;
  border-bottom: 1px solid var(--accent);
  display: inline-block;
  user-select: none;
}
.proj-details summary::-webkit-details-marker {
  display: none;
}
.proj-details summary::marker {
  display: none;
}
.details-arrow {
  display: inline-block;
  transition: transform 0.25s ease;
  font-size: var(--fs-xs);
  margin-right: .35em;
}
.proj-details[open] .details-arrow {
  transform: rotate(180deg);
}
.details-content {
  padding-top: var(--sp-1);
  background: #fff;
}

/* === CASE STUDY EXTENSIONS === */
.nav-case{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-5) var(--sp-15);border-bottom:1px solid #e8e6e0;background:#fff}
.nav-breadcrumb{font-size:var(--fs-sm);color:#999;white-space:nowrap}
.nav-breadcrumb a{color:var(--accent)}
.meta-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-05);margin-top:var(--sp-15);padding:var(--sp-15);border:1px solid #e8e6e0}
.meta-grid dt{font-size:var(--fs-sm);text-transform:uppercase;letter-spacing:.05em;color:#999;margin-bottom:var(--sp-03)}
.meta-grid dd{font-size:var(--fs-md);font-weight:600;margin:0}
.step-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-05);margin:var(--sp-15) 0}
.step-nr{font-size:var(--fs-lg);font-weight:800;color:var(--accent);line-height:1;margin-bottom:var(--sp-05)}
.step-title{font-size:var(--fs-md);font-weight:400;margin:var(--sp-05) 0}
.alt-bg{background:#f7f6f4}
.quote-block{padding:var(--sp-15);margin:var(--sp-15) 0;border-left:4px solid var(--accent);font-style:italic;font-size:var(--fs-md);color:#555;background:var(--a-d)}
.body-text{max-width:720px}
.body-text p{color:#555;font-weight:300;line-height:1.7;margin-bottom:var(--sp-1)}
.sec-subtitle{font-size:var(--fs-md);color:#888;margin:var(--sp-15) 0 var(--sp-1)}
.sec-hero{padding-top:var(--sp-4);margin-top:var(--sp-4)}
.sec-cta{text-align:center}
.result-block{margin:var(--sp-15) 0;padding:var(--sp-15);border:1px solid #e8e6e0}
.result-heading{font-size:var(--fs-sm);color:var(--accent);letter-spacing:.12em;text-transform:uppercase;margin-bottom:var(--sp-05);font-weight:400}
.learnings-list{padding-left:var(--sp-15);margin:var(--sp-1) 0}
.learnings-list li{margin-bottom:var(--sp-1);line-height:1.6;color:#555;font-weight:300}
.learnings-list li strong{color:#2c2c2c;font-weight:400}
.metric-row{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-05);margin:var(--sp-15) 0;padding:var(--sp-15) 0;border-top:1px solid #e8e6e0;border-bottom:1px solid #e8e6e0}
.metric-row .m-num{font-size:var(--fs-lg);font-weight:300;color:var(--accent);line-height:1}
.metric-row .m-label{font-size:var(--fs-sm);color:#999;letter-spacing:.1em;text-transform:uppercase}

