/* ═══════════════════════════════════════════════════════════════
   FRAMEPATH · SHARED DESIGN SYSTEM (v2)
   Wird von allen Seiten geladen. Keine externen Libs.
   Seiten-spezifisches CSS steht inline in der jeweiligen Page.
   ═══════════════════════════════════════════════════════════════ */

/* ─── TOKENS ─── */
:root{
  --ink:#0E0E10;
  --ink-soft:#1A1A1D;
  --paper:#F5F2EC;
  --soft:#EFEBE3;
  --stone:#6B6B73;
  --stone-soft:#A0A0A8;
  --indigo:#6366F1;
  --indigo-deep:#4F46E5;
  --indigo-soft:#A5A8F5;
  --indigo-tint:#EEEFFE;
  --pulse:#22C55E;

  --ease:cubic-bezier(0.2,0.7,0.2,1);
  --container:1280px;
  --wide:1400px;
  --pad:clamp(20px,5vw,80px);

  --f-display:"Syne",sans-serif;
  --f-body:"Geist",system-ui,sans-serif;
  --f-mono:"Geist Mono",ui-monospace,monospace;
  --f-serif:"Instrument Serif",Georgia,serif;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}

body{
  font-family:var(--f-body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body.cursor-on,body.cursor-on a,body.cursor-on button{cursor:none;}

a{color:inherit;text-decoration:none;}
button{font-family:inherit;border:none;background:none;cursor:pointer;color:inherit;}
img,svg{display:block;}

/* ─── A11Y: Skip-Link + Focus ─── */
.skip-link{
  position:absolute;left:-999px;top:0;z-index:10001;
  background:var(--ink);color:var(--paper);
  padding:12px 18px;border-radius:0 0 10px 0;
  font-family:var(--f-mono);font-size:13px;
}
.skip-link:focus{left:0;}
:focus-visible{outline:2px solid var(--indigo);outline-offset:2px;border-radius:2px;}

/* ─── UTILITIES ─── */
.container{max-width:var(--container);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad);}
.serif{font-family:var(--f-serif);font-style:italic;font-weight:400;}
.in{color:var(--indigo);}
.in-soft{color:var(--indigo-soft);}
.eyebrow,.label,.tag{
  font-family:var(--f-mono);font-weight:500;text-transform:uppercase;
  letter-spacing:0.07em;font-size:12px;
}
.label{color:var(--stone);}
.section{padding:clamp(80px,12vh,160px) 0;position:relative;}

/* ─── GRAIN OVERLAY ─── */
.grain{position:fixed;inset:0;z-index:9990;pointer-events:none;opacity:0.06;mix-blend-mode:multiply;}

/* ─── CUSTOM CURSOR (v2 — Ring + kontextueller Dot, kein mix-blend) ─── */
.cursor-ring,.cursor-dot{position:fixed;top:0;left:0;z-index:10000;pointer-events:none;border-radius:50%;will-change:transform;}
.cursor-ring{
  width:40px;height:40px;border:1.5px solid var(--indigo);
  transform:translate(-50%,-50%);
  transition:width .26s var(--ease),height .26s var(--ease),border-color .26s var(--ease);
}
.cursor-dot{
  width:8px;height:8px;background:var(--ink);
  transform:translate(-50%,-50%);
  transition:width .2s var(--ease),height .2s var(--ease),background .2s var(--ease);
}
body.cur-grow .cursor-ring{width:64px;height:64px;}
body.cur-grow .cursor-dot{width:14px;height:14px;background:var(--indigo)!important;}
.cursor-label{
  position:fixed;top:0;left:0;z-index:10000;pointer-events:none;
  font-family:var(--f-mono);font-size:12px;letter-spacing:0.06em;text-transform:uppercase;
  color:var(--indigo);transform:translate(22px,-50%);opacity:0;
  transition:opacity .2s var(--ease);white-space:nowrap;
}
body.cur-label .cursor-label{opacity:1;}

/* ─── REVEAL ─── */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
[data-reveal].in-view{opacity:1;transform:none;}

/* ─── PULSE-DOT ─── */
.pulse{width:8px;height:8px;border-radius:50%;background:var(--pulse);position:relative;flex:none;}
.pulse::after{content:"";position:absolute;inset:0;border-radius:50%;background:var(--pulse);animation:pulse 2s var(--ease) infinite;}
@keyframes pulse{0%{transform:scale(1);opacity:.7;}70%{transform:scale(2.6);opacity:0;}100%{transform:scale(2.6);opacity:0;}}

/* ─── BUTTONS ─── */
.btn{
  font-size:14px;font-weight:500;padding:11px 20px;border-radius:100px;
  transition:transform .25s var(--ease),background .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease);
  display:inline-flex;align-items:center;gap:7px;white-space:nowrap;
}
.btn-primary{background:var(--ink);color:var(--paper);}
.btn-primary:hover{background:var(--indigo-deep);}
.btn-secondary{background:transparent;color:var(--ink);border:1px solid rgba(14,14,16,0.2);}
.btn-secondary:hover{border-color:var(--ink);background:rgba(14,14,16,0.04);}
.btn-lg{padding:16px 30px;font-size:16px;}
/* Auf Ink-Hintergrund */
.on-ink .btn-secondary,.btn-secondary.on-ink{color:var(--paper);border-color:rgba(245,242,236,0.3);}
.on-ink .btn-secondary:hover,.btn-secondary.on-ink:hover{border-color:var(--paper);background:rgba(245,242,236,0.06);}

/* ═══════════════════════════════════════════════════════════════
   HEADER (edge-to-edge, sticky, blur)
   ═══════════════════════════════════════════════════════════════ */
.site-header{
  position:sticky;top:0;z-index:9000;width:100%;
  background:rgba(245,242,236,0.72);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid rgba(14,14,16,0.07);
}
.site-header .inner{
  max-width:var(--wide);margin:0 auto;padding:0 var(--pad);
  display:flex;align-items:center;justify-content:space-between;height:72px;gap:24px;
}
.wordmark{font-family:var(--f-display);font-weight:800;letter-spacing:-0.04em;font-size:24px;color:var(--ink);}
.wordmark .dot{color:var(--indigo);}
.nav-links{display:flex;gap:34px;}
.nav-links a{font-size:15px;color:var(--ink);position:relative;transition:color .2s var(--ease);}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:1px;background:var(--indigo);transition:width .26s var(--ease);}
.nav-links a:hover{color:var(--indigo-deep);}
.nav-links a:hover::after{width:100%;}
.nav-right{display:flex;align-items:center;gap:20px;}
.avail{display:flex;align-items:center;gap:8px;font-family:var(--f-mono);font-size:12px;text-transform:uppercase;letter-spacing:0.06em;color:var(--stone);}

/* ═══════════════════════════════════════════════════════════════
   FOOTER (edge-to-edge, 4 Abschnitte)
   ═══════════════════════════════════════════════════════════════ */
/* a) Closing-Statement-Streifen (Paper) */
.footer-closing{width:100%;background:var(--paper);border-top:1px solid rgba(14,14,16,0.1);}
.footer-closing .inner{
  max-width:var(--wide);margin:0 auto;padding:clamp(60px,9vh,110px) var(--pad);
  display:flex;align-items:flex-end;justify-content:space-between;gap:40px;flex-wrap:wrap;
}
.footer-closing h2{font-family:var(--f-display);font-weight:700;letter-spacing:-0.04em;line-height:1;font-size:clamp(40px,6vw,80px);}
.fc-contact{display:flex;flex-direction:column;gap:12px;align-items:flex-start;}
.fc-mail{font-family:var(--f-display);font-weight:700;letter-spacing:-0.02em;font-size:clamp(22px,2.4vw,30px);position:relative;}
.fc-mail::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:2px;background:var(--indigo);transition:width .3s var(--ease);}
.fc-mail:hover::after{width:100%;}
.fc-meta{display:flex;align-items:center;gap:9px;font-family:var(--f-mono);font-size:12px;text-transform:uppercase;letter-spacing:0.06em;color:var(--stone);}

/* b) Haupt-Footer (Ink) */
.site-footer{width:100%;background:var(--ink);color:var(--paper);overflow:hidden;}
.site-footer .inner{max-width:var(--wide);margin:0 auto;padding:clamp(60px,9vh,110px) var(--pad) 0;}
.footer-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:40px;padding-bottom:70px;}
.fg-brand{grid-column:span 5;}
.fg-sys{grid-column:span 2;}
.fg-studio{grid-column:span 2;}
.fg-live{grid-column:span 3;}
.fg-brand .wordmark{color:var(--paper);font-size:22px;}
.fg-brand p{color:rgba(245,242,236,0.6);font-size:15px;max-width:38ch;margin:16px 0 20px;}
.fg-est{display:flex;align-items:center;gap:10px;font-family:var(--f-mono);font-size:11px;text-transform:uppercase;letter-spacing:0.07em;color:var(--stone);}
.fg-est svg{width:20px;height:20px;}
.footer-col h4{font-family:var(--f-mono);font-size:11px;text-transform:uppercase;letter-spacing:0.07em;color:var(--stone);margin-bottom:16px;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:11px;}
.footer-col li a{font-size:15px;color:rgba(245,242,236,0.82);transition:color .2s var(--ease);}
.footer-col li a:hover{color:var(--indigo-soft);}
.fg-live .clock{font-family:var(--f-display);font-weight:700;letter-spacing:-0.02em;font-size:30px;font-variant-numeric:tabular-nums;margin-bottom:18px;}
.fg-live .status{display:flex;align-items:center;gap:8px;font-family:var(--f-mono);font-size:11px;text-transform:uppercase;letter-spacing:0.06em;color:rgba(245,242,236,0.82);margin-bottom:18px;}
.fg-live .ext{display:flex;flex-direction:column;gap:10px;}
.fg-live .ext a{font-family:var(--f-mono);font-size:12px;letter-spacing:0.05em;color:rgba(245,242,236,0.82);transition:color .2s var(--ease);}
.fg-live .ext a:hover{color:var(--indigo-soft);}

/* c) Mega-Wordmark edge-to-edge */
.footer-mega{
  font-family:var(--f-display);font-weight:800;letter-spacing:-0.06em;line-height:0.78;
  font-size:clamp(140px,26vw,380px);color:var(--paper);text-align:center;
  white-space:nowrap;padding:0 var(--pad);
  transition:transform .5s var(--ease);
}
.footer-mega .dot{color:var(--indigo);}
@media(hover:hover) and (min-width:861px){
  .site-footer:hover .footer-mega{transform:perspective(900px) rotateX(1deg) skewX(-1deg);}
}

/* d) Footer-Bottom-Strip */
.footer-bottom{width:100%;background:var(--ink);border-top:1px solid rgba(255,255,255,0.1);}
.footer-bottom .inner{
  max-width:var(--wide);margin:0 auto;padding:22px var(--pad) 34px;
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  font-family:var(--f-mono);font-size:11px;letter-spacing:0.06em;text-transform:uppercase;color:var(--stone);
}
.footer-bottom .links{display:flex;gap:22px;align-items:center;}
.footer-bottom a,.footer-bottom .cc-reopen{color:var(--stone);transition:color .2s var(--ease);}
.footer-bottom a:hover,.footer-bottom .cc-reopen:hover{color:var(--indigo-soft);}
.cc-reopen{font-family:var(--f-mono);font-size:11px;letter-spacing:0.06em;text-transform:uppercase;background:none;padding:0;}

/* ═══════════════════════════════════════════════════════════════
   SCROLL-COMPANION (fixed Frame+Path rechts)
   ═══════════════════════════════════════════════════════════════ */
.scroll-companion{
  position:fixed;right:clamp(14px,2.4vw,34px);top:12vh;z-index:40;
  width:60px;height:60px;pointer-events:none;color:var(--ink);opacity:0.7;
}
.scroll-companion .sc-path{stroke-dasharray:1;stroke-dashoffset:1;}
.scroll-companion .sc-end{opacity:0;}
@media(max-width:860px){.scroll-companion{display:none;}}

/* ═══════════════════════════════════════════════════════════════
   MARQUEE
   ═══════════════════════════════════════════════════════════════ */
.marquee{background:var(--ink);color:var(--paper);padding:30px 0;overflow:hidden;white-space:nowrap;}
.marquee-track{display:inline-flex;align-items:center;will-change:transform;}
.marquee-track span{font-family:var(--f-display);font-weight:700;font-size:clamp(28px,4vw,52px);letter-spacing:-0.03em;padding:0 8px;}
.marquee-track .star{color:var(--indigo);padding:0 24px;}
.marquee-track .quote{font-family:var(--f-serif);font-style:italic;font-weight:400;color:var(--indigo-soft);}

/* ═══════════════════════════════════════════════════════════════
   SHARED CONTENT BITS (Case-Detail + Legal-Pages)
   ═══════════════════════════════════════════════════════════════ */
/* Generic page hero */
.page-hero{padding:clamp(80px,16vh,180px) 0 clamp(50px,8vh,90px);position:relative;}
.page-hero .eyebrow{color:var(--stone);margin-bottom:26px;display:block;}
.page-hero h1{font-family:var(--f-display);font-weight:800;letter-spacing:-0.04em;line-height:0.92;font-size:clamp(64px,12vw,200px);}
.page-hero h1 .dot{color:var(--indigo);}
.page-hero .tagline{font-family:var(--f-display);font-weight:600;letter-spacing:-0.03em;line-height:1.05;font-size:clamp(28px,4.5vw,56px);margin-top:24px;max-width:18ch;}
.page-hero .tagline .serif{color:var(--indigo);}
.page-hero .meta-row{font-family:var(--f-mono);font-size:12px;text-transform:uppercase;letter-spacing:0.06em;color:var(--stone);margin-top:30px;}

/* Prose (Problem/Lösung + Legal) */
.prose{max-width:62ch;}
.prose p{font-size:clamp(16px,1.4vw,18px);color:var(--ink-soft);margin-bottom:18px;}
.section-head{font-family:var(--f-display);font-weight:800;letter-spacing:-0.04em;line-height:1;font-size:clamp(36px,6vw,76px);margin:18px 0 36px;}
.section-head .serif{color:var(--indigo);}

/* Bullet-Liste mit Frame+Path-Mini-Symbol */
.fp-list{list-style:none;display:flex;flex-direction:column;gap:18px;margin-top:30px;}
.fp-list li{display:grid;grid-template-columns:28px 1fr;gap:16px;align-items:start;font-size:clamp(16px,1.4vw,18px);color:var(--ink-soft);}
.fp-list li svg{width:22px;height:22px;margin-top:2px;color:var(--indigo);flex:none;}

/* Tech-Stack-Chips */
.chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px;}
.chip{font-family:var(--f-mono);font-size:12px;letter-spacing:0.06em;text-transform:uppercase;color:var(--stone);border:1px solid rgba(14,14,16,0.18);padding:8px 14px;border-radius:100px;}

/* Ergebnis-Stats (auf Ink) */
.result{background:var(--ink);color:var(--paper);}
.result .label{color:var(--indigo-soft);}
.result-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px 40px;margin-top:50px;}
.result-stat .num{font-family:var(--f-display);font-weight:800;letter-spacing:-0.04em;line-height:0.9;font-size:clamp(72px,11vw,180px);}
.result-stat .num .u{font-family:var(--f-serif);font-style:italic;font-weight:400;color:var(--indigo);font-size:0.5em;margin-left:6px;}
.result-stat .cap{font-family:var(--f-mono);font-size:12px;text-transform:uppercase;letter-spacing:0.06em;color:rgba(245,242,236,0.66);margin-top:14px;}

/* Next-Case-Navigation */
.case-nav{display:grid;grid-template-columns:1fr 1fr;gap:20px;border-top:1px solid rgba(14,14,16,0.12);padding-top:40px;}
.case-nav a{display:flex;flex-direction:column;gap:8px;padding:24px;border:1px solid rgba(14,14,16,0.12);border-radius:14px;transition:border-color .26s var(--ease),transform .26s var(--ease);}
.case-nav a:hover{border-color:var(--ink);transform:translateY(-4px);}
.case-nav .dir{font-family:var(--f-mono);font-size:11px;text-transform:uppercase;letter-spacing:0.06em;color:var(--stone);}
.case-nav .nm{font-family:var(--f-display);font-weight:700;letter-spacing:-0.03em;font-size:clamp(22px,3vw,34px);}
.case-nav .next{text-align:right;align-items:flex-end;}

/* ═══════════════════════════════════════════════════════════════
   COOKIE CONSENT (DSGVO · Opt-in)
   ═══════════════════════════════════════════════════════════════ */
.cc-banner{
  position:fixed;left:var(--pad);bottom:24px;z-index:9995;
  width:min(440px,calc(100vw - 2 * var(--pad)));
  background:var(--paper);color:var(--ink);
  border:1px solid rgba(14,14,16,0.16);border-radius:16px;
  box-shadow:0 24px 60px rgba(14,14,16,0.18);padding:26px 26px 22px;
  transform:translateY(140%);opacity:0;visibility:hidden;
  transition:transform .5s var(--ease),opacity .5s var(--ease),visibility .5s var(--ease);
}
.cc-banner.open{transform:none;opacity:1;visibility:visible;}
.cc-banner .label{display:block;margin-bottom:14px;}
.cc-banner h2{font-family:var(--f-display);font-weight:700;letter-spacing:-0.03em;font-size:24px;line-height:1.05;margin-bottom:12px;}
.cc-banner p{font-size:14px;color:var(--ink-soft);margin-bottom:18px;}
.cc-banner a.cc-link{color:var(--indigo-deep);border-bottom:1px solid var(--indigo);padding-bottom:1px;}
.cc-banner a.cc-link:hover{color:var(--indigo);}
.cc-options{display:none;margin:0 0 18px;border-top:1px solid rgba(14,14,16,0.12);}
.cc-banner.show-options .cc-options{display:block;}
.cc-opt{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:16px 0;border-bottom:1px solid rgba(14,14,16,0.12);}
.cc-opt .cc-opt-text strong{font-family:var(--f-display);font-weight:700;letter-spacing:-0.02em;font-size:15px;display:block;margin-bottom:3px;}
.cc-opt .cc-opt-text span{font-size:13px;color:var(--stone);}
.cc-switch{position:relative;flex:none;width:44px;height:24px;}
.cc-switch input{position:absolute;opacity:0;width:100%;height:100%;margin:0;cursor:pointer;}
.cc-track{position:absolute;inset:0;border-radius:100px;background:rgba(14,14,16,0.18);transition:background .24s var(--ease);}
.cc-track::after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:var(--paper);box-shadow:0 1px 3px rgba(14,14,16,0.3);transition:transform .24s var(--ease);}
.cc-switch input:checked + .cc-track{background:var(--indigo-deep);}
.cc-switch input:checked + .cc-track::after{transform:translateX(20px);}
.cc-switch input:disabled{cursor:not-allowed;}
.cc-switch input:disabled + .cc-track{background:var(--indigo-soft);opacity:0.7;}
.cc-actions{display:flex;gap:10px;flex-wrap:wrap;}
.cc-btn{flex:1 1 0;min-width:130px;text-align:center;font-size:14px;font-weight:500;padding:13px 18px;border-radius:100px;transition:background .22s var(--ease),color .22s var(--ease),border-color .22s var(--ease);}
.cc-btn-accept{background:var(--ink);color:var(--paper);}
.cc-btn-accept:hover{background:var(--indigo-deep);}
.cc-btn-reject{background:transparent;color:var(--ink);border:1px solid rgba(14,14,16,0.45);}
.cc-btn-reject:hover{border-color:var(--ink);background:rgba(14,14,16,0.05);}
.cc-btn-save{flex-basis:100%;background:transparent;color:var(--ink);border:1px solid rgba(14,14,16,0.45);}
.cc-btn-save:hover{border-color:var(--ink);background:rgba(14,14,16,0.05);}
.cc-settings-link{display:inline-block;margin-top:14px;font-family:var(--f-mono);font-size:11px;text-transform:uppercase;letter-spacing:0.06em;color:var(--stone);background:none;}
.cc-settings-link:hover{color:var(--indigo-deep);}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE (gemeinsam)
   ═══════════════════════════════════════════════════════════════ */
@media(max-width:1100px){
  .footer-grid{grid-template-columns:repeat(8,1fr);gap:36px;}
  .fg-brand{grid-column:span 8;}
  .fg-sys{grid-column:span 3;}
  .fg-studio{grid-column:span 2;}
  .fg-live{grid-column:span 3;}
}
@media(max-width:960px){
  .footer-closing .inner{flex-direction:column;align-items:flex-start;gap:28px;}
  .result-grid{grid-template-columns:1fr;gap:40px;}
}
@media(max-width:860px){
  .nav-links{display:none;}
  .cursor-ring,.cursor-dot,.cursor-label{display:none!important;}
}
@media(max-width:720px){
  :root{--pad:20px;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .fg-brand,.fg-sys,.fg-studio,.fg-live{grid-column:span 1;}
  .case-nav{grid-template-columns:1fr;}
}
@media(max-width:600px){
  .avail{display:none;}
}
@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr;}
  .footer-bottom .inner{flex-direction:column;}
  .cc-banner{left:12px;right:12px;bottom:12px;width:auto;padding:22px 20px 18px;}
}

/* ─── REDUCED MOTION ─── */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:0.001ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;}
  [data-reveal]{transition:opacity .3s ease;transform:none;}
  .marquee-track{animation:none!important;}
  .footer-mega{transition:none;}
}
