@font-face{
  font-family:"Fago";
  src:url("../assets/fonts/FagoNoRegularTf-Roman.woff2") format("woff2");
  font-weight:400;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:"Fago";
  src:url("../assets/fonts/FagoNoBoldTf-Roman.woff2") format("woff2");
  font-weight:700;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:"UniversCondensed";
  src:url("../assets/fonts/UniversLT-LightUltraCondensed.woff2") format("woff2");
  font-weight:300;
  font-style:normal;
  font-display:block;
}

:root{
  --bg:#454545;
  --footer:#393939;
  --text:#f2f2f2;
  --muted:#bdbdbd;
  --green:#98ab31;
  --design:#e41516;
  --print:#f0821a;
  --motion:#407bc4;
  --audio:#8f4fb0;
  --campaign:#98ab31;
  --rail-width:360px;
  --drawer-open:184px;
  --content-cut:44px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:"Fago",Arial,sans-serif;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{display:block}

/* Brand rail */

.brand-rail{
  position:fixed;
  inset:0 auto 0 0;
  width:var(--rail-width);
  min-height:100vh;
  background:var(--bg);
  z-index:100;
}
.brand-system{
  position:absolute;
  left:96px;
  top:64px;
  width:275px;
  height:610px;
}
.mobile-home-link{display:none}
.borr-button{
  position:absolute;
  left:0;
  top:0;
  width:100px;
  height:100px;
  overflow:hidden;
  background:#000;
}
.borr-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}
.borr-green{
  clip-path:inset(0 0 100% 0);
  transition:clip-path 750ms ease-out;
}
.borr-button:hover .borr-green,
.borr-button:focus-visible .borr-green{clip-path:inset(0 0 0 0)}
.studio-tower{
  position:absolute;
  left:0;
  top:104px;
  width:100px;
  height:500px;
  background:#000;
}
.studio-tower img{
  position:absolute;
  left:10px;
  bottom:10px;
  width:80px;
  height:auto;
}
.drawer-nav{
  position:absolute;
  left:100px;
  top:104px;
  width:245px;
  height:500px;
}
.drawer{
  position:absolute;
  left:0;
  width:var(--drawer-open);
  height:100px;
  overflow:hidden;
}
.drawer::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  width:22px;
  height:100%;
  background:currentColor;
  z-index:1;
  transition:width 750ms ease;
}
.drawer:hover::before,
.drawer:focus-visible::before{width:var(--drawer-open)}
.drawer img{
  position:absolute;
  left:34px;
  bottom:1px;
  height:51px;
  width:auto;
  max-width:none;
  z-index:2;
  pointer-events:none;
}
.design{top:0;color:var(--design)}
.print{top:100px;color:var(--print)}
.foto{top:200px;color:var(--motion)}
.sound{top:300px;color:var(--audio)}
.werbung{top:400px;color:var(--campaign)}

/* Global layout and typography */

.site-main{
  margin-left:var(--rail-width);
  min-height:100vh;
}
.hero{
  position:relative;
  min-height:auto;
  display:block;
  overflow:visible;
}
.hero-image{display:none}
.hero-content{
  position:relative;
  max-width:860px;
  padding:64px 72px 72px calc(var(--content-cut) + 72px);
}
.eyebrow{
  margin:0 0 12px;
  color:var(--green);
  font-size:14px;
  letter-spacing:.18em;
  text-transform:none;
}
h1{
  margin:0 0 26px;
  font-family:"UniversCondensed",sans-serif;
  font-weight:300;
  font-size:clamp(58px,7vw,98px);
  line-height:.94;
  letter-spacing:.018em;
}
.lead{
  max-width:740px;
  margin:0 0 12px;
  color:#fff;
  font-family:"UniversCondensed",sans-serif;
  font-weight:300;
  font-size:clamp(34px,3.7vw,54px);
  line-height:1.04;
  letter-spacing:.025em;
}
.lead-secondary{
  margin:18px 0 34px;
  color:#fff;
}
.subline{
  max-width:620px;
  margin:0;
  color:var(--muted);
  font-size:18px;
  line-height:1.55;
}
.hero .quote{color:#9f9f9f}

/* Chapters */

.chapter{position:relative}
.chapter::before{
  content:"";
  position:absolute;
  left:var(--content-cut);
  right:0;
  top:0;
  height:1px;
  background:rgba(255,255,255,.16);
}
.chapter-inner{
  max-width:1120px;
  padding:82px 112px 82px calc(var(--content-cut) + 72px);
  display:grid;
  grid-template-columns:210px minmax(0,1fr);
  gap:28px;
  align-items:start;
}
.chapter-label{
  position:relative;
  padding-top:34px;
}
.chapter-label span{
  position:absolute;
  left:0;
  top:0;
  font-size:14px;
  letter-spacing:.18em;
}
.chapter-label h2{
  margin:0;
  font-family:"UniversCondensed",sans-serif;
  font-weight:300;
  font-size:clamp(46px,5vw,82px);
  line-height:.95;
  letter-spacing:.045em;
  text-transform:uppercase;
}
.chapter-content{
  max-width:760px;
  padding-top:34px;
  min-width:0;
}
.chapter-lead{
  margin:0 0 22px;
  color:#fff;
  font-family:"UniversCondensed",sans-serif;
  font-weight:300;
  font-size:clamp(34px,3.7vw,54px);
  line-height:1.04;
  letter-spacing:.025em;
}
.chapter-content p:not(.chapter-lead){
  margin:0;
  color:var(--muted);
  font-size:19px;
  line-height:1.55;
}
.chapter-design h2,
.chapter-design .chapter-label span{color:var(--design)}
.chapter-print h2,
.chapter-print .chapter-label span{color:var(--print)}
.chapter-motion h2,
.chapter-motion .chapter-label span{color:var(--motion)}
.chapter-audio h2,
.chapter-audio .chapter-label span{color:var(--audio)}
.chapter-campaign h2,
.chapter-campaign .chapter-label span{color:var(--campaign)}

/* Subpages */

.subpage .site-main{
  min-height:calc(100vh - 56px);
  display:flex;
  align-items:flex-start;
}
.subpage-section{
  width:100%;
  max-width:980px;
  padding:64px 72px 82px;
}
.contact-section .eyebrow,
.subpage-section .eyebrow{
  text-transform:none;
  margin-bottom:10px;
}
.subpage-section h1{margin-bottom:26px}
.subpage-section .lead{
  max-width:720px;
  margin-bottom:22px;
}
.subpage-content{
  max-width:860px;
  color:var(--muted);
  font-size:17px;
  line-height:1.52;
}
.subpage-content p{margin:0 0 15px}
.subpage-content a,
.mail-obfuscated{color:#fff}
.subpage-content a:hover,
.mail-obfuscated:hover{color:var(--green)}
.contact-line{
  margin:24px 0 28px;
  font-family:"UniversCondensed",sans-serif;
  font-size:clamp(32px,3.2vw,46px);
  line-height:1;
  letter-spacing:.03em;
  color:#fff;
}
.contact-note{
  max-width:720px;
  margin-top:0;
  color:#9a9a9a;
  font-size:14px;
}

/* Contact form */

.contact-form{
  max-width:720px;
  margin-top:30px;
}
.form-required-note{
  margin:0 0 14px;
  color:#8f8f8f;
  font-size:12px;
}
.form-grid{
  display:grid;
  grid-template-columns:minmax(160px,.55fr) 1fr;
  gap:18px;
}
.contact-company-row{
  grid-template-columns:minmax(130px,.35fr) 1fr;
}
.contact-name-row{
  grid-template-columns:minmax(90px,.25fr) 1fr 1fr;
}
.form-grid-name{grid-template-columns:1fr 2fr 2fr}
.form-row{margin-bottom:16px}
.form-row label{
  display:block;
  margin-bottom:3px;
  color:#d8d8d8;
  font-size:14px;
}
.required{color:var(--green)}
input,
select,
textarea{
  width:100%;
  border:1px solid rgba(255,255,255,.14);
  border-radius:0;
  background:#505050;
  color:#f2f2f2;
  font:inherit;
  padding:11px 13px;
  outline:none;
  transition:border-color .2s ease,background .2s ease;
}
input:focus,
select:focus,
textarea:focus{
  border-color:var(--green);
  background:#555;
}
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus{
  -webkit-text-fill-color:#f2f2f2;
  -webkit-box-shadow:0 0 0 1000px #505050 inset;
  transition:background-color 9999s ease-in-out 0s;
}
textarea{
  display:block;
  resize:vertical;
  min-height:145px;
  padding-bottom:28px;
}
input.is-invalid,
select.is-invalid,
textarea.is-invalid{border-color:var(--design)}
input.is-valid,
select.is-valid,
textarea.is-valid{border-color:var(--green)}
.subject-row,
.message-row{position:relative}
.subject-count,
.char-count{
  position:static;
  display:block;
  margin:6px 0 0;
  padding:0;
  text-align:right;
  color:#858585;
  font-size:11px;
  letter-spacing:.02em;
  pointer-events:none;
  font-variant-numeric:tabular-nums;
}
.form-error{
  min-height:18px;
  margin:7px 0 0;
  color:#f2f2f2;
  font-size:15px;
  line-height:1.35;
  display:flex;
  align-items:center;
  gap:9px;
}
.form-error:empty{display:block}
.form-error:not(:empty)::before{
  content:"";
  display:inline-block;
  width:15px;
  height:15px;
  flex:0 0 15px;
  background:var(--design);
  mask:url("../assets/icons/delete.svg") center/contain no-repeat;
  -webkit-mask:url("../assets/icons/delete.svg") center/contain no-repeat;
}
.honeypot{
  position:absolute;
  left:-9999px;
  width:1px;
  height:1px;
  overflow:hidden;
}
.form-submit,
.thankyou-button{
  display:inline-block;
  border:1px solid var(--green);
  background:var(--green);
  color:#fff;
  font-family:"Fago",Arial,sans-serif;
  font-weight:700;
  font-size:15px;
  letter-spacing:.08em;
  text-decoration:none;
  cursor:pointer;
  transition:filter .2s ease;
}
.form-submit{padding:13px 22px 14px; margin-bottom:28px}
.form-submit:hover,
.form-submit:focus-visible,
.thankyou-button:hover,
.thankyou-button:focus-visible{filter:brightness(1.08)}

/* Custom select */

.native-select{
  position:absolute;
  opacity:0;
  pointer-events:none;
  width:1px;
  height:1px;
}
.custom-select{position:relative}
.custom-select-button{
  width:100%;
  min-height:45px;
  border:1px solid rgba(255,255,255,.14);
  background:#505050;
  color:#f2f2f2;
  font:inherit;
  text-align:left;
  padding:11px 42px 11px 13px;
  cursor:pointer;
}
.custom-select-button::after{
  content:"";
  position:absolute;
  right:15px;
  top:50%;
  width:9px;
  height:9px;
  border-right:2px solid #f2f2f2;
  border-bottom:2px solid #f2f2f2;
  transform:translateY(-65%) rotate(45deg);
}
.custom-select-button:focus-visible{
  outline:none;
  border-color:var(--green);
}
.custom-select-list{
  display:none;
  position:absolute;
  z-index:900;
  left:0;
  right:0;
  top:calc(100% + 4px);
  margin:0;
  padding:6px 0;
  list-style:none;
  background:#2f2f2f;
  border:1px solid rgba(255,255,255,.22);
  box-shadow:0 12px 28px rgba(0,0,0,.35);
}
.custom-select.is-open .custom-select-list{display:block}
.custom-select-list li{
  padding:5px 14px;
  color:#f2f2f2;
  cursor:pointer;
}
.custom-select-list li:hover,
.custom-select-list li.is-selected{
  background:var(--green);
  color:#111;
}
.custom-select.is-invalid .custom-select-button{border-color:#e23a2f}
.custom-select.is-valid .custom-select-button{border-color:var(--green)}

/* Upload */

.file-drop{
  position:relative;
  overflow:hidden;
  border:1px dashed rgba(255,255,255,.22);
  background:#505050;
  padding:20px 18px;
  transition:border-color .2s ease,background .2s ease;
}
.file-drop-watermark{
  position:absolute;
  left:50%;
  top:50%;
  width:92px;
  height:92px;
  transform:translate(-50%,-50%);
  background:url("../assets/icons/upload.svg") center/contain no-repeat;
  opacity:.08;
  pointer-events:none;
  z-index:0;
}
.file-drop.dragover{
  border-color:var(--green);
  background:#555;
}
.file-drop.dragover .file-drop-watermark{opacity:.14}
.file-drop input{
  position:absolute;
  inset:0;
  opacity:0;
  cursor:pointer;
  z-index:3;
}
.file-drop label{
  position:relative;
  z-index:2;
  margin:0;
  pointer-events:none;
}
.file-drop strong{
  display:block;
  color:#fff;
  font-weight:700;
  margin-bottom:5px;
}
.file-drop span{
  display:block;
  color:#969696;
  font-size:13px;
}
.upload-error{
  display:flex;
  align-items:center;
  gap:8px;
  min-height:0;
  margin:9px 0 0;
  color:#f2f2f2;
  font-size:16px;
  font-weight:400;
  line-height:1.35;
  opacity:0;
  transition:opacity .25s ease;
}
.upload-error.is-visible{opacity:1}
.upload-error::before{
  content:"";
  display:inline-block;
  width:13px;
  height:13px;
  flex:0 0 13px;
  background:url("../assets/icons/delete.svg") center/contain no-repeat;
}
.file-list{
  list-style:none;
  padding:0;
  margin:10px 0 0;
}
.file-list li{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  border-top:1px solid rgba(255,255,255,.1);
  padding:8px 0;
  color:#c9c9c9;
  font-size:14px;
}
.file-list li span{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.file-remove{
  appearance:none;
  width:18px;
  height:18px;
  flex:0 0 18px;
  border:0;
  background:url("../assets/icons/delete.svg") center/14px 14px no-repeat;
  color:var(--design);
  cursor:pointer;
  padding:0;
  font-size:0;
  opacity:.78;
}
.file-remove:hover,
.file-remove:focus-visible{opacity:1}

/* Checkbox and social link */

.form-check{margin-top:20px}
.form-check label{
  display:flex;
  gap:10px;
  align-items:flex-start;
  color:#bdbdbd;
  font-size:13px;
  line-height:1.42;
}
.form-check input{
  width:18px;
  height:18px;
  flex:0 0 18px;
  margin-top:1px;
  accent-color:var(--green);
}
.form-check a{
  color:#fff;
  text-decoration:none;
  border-bottom:1px solid rgba(255,255,255,.28);
}
.form-check a:hover,
.form-check a:focus-visible{
  color:var(--green);
  border-bottom-color:var(--green);
}
.linkedin-line{margin:0 0 28px}
.linkedin-link{
  display:inline-flex;
  align-items:center;
  gap:12px;
  font-family:"UniversCondensed",sans-serif;
  font-size:24px;
  letter-spacing:.04em;
  color:#d8d8d8;
}
.linkedin-link img{
  width:32px;
  height:32px;
  opacity:.85;
}
.linkedin-link:hover,
.linkedin-link:focus-visible{color:#fff}
.linkedin-link:hover img,
.linkedin-link:focus-visible img{opacity:1}

/* Footer */

.site-footer{
  position:relative;
  z-index:200;
  width:calc(100% - (var(--rail-width) + var(--content-cut)));
  margin-left:calc(var(--rail-width) + var(--content-cut));
  background:var(--footer);
  color:var(--muted);
  padding:22px 72px 24px 28px;
}
.site-footer::before{
  content:"";
  position:absolute;
  left:calc(-1 * (var(--rail-width) + var(--content-cut)));
  top:0;
  bottom:0;
  width:calc(var(--rail-width) + var(--content-cut));
  background:
    linear-gradient(rgba(20,20,20,.22),rgba(20,20,20,.22)),
    url("../assets/img/footer-moss-desktop.webp") left center/cover no-repeat;
  z-index:0;
}
.site-footer nav,
.site-footer p{
  position:relative;
  z-index:1;
}
.footer-legal,
.footer-legal a,
.footer-legal span{
  font-family:"UniversCondensed",sans-serif;
  font-size:28px;
  font-weight:300;
  line-height:1;
  letter-spacing:.035em;
  text-transform:none;
}
.footer-legal{
  display:flex;
  gap:18px;
  flex-wrap:nowrap;
  white-space:nowrap;
}
.footer-social{
  display:flex;
  align-items:center;
  gap:9px;
  flex-wrap:wrap;
  margin-top:8px;
  font-family:"Fago",Arial,sans-serif;
  font-size:12px;
  line-height:1.2;
  letter-spacing:.02em;
  color:#9a9a9a;
}
.footer-social a{
  display:inline-flex;
  align-items:center;
  gap:5px;
  color:#9a9a9a;
  transition:color .2s ease;
}
.footer-social span{
  color:#8f8f8f;
}
.footer-social-icon{
  display:inline-block;
  width:12px;
  height:12px;
  flex:0 0 12px;
  background:#8f8f8f;
  mask:center/contain no-repeat;
  -webkit-mask:center/contain no-repeat;
  transition:background-color .2s ease;
}
.footer-social-linkedin{
  mask-image:url("../assets/icons/linkedin_footer.svg");
  -webkit-mask-image:url("../assets/icons/linkedin_footer.svg");
}
.footer-social-instagram{
  mask-image:url("../assets/icons/instagram_footer.svg");
  -webkit-mask-image:url("../assets/icons/instagram_footer.svg");
}
.footer-social-youtube{
  mask-image:url("../assets/icons/youtube_footer.svg");
  -webkit-mask-image:url("../assets/icons/youtube_footer.svg");
}
.site-footer a{
  color:#d8d8d8;
  transition:color .2s ease;
}
.site-footer a:hover,
.site-footer a:focus-visible{color:#fff}
.footer-social a:hover,
.footer-social a:focus-visible{color:#d8d8d8}
.footer-social a:hover .footer-social-icon,
.footer-social a:focus-visible .footer-social-icon{background:var(--green)}
.site-footer a[aria-current="page"],
.site-footer a[aria-current="page"]:hover,
.site-footer a[aria-current="page"]:focus-visible{color:var(--green)}
.footer-legal span{color:var(--green)}
.footer-social > span{color:#6f6f6f}
.site-footer p{
  margin:6px 0 0;
  font-family:"Fago",Arial,sans-serif;
  font-size:12px;
  letter-spacing:.02em;
  color:#9a9a9a;
  text-transform:none;
}
.site-footer .copyright{
  display:inline-block;
  font-size:16px;
  line-height:1;
  position:relative;
  top:1px;
}


/* Thank you page */

.thankyou-page{
  min-height:100vh;
  background:#3f3f3d;
  color:#d8d8d8;
  display:flex;
  flex-direction:column;
}
.thankyou-hero{
  background:none;
  display:block;
  overflow:hidden;
  line-height:0;
}
.thankyou-header-img{
  display:block;
  width:100%;
  height:auto;
}
.thankyou-main{
  flex:1;
  display:flex;
  justify-content:center;
  align-items:flex-start;
  padding:120px 28px 90px;
}
.thankyou-content{
  width:min(620px,100%);
  text-align:left;
}
.thankyou-content h1{
  font-family:"UniversCondensed",sans-serif;
  font-size:clamp(58px,8vw,96px);
  line-height:.92;
  font-weight:300;
  letter-spacing:.025em;
  color:#fff;
  margin:0 0 28px;
}
.thankyou-content p{
  font-size:20px;
  line-height:1.55;
  color:#b9b9b9;
  margin:0 0 18px;
}
.thankyou-content .mahalo{
  font-family:"UniversCondensed",sans-serif;
  font-size:28px;
  line-height:1;
  letter-spacing:.14em;
  text-transform:none;
  color:var(--green);
  margin-top:38px;
}
.thankyou-button{
  margin-top:28px;
  padding:13px 22px 14px;
}

/* Desktop and tablet refinement */

@media(min-width:861px){
  .hero-content,
  .chapter-inner{
    padding-left:calc(var(--content-cut) + 28px);
  }
  .chapter-inner{
    max-width:1180px;
    grid-template-columns:240px minmax(0,1fr);
    gap:48px;
  }
  .chapter-content{max-width:680px}
}
@media(min-width:861px) and (max-width:1180px){
  .chapter-inner{
    max-width:1040px;
    grid-template-columns:150px minmax(0,1fr);
    gap:20px;
    padding-right:28px;
  }
  .chapter-content{max-width:760px}
  .chapter-lead{font-size:clamp(38px,3.8vw,56px)}
  .chapter-content p:not(.chapter-lead){font-size:17px}
}
@media(min-width:1181px) and (max-width:1450px){
  .chapter-inner{
    max-width:1040px;
    grid-template-columns:220px minmax(0,1fr);
    gap:42px;
  }
  .chapter-content{max-width:600px}
}

/* Mobile */

@media(max-width:860px){
  :root{
    --rail-width:112px;
    --content-cut:0px;
  }
  .brand-rail{
    position:fixed;
    left:0;
    top:0;
    width:var(--rail-width);
    height:100dvh;
    min-height:100dvh;
    background:var(--bg);
    z-index:500;
    overflow:hidden;
  }
  .brand-system{
    position:fixed;
    left:24px;
    top:20px;
    width:82px;
    height:auto;
    z-index:501;
  }
  .borr-button,
  .studio-tower{display:none}
  .brand-system::before{
    content:"";
    display:block;
    width:90px;
    height:98px;
    background:url("../assets/animation/borr-studio-logo.svg") left top/contain no-repeat;
    margin-left:-3px;
    margin-bottom:24px;
    pointer-events:none;
  }
  .mobile-home-link{
    position:absolute;
    left:-3px;
    top:0;
    width:90px;
    height:98px;
    display:block;
    z-index:999;
    pointer-events:auto;
  }
  .drawer-nav{
    position:relative;
    left:auto;
    top:auto;
    width:86px;
    height:auto;
    display:flex;
    flex-direction:column;
    gap:0;
  }
  .drawer{
    position:relative;
    top:auto;
    width:86px;
    height:37px;
    padding:0 0 0 21px;
    background:transparent;
    overflow:visible;
    transition:none;
  }
  .drawer::before{
    content:"";
    position:absolute;
    left:0;
    top:0;
    width:13px;
    height:37px;
    background:currentColor;
    transition:none;
  }
  .drawer:hover::before,
  .drawer:focus-visible::before{width:13px}
  .drawer img{
    position:absolute;
    left:21px;
    top:auto;
    bottom:0;
    height:26px;
    width:auto;
    max-width:none;
    transform:none;
    z-index:2;
  }
  .site-main{
    margin-left:var(--rail-width);
    width:calc(100% - var(--rail-width));
    min-height:100vh;
    overflow:hidden;
  }
  .hero{min-height:auto;align-items:start}
  .hero-content{
    padding:24px 34px 56px 22px;
    max-width:none;
  }
  .eyebrow{
    font-size:12px;
    letter-spacing:.16em;
    margin-bottom:12px;
  }
  h1{
    font-size:clamp(48px,16vw,72px);
    line-height:.96;
    letter-spacing:.018em;
  }
  .lead{
    font-size:clamp(30px,8.6vw,42px);
    line-height:1.06;
    margin-bottom:10px;
  }
  .lead-secondary{margin:16px 0 30px}
  .subline{
    font-size:16px;
    line-height:1.5;
  }
  .chapter::before{left:22px}
  .chapter-inner{
    padding:64px 42px 64px 22px;
    display:block;
  }
  .chapter-label{
    margin-bottom:22px;
    padding-top:24px;
  }
  .chapter-label span{
    top:0;
    font-size:12px;
  }
  .chapter-label h2{font-size:clamp(42px,14vw,64px)}
  .chapter-content{
    max-width:none;
    padding-top:0;
  }
  .chapter-lead{
    font-size:clamp(30px,8.7vw,42px);
    line-height:1.04;
    letter-spacing:.025em;
  }
  .chapter-content p:not(.chapter-lead){
    font-size:16px;
    line-height:1.5;
  }
  .subpage .site-main{min-height:calc(100vh - 64px)}
  .subpage-section{padding:72px 34px 82px 22px}
  .contact-section{padding-top:42px}
  .subpage-content{font-size:16px}
  .contact-line{
    font-size:clamp(30px,8.8vw,40px);
    margin:22px 0 26px;
  }
  .contact-form{margin-top:28px}
  .form-grid,
  .form-grid-name{display:block}
  .contact-form .form-row{margin-bottom:10px}
  .contact-form label{margin-bottom:3px}
  input,
  select,
  textarea{padding:10px 12px}
  textarea{min-height:138px}
  .form-error{font-size:14px}
  .file-drop{padding:18px 16px}
  .file-drop-watermark{
    width:76px;
    height:76px;
  }
  .form-submit{width:100%}
  .linkedin-line{margin-bottom:24px}
  .linkedin-link{
    font-size:20px;
    gap:10px;
  }
  .linkedin-link img{
    width:28px;
    height:28px;
  }
  .site-footer{
    width:100vw;
    margin-left:0;
    padding:16px 18px 18px calc(var(--rail-width) + 18px);
    z-index:600;
    overflow:hidden;
    background:
      url("../assets/img/footer-moss-mobile.webp") left bottom/var(--rail-width) 100% no-repeat,
      linear-gradient(var(--footer),var(--footer)) var(--rail-width) 0/calc(100% - var(--rail-width)) 100% no-repeat;
  }
  .site-footer::before{display:none}
  .footer-legal,
  .footer-legal a,
  .footer-legal span{
    font-size:24px;
    line-height:1;
    letter-spacing:.03em;
  }
  .footer-legal{gap:6px}
  .footer-social{
    gap:7px;
    margin-top:7px;
    font-size:10px;
  }
  .footer-social a{gap:4px}
  .footer-social-icon{
    width:10px;
    height:10px;
    flex-basis:10px;
  }
  .site-footer p{
    font-size:10px;
    margin-top:6px;
  }
  .site-footer .copyright{
    font-size:14px;
    top:1px;
  }
  .thankyou-main{padding:70px 34px 74px}
  .thankyou-content h1{font-size:64px}
  .thankyou-content p{font-size:18px}
  .thankyou-content .mahalo{
    font-size:22px;
    line-height:1.15;
  }
}
@media(min-width:700px) and (max-width:860px){
  :root{--rail-width:140px}
  .brand-system{
    left:32px;
    top:28px;
    width:110px;
  }
  .brand-system::before{
    width:110px;
    height:120px;
    margin-bottom:28px;
  }
  .mobile-home-link{
    left:-3px;
    width:110px;
    height:120px;
  }
  .drawer-nav{width:110px}
  .drawer{
    width:110px;
    height:44px;
    padding-left:25px;
  }
  .drawer::before,
  .drawer:hover::before,
  .drawer:focus-visible::before{
    width:15px;
    height:44px;
  }
  .drawer img{
    left:25px;
    height:31px;
  }
}
/* Legal pages (Impressum, Datenschutz) */

.legal-section h1{margin-bottom:34px}
.legal-content{max-width:860px}
.legal-brand{
  font-family:"UniversCondensed",sans-serif;
  font-size:clamp(38px,4vw,58px);
  line-height:.95;
  letter-spacing:.045em;
  color:var(--green);
  margin:0 0 34px;
}
.legal-block{margin:0 0 38px}
.legal-block h2{
  font-family:"UniversCondensed",sans-serif;
  font-size:clamp(30px,2.7vw,42px);
  font-weight:300;
  line-height:1;
  letter-spacing:.04em;
  color:#d8d8d8;
  margin:0 0 14px;
}
.legal-block p{margin:0 0 14px;color:#d0d0d0}
.legal-block ul{margin:0 0 14px 18px;padding:0;color:#d0d0d0}
.legal-block li{margin:0 0 5px}
.legal-meta{color:#a9a9a9}
@media(max-width:860px){
  .legal-section h1{margin-bottom:28px}
  .legal-brand{font-size:40px;margin-bottom:30px}
  .legal-block{margin-bottom:32px}
  .legal-block h2{font-size:32px}
}

/* Upload progress overlay */

#upload-progress-overlay{
  position:fixed;
  inset:0;
  z-index:99999;
  background:rgba(48,54,54,.92);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
}
#upload-progress-overlay.is-hidden{display:none}
.upload-progress-box{
  width:min(520px,100%);
  background:#444;
  padding:34px 36px 32px;
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 24px 80px rgba(0,0,0,.35);
  font-family:"Fago",Arial,sans-serif;
  color:#ddd;
}
.upload-progress-box h2{
  margin:0 0 18px;
  font-family:"UniversCondensed",Arial,sans-serif;
  font-size:42px;
  font-weight:400;
  color:#fff;
}
.upload-progress-box p{margin:0 0 18px;font-size:16px;line-height:1.45}
.upload-progress-track{height:14px;background:#2e3333;overflow:hidden}
.upload-progress-track div{
  height:100%;
  width:0;
  background:var(--green);
  transition:width .2s ease;
}
.upload-progress-note{margin-top:18px!important;color:#aaa;font-size:14px!important}

/* Admin transfer page */

.admin-transfer{max-width:1120px;margin:80px auto;padding:0 28px}
.admin-transfer .eyebrow{text-transform:none}
.admin-transfer h1{margin-bottom:30px}
.admin-transfer label{display:block;margin:0 0 5px;color:#d8d8d8}
.admin-transfer input,
.admin-transfer textarea,
.admin-transfer select{margin-bottom:18px;width:100%}
.admin-transfer textarea{min-height:110px}
.project-prefill{max-width:760px;margin-bottom:32px;padding-bottom:28px;border-bottom:1px solid rgba(255,255,255,.12)}
.project-prefill label{display:block;margin-bottom:6px;color:#d8d8d8;font-size:14px;letter-spacing:.04em}
.project-prefill select{width:100%;margin:0}
.admin-form{max-width:760px}
.admin-message{margin:0 0 24px;color:var(--green);font-size:18px}
.admin-link-box{max-width:760px;margin:28px 0;padding:18px;background:#393939;border:1px solid rgba(255,255,255,.14)}
.admin-link-box input{margin:8px 0 14px}
.admin-actions{display:flex;gap:10px;flex-wrap:wrap}
.admin-actions button,
.admin-actions a{
  display:inline-block;
  border:1px solid var(--green);
  background:var(--green);
  color:#fff;
  font-family:"Fago",Arial,sans-serif;
  font-weight:700;
  font-size:13px;
  letter-spacing:.08em;
  text-decoration:none;
  cursor:pointer;
  padding:10px 14px;
}
.admin-actions a.secondary,
.admin-actions button.secondary{background:transparent;color:#d8d8d8}
.copy-status{margin:10px 0 0;color:#9a9a9a;font-size:13px}
.admin-transfer .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 18px}
.admin-transfer .form-grid .full{grid-column:1/-1}
.transfer-overview{margin-top:54px}
.transfer-overview + .transfer-overview{margin-top:64px}
.transfer-overview h2{
  font-family:"UniversCondensed",sans-serif;
  font-weight:300;
  font-size:42px;
  line-height:1;
  letter-spacing:.035em;
  margin:0 0 22px;
}
.transfer-table-wrap{overflow-x:auto;border-top:1px solid rgba(255,255,255,.16)}
.transfer-table{width:100%;border-collapse:collapse;color:#d0d0d0;font-size:14px}
.transfer-table th,
.transfer-table td{
  padding:12px 10px;
  border-bottom:1px solid rgba(255,255,255,.1);
  text-align:left;
  vertical-align:top;
  white-space:nowrap;
}
.transfer-table th{
  color:#fff;
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  cursor:pointer;
}
.transfer-table th:hover{color:var(--green)}
.transfer-table td.project-name,
.transfer-table td.company-name,
.transfer-table td.client-name{white-space:normal}
.status-active{color:var(--green)}
.status-expired{color:#aaa}
.empty-row{color:#888}
.table-actions{display:flex;gap:8px;flex-wrap:wrap}
.table-actions a,
.table-actions button{
  border:1px solid rgba(255,255,255,.18);
  background:transparent;
  color:#d8d8d8;
  font:inherit;
  font-size:12px;
  cursor:pointer;
  padding:7px 9px;
  text-decoration:none;
}
.table-actions a:hover,
.table-actions button:hover{border-color:var(--green);color:#fff}
@media(max-width:860px){
  .admin-transfer{margin:60px 0;padding:0 22px}
  .admin-transfer .form-grid{display:block}
}

/* Transfer upload page */

.transfer-page-main{
  min-height:100vh;
  margin-left:var(--rail-width);
  display:flex;
  align-items:flex-start;
}
.transfer-section{width:100%;max-width:920px;padding:86px 72px 90px 40px}
.transfer-section .eyebrow{text-transform:none}
.transfer-card{margin-top:34px;padding:24px 0 0;border-top:1px solid rgba(255,255,255,.16)}
.transfer-meta{margin:0 0 22px}
.transfer-meta-label{
  display:block;
  color:#8f8f8f;
  font-size:13px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.transfer-meta-value{
  display:block;
  color:#fff;
  font-family:"UniversCondensed",sans-serif;
  font-size:clamp(34px,3.4vw,48px);
  line-height:1;
  letter-spacing:.035em;
}
.transfer-note{margin:28px 0;color:#d0d0d0}
.transfer-note-block{margin:26px 0 28px}
.transfer-note-text{display:block;color:#d0d0d0;font-size:16px;line-height:1.5;margin-top:6px}
.transfer-status{max-width:680px;color:#bdbdbd;font-size:18px}
.transfer-success-card{
  margin-top:34px;
  padding:24px 0 0;
  border-top:1px solid rgba(255,255,255,.16);
  max-width:760px;
}
.transfer-form{margin-top:30px}
.transfer-success-list{margin:18px 0 28px;padding:0;list-style:none;color:#bdbdbd}
.transfer-success-list li{margin:0 0 6px}
.transfer-success-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}
.thankyou-button.secondary{background:transparent;color:#d8d8d8}
.transfer-progress{display:none;margin:24px 0 26px}
.transfer-progress.is-visible{display:block}
.transfer-progress-bar{height:12px;background:#555;overflow:hidden}
.transfer-progress-fill{width:0;height:100%;background:var(--green);transition:width .2s ease}
.transfer-progress-text{margin:8px 0 0;color:#9a9a9a;font-size:13px}
.upload-contact{margin-top:24px;color:#aaa;font-size:14px}
.upload-contact-actions{margin-top:18px}
.upload-contact strong{
  display:block;
  color:#d8d8d8;
  font-family:"UniversCondensed",sans-serif;
  font-size:22px;
  font-weight:300;
  letter-spacing:.035em;
}
@media(max-width:860px){
  .transfer-page-main{margin-left:var(--rail-width);width:calc(100% - var(--rail-width))}
  .transfer-section{padding:72px 34px 82px 22px}
  .transfer-meta-value{font-size:clamp(30px,8.8vw,42px)}
}

.landscape-warning{
  display:none;
}

@media(max-width:860px) and (orientation:landscape) and (max-height:500px){

  body > *:not(.landscape-warning){
    display:none!important;
  }

  .landscape-warning{
    position:fixed;
    inset:0;
    z-index:9999;
    display:flex;
    align-items:center;
    justify-content:center;
    background:#3f3f3d;
    overflow:hidden;
  }

  .landscape-warning-content{
    width:100%;
    text-align:center;
  }

  .landscape-warning-content img{
  width:100%;
  max-width:1480px;
  height:auto;
  display:block;
  margin:0 auto 18px;
}

  .landscape-warning-content strong{
    display:block;
    color:#fff;
    font-family:"UniversCondensed",sans-serif;
    font-size:38px;
    font-weight:300;
    letter-spacing:.035em;
    line-height:1;
    margin-bottom:10px;
  }

  .landscape-warning-content p{
    max-width:460px;
    margin:0 auto;
    color:#bdbdbd;
    font-size:16px;
    line-height:1.4;
  }
}

@media(min-width:861px) and (max-width:1180px) and (max-height:760px){
  :root{
    --rail-width:300px;
    --drawer-open:166px;
  }
  .brand-rail{
    position:fixed;
    width:var(--rail-width);
    height:100dvh;
    min-height:100dvh;
    overflow:hidden;
  }
  .brand-system{
    left:72px;
    top:42px;
    width:245px;
    height:520px;
  }
  .borr-button{
    width:88px;
    height:88px;
  }
  .studio-tower{
    left:0;
    top:92px;
    width:88px;
    height:420px;
  }
  .studio-tower img{
    left:9px;
    bottom:9px;
    width:70px;
  }
  .drawer-nav{
    left:88px;
    top:92px;
    width:220px;
    height:420px;
  }
  .drawer{
    width:var(--drawer-open);
    height:84px;
  }
  .drawer::before{
    width:20px;
  }
  .drawer:hover::before,
  .drawer:focus-visible::before{
    width:var(--drawer-open);
  }
  .drawer img{
    left:31px;
    bottom:1px;
    height:40px;
  }
  .design{top:0}
  .print{top:84px}
  .foto{top:168px}
  .sound{top:252px}
  .werbung{top:336px}
  .site-main{
    margin-left:var(--rail-width);
    width:calc(100% - var(--rail-width));
    min-height:calc(100dvh - 92px);
  }
  .chapter{
    min-height:300px;
  }
  .chapter-inner{
    padding:64px 52px 64px 40px;
    grid-template-columns:190px minmax(0,1fr);
    gap:34px;
  }
  .chapter-content{
    max-width:620px;
  }
  .chapter-label h2{
    font-size:60px;
  }
  .chapter-lead{
    font-size:38px;
  }
  .site-footer{
    margin-left:var(--rail-width);
    width:calc(100% - var(--rail-width));
    padding:16px 52px 16px 40px;
  }
  .site-footer::before{
    left:calc(-1 * var(--rail-width));
    width:var(--rail-width);
  }
}
@media(min-width:1800px){
  :root{
    --wide-shift:clamp(72px,calc((100vw - 1680px)/2),220px);
  }
  .brand-rail{
    left:var(--wide-shift);
  }
  .site-main{
    margin-left:calc(var(--rail-width) + var(--wide-shift));
    width:calc(100% - (var(--rail-width) + var(--wide-shift)));
  }
  .site-footer{
    margin-left:calc(var(--rail-width) + var(--content-cut) + var(--wide-shift));
    width:calc(100% - (var(--rail-width) + var(--content-cut) + var(--wide-shift)));
  }
  .site-footer::before{
    left:calc(-1 * (var(--rail-width) + var(--content-cut) + var(--wide-shift)));
    width:calc(var(--rail-width) + var(--content-cut) + var(--wide-shift));
  }
}

/* ============================================================
   Sprachumschalter (DE | EN) + Barrierefreiheit
   Ergänzt für die zweisprachige Fassung. Nutzt die
   bestehenden Variablen --green (#98ab31) und --bg (#454545).
   ============================================================ */

/* Nur für Screenreader sichtbar, optisch komplett entfernt */
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

/* Container der Sprachwahl in der eyebrow-Zeile */
.lang-switch{
  white-space:nowrap;
}

/* Trenner " · " vor der Sprachwahl, in eyebrow-Grün */
.lang-switch .lang-sep{
  color:var(--green);
}

/* Aktive Sprache: Grün wie die eyebrow-Zeile, mit sichtbaren Klammern */
.lang-current{
  color:var(--green);
}
.lang-current .lang-bracket{
  color:var(--green);
}

/* Pipe-Trenner zwischen den Sprachen, dezent gedämpft */
.lang-pipe{
  color:#7a7a7a;
  margin:0 .5em;
}

/* Wählbare Sprache: ruhiges Grau, klickbar */
.lang-link{
  color:#9a9a9a;
  text-decoration:none;
  transition:color .15s ease;
}
.lang-link:hover,
.lang-link:focus-visible{
  color:#d8d8d8;
}
/* Sichtbarer Tastatur-Fokus (Barrierefreiheit) */
.lang-link:focus-visible{
  outline:2px solid var(--green);
  outline-offset:3px;
}

/* Klammern der INAKTIVEN Sprache: in Hintergrundfarbe = unsichtbar,
   reservieren aber den Platz, damit beim Umschalten nichts springt */
.lang-bracket-hidden{
  color:var(--bg);
}
