/* ============================================
   MH-FLOCKE — Main Stylesheet
   Version 9 — Info banner (accept only), full Complianz override
   ============================================ */

/* === SELF-HOSTED FONTS === */
@font-face { font-family: 'JetBrains Mono'; src: url('../fonts/JetBrainsMono-Variable.woff2') format('woff2'), url('../fonts/JetBrainsMono-VariableFont_wght.ttf') format('truetype'); font-weight: 100 800; font-style: normal; font-display: swap; }
@font-face { font-family: 'Source Serif 4'; src: url('../fonts/SourceSerif4-Variable.woff2') format('woff2'), url('../fonts/SourceSerif4-VariableFont_opsz,wght.ttf') format('truetype'); font-weight: 200 900; font-style: normal; font-display: swap; }

/* === CSS VARIABLES === */
:root { --bg: #0a0e17; --bg-elevated: #111827; --bg-hover: #1a2332; --accent: #00d4ff; --accent-dim: rgba(0, 212, 255, 0.2); --accent-glow: rgba(0, 212, 255, 0.4); --text: #f1f5fb; --text-2: #b0bdd0; --text-3: #5e6e82; --border: #1e293b; --border-light: #2a3650; --font-head: 'JetBrains Mono', 'Consolas', monospace; --font-body: 'Source Serif 4', Georgia, serif; --max-w: 1100px; --max-w-narrow: 800px; }

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body { background: var(--bg); color: var(--text-2); font-family: var(--font-body); font-size: 17px; line-height: 1.7; -webkit-font-smoothing: antialiased; }
a:not(.mhf-btn):not(.mhf-link-card):not(.mhf-header-brand):not(.mhf-post-card-read) { color: var(--accent); text-decoration: none; transition: all 0.3s ease; }
a:not(.mhf-btn):not(.mhf-link-card):not(.mhf-header-brand):not(.mhf-post-card-read):hover { color: #7dd3fc; }
strong, b { color: var(--text); }
em { color: var(--text-2); }
code { background: rgba(0,212,255,0.08); padding: 2px 8px; border-radius: 4px; font-family: var(--font-head); font-size: 0.85em; color: var(--accent); border: 1px solid rgba(0,212,255,0.15); }
img { max-width: 100%; height: auto; }
h1, h2, h3, h4, h5 { font-family: var(--font-head); color: var(--text); letter-spacing: -0.02em; line-height: 1.2; }

/* === HEADER === */
.mhf-header { position: sticky; top: 0; z-index: 9999; background: rgba(10,14,23,0.92); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border-bottom: 1px solid var(--border); padding: 0 2rem; }
.mhf-header-inner { max-width: var(--max-w); margin: 0 auto; display: flex; align-items: center; justify-content: space-between; height: 80px; }
a.mhf-header-brand, .mhf-header-brand { display: flex; align-items: center; gap: 0.85rem; text-decoration: none; color: var(--text); }
.mhf-header-brand img { width: 56px; height: 56px; border-radius: 12px; box-shadow: 0 0 12px var(--accent-dim); }
.mhf-header-brand span { font-family: var(--font-head); font-weight: 700; font-size: 1.25rem; color: var(--text); letter-spacing: -0.02em; }
.mhf-nav { display: flex; gap: 2rem; align-items: center; }
.mhf-nav a { font-family: var(--font-head); font-size: 0.85rem; color: var(--text-2); text-decoration: none; transition: color 0.3s; position: relative; padding: 0.25rem 0; }
.mhf-nav a:hover, .mhf-nav a.current { color: var(--text); }
.mhf-nav a.current::after { content: ''; position: absolute; bottom: -2px; left: 0; width: 100%; height: 2px; background: var(--accent); border-radius: 1px; }
.mhf-hamburger { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: 8px; background: none; border: none; }
.mhf-hamburger span { display: block; width: 24px; height: 2px; background: var(--text); border-radius: 1px; transition: all 0.3s; }
.mhf-hamburger.active span:nth-child(1) { transform: rotate(45deg) translate(5px,5px); }
.mhf-hamburger.active span:nth-child(2) { opacity: 0; }
.mhf-hamburger.active span:nth-child(3) { transform: rotate(-45deg) translate(5px,-5px); }
.mhf-mobile-nav { display: none; position: fixed; top: 80px; left: 0; right: 0; bottom: 0; background: rgba(10,14,23,0.98); backdrop-filter: blur(20px); flex-direction: column; padding: 2rem; gap: 0; z-index: 9998; }
.mhf-mobile-nav.open { display: flex; }
.mhf-mobile-nav a { font-family: var(--font-head); font-size: 1.3rem; color: var(--text-2); padding: 1.25rem 0; border-bottom: 1px solid var(--border); text-decoration: none; }
.mhf-mobile-nav a:hover { color: var(--text); }
@media (max-width: 768px) { .mhf-nav { display: none; } .mhf-hamburger { display: flex; } }

/* === FOOTER === */
.mhf-footer { background: var(--bg); border-top: 1px solid var(--border); padding: 4rem 2rem 2rem; }
.mhf-footer-inner { max-width: var(--max-w); margin: 0 auto; display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 3rem; }
.mhf-footer-brand p { color: var(--text-3); font-size: 0.9rem; margin-top: 1rem; max-width: 300px; line-height: 1.6; }
.mhf-footer h4 { font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-3); margin-bottom: 1rem; }
.mhf-footer-links { list-style: none; }
.mhf-footer-links li { margin-bottom: 0.6rem; }
.mhf-footer-links a { color: var(--text-2); font-family: var(--font-head); font-size: 0.85rem; text-decoration: none; }
.mhf-footer-links a:hover { color: var(--text); }
.mhf-footer-bottom { max-width: var(--max-w); margin: 3rem auto 0; padding-top: 2rem; border-top: 1px solid var(--border); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem; }
.mhf-footer-bottom p { color: var(--text-3); font-size: 0.85rem; }
.mhf-footer-legal { display: flex; gap: 1.5rem; list-style: none; }
.mhf-footer-legal a { color: var(--text-3); font-family: var(--font-head); font-size: 0.8rem; text-decoration: none; }
.mhf-footer-legal a:hover { color: var(--text-2); }
.mhf-dedication { text-align: center; padding: 2rem; color: var(--text-2); font-style: italic; font-size: 0.95rem; }
@media (max-width: 768px) { .mhf-footer-inner { grid-template-columns: 1fr; gap: 2rem; } .mhf-footer-bottom { flex-direction: column; text-align: center; } }

/* === HERO === */
.mhf-hero { min-height: 100vh; display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; padding: 4rem 2rem; position: relative; overflow: hidden; }
.mhf-hero::before { content: ''; position: absolute; top: -50%; left: -50%; width: 200%; height: 200%; background: radial-gradient(ellipse at 30% 50%, var(--accent-dim) 0%, transparent 50%), radial-gradient(ellipse at 70% 30%, rgba(30,64,175,0.1) 0%, transparent 40%); animation: hero-drift 20s ease-in-out infinite alternate; pointer-events: none; }
@keyframes hero-drift { 0% { transform: translate(0,0); } 100% { transform: translate(-3%,2%) rotate(2deg); } }
.mhf-hero-content { position: relative; z-index: 1; max-width: 900px; }
.mhf-hero-logo { width: 180px; height: 180px; border-radius: 24px; margin: 0 auto 2.5rem; display: block; box-shadow: 0 0 80px var(--accent-glow), 0 0 160px var(--accent-dim); }
.mhf-hero h1 { font-size: clamp(2.8rem,7vw,5rem); font-weight: 700; letter-spacing: -0.03em; line-height: 1.1; margin-bottom: 1.5rem; background: linear-gradient(135deg, var(--accent), #60a5fa); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.mhf-hero-tagline { font-size: clamp(1.15rem,2.5vw,1.45rem); color: var(--text-2); max-width: 700px; margin: 0 auto 2.5rem; font-weight: 300; }
.mhf-stats { display: flex; gap: 3rem; justify-content: center; flex-wrap: wrap; margin-bottom: 3rem; }
.mhf-stat-val { font-family: var(--font-head); font-size: 2.2rem; font-weight: 700; color: var(--accent); }
.mhf-stat-lbl { font-size: 0.8rem; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.1em; font-family: var(--font-head); }

/* === BUTTONS === */
.mhf-cta { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
a.mhf-btn, .mhf-btn { display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.9rem 2rem; border-radius: 8px; font-family: var(--font-head); font-size: 0.9rem; font-weight: 600; text-decoration: none; transition: all 0.3s; border: none; cursor: pointer; }
a.mhf-btn-primary, .mhf-btn-primary { background: var(--accent); color: #0a0e17 !important; }
a.mhf-btn-primary:hover, .mhf-btn-primary:hover { box-shadow: 0 0 30px var(--accent-glow); transform: translateY(-2px); color: #0a0e17 !important; }
a.mhf-btn-outline, .mhf-btn-outline { background: transparent; color: var(--text) !important; border: 1px solid var(--border-light); }
a.mhf-btn-outline:hover, .mhf-btn-outline:hover { border-color: var(--accent); color: var(--accent) !important; }

/* === VIDEO === */
.mhf-video-section { padding: 4rem 2rem; max-width: 960px; margin: 0 auto; }
.mhf-section-label { font-family: var(--font-head); font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.15em; color: var(--accent); margin-bottom: 2rem; text-align: center; }
.mhf-video-wrap { position: relative; padding-bottom: 56.25%; border-radius: 12px; overflow: hidden; border: 1px solid var(--border-light); box-shadow: 0 20px 60px rgba(0,0,0,0.5); }
.mhf-video-wrap iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

/* === SECTIONS === */
.mhf-section { padding: 6rem 2rem; }
.mhf-section-narrow { max-width: var(--max-w-narrow); margin: 0 auto; }
.mhf-section-wide { max-width: var(--max-w); margin: 0 auto; }
.mhf-gradient-bg { background: linear-gradient(180deg, transparent 0%, #0d121d 50%, transparent 100%); }
.mhf-section h2 { font-size: clamp(1.8rem,4vw,2.5rem); margin-bottom: 2rem; }
.mhf-section h2.centered { text-align: center; }
.mhf-section p { font-size: 1.15rem; color: var(--text-2); margin-bottom: 1.5rem; }
.mhf-highlight { border-left: 3px solid var(--accent); padding-left: 1.5rem; margin: 2rem 0; font-style: italic; font-size: 1.2rem; color: var(--text); }
.mhf-subtitle { text-align: center; color: var(--text-2); font-size: 1.2rem; margin-bottom: 3rem; max-width: 600px; margin-left: auto; margin-right: auto; }

/* === CARDS === */
.mhf-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 1.5rem; }
.mhf-card { background: var(--bg-elevated); border: 1px solid var(--border); border-radius: 12px; padding: 2rem; transition: all 0.3s ease; }
.mhf-card:hover { background: var(--bg-hover); border-color: var(--accent-dim); transform: translateY(-4px); box-shadow: 0 12px 40px rgba(0,0,0,0.3); }
.mhf-card-icon { font-size: 2rem; margin-bottom: 1rem; }
.mhf-card h3 { font-size: 1.1rem; font-weight: 600; margin-bottom: 0.75rem; }
.mhf-card p { color: var(--text-2); font-size: 0.95rem; line-height: 1.6; margin-bottom: 0; }

/* === NUMBERED === */
.mhf-numbered-item { display: flex; gap: 2rem; margin-bottom: 2.5rem; align-items: flex-start; }
.mhf-num { font-family: var(--font-head); font-size: 2.5rem; font-weight: 700; color: var(--accent); opacity: 0.35; min-width: 60px; text-align: right; line-height: 1; }
.mhf-numbered-item h3 { font-size: 1.1rem; margin-bottom: 0.5rem; }
.mhf-numbered-item p { color: var(--text-2); font-size: 1rem; }
@media (max-width: 700px) { .mhf-numbered-item { flex-direction: column; gap: 0.5rem; } .mhf-num { text-align: left; min-width: auto; } }

/* === RESULTS === */
.mhf-results-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.mhf-result-card { background: var(--bg-elevated); border: 1px solid var(--border); border-radius: 12px; padding: 2.5rem; text-align: center; }
.mhf-big-num { font-family: var(--font-head); font-size: 3.2rem; font-weight: 700; background: linear-gradient(135deg, var(--accent), #60a5fa); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.mhf-result-desc { color: var(--text); font-size: 0.95rem; margin-top: 0.5rem; }
.mhf-result-detail { font-family: var(--font-head); font-size: 0.8rem; color: var(--text-3); margin-top: 0.5rem; }
@media (max-width: 700px) { .mhf-results-grid { grid-template-columns: 1fr; } }

/* === LINK CARDS === */
.mhf-links-grid { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
a.mhf-link-card, .mhf-link-card { background: var(--bg-elevated); border: 1px solid var(--border); border-radius: 12px; padding: 1.25rem 2rem; color: var(--text); font-family: var(--font-head); font-size: 0.9rem; transition: all 0.3s; display: flex; align-items: center; gap: 0.75rem; text-decoration: none; }
a.mhf-link-card:hover, .mhf-link-card:hover { border-color: var(--accent); background: var(--bg-hover); transform: translateY(-2px); color: var(--text); }

/* === UTILITY === */
.mhf-container { max-width: var(--max-w); margin: 0 auto; padding: 0 2rem; }
.mhf-text-center { text-align: center; }

/* === PAGE CONTENT (Impressum, Privacy Policy, Cookie Policy) === */
.mhf-single-content { font-size: 1rem; line-height: 1.8; color: var(--text-2); }
.mhf-single-content h2 { font-size: 1.6rem; margin-top: 3rem; margin-bottom: 1rem; padding-bottom: 0.5rem; border-bottom: 1px solid var(--border); }
.mhf-single-content h3 { font-size: 1.2rem; margin-top: 2rem; margin-bottom: 0.75rem; color: var(--text); }
.mhf-single-content h4 { font-size: 1rem; margin-top: 1.5rem; margin-bottom: 0.5rem; color: var(--text); font-weight: 600; }
.mhf-single-content p { font-size: 1rem; color: var(--text-2); margin-bottom: 1rem; line-height: 1.8; }
.mhf-single-content a { color: var(--accent); text-decoration: underline; text-underline-offset: 3px; text-decoration-color: rgba(0,212,255,0.3); }
.mhf-single-content a:hover { color: #7dd3fc; text-decoration-color: rgba(125,211,252,0.5); }
.mhf-single-content ul, .mhf-single-content ol { margin: 1rem 0 1.5rem 1.5rem; color: var(--text-2); }
.mhf-single-content li { margin-bottom: 0.5rem; line-height: 1.7; }
.mhf-single-content hr { border: none; border-top: 1px solid var(--border-light); margin: 3rem 0; }
.mhf-single-content strong { color: var(--text); }

/* === COMPLIANZ COOKIE BANNER — Dark theme, info-only (Accept button only) === */
#cmplz-cookiebanner-container .cmplz-cookiebanner,
.cmplz-cookiebanner {
  background: #111827 !important;
  border: 1px solid #1e293b !important;
  border-radius: 12px !important;
  font-family: 'Source Serif 4', Georgia, serif !important;
  box-shadow: 0 20px 60px rgba(0,0,0,0.6) !important;
  color: #b0bdd0 !important;
}
.cmplz-cookiebanner .cmplz-title,
.cmplz-cookiebanner .cmplz-header {
  font-family: 'JetBrains Mono', Consolas, monospace !important;
  color: #f1f5fb !important;
  font-size: 1.1rem !important;
  font-weight: 600 !important;
}
.cmplz-cookiebanner .cmplz-message,
.cmplz-cookiebanner .cmplz-body {
  color: #b0bdd0 !important;
  font-size: 0.9rem !important;
  line-height: 1.6 !important;
}
/* Accept button — styled like our CTA */
.cmplz-cookiebanner .cmplz-btn.cmplz-accept {
  background: #00d4ff !important;
  color: #0a0e17 !important;
  border: none !important;
  border-radius: 8px !important;
  font-family: 'JetBrains Mono', Consolas, monospace !important;
  font-weight: 600 !important;
}
.cmplz-cookiebanner .cmplz-btn.cmplz-accept:hover {
  box-shadow: 0 0 20px rgba(0,212,255,0.4) !important;
}
/* Hide Deny and View Preferences — only functional cookies, no consent needed */
.cmplz-cookiebanner .cmplz-btn.cmplz-deny,
.cmplz-cookiebanner .cmplz-btn.cmplz-manage,
.cmplz-cookiebanner .cmplz-btn.cmplz-view-preferences {
  display: none !important;
}
/* Links */
.cmplz-cookiebanner a,
.cmplz-cookiebanner .cmplz-links a {
  color: #00d4ff !important;
}
.cmplz-cookiebanner a:hover,
.cmplz-cookiebanner .cmplz-links a:hover {
  color: #7dd3fc !important;
}
/* Manage consent floating button */
#cmplz-manage-consent .cmplz-btn.cmplz-manage-consent,
#cmplz-manage-consent button,
button.cmplz-manage-consent {
  background: #111827 !important;
  color: #b0bdd0 !important;
  border: 1px solid #1e293b !important;
  font-family: 'JetBrains Mono', Consolas, monospace !important;
  font-size: 0.75rem !important;
  border-radius: 8px !important;
}
#cmplz-manage-consent .cmplz-btn.cmplz-manage-consent:hover,
#cmplz-manage-consent button:hover,
button.cmplz-manage-consent:hover {
  border-color: #2a3650 !important;
  color: #f1f5fb !important;
}
/* === DOCS LAYOUT === */
.mhf-docs-layout{display:grid;grid-template-columns:260px 1fr;min-height:calc(100vh - 80px)}
.mhf-docs-sidebar{background:#0d1117;border-right:1px solid #1e293b;padding:2rem 0;position:sticky;top:60px;height:calc(100vh - 60px);overflow-y:auto}
.mhf-docs-sidebar-inner{display:flex;flex-direction:column;gap:2px}
.mhf-docs-sidebar-title{font-family:'Source Serif 4',serif;font-size:1.1rem;font-weight:700;color:#00d4ff;padding:.5rem 1.5rem 1rem;text-decoration:none;border-bottom:1px solid #1e293b;margin-bottom:.5rem}
.mhf-docs-nav-item{display:block;padding:.5rem 1.5rem;color:#8b949e;text-decoration:none;font-size:.85rem;font-family:'JetBrains Mono',Consolas,monospace;transition:all .15s;border-left:3px solid transparent}
.mhf-docs-nav-item:hover{color:#c9d1d9;background:rgba(0,212,255,.04)}
.mhf-docs-nav-item.active{color:#00d4ff;background:rgba(0,212,255,.08);border-left-color:#00d4ff}
.mhf-docs-content{padding:2.5rem 3rem;max-width:900px}
.mhf-docs-content h1{font-family:'Source Serif 4',serif;font-size:2rem;color:#f0f6fc;margin-bottom:2rem}
.mhf-docs-content h2{font-family:'Source Serif 4',serif;font-size:1.5rem;color:#e6edf3;margin-top:2.5rem;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid #1e293b}
.mhf-docs-content h3{font-size:1.1rem;color:#c9d1d9;margin-top:2rem;margin-bottom:.75rem}
.mhf-docs-content h4{font-size:.95rem;color:#b0bdd0;margin-top:1.5rem;margin-bottom:.5rem;font-family:'JetBrains Mono',Consolas,monospace}
.mhf-docs-content pre{background:#0d1117;border:1px solid #1e293b;border-radius:6px;padding:1rem 1.25rem;overflow-x:auto;font-family:'JetBrains Mono',Consolas,monospace;font-size:.8rem;line-height:1.6;color:#8b949e;margin:1rem 0}
.mhf-docs-content code{font-family:'JetBrains Mono',Consolas,monospace;font-size:.85rem;color:#00d4ff;background:rgba(0,212,255,.08);padding:.1rem .3rem;border-radius:3px}
.mhf-docs-content pre code{background:none;padding:0;color:inherit}
.mhf-docs-content table{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.85rem}
.mhf-docs-content th{background:#161b22;color:#c9d1d9;text-align:left;padding:.6rem 1rem;border:1px solid #1e293b;font-weight:600}
.mhf-docs-content td{padding:.5rem 1rem;border:1px solid #1e293b;color:#8b949e}
.mhf-docs-content em{color:#a5b4c6}
.mhf-docs-content ul,.mhf-docs-content ol{padding-left:1.5rem;margin:.75rem 0}
.mhf-docs-content li{margin:.4rem 0;color:#8b949e;line-height:1.6}
.mhf-docs-content li strong{color:#c9d1d9}
.mhf-docs-content p{line-height:1.7;color:#8b949e;margin:.75rem 0}
@media(max-width:768px){.mhf-docs-layout{grid-template-columns:1fr}.mhf-docs-sidebar{position:relative;top:0;height:auto;border-right:none;border-bottom:1px solid #1e293b}.mhf-docs-sidebar-inner{flex-direction:row;flex-wrap:wrap;gap:0;padding:.5rem 1rem}.mhf-docs-nav-item{padding:.4rem .8rem;border-left:none;border-bottom:2px solid transparent;font-size:.75rem}.mhf-docs-nav-item.active{border-left-color:transparent;border-bottom-color:#00d4ff}.mhf-docs-content{padding:1.5rem}}
/* === DOCS OVERVIEW CARDS === */
.mhf-docs-intro{font-size:1.05rem;color:#8b949e;line-height:1.7;max-width:700px;margin-bottom:2.5rem}
.mhf-docs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}
.mhf-docs-card{display:flex;flex-direction:column;gap:.4rem;padding:1.25rem 1.5rem;background:#111827;border:1px solid #1e293b;border-radius:8px;text-decoration:none;transition:all .2s}
.mhf-docs-card:hover{border-color:#00d4ff;background:#0d1520;transform:translateY(-2px)}
.mhf-docs-card-icon{font-size:1.5rem;margin-bottom:.25rem}
.mhf-docs-card strong{font-family:'Source Serif 4',serif;font-size:1.05rem;color:#e6edf3}
.mhf-docs-card span:last-child{font-size:.82rem;color:#8b949e;line-height:1.5}
@media(max-width:768px){.mhf-docs-grid{grid-template-columns:1fr}}
/* Docs sidebar scrollbar — thin, dark, unobtrusive */
.mhf-docs-sidebar::-webkit-scrollbar { width: 4px; }
.mhf-docs-sidebar::-webkit-scrollbar-track { background: transparent; }
.mhf-docs-sidebar::-webkit-scrollbar-thumb { background: #1e293b; border-radius: 2px; }
.mhf-docs-sidebar::-webkit-scrollbar-thumb:hover { background: #334155; }
.mhf-docs-sidebar { scrollbar-width: thin; scrollbar-color: #1e293b transparent; }
