:root{ --display:"Bodoni Moda",Georgia,serif; --sans:"Hanken Grotesk",system-ui,-apple-system,sans-serif; --ink:#1a1622; }
.seo-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap;border:0}
*{margin:0;padding:0;box-sizing:border-box}
html{background:#EFEAF2}
body{font-family:var(--sans);background:#EFEAF2;cursor:none}
::selection{background:#0C0C0C;color:#fff}
#spacer{position:relative;z-index:0;height:2000vh}
#c{position:fixed;inset:0;width:100%;height:100%;display:block;z-index:1}
#fx{position:fixed;inset:0;width:100%;height:100%;z-index:3;pointer-events:none}
#txt{position:fixed;inset:0;width:100%;height:100%;z-index:2;pointer-events:none}
.refveil{position:fixed;inset:0;z-index:2;pointer-events:none;opacity:0;background:linear-gradient(to bottom,rgba(255,255,255,0) 0%,rgba(255,255,255,.5) 8%,rgba(255,255,255,.5) 92%,rgba(255,255,255,0) 100%)}
/* Sequenz 06: Marken (vorne, lesbar) */
.refcard{position:fixed;left:clamp(20px,5vw,56px);bottom:clamp(24px,6vh,48px);z-index:4;max-width:min(780px,93vw);opacity:0;transition:opacity .4s ease;pointer-events:none}
.refrow{display:flex;align-items:stretch}
.refcell-logo{display:flex;align-items:center;justify-content:center}
.reflogo{width:50px;height:50px;border-radius:50%;border:1px solid rgba(40,30,60,.45);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:600;font-size:16px;letter-spacing:.02em;color:var(--ink);flex:0 0 auto;background:rgba(255,255,255,.25)}
.vr{width:1px;background:var(--ink);opacity:.55;align-self:stretch;margin:2px 16px;flex:0 0 auto}
.refinfo{display:flex;flex-direction:column;justify-content:center;min-width:160px}
.reffirma{font-family:var(--display);font-weight:600;font-size:clamp(16px,1.9vw,22px);line-height:1.1;color:var(--ink)}
.refseat{font-family:var(--display);font-style:italic;font-weight:500;font-size:clamp(12px,1.4vw,15px);color:var(--ink);opacity:.8;margin-top:2px}
.refkpi{font-family:var(--sans);font-size:11px;letter-spacing:.02em;color:var(--ink);opacity:.6;margin-top:8px;line-height:1.4;max-width:220px}
.refwork{display:flex;align-items:center;min-width:150px}
.refwork-list{list-style:none}
.refwork-list li{font-family:var(--sans);font-size:12px;line-height:1.45;color:var(--ink);opacity:.78;margin:4px 0;max-width:250px}
.refwork-list .cat{display:inline-block;font-weight:700;font-size:8.5px;letter-spacing:.14em;text-transform:uppercase;opacity:.55;margin-right:7px}
.contact{position:fixed;inset:0;z-index:2;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;opacity:0;pointer-events:none;text-align:left;padding-left:clamp(24px,22vw,320px);padding-right:clamp(24px,6vw,80px)}
.c-word{font-family:var(--display);font-weight:600;font-size:clamp(30px,5vw,52px);letter-spacing:.14em;text-transform:uppercase;color:var(--ink)}
.c-sub{font-family:var(--sans);font-weight:500;font-size:clamp(10px,1.4vw,13px);letter-spacing:.42em;text-transform:uppercase;color:var(--ink);opacity:.85;margin-top:9px}
.c-addr{font-family:var(--display);font-style:italic;font-size:clamp(14px,1.8vw,18px);color:var(--ink);opacity:.85;margin-top:24px}
.c-tel{font-family:var(--sans);font-size:13px;letter-spacing:.08em;color:var(--ink);opacity:.7;margin-top:6px}
.outro{position:fixed;inset:0;z-index:2;display:flex;align-items:flex-end;justify-content:center;padding-bottom:20vh;opacity:0;pointer-events:none}
.cta-wrap{position:relative;display:flex;flex-direction:column;align-items:center;gap:16px;pointer-events:auto}
.cta{position:relative;cursor:pointer;font-family:var(--sans);font-weight:600;font-size:14px;letter-spacing:.1em;text-transform:uppercase;color:rgba(40,30,60,.85);background:transparent;border:1px solid rgba(40,30,60,.5);border-radius:0;padding:17px 42px;display:inline-block;text-decoration:none;transition:color .5s ease}
.cta>span{position:relative;z-index:1}
.cta::before{content:'';position:absolute;inset:1px;background:rgba(40,30,60,.92);opacity:0;transition:opacity .5s ease;z-index:0}
.cta:hover{color:#fff}
.cta:hover::before{opacity:1}
.contacts{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:flex-start;gap:11px}
.crow{display:flex;align-items:center;gap:14px;text-decoration:none;color:rgba(40,30,60,.85);font-family:var(--sans);font-size:14px;letter-spacing:.03em;opacity:0;transform:translateY(-14px);pointer-events:none;transition:opacity .5s ease,transform .55s cubic-bezier(.22,.61,.36,1)}
.cta-wrap:hover .crow{opacity:1;transform:translateY(0);pointer-events:auto}
.cta-wrap:hover .crow:nth-child(1){transition-delay:.04s}
.cta-wrap:hover .crow:nth-child(2){transition-delay:.16s}
.cta-wrap:hover .crow:nth-child(3){transition-delay:.28s}
.cicon{flex:none;width:32px;height:32px;border:1px solid rgba(40,30,60,.5);border-radius:50%;display:flex;align-items:center;justify-content:center;color:rgba(40,30,60,.6);transition:background .35s ease,color .35s ease}
.crow:hover{color:rgba(40,30,60,1)}
.crow:hover .cicon{background:rgba(40,30,60,.92);color:#fff}
.top{position:fixed;top:0;left:0;right:0;z-index:4;display:flex;align-items:center;justify-content:space-between;padding:22px clamp(20px,5vw,56px);pointer-events:none}
.logo{pointer-events:auto;line-height:1;position:relative}
.logo .word{font-family:var(--display);font-weight:600;font-size:23px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink)}
.logo .sub{font-family:var(--sans);font-weight:500;font-size:9.5px;letter-spacing:.42em;text-transform:uppercase;color:var(--ink);opacity:.85;margin-top:6px}
.logo .brandmark{width:340px;max-width:46vw;height:auto;display:block}
.topclaim{position:absolute;left:0;top:50%;transform:translateY(-50%);font-family:var(--sans);font-weight:500;font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink);opacity:0;line-height:1.7;pointer-events:none;white-space:nowrap}
.contact .brandmark{width:clamp(220px,34vw,420px);height:auto;display:block;margin-bottom:6px}
.sound{pointer-events:auto;cursor:pointer;font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);display:flex;align-items:center;gap:9px;background:none;border:none}
.sidenav{position:fixed;right:clamp(12px,2vw,22px);top:50%;transform:translateY(-50%);z-index:6;pointer-events:none;display:flex;flex-direction:column;align-items:flex-end;gap:16px}
.sidenav .grp{display:flex;align-items:center;gap:10px}
.sidenav .divider{width:30px;height:1px;background:var(--ink);opacity:.4;align-self:flex-end}
.sidenav .ticks{display:flex;flex-direction:column;align-items:flex-end;gap:5px}
.sidenav .lab{writing-mode:vertical-rl;transform:rotate(180deg);pointer-events:auto;cursor:pointer;font-family:var(--sans);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);opacity:.5;background:none;border:none;padding:0;transition:opacity .3s}
.sidenav .lab:hover{opacity:.95}
.sidenav .tick{pointer-events:auto;cursor:pointer;width:15px;height:2px;border-radius:2px;border:none;padding:0;background:var(--ink);opacity:.25;transition:width .35s,opacity .35s}
.sidenav .tick:hover{opacity:.6;width:21px}
.sidenav .tick.on{width:27px;opacity:.9}
@media(max-width:680px){.sidenav{right:8px}.sidenav .ticks{gap:4px}.sidenav .tick{width:12px}.sidenav .tick.on{width:19px}.sidenav .lab{font-size:8px}.sidenav .half{gap:7px}.sidenav .divider{width:24px}}
.sound .bars{display:inline-flex;gap:2px;align-items:flex-end;height:12px}
.sound .bars i{width:2px;background:var(--ink);height:4px}
.sound.on .bars i{animation:eq 1s ease-in-out infinite}
.sound.on .bars i:nth-child(2){animation-delay:.2s}.sound.on .bars i:nth-child(3){animation-delay:.4s}
@keyframes eq{0%,100%{height:3px}50%{height:12px}}
.scrollhint{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:4;font-family:var(--sans);font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink);opacity:.5;transition:opacity .5s}
.caption{position:fixed;left:clamp(20px,5vw,56px);bottom:clamp(24px,6vh,48px);z-index:4;font-family:var(--sans);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);opacity:.7;border-left:1px solid var(--ink);padding-left:14px;line-height:1.7;pointer-events:none}
.signcaption{position:fixed;z-index:4;font-family:var(--sans);font-size:clamp(11px,1.15vw,13px);letter-spacing:.08em;color:var(--ink);opacity:0;transform:translate(-50%,-100%);pointer-events:none;white-space:nowrap}
.legalbar{position:fixed;right:clamp(20px,5vw,56px);bottom:clamp(24px,6vh,48px);z-index:6;display:flex;gap:20px;font-family:var(--sans);font-size:11px;letter-spacing:.16em;text-transform:uppercase}
.legalbar button{background:none;border:0;padding:0;color:var(--ink);opacity:.5;cursor:pointer;font:inherit;letter-spacing:inherit;text-transform:inherit;transition:opacity .3s ease}
.legalbar button:hover{opacity:1}
.legalmodal{position:fixed;inset:0;z-index:20;display:flex;align-items:center;justify-content:center;background:rgba(239,234,242,.32);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);cursor:auto;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .5s ease,visibility 0s linear .5s}
.legalmodal.open{opacity:1;visibility:visible;pointer-events:auto;transition:opacity .5s ease,visibility 0s}
.legalbox{position:relative;display:flex;flex-direction:column;max-width:640px;width:88vw;max-height:82vh;overflow:auto;background:transparent;color:var(--ink);padding:clamp(28px,5vw,52px);border:1px solid rgba(40,30,60,.22);border-radius:0;cursor:auto}
.legalclose{position:sticky;top:0;align-self:flex-end;flex:0 0 auto;box-sizing:border-box;margin:-8px -8px 4px 0;width:32px;height:32px;padding:0;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid rgba(40,30,60,.35);border-radius:0;line-height:1;color:var(--ink);opacity:.7;cursor:pointer;z-index:2;transition:opacity .25s ease,border-color .25s ease,background .25s ease}
.legalclose:hover{opacity:1;border-color:rgba(40,30,60,.7);background:rgba(40,30,60,.06)}
.legalcontent h2{font-family:var(--display);font-weight:600;font-size:26px;margin:0 0 18px}
.legalcontent h3{font-family:var(--sans);font-weight:600;font-size:12px;letter-spacing:.08em;text-transform:uppercase;margin:22px 0 6px;opacity:.7}
.legalcontent p{font-family:var(--sans);font-size:14px;line-height:1.7;margin:0 0 10px}
.legalcontent .hint{font-size:12px;opacity:.55;margin-top:22px}
.legalcontent a{color:inherit;text-decoration:underline;text-underline-offset:2px}
.caption b{font-weight:700;opacity:1}
.cursor{position:fixed;top:0;left:0;width:42px;height:42px;border:1px solid rgba(40,30,60,.5);border-radius:50%;z-index:5;pointer-events:none;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;color:rgba(40,30,60,.6);font-size:11px}
@media(hover:none){.cursor{display:none} body{cursor:auto}}
#loader{position:fixed;inset:0;z-index:10;display:flex;align-items:center;justify-content:center;background:#EFEAF2;transition:opacity .8s ease,visibility .8s}
#loader.done{opacity:0;visibility:hidden}
.l-mark{font-family:var(--display);font-weight:600;font-size:clamp(22px,5vw,38px);letter-spacing:.22em;text-transform:uppercase;color:var(--ink)}
.l-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--ink);margin-left:0;animation:bp 1s ease-in-out infinite}
@keyframes bp{0%,100%{transform:scale(.5);opacity:.3}50%{transform:scale(1);opacity:1}}
.fallback{position:fixed;inset:0;display:none;align-items:center;justify-content:center;text-align:center;padding:30px;z-index:6;font-family:var(--sans);color:#555}
@media(max-width:680px){
  /* Impressum/Datenschutz ganz unten mittig, eigener Streifen */
  .legalbar{left:0;right:0;justify-content:center;bottom:16px;gap:16px;z-index:8;font-size:9.5px;letter-spacing:.08em}
  /* Referenzkarte volle Breite, vertikal gestapelt, vertikal mittig (oben/unten ausgemittelt) */
  .refcard{left:32px;right:clamp(56px,20vw,160px);max-width:none;top:50%;bottom:auto;transform:translateY(-50%)}
  .refrow{flex-direction:column;align-items:flex-start;gap:7px}
  .refrow .vr{display:none}
  .refcell-logo{display:none}
  .refinfo{min-width:0;width:100%}
  .reffirma{font-size:22px}
  .refseat{font-size:14.5px}
  .refkpi{font-size:12.5px;max-width:none;border-bottom:1px solid rgba(40,30,60,.35);padding-bottom:10px;margin-bottom:6px}
  .refwork{min-width:0}
  .refwork-list li{font-size:14px;line-height:1.5;max-width:none}
  .refwork-list .cat{font-size:9.5px}
  /* Bildunterschrift auf dem Handy ausgeblendet (verursachte Überlagerung; Inhalt kommt als Slide) */
  .caption{display:none}
  .scrollhint{bottom:48px}
  /* Logo im Header auf dem Handy deutlich größer */
  .logo .brandmark{width:88vw;max-width:430px}
  /* Ton-Knopf kompakt und aus dem Fluss, damit das Logo den Platz voll nutzt */
  .sound{position:absolute;top:20px;right:16px;font-size:0;gap:0;z-index:6}
  .sound .bars{height:14px}
  /* Adresse am Ende auf dem Handy nicht einblenden */
  .contact{display:none}
  /* Kontaktfelder nach OBEN ausklappen, damit sie nicht über Impressum/Datenschutz laufen */
  .contacts{top:auto;bottom:calc(100% + 14px);padding:16px 18px;border-radius:0;background:transparent;border:1px solid transparent;transition:background .4s ease,border-color .4s ease,box-shadow .4s ease;pointer-events:none}
  .cta-wrap:hover .contacts{background:rgba(239,234,242,.45);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-color:rgba(40,30,60,.18);box-shadow:0 14px 34px rgba(40,30,60,.16)}
  .cta-wrap:hover .crow{pointer-events:auto}
  .crow{transform:translateY(14px)}
  .cta-wrap:hover .crow{transform:translateY(0)}
  /* Anfrage-Button nach unten, knapp über die Rechtsleiste -> keine Überlappung mit der Referenzkarte */
  .outro{padding-bottom:56px}
}
