/* ============================================
   DisplayMetric — Shared Stylesheet
   Last update: Mai 2026
   
   Verwendung: <link rel="stylesheet" href="/displaymetric.css">
   Plus die folgenden Google-Fonts im <head>:
   
   <link rel="preconnect" href="https://fonts.googleapis.com">
   <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
   <link href="https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,200..800&family=DM+Sans:opsz,wght@9..40,400..700&family=Instrument+Serif:ital@0;1&family=JetBrains+Mono:wght@400;500;600&display=swap" rel="stylesheet">
   ============================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-size:16px}
html,body{background:#fff}
body{font-family:'DM Sans',-apple-system,system-ui,sans-serif;background:#fff;color:#0a0a0a;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;font-size:1.0625rem}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

:root{
  --petrol:#0E7C7B;--petrol-dark:#0A5A59;--petrol-light:#1A9994;
  --petrol-tint:#E0EFEE;--petrol-tint-2:#F0F7F6;--petrol-glow:rgba(14,124,123,0.15);
  --ink:#0a0a0a;--ink-2:#2a2a2a;--ink-3:#525252;--ink-4:#7a7a7a;
  --line:#e0e0e0;--line-2:#f0f0f0;
  --sand:#FAF8F4;--sand-2:#F4F0E8;
  --warning:#E89B2C;
  --code-bg:#fafafa;
}
.serif{font-family:'Instrument Serif',Georgia,serif;font-style:italic;font-weight:400}
.mono{font-family:'JetBrains Mono',ui-monospace,monospace}
.eyebrow{font-size:0.8rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--petrol)}
.container{max-width:1240px;margin:0 auto;padding:0 1.25rem}
@media(min-width:680px){.container{padding:0 2rem}}

/* NAV */
nav.topnav{position:fixed;top:0;left:0;right:0;z-index:50;padding:0.7rem 0;background:#fff;transition:padding 0.3s ease,box-shadow 0.3s ease}
nav.topnav.scrolled{background:#fff;padding:0.7rem 0;box-shadow:0 1px 12px rgba(0,0,0,0.06),0 0 0 1px var(--line-2)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:0 1.25rem;max-width:1240px;margin:0 auto;gap:0.5rem}
@media(min-width:680px){.nav-inner{padding:0 2rem}}
.logo{display:flex;align-items:center;gap:0.5rem;font-weight:700;letter-spacing:-0.02em;font-size:1.1rem;color:var(--ink)}
.logo-mark{width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:var(--petrol);flex-shrink:0}
.logo-mark svg{width:100%;height:100%}
.nav-links{display:none;gap:2rem;align-items:center}
.nav-links a{color:var(--ink-2);font-size:0.95rem;font-weight:500;transition:color 0.2s}
.nav-links a:hover{color:var(--petrol)}
.nav-links a.active{color:var(--petrol);font-weight:600}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:0.4rem;padding:0.75rem 1.3rem;border-radius:8px;font-size:0.95rem;font-weight:600;transition:all 0.25s ease;letter-spacing:-0.01em;cursor:pointer;min-height:44px;white-space:nowrap}
.btn-primary{background:var(--petrol);color:#fff;box-shadow:0 1px 3px rgba(14,124,123,0.18),0 8px 24px -10px rgba(14,124,123,0.4)}
.btn-primary:hover{background:var(--petrol-dark);transform:translateY(-1px)}
.btn-primary.nav-btn{padding:0.5rem 1rem;font-size:0.88rem;min-height:38px}
.btn-ghost{color:var(--ink);border:1px solid var(--line);background:#fff}
.btn-ghost:hover{border-color:var(--petrol);color:var(--petrol)}
.btn-lg{padding:1rem 1.9rem;font-size:1.02rem;border-radius:10px;min-height:52px}
@media(min-width:880px){.nav-links{display:flex}.btn-primary.nav-btn{padding:0.55rem 1.2rem;font-size:0.9rem}}

/* HERO */
.subhero{padding:9rem 0 2.5rem;background:#fff;position:relative;overflow:hidden}
.subhero::before{content:"";position:absolute;top:-200px;right:-300px;width:600px;height:600px;background:radial-gradient(circle,var(--petrol-glow) 0%,transparent 60%);pointer-events:none}
@media(min-width:760px){.subhero{padding:11rem 0 3rem}}
.subhero-inner{position:relative;z-index:1}
.subhero .breadcrumb{font-size:0.88rem;color:var(--ink-3);margin-bottom:1.2rem;display:flex;gap:0.5rem;align-items:center;flex-wrap:wrap;justify-content:center}
.subhero .breadcrumb a{color:var(--petrol);font-weight:500;transition:color 0.2s}
.subhero .breadcrumb a:hover{color:var(--petrol-dark)}
.subhero .breadcrumb-sep{color:var(--ink-4)}
.subhero .eyebrow{margin-bottom:1rem;display:block;text-align:center}
.subhero h1{font-family:'Bricolage Grotesque',sans-serif;font-variation-settings:"opsz" 72,"wght" 500;font-size:clamp(2.2rem,5.5vw,3.8rem);letter-spacing:-0.02em;line-height:1.12;color:var(--ink);margin-bottom:1.4rem;max-width:820px;margin-left:auto;margin-right:auto;text-align:center}
.subhero h1 .serif{color:var(--petrol)}
.subhero-sub{font-size:clamp(1.08rem,1.4vw,1.25rem);color:var(--ink-2);max-width:680px;line-height:1.6;margin:0 auto 2rem;text-align:center}

/* ANCHOR NAV (sticky) */
.anchor-nav{position:sticky;top:56px;background:#fff;border-bottom:1px solid var(--line-2);z-index:40;padding:0.5rem 0}
.anchor-nav-inner{display:flex;gap:0.4rem;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:0 1.25rem;max-width:1240px;margin:0 auto;scrollbar-width:none;justify-content:safe center}
.anchor-nav-inner::-webkit-scrollbar{display:none}
@media(min-width:680px){.anchor-nav-inner{padding:0 2rem;gap:0.5rem}}
.anchor-nav a{padding:0.5rem 1rem;font-size:0.88rem;font-weight:600;color:var(--ink-3);border-radius:8px;transition:all 0.2s ease;white-space:nowrap;flex-shrink:0}
.anchor-nav a:hover{color:var(--petrol);background:var(--petrol-tint-2)}
.anchor-nav a.active{color:var(--petrol);background:var(--petrol-tint)}

/* SECTIONS */
.fsection{padding:5rem 0;scroll-margin-top:115px;position:relative;background:#fff}
@media(min-width:760px){.fsection{padding:7rem 0}}
.fsection-alt{background:var(--sand)}
.fsection-dark{background:var(--ink);color:#fff}

.fsection-head{max-width:780px;margin-bottom:3.5rem}
.fsection-head .eyebrow{margin-bottom:0.9rem;display:block}

.fsection-head .kicker{font-family:'Instrument Serif',Georgia,serif;font-style:italic;font-size:clamp(1.1rem,1.5vw,1.35rem);color:var(--petrol);margin-top:-0.4rem;margin-bottom:1.1rem;letter-spacing:-0.005em;line-height:1.3;font-weight:400}
.fsection-dark .fsection-head .kicker{color:var(--petrol-light)}
.fsection-head h2{font-family:'Bricolage Grotesque',sans-serif;font-variation-settings:"opsz" 56,"wght" 500;font-size:clamp(1.85rem,3.8vw,2.7rem);letter-spacing:-0.018em;line-height:1.2;color:var(--ink);margin-bottom:1.2rem}
.fsection-head h2 .serif{color:var(--petrol)}
.fsection-head p{font-size:1.1rem;color:var(--ink-2);line-height:1.65;max-width:620px}
.fsection-dark .fsection-head h2{color:#fff}
.fsection-dark .fsection-head h2 .serif{color:var(--petrol-light)}
.fsection-dark .fsection-head p{color:#d0d0d0}
.fsection-dark .eyebrow{color:var(--petrol-light)}

/* FEATURE LIST INLINE */
.feat-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;margin-bottom:3rem;align-items:start}
@media(min-width:880px){.feat-grid{grid-template-columns:1fr 1fr;gap:4rem}}
@media(min-width:1100px){.feat-grid.three{grid-template-columns:repeat(3,1fr);gap:2.5rem}}

.feat{padding:0}
.feat-icon{width:48px;height:48px;border-radius:11px;background:var(--petrol-tint);color:var(--petrol);display:flex;align-items:center;justify-content:center;margin-bottom:1.2rem}
.feat-icon svg{width:22px;height:22px}
.feat h3{font-family:'Bricolage Grotesque',sans-serif;font-variation-settings:"opsz" 32,"wght" 550;font-size:1.35rem;letter-spacing:-0.01em;color:var(--ink);margin-bottom:0.7rem;line-height:1.3}
.feat p{color:var(--ink-2);font-size:1.02rem;line-height:1.6}
.feat p strong{color:var(--ink);font-weight:600}

.fsection-dark .feat-icon{background:rgba(14,124,123,0.15);color:var(--petrol-light)}
.fsection-dark .feat h3{color:#fff}
.fsection-dark .feat p{color:#d0d0d0}
.fsection-dark .feat p strong{color:#fff}

/* TECH BADGE ROW */
.tech-badges{display:flex;flex-wrap:wrap;gap:0.6rem;margin:1.8rem 0 0}
.tech-badge{display:inline-flex;align-items:center;gap:0.4rem;padding:0.4rem 0.85rem;border-radius:100px;background:var(--code-bg);border:1px solid var(--line);font-family:'JetBrains Mono',monospace;font-size:0.78rem;font-weight:500;color:var(--ink-2)}
.tech-badge .dot{width:7px;height:7px;border-radius:50%;background:var(--petrol);flex-shrink:0}
.fsection-dark .tech-badge{background:rgba(255,255,255,0.06);border-color:rgba(255,255,255,0.1);color:#d0d0d0}

/* MOCKUP CONTAINER */
.mockup{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:0 24px 64px rgba(10,10,10,0.08),0 1px 3px rgba(10,10,10,0.04);margin-top:2rem;max-width:1100px;margin-left:auto;margin-right:auto}
.mockup-bar{padding:0.8rem 1rem;border-bottom:1px solid var(--line);background:var(--line-2);display:flex;align-items:center;gap:0.4rem}
.mockup-bar-dot{width:10px;height:10px;border-radius:50%}
.mockup-bar-dot:nth-child(1){background:#ff5f57}
.mockup-bar-dot:nth-child(2){background:#ffbd2e}
.mockup-bar-dot:nth-child(3){background:#28ca42}
.mockup-bar-url{margin-left:0.8rem;background:#fff;border-radius:6px;padding:0.35rem 0.7rem;font-family:'JetBrains Mono',monospace;font-size:0.75rem;color:var(--ink-3);flex-grow:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mockup-body{padding:1.5rem 1.25rem;background:#fff}
@media(min-width:680px){.mockup-body{padding:2rem}}

/* CMS MOCKUP — Asset Library */
.cms-sidebar-grid{display:grid;grid-template-columns:200px 1fr;gap:1.5rem;margin-bottom:1rem}
@media(max-width:760px){.cms-sidebar-grid{grid-template-columns:1fr;gap:1rem}}
.cms-sidebar{padding:1rem;background:var(--code-bg);border-radius:10px}
@media(max-width:760px){.cms-sidebar{padding:0.8rem}}
.cms-sidebar-title{font-size:0.72rem;font-weight:700;color:var(--ink-3);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:0.7rem}
.cms-sidebar-item{padding:0.55rem 0.7rem;font-size:0.85rem;color:var(--ink-2);border-radius:6px;display:flex;align-items:center;gap:0.5rem;cursor:default}
.cms-sidebar-item.active{background:var(--petrol-tint);color:var(--petrol);font-weight:600}
.cms-sidebar-item svg{width:14px;height:14px;flex-shrink:0}
.cms-sidebar-item .count{margin-left:auto;font-size:0.75rem;color:var(--ink-4);background:#fff;padding:0.1rem 0.5rem;border-radius:100px}
.cms-sidebar-item.active .count{background:var(--petrol);color:#fff}

.cms-main-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.2rem;flex-wrap:wrap;gap:0.7rem}
.cms-main-title{font-size:1.1rem;font-weight:700;color:var(--ink);letter-spacing:-0.01em}
.cms-search{display:flex;align-items:center;gap:0.5rem;padding:0.5rem 0.9rem;border:1px solid var(--line);border-radius:8px;background:#fff;font-size:0.85rem;color:var(--ink-3);min-width:180px}
.cms-search svg{width:14px;height:14px;color:var(--ink-4)}
.cms-upload{background:var(--petrol);color:#fff;padding:0.55rem 1rem;border-radius:8px;font-size:0.85rem;font-weight:600;display:inline-flex;align-items:center;gap:0.4rem}
.cms-upload svg{width:14px;height:14px}

.asset-bib{display:grid;grid-template-columns:repeat(2,1fr);gap:0.8rem}
@media(min-width:560px){.asset-bib{grid-template-columns:repeat(3,1fr)}}
@media(min-width:880px){.asset-bib{grid-template-columns:repeat(4,1fr)}}
.asset-bib-tile{aspect-ratio:4/3;border-radius:10px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:0.85rem;font-weight:600;text-align:center;padding:0.6rem}
.asset-bib-tile::after{content:attr(data-meta);position:absolute;bottom:0.4rem;left:0.4rem;right:0.4rem;background:rgba(0,0,0,0.65);color:#fff;font-size:0.7rem;padding:0.2rem 0.5rem;border-radius:4px;font-weight:500;text-align:left}
.asset-bib-tile:nth-child(1){background:linear-gradient(135deg,#ffe8d6,#ffc8a8);color:#7a3a0e}
.asset-bib-tile:nth-child(2){background:linear-gradient(135deg,var(--petrol-tint),var(--petrol-light));color:#fff}
.asset-bib-tile:nth-child(3){background:linear-gradient(135deg,#f4eaff,#dcc6ff);color:#42228a}
.asset-bib-tile:nth-child(4){background:linear-gradient(135deg,#fff,#f0f0f0);color:var(--ink-3);border:1px solid var(--line)}
.asset-bib-tile:nth-child(5){background:linear-gradient(135deg,#fff8db,#ffe8a0);color:#7a5a0e}
.asset-bib-tile:nth-child(6){background:linear-gradient(135deg,#e0f4ff,#a8d8ff);color:#0e3a7a}
.asset-bib-tile:nth-child(7){background:linear-gradient(135deg,#dcfce7,#86efac);color:#14532d}
.asset-bib-tile:nth-child(8){background:linear-gradient(135deg,#fce7f3,#f9a8d4);color:#831843}

/* PLAYLIST MOCKUP */
.pl-mockup{background:#fff;border:1px solid var(--line);border-radius:10px;padding:1.2rem;margin-top:1.2rem}
.pl-mockup-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;padding-bottom:0.8rem;border-bottom:1px solid var(--line-2)}
.pl-mockup-name{font-weight:700;font-size:1rem;color:var(--ink)}
.pl-mockup-stats{font-size:0.82rem;color:var(--ink-3);display:flex;gap:1rem;flex-wrap:wrap}
.pl-mockup-stats span{display:flex;align-items:center;gap:0.3rem}
.pl-mockup-stats .live-dot{width:7px;height:7px;border-radius:50%;background:#22c55e;box-shadow:0 0 6px rgba(34,197,94,0.6)}
.pl-mockup-items{display:flex;flex-direction:column;gap:0.5rem}
.pl-item{display:flex;align-items:center;gap:0.7rem;padding:0.6rem;background:var(--code-bg);border-radius:8px;font-size:0.88rem}
.pl-item-num{width:24px;height:24px;border-radius:6px;background:var(--petrol);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:0.78rem;flex-shrink:0}
.pl-item-name{flex-grow:1;color:var(--ink);font-weight:500}
.pl-item-dur{color:var(--ink-3);font-family:'JetBrains Mono',monospace;font-size:0.78rem;flex-shrink:0}

/* SCHEDULE WEEK GRID */
.schedule-week{display:grid;grid-template-columns:60px repeat(7,1fr);gap:2px;background:var(--line);border-radius:10px;overflow:hidden;border:1px solid var(--line);font-size:0.7rem}
.sw-cell{background:#fff;padding:0.5rem 0.3rem;text-align:center;min-height:36px;display:flex;align-items:center;justify-content:center}
.sw-cell.head{background:var(--line-2);font-weight:700;color:var(--ink);text-transform:uppercase;letter-spacing:0.04em;font-size:0.65rem}
.sw-cell.time{background:var(--line-2);font-weight:600;color:var(--ink-3);font-family:'JetBrains Mono',monospace}
.sw-cell.event{font-weight:600;font-size:0.7rem;text-align:left;padding:0.4rem;justify-content:flex-start;line-height:1.2}
.sw-cell.event.frueh{background:linear-gradient(135deg,#fff8db,#ffe8a0);color:#7a5a0e}
.sw-cell.event.mittag{background:linear-gradient(135deg,var(--petrol-tint),var(--petrol-light));color:#fff}
.sw-cell.event.abend{background:linear-gradient(135deg,#f4eaff,#dcc6ff);color:#42228a}
.sw-cell.event.aktion{background:linear-gradient(135deg,#ffe8d6,#ffc8a8);color:#7a3a0e}
@media(max-width:680px){
  .schedule-week{font-size:0.62rem}
  .sw-cell{padding:0.35rem 0.2rem;min-height:32px}
  .sw-cell.event{font-size:0.62rem}
}

/* ANALYTICS DASHBOARD MOCKUP */
.ana-kpi-row{display:grid;grid-template-columns:repeat(2,1fr);gap:0.8rem;margin-bottom:1.2rem}
@media(min-width:680px){.ana-kpi-row{grid-template-columns:repeat(4,1fr)}}
.ana-kpi{padding:1.1rem;border:1px solid var(--line);border-radius:10px;background:#fff}
.ana-kpi-lbl{font-size:0.7rem;font-weight:700;color:var(--ink-3);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:0.4rem}
.ana-kpi-val{font-family:'Bricolage Grotesque',sans-serif;font-variation-settings:"wght" 600;font-size:1.8rem;color:var(--ink);letter-spacing:-0.02em;line-height:1}
.ana-kpi-trend{font-size:0.78rem;color:#15803d;margin-top:0.35rem;font-weight:500;display:flex;align-items:center;gap:0.3rem}
.ana-kpi-trend.down{color:#dc2626}

.ana-chart-wrap{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:1.2rem}
@media(min-width:880px){.ana-chart-wrap{grid-template-columns:2fr 1fr}}
.ana-chart{background:linear-gradient(180deg,var(--petrol-tint-2) 0%,#fff 100%);border:1px solid var(--line);border-radius:10px;padding:1.2rem;min-height:200px}
.ana-chart-head{display:flex;justify-content:space-between;margin-bottom:0.8rem;font-size:0.88rem;color:var(--ink-2);font-weight:600}
.ana-chart-svg{width:100%;height:160px}

.ana-side{display:flex;flex-direction:column;gap:0.8rem}
.ana-side-card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:1rem}
.ana-side-title{font-size:0.78rem;font-weight:700;color:var(--ink-3);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:0.7rem}
.ana-bar-item{display:flex;align-items:center;gap:0.6rem;font-size:0.85rem;padding:0.35rem 0}
.ana-bar-label{flex-shrink:0;width:80px;color:var(--ink-2);font-weight:500}
.ana-bar-track{flex-grow:1;height:6px;background:var(--line-2);border-radius:3px;overflow:hidden}
.ana-bar-fill{height:100%;background:var(--petrol);border-radius:3px}
.ana-bar-val{flex-shrink:0;font-family:'JetBrains Mono',monospace;font-size:0.78rem;color:var(--ink);font-weight:600;min-width:34px;text-align:right}

/* TRIGGER BUILDER MOCKUP */
.trig-builder{padding:1.5rem;border:1px solid var(--line);border-radius:12px;background:#fff;margin-top:1.5rem}
.trig-builder-head{font-weight:700;font-size:1rem;color:var(--ink);margin-bottom:1rem}
.trig-row{display:flex;align-items:center;gap:0.7rem;padding:1rem;background:var(--code-bg);border-radius:10px;margin-bottom:0.8rem;flex-wrap:wrap}
.trig-label{font-family:'JetBrains Mono',monospace;font-size:0.75rem;font-weight:700;color:var(--petrol);background:var(--petrol-tint);padding:0.25rem 0.6rem;border-radius:5px;flex-shrink:0}
.trig-text{flex-grow:1;font-size:0.92rem;color:var(--ink-2);line-height:1.4;min-width:200px}
.trig-text strong{color:var(--ink);font-weight:700}
.trig-arrow{color:var(--petrol);font-size:1rem;flex-shrink:0}
.trig-result{font-weight:600;color:var(--petrol);font-size:0.92rem;flex-shrink:0;background:#fff;padding:0.35rem 0.7rem;border:1px solid var(--petrol-tint);border-radius:6px}
.trig-status{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.trig-status.live{background:#22c55e;box-shadow:0 0 8px rgba(34,197,94,0.6);animation:pulse 1.5s infinite}
.trig-status.idle{background:var(--ink-4)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.4}}

/* USE CASE BOXES */
.usecase-grid{display:grid;grid-template-columns:1fr;gap:1.2rem;margin-top:3rem;max-width:1100px;margin-left:auto;margin-right:auto}
@media(min-width:880px){.usecase-grid{grid-template-columns:repeat(3,1fr)}}
.usecase{padding:1.8rem 1.5rem;background:#fff;border:1px solid var(--line);border-radius:14px}
.fsection-dark .usecase{background:rgba(255,255,255,0.04);border-color:rgba(255,255,255,0.1)}
.usecase-icon{width:42px;height:42px;border-radius:10px;background:var(--petrol-tint);color:var(--petrol);display:flex;align-items:center;justify-content:center;margin-bottom:1rem}
.usecase-icon svg{width:20px;height:20px}
.fsection-dark .usecase-icon{background:rgba(14,124,123,0.2);color:var(--petrol-light)}
.usecase-name{font-family:'Bricolage Grotesque',sans-serif;font-variation-settings:"wght" 600;font-size:1.05rem;color:var(--ink);margin-bottom:0.5rem;letter-spacing:-0.015em}
.fsection-dark .usecase-name{color:#fff}
.usecase-trigger{font-family:'JetBrains Mono',monospace;font-size:0.82rem;color:var(--ink-3);margin-bottom:0.6rem;line-height:1.5;padding:0.6rem 0.8rem;background:var(--code-bg);border-radius:6px;border-left:3px solid var(--petrol)}
.fsection-dark .usecase-trigger{background:rgba(255,255,255,0.04);color:#bababa}
.usecase-trigger strong{color:var(--ink);font-weight:600}
.fsection-dark .usecase-trigger strong{color:#fff}
.usecase-desc{font-size:0.92rem;color:var(--ink-2);line-height:1.6}
.fsection-dark .usecase-desc{color:#d0d0d0}

/* DEVICE LIST */
.dev-list{margin-top:2rem;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.dev-list-head{padding:0.8rem 1.2rem;background:var(--code-bg);border-bottom:1px solid var(--line);display:flex;font-size:0.72rem;font-weight:700;color:var(--ink-3);text-transform:uppercase;letter-spacing:0.06em;gap:1rem}
.dev-list-head .col-name{flex:2}
.dev-list-head .col-status{flex:1}
.dev-list-head .col-last{flex:1;text-align:right}
@media(max-width:680px){.dev-list-head{display:none}}
.dev-row{padding:1rem 1.2rem;display:flex;align-items:center;gap:1rem;border-bottom:1px solid var(--line-2);flex-wrap:wrap}
.dev-row:last-child{border-bottom:none}
.dev-row .col-name{flex:2;display:flex;align-items:center;gap:0.8rem;min-width:140px}
.dev-row .col-status{flex:1;display:flex;align-items:center;gap:0.4rem;font-size:0.88rem;min-width:100px}
.dev-row .col-last{flex:1;text-align:right;font-family:'JetBrains Mono',monospace;font-size:0.82rem;color:var(--ink-3);min-width:90px}
.dev-icon{width:36px;height:36px;border-radius:8px;background:var(--petrol-tint);color:var(--petrol);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.dev-icon svg{width:18px;height:18px}
.dev-info{min-width:0}
.dev-name{font-weight:600;font-size:0.95rem;color:var(--ink);margin-bottom:0.15rem}
.dev-loc{font-size:0.78rem;color:var(--ink-3)}
.dev-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dev-dot.online{background:#22c55e;box-shadow:0 0 6px rgba(34,197,94,0.5)}
.dev-dot.offline{background:#dc2626}
.dev-dot.warning{background:var(--warning)}

/* DSGVO DIAGRAM */
.dsgvo-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;align-items:center;margin:3rem auto;max-width:1100px}
@media(min-width:880px){.dsgvo-grid{grid-template-columns:1.2fr 1fr;gap:4rem}}
.dsgvo-list{list-style:none;padding:0;margin:0}
.dsgvo-list li{display:flex;align-items:flex-start;gap:0.8rem;padding:1rem 0;border-bottom:1px solid var(--line)}
.dsgvo-list li:last-child{border-bottom:none}
.dsgvo-list .check-icon{width:24px;height:24px;border-radius:50%;background:var(--petrol-tint);color:var(--petrol);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:0.15rem}
.dsgvo-list .x-icon{width:24px;height:24px;border-radius:50%;background:#fee2e2;color:#dc2626;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:0.15rem}
.dsgvo-list .check-icon svg,.dsgvo-list .x-icon svg{width:14px;height:14px}
.dsgvo-list .content{flex-grow:1}
.dsgvo-list .content strong{display:block;font-size:1.02rem;color:var(--ink);margin-bottom:0.2rem;font-weight:600}
.dsgvo-list .content p{font-size:0.92rem;color:var(--ink-2);line-height:1.55;margin:0}

.dsgvo-diagram{padding:2rem 1.5rem;background:linear-gradient(180deg,var(--sand) 0%,#fff 100%);border:1px solid var(--line);border-radius:14px}
.dsgvo-diagram-title{font-size:0.78rem;font-weight:700;color:var(--ink-3);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:1.2rem;text-align:center}
.dsgvo-svg{width:100%;height:auto;max-width:380px;display:block;margin:0 auto}

/* CTA STRIP */
.cta-strip{background:linear-gradient(135deg,var(--petrol) 0%,var(--petrol-dark) 100%);padding:5rem 0;color:#fff;text-align:center;position:relative;overflow:hidden}
.cta-strip::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(255,255,255,0.1) 0%,transparent 60%);pointer-events:none}
.cta-strip-inner{position:relative;max-width:680px;margin:0 auto;padding:0 1.25rem}
.cta-strip h2{font-family:'Bricolage Grotesque',sans-serif;font-variation-settings:"opsz" 64,"wght" 500;font-size:clamp(1.8rem,4vw,2.6rem);letter-spacing:-0.015em;line-height:1.2;color:#fff;margin-bottom:1rem}
.cta-strip h2 .serif{color:rgba(255,255,255,0.85)}
.cta-strip p{color:rgba(255,255,255,0.92);font-size:1.05rem;line-height:1.6;margin-bottom:2rem;max-width:520px;margin-left:auto;margin-right:auto}
.btn-white{background:#fff;color:var(--petrol);box-shadow:0 4px 12px rgba(0,0,0,0.15)}
.btn-white:hover{background:#fff;transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,0.2)}

/* FOOTER */
footer{background:var(--ink);color:#a8a8a8;padding:4rem 0 2rem;font-size:0.93rem}
.footer-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;margin-bottom:3rem}
.footer-brand{max-width:360px}
.footer-brand .logo{color:#fff;margin-bottom:1rem}
.footer-brand p{color:#a8a8a8;line-height:1.6;margin-bottom:1rem}
.footer-brand-founder{padding-top:1rem;border-top:1px solid #1f1f1f;color:#c0c0c0;font-size:0.88rem}
.footer-brand-founder strong{color:#fff;font-weight:600}
.footer-col h4{color:#fff;font-size:0.82rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;margin-bottom:1rem}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col li{margin-bottom:0.7rem}
.footer-col a{color:#a8a8a8;transition:color 0.2s;font-size:0.95rem}
.footer-col a:hover{color:var(--petrol-light)}
.footer-bottom{padding-top:2rem;border-top:1px solid #1f1f1f;display:flex;flex-direction:column;gap:1rem;justify-content:space-between;align-items:center;text-align:center;font-size:0.88rem}
.footer-bottom-links{display:flex;gap:1.5rem;flex-wrap:wrap;justify-content:center}
.footer-bottom-links a{color:#a8a8a8}
.footer-bottom-links a:hover{color:var(--petrol-light)}
@media(min-width:760px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem}.footer-bottom{flex-direction:row;text-align:left}}

/* Reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.8s cubic-bezier(0.16,1,0.3,1),transform 0.8s cubic-bezier(0.16,1,0.3,1)}
.reveal.in{opacity:1;transform:translateY(0)}

/* ============================================
   TEXT-PAGES — Impressum, Datenschutz, AVV, TOM
   ============================================ */

.legal-page{padding:7rem 0 4rem;background:#fff;min-height:60vh}
@media(min-width:760px){.legal-page{padding:9rem 0 6rem}}

.legal-container{max-width:760px;margin:0 auto;padding:0 1.25rem}
@media(min-width:680px){.legal-container{padding:0 2rem}}

.legal-breadcrumb{font-size:0.88rem;color:var(--ink-3);margin-bottom:1.5rem;display:flex;gap:0.5rem;align-items:center;flex-wrap:wrap}
.legal-breadcrumb a{color:var(--petrol);font-weight:500;transition:color 0.2s}
.legal-breadcrumb a:hover{color:var(--petrol-dark)}
.legal-breadcrumb-sep{color:var(--ink-4)}

.legal-page .eyebrow{margin-bottom:1rem;display:block}

.legal-page h1{font-family:'Bricolage Grotesque',sans-serif;font-variation-settings:"opsz" 72,"wght" 500;font-size:clamp(2rem,4.5vw,3.2rem);letter-spacing:-0.02em;line-height:1.12;color:var(--ink);margin-bottom:2rem}
.legal-page h1 .serif{color:var(--petrol)}

.legal-page h2{font-family:'Bricolage Grotesque',sans-serif;font-variation-settings:"opsz" 32,"wght" 600;font-size:1.3rem;letter-spacing:-0.01em;line-height:1.3;color:var(--ink);margin-top:2.5rem;margin-bottom:0.8rem}

.legal-page h3{font-family:'DM Sans',sans-serif;font-weight:600;font-size:1.05rem;color:var(--ink);margin-top:1.8rem;margin-bottom:0.6rem;line-height:1.3}

.legal-page p{color:var(--ink-2);font-size:1.02rem;line-height:1.7;margin-bottom:1rem}
.legal-page p strong{color:var(--ink);font-weight:600}

.legal-page ul,.legal-page ol{margin:0.6rem 0 1.2rem;padding-left:1.4rem}
.legal-page li{color:var(--ink-2);font-size:1.02rem;line-height:1.65;margin-bottom:0.4rem}
.legal-page li strong{color:var(--ink);font-weight:600}

.legal-page a{color:var(--petrol);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.legal-page a:hover{color:var(--petrol-dark);text-decoration-thickness:2px}

.legal-meta{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--line);font-size:0.92rem;color:var(--ink-3);line-height:1.55}
.legal-meta strong{color:var(--ink);font-weight:600}

.legal-back{display:inline-flex;align-items:center;gap:0.4rem;margin-top:2.5rem;padding:0.7rem 1.2rem;background:var(--petrol-tint-2);color:var(--petrol);border-radius:8px;font-size:0.92rem;font-weight:600;text-decoration:none}
.legal-back:hover{background:var(--petrol-tint);text-decoration:none}


/* ============================================
   LEGAL-DOC EXTRAS — AVV, TOM (komplexere Dokumente)
   ============================================ */

.legal-page .doc-meta{font-size:0.92rem;color:var(--ink-3);margin:-1rem 0 1.5rem;padding-bottom:1.2rem;border-bottom:1px solid var(--line);line-height:1.55}

.legal-page .parties{display:grid;grid-template-columns:1fr;gap:1.2rem;margin:2rem 0;padding:1.5rem;background:var(--petrol-tint-2);border-radius:12px;border:1px solid var(--petrol-tint);font-size:0.95rem}
@media(min-width:680px){.legal-page .parties{grid-template-columns:1fr 1fr;gap:2rem;padding:1.8rem}}
.legal-page .parties h3{margin-top:0;font-size:0.78rem;text-transform:uppercase;letter-spacing:0.08em;color:var(--petrol);font-weight:700;font-family:'DM Sans',sans-serif;margin-bottom:0.7rem}
.legal-page .parties strong{display:inline-block;margin-bottom:0.3rem}

.legal-page .toc{background:var(--petrol-tint-2);border-left:4px solid var(--petrol);padding:1.3rem 1.5rem;margin:2rem 0;font-size:0.95rem;border-radius:0 8px 8px 0}
.legal-page .toc h3{margin-top:0;font-size:0.78rem;text-transform:uppercase;letter-spacing:0.08em;color:var(--petrol);font-weight:700;font-family:'DM Sans',sans-serif;margin-bottom:0.8rem}
.legal-page .toc ol{margin:0;padding-left:1.3rem;color:var(--ink-2)}
.legal-page .toc li{margin-bottom:0.35rem;font-size:0.94rem;line-height:1.5}
.legal-page .toc a{color:var(--ink-2);text-decoration:none}
.legal-page .toc a:hover{color:var(--petrol);text-decoration:underline}

.legal-page .signatures{display:grid;grid-template-columns:1fr;gap:2rem;margin-top:4rem;padding-top:2rem;border-top:1px solid var(--line)}
@media(min-width:680px){.legal-page .signatures{grid-template-columns:1fr 1fr;gap:3rem}}
.legal-page .sig-block{font-size:0.92rem;color:var(--ink-2)}
.legal-page .sig-line{border-bottom:1.5px solid var(--ink-2);height:2.8rem;margin-bottom:0.5rem}
.legal-page .sig-label{color:var(--ink-3);font-size:0.82rem;font-weight:500}

.legal-page table{width:100%;border-collapse:collapse;margin:1.2rem 0;font-size:0.92rem;background:#fff;border:1px solid var(--line);border-radius:8px;overflow:hidden}
.legal-page th,.legal-page td{text-align:left;padding:0.7rem 0.9rem;border-bottom:1px solid var(--line);vertical-align:top}
.legal-page th{font-weight:700;color:var(--ink);background:var(--code-bg);font-size:0.78rem;text-transform:uppercase;letter-spacing:0.06em;font-family:'DM Sans',sans-serif}
.legal-page tr:last-child td{border-bottom:none}

.legal-page .placeholder{background:#fef3c7;padding:0.15em 0.5em;border-radius:4px;font-family:'JetBrains Mono',monospace;font-size:0.85em;color:#92400e;font-weight:500}

.legal-page .footer-note{font-size:0.85rem;color:var(--ink-3);margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--line);line-height:1.6}

@media print {
  .topnav,footer,.legal-back{display:none !important}
  .legal-page{padding:0}
  body{background:#fff;font-size:11pt}
  .legal-page h1,.legal-page h2,.legal-page h3{page-break-after:avoid;color:#000}
  .legal-page table,.legal-page .signatures,.legal-page .parties{page-break-inside:avoid}
}

/* ============================================
   MOBILE HAMBURGER MENU
   ============================================ */

.mobile-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:8px;background:transparent;border:none;cursor:pointer;color:var(--ink);transition:background 0.2s ease;flex-shrink:0;padding:0}
.mobile-toggle:hover{background:var(--line-2)}
.mobile-toggle svg{width:24px;height:24px;display:block}
.mobile-toggle .icon-close{display:none}
.mobile-toggle.open .icon-open{display:none}
.mobile-toggle.open .icon-close{display:block}

@media(min-width:880px){
  .mobile-toggle{display:none}
}

/* Auf Mobile: Login-Button in Topnav verstecken (kommt ins Menü) */
@media(max-width:879px){
  .btn-primary.nav-btn:not(.in-menu){display:none}
}

/* Mobile Menü Overlay */
.mobile-menu-overlay{position:fixed;inset:0;background:rgba(10,10,10,0.4);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:60;opacity:0;pointer-events:none;transition:opacity 0.35s cubic-bezier(0.16,1,0.3,1)}
.mobile-menu-overlay.open{opacity:1;pointer-events:auto}

/* Mobile Menü Panel */
.mobile-menu{position:fixed;top:0;right:0;bottom:0;width:88%;max-width:380px;background:#fff;z-index:70;transform:translateX(100%);transition:transform 0.4s cubic-bezier(0.16,1,0.3,1);display:flex;flex-direction:column;box-shadow:-12px 0 40px rgba(10,10,10,0.12)}
.mobile-menu.open{transform:translateX(0)}

.mobile-menu-head{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--line-2);min-height:64px}
.mobile-menu-head .logo{font-size:1.05rem}
.mobile-menu-head .logo-mark{width:30px;height:30px}

.mobile-menu-body{flex-grow:1;display:flex;flex-direction:column;padding:1.5rem 1.25rem 2rem;overflow-y:auto}

.mobile-menu .btn-primary.in-menu{width:100%;justify-content:center;margin-bottom:1.5rem;min-height:48px}

.mobile-menu-links{display:flex;flex-direction:column;gap:0.2rem;flex-grow:1}
.mobile-menu-links a{display:flex;align-items:center;justify-content:space-between;padding:1rem 0.4rem;font-family:'Bricolage Grotesque',sans-serif;font-variation-settings:"wght" 500;font-size:1.4rem;letter-spacing:-0.01em;color:var(--ink);transition:color 0.2s ease,background 0.2s ease;border-radius:8px;text-decoration:none}
.mobile-menu-links a:hover,.mobile-menu-links a.active{color:var(--petrol)}
.mobile-menu-links a.active{font-variation-settings:"wght" 600}
.mobile-menu-links a::after{content:"›";font-family:'DM Sans',sans-serif;font-size:1.4rem;color:var(--ink-4);font-weight:300;transition:color 0.2s ease,transform 0.2s ease}
.mobile-menu-links a:hover::after{color:var(--petrol);transform:translateX(3px)}

.mobile-menu-foot{padding-top:1.5rem;margin-top:1.5rem;border-top:1px solid var(--line-2);font-size:0.85rem;color:var(--ink-3);line-height:1.5}
.mobile-menu-foot strong{color:var(--ink);font-weight:600;display:block;margin-bottom:0.3rem}
.mobile-menu-foot a{color:var(--petrol);font-weight:500;text-decoration:none}

/* Body-Scroll-Lock wenn Menü offen */
body.menu-open{overflow:hidden}


/* Hamburger-Fix: explizit position:static damit globale nav-Regeln nicht greifen */
.mobile-menu-links{position:static}