:root{
  --bg:#0b0e14;
  --text:#e8eefc;
  --muted:#aab6d6;
  --line:rgba(232,238,252,.12);
  --glow:rgba(74,222,128,.18);
  --accent:#4ade80;
  --accent2:#facc15;
  --ok:#4ade80;
  --warn:#ffcf5a;
  --danger:#ff5c7a;
  --radius:18px;
  --shadow:0 18px 40px rgba(0,0,0,.45);
  --shadow2:0 10px 24px rgba(0,0,0,.35);
  --max:1160px;
  --content-max:1160px;
  --frame-bleed:0px;
  --topbar-bleed:42px;
    --pad:18px;
  --pad2:26px;
  --font:ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--font);
  color:var(--text);
  background:
    linear-gradient(180deg, rgba(18,24,34,.44), rgba(20,26,36,.38)),
    radial-gradient(1100px 680px at 14% 12%, rgba(92,180,255,.10), transparent 62%),
    radial-gradient(1100px 720px at 84% 24%, rgba(155,123,255,.08), transparent 64%),
    radial-gradient(900px 520px at 50% 42%, rgba(255,255,255,.06), transparent 68%),
    url("background.png?v=6") center top / cover no-repeat fixed;
  overflow-x:hidden;
}

a{color:inherit; text-decoration:none}
main, section, .wrap{background:transparent !important}
.wrap{max-width:var(--max); margin:0 auto; padding:0 18px}
.muted{color:var(--muted)}
.sr{position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 16px;
  border-radius:999px;
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  box-shadow:var(--shadow2);
  cursor:pointer;
  user-select:none;
  transition:transform .12s ease, border-color .12s ease, background .12s ease;
  color:var(--text);
  font-weight:600;
  font-size:13px;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-1px); border-color:rgba(92,180,255,.35)}
.btn.primary{
  border-color:rgba(92,180,255,.35);
  background:linear-gradient(180deg, rgba(92,180,255,.24), rgba(92,180,255,.08));
}
.btn.ghost{background:transparent; box-shadow:none}
.btn.small{padding:10px 14px; font-size:12px}
.btn:disabled{opacity:.55; cursor:not-allowed; transform:none}

.pill{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  color:var(--muted);
  font-size:12px;
}
.dot{width:8px; height:8px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 6px var(--glow)}
.tagRow{display:flex; flex-wrap:wrap; gap:8px; margin-top:10px}
.tag{
  font-size:11px;
  color:rgba(232,238,252,.78);
  border:1px solid rgba(232,238,252,.12);
  background:rgba(255,255,255,.03);
  padding:6px 10px;
  border-radius:999px;
}

.card{
  background:linear-gradient(180deg, rgba(11,14,20,.50), rgba(11,14,20,.34));
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
  backdrop-filter:blur(34px) saturate(120%);
  -webkit-backdrop-filter:blur(34px) saturate(120%);
}
.card .in{padding:var(--pad2)}
.subtle{
  background:linear-gradient(180deg, rgba(11,14,20,.42), rgba(11,14,20,.28));
  border:1px solid var(--line);
  border-radius:16px;
  padding:var(--pad);
  backdrop-filter:blur(28px) saturate(120%);
  -webkit-backdrop-filter:blur(28px) saturate(120%);
}

.topbar{
  position:sticky;
  top:0;
  z-index:50;
  background:transparent;
  border-bottom:none;
  padding:10px 0 4px;
}
.topbar .row{
  display:flex;
  align-items:center;
  gap:6px;
  min-height:84px;
  padding:0 0 0 0;
  width:100%;
  margin:0;
  border-radius:var(--radius);
  background:linear-gradient(180deg, rgba(11,14,20,.50), rgba(11,14,20,.34));
  border:1px solid var(--line);
  box-shadow:0 18px 40px rgba(0,0,0,.38);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  position:relative;
  overflow:hidden;
}
.topbar .row::before,
.topbar .row::after{content:none}
.brand{
  display:flex;
  align-items:center;
  gap:14px;
  position:relative;
}
.topbar .brand{
  min-height:84px;
  min-width:0;
  width:clamp(205px, 19vw, 270px);
  flex:0 0 auto;
  padding:0 10px 0 12px;
  gap:9px;
  background:rgba(255,255,255,.998);
  border-radius:calc(var(--radius) - 1px) 0 0 calc(var(--radius) - 1px);
  color:#141821;
  isolation:isolate;
  overflow:visible;
  z-index:1;
  pointer-events:auto;
}
.topbar .brand::before{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  right:-30px;
  width:68px;
  background:linear-gradient(90deg, rgba(255,255,255,.998) 0%, rgba(255,255,255,.996) 24%, rgba(248,249,250,.94) 48%, rgba(230,234,238,.58) 72%, rgba(184,191,199,.18) 90%, rgba(11,14,20,0) 100%);
  clip-path:polygon(-6% 0, 62% 0, 100% 100%, -6% 100%);
  filter:blur(2px);
  opacity:1;
  pointer-events:none;
  z-index:-1;
}
.topbar .brand::after{
  content:"";
  position:absolute;
  top:-18px;
  bottom:-18px;
  right:-42px;
  width:92px;
  background:linear-gradient(90deg, rgba(255,255,255,.72) 0%, rgba(255,255,255,.60) 28%, rgba(242,245,248,.38) 54%, rgba(205,212,220,.14) 78%, rgba(11,14,20,0) 100%);
  clip-path:polygon(-6% 0, 64% 0, 100% 100%, -6% 100%);
  filter:blur(18px);
  opacity:.92;
  pointer-events:none;
  z-index:-2;
}
.topbar .brand > div{
  display:grid;
  gap:4px;
}
.logo{
  object-fit:cover;
  display:block;
}
.topbar .logo{
  width:52px;
  height:52px;
  border-radius:0;
  flex:none;
  background:transparent;
  box-shadow:none;
  border:none;
}
.topbar .brand b{
  font-size:20px;
  letter-spacing:.01em;
  line-height:1;
  font-weight:900;
  color:#11151b;
}
.topbar .brand small{
  display:block;
  color:#252b34;
  font-size:13px;
  margin-top:0;
  font-weight:600;
  opacity:.92;
}
nav{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:3px;
  flex:1 1 auto;
  position:relative;
  z-index:1;
  min-width:0;
  overflow:visible;
  padding-left:0;
  padding-right:10px;
  padding-right:4px;
}
nav a{
  color:var(--muted);
  font-size:11px;
  font-weight:500;
  letter-spacing:.01em;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid transparent;
  transition:color .15s ease, border-color .15s ease, background .15s ease;
  white-space:nowrap;
  text-decoration:none;
}
nav a:hover{
  color:var(--text);
  border-color:rgba(232,238,252,.12);
  background:rgba(255,255,255,.04);
}
nav a.active{
  color:var(--text);
  border-color:rgba(232,238,252,.18);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.05);
}
.navRight{display:flex; align-items:center; gap:4px; flex:0 0 auto; margin-left:0}
.navRight{position:relative; z-index:1}
.menuBtn{display:none}
.menuNavLink{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 11px;
  border-radius:999px;
  border:1px solid rgba(232,238,252,.16);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.04);
  color:var(--text);
  font-size:13px;
  font-weight:700;
  white-space:nowrap;
}
.menuNavLink:hover{
  border-color:rgba(232,238,252,.24);
  background:linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.05));
}
.mobileNav{display:none; padding:12px 0 2px 0}
.mobileNav a{
  display:block;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(11,14,20,.50), rgba(11,14,20,.34));
  box-shadow:var(--shadow);
  backdrop-filter:blur(34px) saturate(120%);
  -webkit-backdrop-filter:blur(34px) saturate(120%);
  margin-top:10px;
  color:rgba(232,238,252,.92);
}
.mobileNav a:hover{color:var(--text); border-color:rgba(232,238,252,.24); background:linear-gradient(180deg, rgba(14,18,26,.56), rgba(11,14,20,.38))}
.mobileNav a.active{color:var(--text); border-color:rgba(232,238,252,.28); background:linear-gradient(180deg, rgba(17,22,32,.58), rgba(11,14,20,.40))}
.topbar .btn:hover{border-color:rgba(232,238,252,.18)}
.topbar .btn.ghost:hover{background:rgba(255,255,255,.04)}
.topbar .btn.primary{
  padding:11px 18px;
  border-color:rgba(232,238,252,.16);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.04);
}
.topbar .btn.primary:hover{
  border-color:rgba(232,238,252,.24);
  background:linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.05));
}

.hero{padding:46px 18px 28px}
.heroGrid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  align-items:stretch;
}
.pageMain{padding:32px 18px 20px}
.pageHero{padding:10px 0 22px}
h1{
  margin:12px 0 12px;
  font-size:44px;
  line-height:1.05;
  letter-spacing:-.8px;
}
.lead{font-size:16px; color:var(--muted); line-height:1.65; margin:0}
.heroBadges{display:flex; flex-wrap:wrap; gap:10px; margin-top:16px}
.kpis{display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-top:18px}
.kpi{padding:14px; border-radius:16px; border:1px solid var(--line); background:rgba(255,255,255,.02)}
.kpi b{display:block; font-size:18px}
.kpi span{color:var(--muted); font-size:12px; line-height:1.4}

section{padding:22px 0}
.secHead{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:14px;
  margin-bottom:12px;
}
.secHead h2,.sectionTitle{margin:0; font-size:22px; letter-spacing:-.2px}
.secHead p{margin:0; color:var(--muted); max-width:720px; line-height:1.6; font-size:13px}
.sectionText{margin-top:8px; font-size:13px; line-height:1.65}

.cols3{display:grid; grid-template-columns:repeat(3,1fr); gap:14px}
.cols2{display:grid; grid-template-columns:repeat(2,1fr); gap:14px}

/* Keep cards in the same row at equal height across pages */
.cols2,
.cols3,
.kpis,
.steps,
.stepsCompact,
.heroStats,
.heroInfoGrid,
.heroFoot,
.policyQuickGrid,
.policyMeta{
  align-items:stretch;
}
.cols2 > *,
.cols3 > *,
.kpis > *,
.steps > *,
.stepsCompact > *,
.heroStats > *,
.heroInfoGrid > *,
.heroFoot > *,
.policyQuickGrid > *,
.policyMeta > *{
  height:100%;
}
.icon{
  width:40px;
  height:40px;
  border-radius:14px;
  margin-bottom:10px;
  border:1px solid rgba(232,238,252,.16);
  background:
    radial-gradient(18px 18px at 30% 30%, rgba(255,255,255,.18), transparent 60%),
    linear-gradient(135deg, rgba(92,180,255,.20), rgba(155,123,255,.14));
  box-shadow:0 10px 26px rgba(0,0,0,.35);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  color:rgba(232,238,252,.90);
}

.pageLinks{display:grid; gap:10px; margin-top:14px}
.pageLink{
  display:grid;
  gap:6px;
  padding:14px 16px;
  border-radius:16px;
  border:1px solid rgba(232,238,252,.12);
  background:rgba(255,255,255,.02);
  transition:transform .12s ease, border-color .12s ease, background .12s ease;
}
.pageLink:hover{transform:translateY(-1px); border-color:rgba(92,180,255,.35); background:rgba(255,255,255,.04)}
.pageLink b{font-size:14px}
.pageLink span{color:var(--muted); font-size:12px; line-height:1.55}
.cardLink{display:block; transition:transform .12s ease, border-color .12s ease}
.cardLink:hover{transform:translateY(-2px); border-color:rgba(92,180,255,.35)}
.ctaRow{display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap}
.ctaTitle{font-size:16px}
.ctaActions{display:flex; gap:10px; flex-wrap:wrap}
.pageFormWrap{display:grid; grid-template-columns:1.15fr .85fr; gap:16px; align-items:start}
.portfolioCard{
  min-height:0;
  padding:0;
  overflow:hidden;
}
.portfolioGallery{
  position:relative;
  width:100%;
  height:100%;
  min-height:100%;
  border-radius:var(--radius);
  overflow:hidden;
  background:#0a0d14;
}
.portfolioGallery::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  background:
    linear-gradient(180deg, rgba(7,10,16,.18) 0%, rgba(7,10,16,.34) 48%, rgba(7,10,16,.66) 100%),
    linear-gradient(90deg, rgba(7,10,16,.24) 0%, rgba(7,10,16,.03) 40%, rgba(7,10,16,.20) 100%);
}
.portfolioSlide{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center;
  background-position:center;
  background-size:cover;
  background-repeat:no-repeat;
  opacity:0;
  transform:scale(1.12) translate3d(0,0,0);
  transition:opacity .65s ease;
  will-change:transform, opacity;
  z-index:0;
}
.portfolioSlide::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(7,10,16,.20) 0%, rgba(7,10,16,.36) 48%, rgba(7,10,16,.68) 100%),
    linear-gradient(90deg, rgba(7,10,16,.26) 0%, rgba(7,10,16,.04) 40%, rgba(7,10,16,.22) 100%);
}
.portfolioSlide.is-active{
  opacity:1;
  animation:portfolioPanA 8.5s ease-out forwards;
}
.portfolioSlide.is-active:nth-child(even){
  animation-name:portfolioPanB;
}
.portfolioOverlay{
  position:absolute;
  inset:0;
  z-index:2;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  padding:24px;
  pointer-events:none;
}
.portfolioOverlay .portfolioHead,
.portfolioOverlay .portfolioDots{pointer-events:auto}
.portfolioHead{max-width:420px}
.portfolioEyebrow{
  display:inline-flex;
  margin-bottom:10px;
  padding:7px 11px;
  border-radius:999px;
  border:1px solid rgba(232,238,252,.18);
  background:rgba(8,12,18,.24);
  backdrop-filter:blur(12px);
  color:rgba(232,238,252,.86);
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.portfolioHead h3{
  margin:0;
  font-size:28px;
  line-height:1.1;
}
.portfolioHead p{
  margin:10px 0 0;
  color:rgba(232,238,252,.82);
  font-size:14px;
  line-height:1.6;
}
.portfolioControls{
  position:absolute;
  inset:50% 18px auto 18px;
  display:flex;
  justify-content:space-between;
  transform:translateY(-50%);
  pointer-events:none;
}
.portfolioArrow{
  width:48px;
  height:48px;
  border-radius:999px;
  border:1px solid rgba(232,238,252,.18);
  background:rgba(8,12,18,.34);
  color:var(--text);
  font-size:28px;
  line-height:1;
  cursor:pointer;
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  box-shadow:var(--shadow2);
  pointer-events:auto;
}
.portfolioArrow:hover{border-color:rgba(92,180,255,.4); background:rgba(8,12,18,.5)}
.portfolioDots{
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
  max-width:100%;
}
.portfolioDot{
  width:10px;
  height:10px;
  border-radius:999px;
  background:rgba(232,238,252,.34);
  border:1px solid rgba(232,238,252,.18);
  transition:all .2s ease;
}
.portfolioDot.is-active{
  width:28px;
  background:rgba(232,238,252,.92);
}

@keyframes portfolioPanA{
  0%{transform:scale(1.12) translate3d(-2.5%, -1.4%, 0)}
  100%{transform:scale(1.03) translate3d(2.5%, 1.4%, 0)}
}
@keyframes portfolioPanB{
  0%{transform:scale(1.11) translate3d(2.3%, 1.2%, 0)}
  100%{transform:scale(1.03) translate3d(-2.3%, -1.2%, 0)}
}

@media (prefers-reduced-motion: reduce){
  .portfolioSlide{transition:none}
  .portfolioSlide.is-active{
    animation:none;
    transform:scale(1.03);
  }
}

.rfqHead{display:flex; align-items:flex-start; justify-content:space-between; gap:12px}
.rfqHead h3{margin:0 0 6px; font-size:14px; letter-spacing:.2px}
.rfqHead p{margin:0; color:var(--muted); font-size:13px; line-height:1.55}
.form{display:grid; gap:10px}
.field{display:grid; gap:6px}
label{font-size:12px; color:var(--muted)}
input, select, textarea{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(232,238,252,.14);
  background:rgba(5,8,15,.55);
  color:var(--text);
  outline:none;
}
input:focus, select:focus, textarea:focus{
  border-color:rgba(92,180,255,.55);
  box-shadow:0 0 0 6px rgba(92,180,255,.10);
}
textarea{min-height:88px; resize:vertical}
.formRow{display:grid; grid-template-columns:1fr 1fr; gap:10px}
.drop{
  border:1px dashed rgba(232,238,252,.22);
  background:rgba(255,255,255,.02);
  border-radius:16px;
  padding:14px;
}
.dropTop{display:flex; align-items:flex-start; justify-content:space-between; gap:10px}
.drop b{font-size:13px}
.drop small{display:block; color:rgba(232,238,252,.60); margin-top:6px; line-height:1.45}
.files{margin-top:10px; display:grid; gap:8px}
.fileItem{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  border:1px solid rgba(232,238,252,.12);
  background:rgba(255,255,255,.02);
  border-radius:14px;
  padding:10px 12px;
  font-size:12px;
  color:rgba(232,238,252,.85);
}
.fileItem em{font-style:normal; color:rgba(232,238,252,.60); font-size:11px}
.actionsRow{display:flex; gap:10px; flex-wrap:wrap; margin-top:10px}
.hint{
  margin-top:10px;
  border:1px solid rgba(57,217,138,.18);
  background:rgba(57,217,138,.06);
  border-radius:16px;
  padding:12px 12px;
  font-size:12px;
  color:rgba(232,238,252,.82);
  line-height:1.55;
}
.hint b{color:rgba(232,238,252,.96)}
.stepPane{display:none}
.stepPane.active{display:block}

.steps{display:grid; grid-template-columns:repeat(4,1fr); gap:14px}
.stepBox b{display:block; margin:0 0 6px; font-size:13px}
.stepBox span{color:var(--muted); font-size:12px; line-height:1.6}
.num{
  width:34px;
  height:34px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(92,180,255,.28);
  background:rgba(92,180,255,.10);
  margin-bottom:10px;
  font-weight:800;
}

.gallery{display:grid; grid-template-columns:1.2fr .8fr; gap:14px}
.bigShot{
  height:320px;
  border-radius:18px;
  border:1px solid rgba(232,238,252,.12);
  background:
    radial-gradient(260px 160px at 30% 35%, rgba(92,180,255,.22), transparent 60%),
    radial-gradient(320px 200px at 70% 55%, rgba(155,123,255,.18), transparent 60%),
    linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  position:relative;
  overflow:hidden;
}
.bigShot:before{
  content:"Werkstatt";
  position:absolute;
  left:16px;
  bottom:14px;
  font-size:12px;
  color:rgba(232,238,252,.70);
  border:1px solid rgba(232,238,252,.14);
  background:rgba(0,0,0,.25);
  padding:8px 10px;
  border-radius:999px;
  backdrop-filter:blur(8px);
}
.thumbs{display:grid; grid-template-columns:1fr; gap:14px}
.thumb{
  height:150px;
  border-radius:18px;
  border:1px solid rgba(232,238,252,.12);
  background:
    radial-gradient(200px 120px at 35% 35%, rgba(92,180,255,.18), transparent 60%),
    linear-gradient(135deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  position:relative;
  overflow:hidden;
}
.thumb:before{
  content:"Detailansicht";
  position:absolute;
  left:14px;
  bottom:12px;
  font-size:11px;
  color:rgba(232,238,252,.70);
  border:1px solid rgba(232,238,252,.14);
  background:rgba(0,0,0,.25);
  padding:7px 10px;
  border-radius:999px;
  backdrop-filter:blur(8px);
}

.list{margin:0; padding-left:18px; color:var(--muted); font-size:13px; line-height:1.7}

footer{padding:28px 0 40px; border-top:1px solid rgba(232,238,252,.10); margin-top:10px}
.foot{display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap}
.foot small{color:rgba(232,238,252,.55)}

.toast{
  position:fixed;
  right:16px;
  bottom:16px;
  z-index:80;
  background:rgba(17,23,38,.92);
  border:1px solid rgba(232,238,252,.14);
  border-radius:16px;
  padding:12px 14px;
  box-shadow:var(--shadow);
  display:none;
  max-width:380px;
}
.toast b{display:block; font-size:13px; margin-bottom:4px}
.toast span{display:block; color:var(--muted); font-size:12px; line-height:1.5}

@media (max-width:980px){
  .topbar{padding-top:8px}
  .topbar .row{min-height:66px; padding:0 8px 0 0; gap:12px}
  .topbar .brand{min-height:66px; min-width:0; padding:0 16px 0 10px; gap:12px}
  .topbar .brand::before{right:-112px; width:165px}
  .topbar .brand::after{right:-136px; width:205px}
  .topbar .logo{width:46px; height:46px}
  .heroGrid{grid-template-columns:1fr}
  .pageFormWrap{grid-template-columns:1fr}
  h1{font-size:38px}
  .portfolioOverlay{min-height:500px}
  nav{display:none}
  .menuBtn{display:inline-flex}
  .cols3{grid-template-columns:1fr}
  .cols2{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr}
  .kpis{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:1fr}
  .thumbs{grid-template-columns:1fr 1fr}
}

@media (max-width:520px){
  .topbar .row{padding:0 8px 0 0}
  .topbar .brand{gap:10px; padding:0 12px 0 8px}
  .topbar .brand::before{right:-76px; width:118px}
  .topbar .brand::after{right:-98px; width:156px}
  .topbar .brand > div{max-width:168px}
  .topbar .brand b{font-size:16px}
  .topbar .brand small{font-size:10.5px}
  .topbar .logo{width:40px; height:40px}
  h1{font-size:34px}
  .steps{grid-template-columns:1fr}
  .formRow{grid-template-columns:1fr}
  .kpis{grid-template-columns:1fr}
  .thumbs{grid-template-columns:1fr}
  .pageMain{padding-top:24px}
  .portfolioOverlay{min-height:420px; padding:20px}
  .portfolioHead h3{font-size:24px}
  .portfolioControls{inset:50% 12px auto 12px}
  .portfolioArrow{width:42px; height:42px; font-size:24px}
}

.heroGrid{
  grid-template-columns:minmax(0, 1fr) minmax(360px, 1fr);
  gap:18px;
  width:100%;
  margin:0;
  align-items:stretch;
}
.pageMain{
  padding:32px 18px 20px;
}
.pageMain > section{
  width:100%;
  margin:0;
}

.heroPanel{
  display:grid;
  gap:12px;
}
.heroPanel h1{margin:0}
.hero > .heroGrid > .heroPanel{
  background:linear-gradient(180deg, rgba(11,14,20,.66), rgba(11,14,20,.52));
  border-color:rgba(232,238,252,.16);
  box-shadow:0 22px 44px rgba(0,0,0,.46);
}
.heroStats{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:10px;
}
.heroStat{
  padding:13px 14px;
  border-radius:16px;
  border:1px solid rgba(232,238,252,.10);
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
}
.heroStat span{
  display:block;
  color:rgba(232,238,252,.58);
  font-size:11px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.heroStat b{
  display:block;
  margin-top:6px;
  font-size:14px;
  line-height:1.4;
}
.heroInfoGrid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;
}
.heroInfo{
  padding:15px 16px;
  border-radius:16px;
  border:1px solid rgba(232,238,252,.10);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015));
}
.heroInfo h2{
  margin:0;
  font-size:14px;
  letter-spacing:-.2px;
}
.heroList{
  margin:10px 0 0;
  padding-left:18px;
  color:var(--muted);
  font-size:12.5px;
  line-height:1.6;
}
.heroFoot{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:10px;
}
.heroFootItem{
  display:grid;
  gap:8px;
  padding:15px 16px;
  border-radius:16px;
  border:1px solid rgba(232,238,252,.10);
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
}
.heroFootItem span{
  color:var(--text);
  font-size:15px;
  font-weight:800;
  letter-spacing:-.02em;
  text-transform:none;
}
.heroFootItem b{
  display:block;
  color:var(--muted);
  font-size:13px;
  font-weight:500;
  line-height:1.6;
}
.heroPanel .heroBadges,
.heroPanel .kpis{display:none}

.serviceCard .in{padding:20px}
.serviceCard b{display:block; font-size:17px; line-height:1.25}
.serviceCard .sectionText{margin-top:8px; font-size:12.5px; line-height:1.55}
.serviceCard .tagRow{gap:6px; margin-top:12px}
.serviceCard .tag{padding:5px 9px; font-size:10px}

.trustGrid .card .in b{
  display:block;
  font-size:17px;
  line-height:1.3;
}

.serviceDetailGrid{
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
}
.serviceDetailCard .in{
  display:grid;
  gap:12px;
  align-content:start;
}
.serviceDetailCard h3{
  margin:0;
  font-size:20px;
  letter-spacing:-.02em;
}
.serviceDetailCard .muted{
  margin:0;
  font-size:13px;
  line-height:1.65;
}
.servicePair{
  border:1px solid rgba(232,238,252,.12);
  background:rgba(255,255,255,.02);
  border-radius:14px;
  padding:10px 12px;
  display:grid;
  gap:5px;
}
.servicePair b{
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(232,238,252,.76);
}
.servicePair span{
  color:var(--muted);
  font-size:13px;
  line-height:1.55;
}

.faqList{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;
}
.faqItem{
  border:1px solid rgba(232,238,252,.12);
  background:rgba(255,255,255,.02);
  border-radius:14px;
  padding:14px;
}
.faqItem h3{
  margin:0;
  font-size:15px;
  line-height:1.35;
}
.faqItem p{
  margin:8px 0 0;
  color:var(--muted);
  font-size:13px;
  line-height:1.65;
}

.legalPage .pageHero .card .in{padding:28px 30px}
.legalPage .pageHero .lead{max-width:640px}
.legalPage .cols2{gap:18px}
.legalPage .cols2 > .card .in{padding:30px}
.legalPage .cols2 > .card .sectionTitle{
  font-size:14px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(232,238,252,.62);
}
.legalPage .cols2 > .card .sectionText{margin-top:10px}
.legalPage .cols2 > .card .sectionText[style]{margin-top:18px !important}
.legalPage .cols2 > .card .sectionText b{
  display:block;
  font-size:11px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(232,238,252,.54);
}
.legalPage .cols2 > .card .muted.sectionText{
  margin-top:6px;
  color:var(--text);
  font-size:18px;
  font-weight:600;
  line-height:1.45;
}
.legalPage .cols2 > .card .muted.sectionText a{color:var(--text)}
.legalPage #datenschutz .card .in{padding:28px 30px}
.legalPage #datenschutz .sectionTitle{
  font-size:14px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(232,238,252,.62);
}
.legalPage #datenschutz .muted.sectionText{
  margin-top:12px;
  max-width:760px;
  font-size:15px;
  line-height:1.75;
  color:rgba(232,238,252,.82);
}

.policyPage .pageHero .card .in{padding:30px}
.policyPage .pageHero .lead{max-width:760px}
.policyQuickGrid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:14px;
}
.policyQuick{
  padding:20px 22px;
  border-radius:16px;
  border:1px solid rgba(232,238,252,.10);
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
}
.policyQuick span{
  display:block;
  color:rgba(232,238,252,.58);
  font-size:11px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.policyQuick b{
  display:block;
  margin-top:8px;
  font-size:18px;
  line-height:1.4;
}
.policyQuick .muted{
  display:block;
  margin-top:8px;
  font-size:12.5px;
  line-height:1.6;
}
.policyContent{display:grid; gap:24px}
.policySection{
  display:grid;
  gap:12px;
  padding-top:22px;
  border-top:1px solid rgba(232,238,252,.10);
}
.policySection:first-child{
  padding-top:0;
  border-top:none;
}
.policySection h2{
  margin:0;
  font-size:18px;
  letter-spacing:-.2px;
}
.policySection p{
  margin:0;
  color:var(--muted);
  font-size:14px;
  line-height:1.75;
}
.policyNote{
  padding:14px 16px;
  border-radius:14px;
  border:1px solid rgba(232,238,252,.10);
  background:rgba(255,255,255,.03);
  color:rgba(232,238,252,.88);
  font-size:13px;
  line-height:1.65;
}
.policyList{
  margin:0;
  padding-left:18px;
  color:var(--muted);
  font-size:14px;
  line-height:1.75;
}
.policyMeta{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;
}
.policyMetaItem{
  padding:16px 18px;
  border-radius:14px;
  border:1px solid rgba(232,238,252,.10);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015));
}
.policyMetaItem span{
  display:block;
  color:rgba(232,238,252,.72);
  font-size:12.5px;
  font-weight:800;
  letter-spacing:.1em;
  text-transform:uppercase;
}
.policyMetaItem b{
  display:block;
  margin-top:9px;
  font-size:15px;
  font-weight:700;
  line-height:1.25;
  letter-spacing:-.02em;
}
.policyMetaItem div{
  margin-top:7px;
  color:var(--muted);
  font-size:12.5px;
  line-height:1.55;
}
.policyMetaItem a{color:var(--text)}

.stepsCompact{
  margin-top:6px;
  gap:10px;
}
.stepBox .in{
  display:grid;
  grid-template-columns:auto 1fr;
  align-items:center;
  column-gap:12px;
  row-gap:12px;
  padding:22px 24px;
}
.stepBox b{
  display:block;
  grid-column:2;
  margin:0;
  font-size:18px;
  font-weight:800;
  letter-spacing:-.02em;
  line-height:1.2;
}
.stepBox span{
  grid-column:1 / -1;
  color:var(--muted);
  font-size:13px;
  line-height:1.7;
}
.num{
  grid-column:1;
  width:28px;
  height:28px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(232,238,252,.18);
  background:rgba(255,255,255,.05);
  color:var(--text);
  margin-bottom:0;
  font-size:14px;
  font-weight:700;
}

.aboutPage .pageHero .card .in{padding:30px}
.aboutPage h1{max-width:860px}
.aboutIntro{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:14px;
}
.aboutFacts{
  display:grid;
  gap:10px;
  align-content:start;
}
.aboutFacts .subtle{padding:14px}
.aboutFacts .subtle b{
  display:block;
  font-size:16px;
  line-height:1.3;
}
.aboutFacts .subtle .muted{
  margin-top:6px;
  font-size:12.5px;
  line-height:1.55;
}
.aboutValues .card .in{padding:24px}
.aboutContact{
  margin-top:14px;
  padding:14px 16px;
  border-radius:14px;
  border:1px solid rgba(232,238,252,.12);
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  display:grid;
  gap:6px;
}
.aboutContact span{
  display:block;
  color:rgba(232,238,252,.62);
  font-size:11px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.aboutContact b{
  display:block;
  font-size:34px;
  line-height:1.1;
  letter-spacing:-.02em;
}

.workshopShowcase{
  display:grid;
  grid-template-columns:minmax(0, 1.08fr) minmax(360px, .92fr);
  gap:16px;
  align-items:stretch;
}
.workshopGalleryCard .portfolioOverlay{
  min-height:540px;
  padding:24px;
}
.workshopGalleryCard .portfolioHead{max-width:360px}
.workshopGalleryCard .portfolioHead h3{font-size:24px}
.workshopGalleryCard .portfolioHead p{
  font-size:13px;
  line-height:1.65;
}
.workshopTextCard .in{
  display:grid;
  gap:16px;
  align-content:start;
  padding:30px;
}
.workshopTextCard .pill{width:max-content}
.workshopTextCard .sectionTitle{
  font-size:30px;
  line-height:1.14;
}
.workshopTextCard .sectionText{
  margin-top:0;
  font-size:14px;
  line-height:1.75;
}
.workshopTextMeta{
  display:grid;
  gap:0;
  margin-top:4px;
  border-top:1px solid rgba(232,238,252,.10);
}
.workshopTextRow{
  display:grid;
  gap:8px;
  padding:16px 0;
  border-bottom:1px solid rgba(232,238,252,.10);
}
.workshopTextRow span{
  display:block;
  font-size:11px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(232,238,252,.56);
}
.workshopTextRow b{
  display:block;
  font-size:17px;
  line-height:1.4;
}

.workshopPage .pageMain{padding-top:24px}
.workshopPage .pageHero{padding:6px 0 16px}
.workshopPage .pageHero .card .in{padding:18px 20px}
.workshopPage h1{
  font-size:36px;
  line-height:1.08;
}
.workshopPage .lead{
  font-size:14px;
  line-height:1.55;
}
.workshopPage section{padding:16px 0}
.workshopPage .workshopShowcase{
  gap:12px;
  align-items:stretch;
  grid-template-columns:minmax(0, 1fr) minmax(0, 1fr);
}
.workshopPage .portfolioCard{min-height:0}
.workshopPage .workshopGalleryCard{min-height:0}
.workshopPage .workshopGalleryCard .portfolioGallery{
  min-height:clamp(340px, 40vw, 560px);
}
.workshopPage .workshopGalleryCard .portfolioOverlay{
  position:absolute;
  inset:0;
  min-height:0;
  padding:18px;
}
.workshopPage .workshopGalleryCard .portfolioHead{max-width:320px}
.workshopPage .workshopGalleryCard .portfolioHead h3{font-size:20px}
.workshopPage .workshopGalleryCard .portfolioHead p{
  font-size:12px;
  line-height:1.5;
}
.workshopPage .workshopTextCard .in{
  display:flex;
  flex-direction:column;
  gap:10px;
  height:100%;
  padding:20px;
}
.workshopPage .workshopTextCard .sectionTitle{
  font-size:21px;
  line-height:1.15;
}
.workshopPage .workshopTextCard .sectionText{
  font-size:14px;
  line-height:1.65;
  max-width:100%;
}
.workshopPage .workshopTextMeta{
  margin-top:auto;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:8px;
  border-top:none;
}
.workshopPage .workshopTextRow{
  padding:12px 11px 11px;
  display:flex;
  flex-direction:column;
  gap:6px;
  border:0;
  border-radius:16px;
  background:rgba(255,255,255,.03);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
  min-height:150px;
}
.workshopPage .workshopTextRow span{
  font-size:10px;
  font-weight:800;
  color:rgba(232,238,252,.82);
}
.workshopPage .workshopTextRow b{
  font-size:11.5px;
  line-height:1.42;
  font-weight:600;
  color:rgba(232,238,252,.84);
  text-wrap:balance;
}
.workshopPage .cols3{gap:10px}
.workshopPage .cols3 > .subtle{padding:12px}
.workshopPage .cols3 > .subtle b{font-size:12px}
.workshopPage .cols3 > .subtle .muted{
  font-size:11px;
  line-height:1.45;
}
.workshopPage footer{
  width:100%;
  margin:16px 0 0;
  border-top:none;
  padding:0 0 24px;
}
.workshopPage .workshopFooterCard{
  width:100%;
  background:linear-gradient(180deg, rgba(11,14,20,.84), rgba(11,14,20,.62));
  border-color:rgba(232,238,252,.16);
  box-shadow:0 22px 44px rgba(0,0,0,.46);
}
.workshopPage .workshopFooterCard .in{padding:16px 18px}
.workshopPage .workshopFooterCard .foot{align-items:center}
.workshopPage .workshopFooterCard small{color:rgba(232,238,252,.86)}
.workshopPage .workshopFooterCard a{
  color:var(--text);
  text-decoration:underline;
  text-underline-offset:2px;
}

footer{
  padding:0;
  border-top:none;
  margin-top:16px;
}
.pageMain > footer{
  width:100%;
  margin:16px 0 0;
}
.foot{
  display:flex;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}
.footExtended{
  display:grid;
  grid-template-columns:1.25fr .8fr .95fr;
  gap:18px;
}
.footExtended .brand{
  pointer-events:auto;
  min-height:auto;
  padding:0;
  border-radius:0;
  background:transparent;
  color:var(--text);
}
.footExtended .brand::before,
.footExtended .brand::after{display:none}
.footDescriptor{
  margin:10px 0 0;
  color:rgba(232,238,252,.76);
  font-size:12.5px;
  line-height:1.6;
  max-width:560px;
}
.footNav,
.footContact{
  display:grid;
  align-content:start;
  gap:8px;
}
.footNav b,
.footContact b{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:rgba(232,238,252,.74);
}
.footNav a{
  color:rgba(232,238,252,.9);
  font-size:13px;
}
.footNav a:hover{color:var(--text)}
.footContact span{
  color:rgba(232,238,252,.8);
  font-size:12.5px;
}
.footLegal{
  grid-column:1 / -1;
  padding-top:6px;
}
footer > .foot{
  width:100%;
  padding:16px 18px;
  background:linear-gradient(180deg, rgba(11,14,20,.84), rgba(11,14,20,.62));
  border:1px solid rgba(232,238,252,.16);
  border-radius:var(--radius);
  box-shadow:0 22px 44px rgba(0,0,0,.46);
  overflow:hidden;
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  align-items:center;
}
footer .brand > div{
  display:grid;
  gap:4px;
  align-content:start;
}
footer > .foot small{color:rgba(232,238,252,.82)}
footer > .foot a{
  color:var(--text);
  text-decoration:underline;
  text-underline-offset:2px;
}

@media (max-width:980px){
  .topbar{padding-top:8px}
  .topbar .row{
    grid-template-columns:minmax(0, 1fr) auto;
    min-height:66px;
    padding:0 8px 0 0;
    gap:12px;
    width:100%;
    margin:0;
  }
  .topbar .brand{
    min-height:66px;
    min-width:0;
    width:clamp(220px, 58%, 340px);
    padding:0 8px 0 10px;
    gap:10px;
    border-radius:calc(var(--radius) - 1px) 0 0 calc(var(--radius) - 1px);
    overflow:visible;
    background:rgba(255,255,255,.998);
  }
  .topbar .brand::before{
    display:block;
    right:-84px;
    width:148px;
    top:0;
    bottom:0;
    background:linear-gradient(90deg, rgba(255,255,255,.998) 0%, rgba(255,255,255,.996) 24%, rgba(248,249,250,.94) 48%, rgba(230,234,238,.58) 72%, rgba(184,191,199,.18) 90%, rgba(11,14,20,0) 100%);
    clip-path:polygon(-6% 0, 62% 0, 100% 100%, -6% 100%);
    filter:blur(2px);
    opacity:1;
  }
  .topbar .brand::after{
    display:block;
    right:-110px;
    width:188px;
    top:-14px;
    bottom:-14px;
    background:linear-gradient(90deg, rgba(255,255,255,.72) 0%, rgba(255,255,255,.60) 28%, rgba(242,245,248,.38) 54%, rgba(205,212,220,.14) 78%, rgba(11,14,20,0) 100%);
    clip-path:polygon(-6% 0, 64% 0, 100% 100%, -6% 100%);
    filter:blur(16px);
    opacity:.92;
  }
  .topbar .logo{width:44px; height:44px}
  .topbar .brand > div{max-width:170px}
  .topbar .brand b{font-size:18px}
  .topbar .brand small{font-size:11px; line-height:1.2}
  .topbar .navRight{margin-left:0; gap:8px; padding-right:6px}
  .topbar .menuBtn{
    padding:10px 12px;
    font-size:14px;
  }
  .topbar .menuBtn{
    border-color:rgba(232,238,252,.24);
    background:linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04));
  }
  .topbar .menuNavLink{display:none}
  .topbar .row{gap:12px}
  .navRight{gap:8px}
  .heroGrid{grid-template-columns:1fr; width:100%; margin:0}
  .pageMain > section{width:100%; margin:0}
  .pageMain > footer{width:100%; margin:16px 0 0}
  .heroStats{grid-template-columns:1fr}
  .heroInfoGrid{grid-template-columns:1fr}
  .policyQuickGrid{grid-template-columns:1fr}
  .policyMeta{grid-template-columns:1fr}
  .pageFormWrap{grid-template-columns:1fr}
  h1{font-size:38px}
  .portfolioOverlay{min-height:500px}
  nav{display:none}
  .menuBtn{display:inline-flex}
  .cols3{grid-template-columns:1fr}
  .cols2{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr}
  .kpis{grid-template-columns:1fr 1fr}
  .workshopShowcase{grid-template-columns:1fr}
  .workshopGalleryCard .portfolioOverlay{min-height:500px}
  .workshopPage .pageMain{padding-top:20px}
  .workshopPage .pageHero{padding:4px 0 12px}
  .workshopPage .pageHero .card .in{padding:16px 18px}
  .workshopPage h1{font-size:32px}
  .workshopPage .lead{font-size:13px}
  .workshopPage section{padding:14px 0}
  .workshopPage .workshopShowcase{grid-template-columns:1fr}
  .workshopPage .workshopGalleryCard .portfolioGallery{min-height:340px}
  .workshopPage .workshopGalleryCard .portfolioOverlay{padding:16px}
  .workshopPage .workshopTextCard .in{padding:16px}
  .workshopPage .workshopTextCard .sectionTitle{font-size:20px}
  .workshopPage .workshopTextMeta{grid-template-columns:1fr}
  .workshopPage .cols3{grid-template-columns:1fr}
  .workshopPage .cols3 > .subtle{padding:12px}
  .workshopPage footer{width:100%; margin:16px 0 0}
  .aboutIntro{grid-template-columns:1fr}
  .aboutValues{grid-template-columns:1fr}
  .aboutContact b{font-size:30px}
  .serviceDetailGrid,
  .faqList{grid-template-columns:1fr}
  .footExtended{
    grid-template-columns:1fr;
    gap:14px;
  }
}

@media (max-width:520px){
  .topbar .row{padding:0 8px 0 0}
  .topbar .brand{
    width:clamp(178px, 56%, 250px);
    gap:8px;
    padding:0 8px;
  }
  .topbar .brand::before{
    right:-66px;
    width:120px;
    clip-path:polygon(-6% 0, 62% 0, 100% 100%, -6% 100%);
  }
  .topbar .brand::after{
    right:-88px;
    width:150px;
    top:-10px;
    bottom:-10px;
    clip-path:polygon(-6% 0, 64% 0, 100% 100%, -6% 100%);
  }
  .topbar .brand > div{max-width:142px}
  .topbar .brand b{font-size:15px}
  .topbar .brand small{display:none}
  .topbar .logo{width:36px; height:36px}
  .topbar .navRight{gap:6px; padding-right:4px}
  .topbar .menuBtn{
    padding:8px 10px;
    font-size:13px;
  }
  .heroPanel{gap:16px}
  .heroInfo{padding:16px}
  .heroFoot{grid-template-columns:1fr}
  .legalPage .pageHero .card .in,
  .legalPage .cols2 > .card .in,
  .legalPage #datenschutz .card .in{padding:22px}
  .legalPage .cols2 > .card .muted.sectionText{font-size:16px}
  .legalPage #datenschutz .muted.sectionText{font-size:14px; line-height:1.7}
  .policyPage .pageHero .card .in,
  .policyQuick,
  .policyMetaItem{padding:18px}
  .policyContent{gap:20px}
  .policySection{padding-top:18px}
  .policySection h2{font-size:17px}
  .policySection p,
  .policyList{font-size:13px; line-height:1.7}
  .policyMetaItem span{font-size:11px}
  .policyMetaItem b,
  .policyQuick b{font-size:15px}
  .policyMetaItem div{font-size:12px; line-height:1.6}
  h1{font-size:34px}
  .steps{grid-template-columns:1fr}
  .stepsCompact{grid-template-columns:1fr}
  .formRow{grid-template-columns:1fr}
  .kpis{grid-template-columns:1fr}
  .stepBox .in{row-gap:10px; padding:20px}
  .workshopGalleryCard .portfolioOverlay{min-height:420px; padding:20px}
  .workshopGalleryCard .portfolioHead h3{font-size:22px}
  .workshopTextCard .in{padding:22px}
  .workshopTextCard .sectionTitle{font-size:24px}
  .pageMain{padding-top:24px}
  .portfolioOverlay{min-height:420px; padding:20px}
  .portfolioHead h3{font-size:24px}
  .portfolioControls{inset:50% 12px auto 12px}
  .portfolioArrow{width:42px; height:42px; font-size:24px}
  .workshopPage .pageMain{padding-top:18px}
  .workshopPage .pageHero{padding:2px 0 10px}
  .workshopPage .pageHero .card .in{padding:14px 16px}
  .workshopPage h1{font-size:28px}
  .workshopPage .lead{font-size:12.5px}
  .workshopPage section{padding:12px 0}
  .workshopPage .workshopGalleryCard .portfolioGallery{min-height:300px}
  .workshopPage .workshopGalleryCard .portfolioOverlay{padding:14px}
  .workshopPage .workshopGalleryCard .portfolioHead h3{font-size:18px}
  .workshopPage .workshopTextCard .in{padding:14px; gap:10px}
  .workshopPage .workshopTextCard .sectionTitle{font-size:18px}
  .workshopPage .workshopTextCard .sectionText{font-size:13px; line-height:1.65}
  .workshopPage .workshopTextMeta{grid-template-columns:1fr; gap:10px}
  .workshopPage .workshopTextRow{min-height:0; padding:11px}
  .workshopPage .workshopTextRow span{font-size:10px}
  .workshopPage .workshopTextRow b{font-size:12px; line-height:1.42}
  .workshopPage .cols3 > .subtle{padding:10px}
  .workshopPage footer{width:100%; margin:12px 0 0}
  .aboutPage .pageHero .card .in{padding:20px}
  .aboutPage h1{font-size:32px}
  .aboutContact b{font-size:26px}
}

@media (min-width:981px){
  .topbar .row,
  .heroGrid,
  .pageMain > section,
  .pageMain > footer,
  .workshopPage footer{
    width:100%;
    max-width:none;
    margin-left:0;
    margin-right:0;
  }
}
