/* ============================================
   VELTRIC 2.0 — SHARED STYLES (alle Seiten)
   Design Tokens + Nav + Footer + Buttons + Effekte
   ============================================ */

/* Tabler Icons Subset, MIT, https://tabler.io/icons */
@font-face {
  font-family: 'tabler-icons';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/styles/icons/fonts/tabler-icons-subset.woff2') format('woff2');
}
.ti {
  font-family: 'tabler-icons' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.ti-activity:before { content: "\ed23"; }
.ti-adjustments:before { content: "\ea03"; }
.ti-alert-triangle:before { content: "\ea06"; }
.ti-armchair:before { content: "\ef9e"; }
.ti-arrow-left:before { content: "\ea19"; }
.ti-arrow-right:before { content: "\ea1f"; }
.ti-arrow-up-right:before { content: "\ea24"; }
.ti-bolt:before { content: "\ea38"; }
.ti-bolt-off:before { content: "\ecec"; }
.ti-brand-instagram:before { content: "\ec20"; }
.ti-brand-linkedin:before { content: "\ec8c"; }
.ti-brand-x:before { content: "\fc0f"; }
.ti-browser:before { content: "\ebb7"; }
.ti-building:before { content: "\ea4f"; }
.ti-building-store:before { content: "\ea4e"; }
.ti-calendar:before { content: "\ea53"; }
.ti-calendar-event:before { content: "\ea52"; }
.ti-calendar-star:before { content: "\f830"; }
.ti-camera:before { content: "\ea54"; }
.ti-certificate:before { content: "\ed76"; }
.ti-chart-donut:before { content: "\ea5b"; }
.ti-check:before { content: "\ea5e"; }
.ti-chevron-down:before { content: "\ea5f"; }
.ti-circle:before { content: "\ea6b"; }
.ti-circle-check:before { content: "\ea67"; }
.ti-clipboard-check:before { content: "\ea6c"; }
.ti-confetti:before { content: "\ee46"; }
.ti-copy:before { content: "\ea7a"; }
.ti-dashboard:before { content: "\ea87"; }
.ti-device-mobile-vibration:before { content: "\eb86"; }
.ti-discount-check-filled:before { content: "\f746"; }
.ti-download:before { content: "\ea96"; }
.ti-edit:before { content: "\ea98"; }
.ti-eye-off:before { content: "\ecf0"; }
.ti-file-check:before { content: "\ea9c"; }
.ti-file-spreadsheet:before { content: "\f03e"; }
.ti-file-text:before { content: "\eaa2"; }
.ti-filter:before { content: "\eaa5"; }
.ti-folder:before { content: "\eaad"; }
.ti-gavel:before { content: "\ef90"; }
.ti-gift:before { content: "\eb68"; }
.ti-git-branch:before { content: "\eab2"; }
.ti-heart:before { content: "\eabe"; }
.ti-history:before { content: "\ebea"; }
.ti-info-circle:before { content: "\eac5"; }
.ti-layout-dashboard:before { content: "\f02c"; }
.ti-link:before { content: "\eade"; }
.ti-list:before { content: "\eb6b"; }
.ti-list-check:before { content: "\eb6a"; }
.ti-lock:before { content: "\eae2"; }
.ti-mail:before { content: "\eae5"; }
.ti-mail-bolt:before { content: "\f937"; }
.ti-mail-search:before { content: "\f945"; }
.ti-map-pin:before { content: "\eae8"; }
.ti-message:before { content: "\eaef"; }
.ti-movie:before { content: "\eafa"; }
.ti-news:before { content: "\eafd"; }
.ti-paperclip:before { content: "\eb02"; }
.ti-phone:before { content: "\eb09"; }
.ti-plus:before { content: "\eb0b"; }
.ti-presentation:before { content: "\eb70"; }
.ti-qrcode:before { content: "\eb11"; }
.ti-receipt-tax:before { content: "\edbd"; }
.ti-rectangle:before { content: "\ed37"; }
.ti-rocket:before { content: "\ec45"; }
.ti-route:before { content: "\eb17"; }
.ti-scale:before { content: "\ebc2"; }
.ti-scan:before { content: "\ebc8"; }
.ti-search:before { content: "\eb1c"; }
.ti-send:before { content: "\eb1e"; }
.ti-server:before { content: "\eb1f"; }
.ti-settings:before { content: "\eb20"; }
.ti-shield-check:before { content: "\eb22"; }
.ti-shield-lock:before { content: "\ed58"; }
.ti-signal-4g:before { content: "\f1ef"; }
.ti-sparkles:before { content: "\f6d7"; }
.ti-square-off:before { content: "\eeef"; }
.ti-star-filled:before { content: "\f6a6"; }
.ti-tag:before { content: "\eb34"; }
.ti-target:before { content: "\eb35"; }
.ti-template:before { content: "\eb39"; }
.ti-tools:before { content: "\ebca"; }
.ti-trending-up:before { content: "\eb43"; }
.ti-user:before { content: "\eb4d"; }
.ti-user-check:before { content: "\eb49"; }
.ti-users:before { content: "\ebf2"; }
.ti-users-group:before { content: "\fa21"; }
.ti-users-plus:before { content: "\fa0f"; }
.ti-wallet:before { content: "\eb75"; }
.ti-wifi:before { content: "\eb52"; }
.ti-world:before { content: "\eb54"; }
.ti-x:before { content: "\eb55"; }

/* Inter font, SIL Open Font License 1.1, https://rsms.me/inter/ */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/fonts/inter-400.woff2') format('woff2');
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('/fonts/inter-500.woff2') format('woff2');
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('/fonts/inter-600.woff2') format('woff2');
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('/fonts/inter-700.woff2') format('woff2');
}

:root {
  --font-light-primary:    #121212;
  --font-light-secondary:  #475569;
  --font-light-tertiary:   #64748B;
  --font-dark-primary:     #FFFFFF;
  --font-dark-secondary:   #E2E8F0;
  --font-dark-tertiary:    #94A3B8;
  --outline-light-primary:   #3796FF;
  --outline-light-secondary: #E2E8F0;
  --outline-light-tertiary:  #F1F5F9;
  --outline-dark-primary:    #3796FF;
  --outline-dark-secondary:  #2A2A2A;
  --outline-dark-tertiary:   #404040;
  --surface-light-primary:   #FFFFFF;
  --surface-light-secondary: #FAFAF7;
  --surface-light-tertiary:  #F4F4F0;
  --surface-dark-primary:    #121212;
  --surface-dark-secondary:  #1E1E1E;
  --surface-dark-tertiary:   #2A2A2A;
  --accent-primary:  #3796FF;
  --accent-primary-rgb: 55, 150, 255;
  --accent-hover:    #1F7AE0;
  --accent-deep:     #0E5FBE;
  --accent-mid:      #5BA8FF;
  --accent-light:    #78BEFF;
  --accent-warm:     #D8B26B;
  --accent-warm-rgb: 216, 178, 107;
  --accent-warm-soft:#E6CB95;
  --outline-strong:  #94A3B8;

  /* Heartbeat — Brand-Signatur */
  --beat: 1.6s;

  /* Easings — eine Sprache */
  --ease-out-soft:   cubic-bezier(0.16, 1, 0.3, 1);
  --ease-out-spring: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-out-snap:   cubic-bezier(0.34, 1.4, 0.64, 1);

  /* Durations — drei Tiers */
  --dur-fast: 150ms;
  --dur-base: 250ms;
  --dur-med:  400ms;
  --dur-slow: 700ms;

  /* Border-Alpha — 4 Tiers statt 16 */
  --border-subtle:   rgba(18,18,18,.06);
  --border:          rgba(18,18,18,.10);
  --border-strong:   rgba(18,18,18,.18);
  --border-emphasis: rgba(18,18,18,.30);

  /* Radius — 7 Werte total */
  --r-xs: 4px; --r-sm: 8px; --r-md: 12px; --r-lg: 16px; --r-xl: 24px; --r-2xl: 32px; --r-pill: 999px;

  /* Shadow — 5 Tiers */
  --shadow-1: 0 1px 2px rgba(18,18,18,.04);
  --shadow-2: 0 4px 14px -4px rgba(18,18,18,.10);
  --shadow-3: 0 12px 32px -12px rgba(18,18,18,.16);
  --shadow-4: 0 24px 60px -20px rgba(18,18,18,.22);
  --shadow-inset: inset 0 1px 0 rgba(255,255,255,.6);

  --font-heading: 'Inter', sans-serif;
  --font-body:    'Inter', sans-serif;
  --font-mono:    'JetBrains Mono', monospace;

  --h1-size: 3.625rem;  --h1-weight: 700; --h1-leading: 1.04; --h1-tracking: -0.035em;
  --h2-size: 2.375rem;  --h2-weight: 700; --h2-leading: 1.15; --h2-tracking: -0.025em;
  --h3-size: 1.25rem;   --h3-weight: 600; --h3-leading: 1.25; --h3-tracking: -0.018em;
  --h4-size: 1rem;      --h4-weight: 500; --h4-leading: 1.4;  --h4-tracking: -0.01em;
  --body1-size: 1rem;     --body1-weight: 400; --body1-bold: 600; --body1-leading: 1.6;
  --body2-size: 0.9375rem;--body2-weight: 400; --body2-bold: 600; --body2-leading: 1.55;
  --body3-size: 0.8125rem;--body3-weight: 400; --body3-bold: 500; --body3-leading: 1.5;
  --body4-size: 0.6875rem;--body4-weight: 400; --body4-bold: 600; --body4-leading: 1.5;

  /* Page-Edge-Padding (links/rechts) — eine Quelle, überall identisch */
  --page-pad-x: 24px;
}
@media (max-width: 1024px) {
  :root {
    --h1-size: 2.875rem; --h2-size: 2rem; --h3-size: 1.125rem; --h4-size: 0.9375rem;
    --body1-size: 0.9375rem; --body2-size: 0.875rem; --body3-size: 0.78125rem; --body4-size: 0.6875rem;
  }
}
@media (max-width: 767px) {
  :root {
    --h1-size: 2.25rem; --h2-size: 1.625rem; --h3-size: 1rem; --h4-size: 0.875rem;
    --body1-size: 0.9375rem; --body2-size: 0.875rem; --body3-size: 0.78125rem; --body4-size: 0.6875rem;
    --page-pad-x: 24px;
  }
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; scroll-padding-top: 110px; overflow-x: clip; }
body { overflow-x: clip; }
body {
  font-family: var(--font-body);
  background: var(--surface-light-primary);
  color: var(--font-light-primary);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-feature-settings: "ss01", "cv11";
  caret-color: var(--accent-primary);
  overflow-x: hidden;
  min-height: 100vh;
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
}
main { flex: 1 0 auto; }
.footer { flex-shrink: 0; }
/* Tabular numerals für alle numerischen Kontexte */
.t-h1, .t-h2, .t-h3, .t-h4, .price-card .num, .addon-card .addon-price .num, table, .features-table { font-variant-numeric: tabular-nums; }
/* Pro-Link-Underline */
a { text-underline-offset: 3px; text-decoration-thickness: 1px; }
/* Focus-Visible (a11y + pro) */
:focus-visible { outline: 2px solid var(--accent-primary); outline-offset: 3px; border-radius: 4px; }

/* TYPO TOKEN CLASSES */
.t-h1 { font-family: var(--font-heading); font-size: var(--h1-size); font-weight: var(--h1-weight); line-height: var(--h1-leading); letter-spacing: var(--h1-tracking); }
.t-h2 { font-family: var(--font-heading); font-size: var(--h2-size); font-weight: var(--h2-weight); line-height: var(--h2-leading); letter-spacing: var(--h2-tracking); }
.t-h3 { font-family: var(--font-heading); font-size: var(--h3-size); font-weight: var(--h3-weight); line-height: var(--h3-leading); letter-spacing: var(--h3-tracking); }
.t-h4 { font-family: var(--font-heading); font-size: var(--h4-size); font-weight: var(--h4-weight); line-height: var(--h4-leading); letter-spacing: var(--h4-tracking); font-style: italic; }
.t-body1      { font-family: var(--font-body); font-size: var(--body1-size); font-weight: var(--body1-weight); line-height: var(--body1-leading); }
.t-body1-bold { font-family: var(--font-body); font-size: var(--body1-size); font-weight: var(--body1-bold);   line-height: var(--body1-leading); }
.t-body2      { font-family: var(--font-body); font-size: var(--body2-size); font-weight: var(--body2-weight); line-height: var(--body2-leading); }
.t-body2-bold { font-family: var(--font-body); font-size: var(--body2-size); font-weight: var(--body2-bold);   line-height: var(--body2-leading); }
.t-body3      { font-family: var(--font-body); font-size: var(--body3-size); font-weight: var(--body3-weight); line-height: var(--body3-leading); }
.t-body3-bold { font-family: var(--font-body); font-size: var(--body3-size); font-weight: var(--body3-bold);   line-height: var(--body3-leading); }
.t-body4      { font-family: var(--font-body); font-size: var(--body4-size); font-weight: var(--body4-weight); line-height: var(--body4-leading); }
.t-body4-bold { font-family: var(--font-body); font-size: var(--body4-size); font-weight: var(--body4-bold);   line-height: var(--body4-leading); }

/* SCROLLBAR + SELECTION */
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: var(--surface-light-secondary); }
::-webkit-scrollbar-thumb { background: var(--outline-light-secondary); border-radius: 999px; }
::-webkit-scrollbar-thumb:hover { background: var(--accent-primary); }
html { scrollbar-color: var(--outline-light-secondary) var(--surface-light-secondary); scrollbar-width: thin; }
::selection      { background: var(--accent-primary); color: var(--font-dark-primary); }
::-moz-selection { background: var(--accent-primary); color: var(--font-dark-primary); }

/* GRAIN OVERLAY */
body::after {
  content: ''; position: fixed; inset: 0; z-index: 9998;
  pointer-events: none; opacity: 0.045;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 256px 256px; mix-blend-mode: multiply;
}

/* GLASS */
.glass-light { background: rgba(255,255,255,0.72); backdrop-filter: blur(20px) saturate(1.6); -webkit-backdrop-filter: blur(20px) saturate(1.6); }
.glass-dark  { background: rgba(15,23,42,0.72); backdrop-filter: blur(20px) saturate(1.6); -webkit-backdrop-filter: blur(20px) saturate(1.6); }

/* REVEAL — kein Scale (Subpixel-Flicker) */
.reveal { opacity: 0; transform: translateY(28px); filter: blur(4px); transition: opacity 1.05s var(--ease-out-soft), transform 1.05s var(--ease-out-soft), filter 0.8s var(--ease-out-soft); }
.reveal.visible { opacity: 1; transform: translateY(0); filter: blur(0); }
.reveal-delay-1 { transition-delay: 0.06s; }
.reveal-delay-2 { transition-delay: 0.14s; }
.reveal-delay-3 { transition-delay: 0.22s; }
.reveal-delay-4 { transition-delay: 0.32s; }
.reveal-delay-5 { transition-delay: 0.42s; }
@media (prefers-reduced-motion: reduce) {
  .reveal, .reveal.visible { opacity: 1; transform: none; filter: none; transition: none; }
}

/* BUTTONS */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 12px 22px; border-radius: 999px; font-family: var(--font-body); font-size: 0.875rem; font-weight: 500; line-height: 1; letter-spacing: -0.01em; transition: transform 0.25s cubic-bezier(0.22,1,0.36,1), background 0.25s, color 0.25s, border-color 0.25s, box-shadow 0.25s; white-space: nowrap; text-decoration: none; border: 1px solid transparent; }
.btn-light-primary  { background: var(--font-light-primary); color: var(--font-dark-primary); box-shadow: 0 1px 0 rgba(255,255,255,0.10) inset, 0 4px 14px -4px rgba(18,18,18,0.30); }
.btn-light-primary:hover  { background: #2A2A2A; transform: translateY(-1px); box-shadow: 0 1px 0 rgba(255,255,255,0.10) inset, 0 10px 24px -6px rgba(18,18,18,0.42); }
.btn-light-secondary { background: var(--surface-light-primary); color: var(--font-light-primary); border-color: var(--outline-light-secondary); box-shadow: 0 1px 0 rgba(255,255,255,0.6) inset, 0 1px 2px rgba(18,18,18,0.04); }
.btn-light-secondary:hover { background: var(--surface-light-secondary); border-color: #C5D2E0; transform: translateY(-1px); box-shadow: 0 6px 16px -6px rgba(18,18,18,0.10); }
.btn-light-tertiary { background: transparent; color: var(--font-light-primary); }
.btn-light-tertiary:hover { color: var(--accent-primary); }
.btn-dark-primary  { background: var(--font-dark-primary); color: var(--font-light-primary); }
.btn-dark-primary:hover  { background: #E2E8F0; transform: translateY(-1px); }
.btn-dark-secondary { background: transparent; color: var(--font-dark-primary); border-color: var(--outline-dark-tertiary); }
.btn-dark-secondary:hover { background: rgba(255,255,255,0.05); border-color: var(--font-dark-secondary); transform: translateY(-1px); }
.btn-dark-tertiary { background: transparent; color: var(--font-dark-primary); }
.btn-dark-tertiary:hover { color: var(--accent-primary); }
@media (max-width: 767px) {
  .btn { min-height: 44px; padding: 13px 22px 11px; }
  .skip-link { min-height: 44px; display: inline-flex; align-items: center; }
  .footer-legal a { min-height: 44px; display: inline-flex; align-items: center; padding: 8px 4px; }
}

/* GLOBALE ICON-MITTIGKEIT: alle Tabler-Icons exakt vertikal+horizontal mittig in ihrem Wrapper */
.ti { line-height: 1; vertical-align: middle; }
[class$="-icon"], [class*="-icon "], .icon, .ic { line-height: 1; }
[class$="-icon"] > i, [class*="-icon "] > i, .icon > i, .ic > i, .v3-trust-item .icon i { display: block; line-height: 1; }

/* MAGNETIC */
.magnetic { display: inline-block; transition: transform 0.4s cubic-bezier(0.22,1,0.36,1); }

/* NAV */
.nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; padding: 16px var(--page-pad-x); transition: padding 0.4s cubic-bezier(0.22,1,0.36,1); }
.nav-inner { max-width: 1280px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 8px 12px 8px 22px; border-radius: 999px; border: 1px solid rgba(18,18,18,0.06); box-shadow: 0 1px 0 rgba(255,255,255,0.6) inset, 0 8px 32px -16px rgba(18,18,18,0.18), 0 2px 6px -2px rgba(18,18,18,0.06); transition: box-shadow 0.4s cubic-bezier(0.22,1,0.36,1), border-color 0.4s; }
.nav.is-scrolled { padding: 12px var(--page-pad-x); }
.nav.is-scrolled .nav-inner { box-shadow: 0 1px 0 rgba(255,255,255,0.6) inset, 0 12px 40px -16px rgba(18,18,18,0.22), 0 4px 10px -4px rgba(18,18,18,0.08); }
.logo-wordmark { font-family: var(--font-heading); font-weight: 700; font-size: 1.5rem; letter-spacing: -0.04em; color: var(--font-light-primary); text-decoration: none; display: inline-flex; align-items: baseline; position: relative; }
.logo-wordmark .dot-i { position: relative; display: inline-block; }
.logo-wordmark .dot-i::after { content: ''; position: absolute; left: 50%; top: -0.30em; width: 0.22em; height: 0.22em; border-radius: 50%; background: var(--accent-warm); transform: translateX(-50%) scale(1); animation: dotPulse var(--beat) ease-in-out infinite; }
.logo-img { display: inline-flex; align-items: center; text-decoration: none; min-height: 44px; padding: 4px 0; }
.logo-img img { height: 19px; width: auto; display: block; }
.logo-img.logo-img-dark img { filter: brightness(0) invert(1); }
@media (max-width: 767px) { .logo-img img { height: 18px; } }
@keyframes dotPulse {
  0%, 100% { transform: translateX(-50%) scale(1);    box-shadow: 0 0 8px rgba(var(--accent-warm-rgb), 0.55); }
  50%      { transform: translateX(-50%) scale(1.55); box-shadow: 0 0 14px rgba(var(--accent-warm-rgb), 0.85); }
}
.nav-links { display: flex; align-items: center; gap: 4px; }
.nav-link { padding: 8px 14px; font-family: var(--font-body); font-size: 0.875rem; font-weight: 500; color: var(--font-light-secondary); text-decoration: none; border-radius: 999px; transition: color 0.2s, background 0.2s; display: inline-flex; align-items: center; gap: 6px; }
.nav-link:hover { color: var(--font-light-primary); background: var(--surface-light-secondary); }
.nav-link.active { color: var(--font-light-primary); background: var(--surface-light-secondary); }
.nav-cta { display: flex; align-items: center; gap: 8px; }
.hamburger { display: none; width: 44px; height: 44px; border: 1px solid var(--outline-light-secondary); background: var(--surface-light-primary); border-radius: 999px; align-items: center; justify-content: center; cursor: pointer; }
.hamburger span { display: block; width: 16px; height: 1.5px; background: var(--font-light-primary); position: relative; transition: transform 0.3s; }
.hamburger span::before, .hamburger span::after { content: ''; position: absolute; left: 0; width: 16px; height: 1.5px; background: var(--font-light-primary); transition: transform 0.3s; }
.hamburger span::before { top: -5px; }
.hamburger span::after  { top: 5px; }
@media (max-width: 1024px) { .nav-links { display: none; } .hamburger { display: inline-flex; } }

/* MOBILE POPUP */
.mobile-popup { position: fixed; inset: 0; z-index: 200; background: var(--surface-light-primary); transform: translateY(-100%); transition: transform 0.5s cubic-bezier(0.22,1,0.36,1); display: flex; flex-direction: column; }
.mobile-popup.is-open { transform: translateY(0); }
.mobile-popup-top { padding: 12px var(--page-pad-x); }
.mobile-popup-inner { max-width: 1280px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 10px 16px 10px 20px; border-radius: 999px; border: 1px solid var(--outline-light-tertiary); }
.mobile-popup-close { width: 44px; height: 44px; border: 1px solid var(--outline-light-secondary); background: var(--surface-light-primary); border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; cursor: pointer; font-size: 1.2rem; color: var(--font-light-primary); }
.mobile-popup-links { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 28px; padding: 32px; }
.mobile-popup-link { font-family: var(--font-heading); font-size: 1.875rem; font-weight: 700; color: var(--font-light-primary); text-decoration: none; letter-spacing: -0.03em; }
.mobile-popup-cta { padding: 32px; display: flex; flex-direction: column; gap: 12px; }

/* SECTIONS */
section { padding: 96px var(--page-pad-x); position: relative; }
section.section-sm { padding: 64px var(--page-pad-x); }
section.section-lg { padding: 128px var(--page-pad-x); }
.container { max-width: 1200px; margin: 0 auto; position: relative; z-index: 1; }
.container-narrow { max-width: 820px; margin: 0 auto; position: relative; z-index: 1; }
@media (max-width: 767px) { section { padding-top: 72px; padding-bottom: 72px; } section.section-sm { padding-top: 48px; padding-bottom: 48px; } }

/* HAIRLINE SECTION DIVIDER — Pro-Touch */
.section-divider { max-width: 1200px; margin: 0 auto; height: 1px; background: linear-gradient(90deg, transparent, rgba(18,18,18,0.10) 30%, rgba(18,18,18,0.10) 70%, transparent); }

/* DOT GRID BACKGROUND (College/Blog vibe) — als modifier-Klasse pro Section */
.dotgrid { position: relative; }
.dotgrid::before {
  content: ''; position: absolute; inset: 0;
  background-image: radial-gradient(rgba(18,18,18,0.13) 1px, transparent 1px);
  background-size: 22px 22px;
  background-position: 0 0;
  mask-image: radial-gradient(ellipse 75% 70% at 50% 50%, black 25%, transparent 90%);
  -webkit-mask-image: radial-gradient(ellipse 75% 70% at 50% 50%, black 25%, transparent 90%);
  opacity: 0.50;
  pointer-events: none;
  z-index: 0;
}
.dotgrid > * { position: relative; z-index: 1; }
.dotgrid-soft::before { opacity: 0.32; }
.dotgrid-edge::before {
  mask-image: radial-gradient(ellipse 90% 80% at 50% 50%, transparent 30%, black 75%);
  -webkit-mask-image: radial-gradient(ellipse 90% 80% at 50% 50%, transparent 30%, black 75%);
}

.section-eyebrow { display: inline-flex; align-items: center; gap: 10px; padding: 0; border: none; background: transparent; font-family: var(--font-body); font-size: 0.6875rem; font-weight: 600; color: var(--font-light-secondary); letter-spacing: 0.14em; text-transform: uppercase; }
.section-eyebrow::before { content: ''; width: 18px; height: 1px; background: var(--accent-primary); flex-shrink: 0; }
.section-eyebrow i { display: none; }
.section-eyebrow .num { color: var(--accent-primary); font-variant-numeric: tabular-nums; font-weight: 700; }

/* FOOTER */
.footer { background: var(--surface-light-secondary); color: var(--font-light-secondary); padding: 28px var(--page-pad-x); border-top: 1px solid var(--outline-light-tertiary); font-family: var(--font-body); font-size: 0.875rem; }
.footer-row { max-width: 1280px; margin: 0 auto; display: flex; align-items: center; gap: 24px; flex-wrap: wrap; }
.footer-logo-img { display: inline-flex; align-items: center; min-height: 44px; padding: 4px 0; }
.footer-logo-img img { height: 19px; width: auto; display: block; }
@media (max-width: 767px) { .footer-logo-img img { height: 18px; } }
.footer-row a { color: var(--font-light-secondary); text-decoration: none; transition: color 0.25s cubic-bezier(0.16,1,0.3,1); }
.footer-row a:hover { color: var(--font-light-primary); }
.footer-legal { margin-left: auto; display: inline-flex; gap: 22px; align-items: center; font-size: 0.8125rem; flex-wrap: wrap; }
.footer-copy { font-size: 0.8125rem; color: var(--font-light-tertiary); padding-left: 12px; border-left: 1px solid var(--outline-light-tertiary); }
@keyframes livePulse { 0%, 100% { opacity: 1; transform: scale(1); } 50% { opacity: 0.55; transform: scale(0.92); } }

@media (max-width: 767px) {
  .footer { padding-top: 32px; padding-bottom: 32px; }
  .footer-row { flex-direction: column; align-items: center; gap: 20px; text-align: center; }
  .footer-logo-img { min-height: auto; padding: 0; }
  .footer-legal { margin-left: 0; width: auto; justify-content: center; gap: 18px; flex-wrap: wrap; font-size: 0.875rem; }
  .footer-copy { flex-basis: 100%; padding: 12px 0 0; border-left: 0; border-top: 1px solid var(--outline-light-tertiary); margin-top: 4px; font-size: 0.75rem; color: var(--font-light-tertiary); }
}

/* SUBPAGE HERO (für Pricing/Cases/Contact/Legal) */
.subpage-hero { padding: 180px var(--page-pad-x) 64px; position: relative; overflow: hidden; text-align: center; background:
  radial-gradient(ellipse 50% 35% at 50% 8%, rgba(55,150,255,0.10) 0%, transparent 65%),
  radial-gradient(ellipse 35% 22% at 85% 35%, rgba(120,190,255,0.07) 0%, transparent 65%),
  var(--surface-light-primary);
}
.subpage-hero::before { content: ''; position: absolute; inset: 0;
  background-image: radial-gradient(rgba(18,18,18,0.14) 1px, transparent 1px);
  background-size: 22px 22px;
  mask-image: radial-gradient(ellipse 70% 80% at 50% 30%, black 25%, transparent 85%);
  -webkit-mask-image: radial-gradient(ellipse 70% 80% at 50% 30%, black 25%, transparent 85%);
  opacity: 0.45;
  pointer-events: none;
}
.subpage-hero > * { position: relative; z-index: 1; }
.subpage-hero h1 { color: var(--font-light-primary); margin-bottom: 16px; font-size: clamp(1.875rem, 4vw, 2.75rem); }
.subpage-hero .lead { color: var(--font-light-secondary); max-width: 640px; margin: 0 auto; text-wrap: balance; }
@media (max-width: 767px) { .subpage-hero { padding-top: 156px; padding-bottom: 56px; } }

/* SKIP-LINK (A11Y) */
.skip-link { position: absolute; top: -48px; left: 12px; background: var(--font-light-primary); color: var(--font-dark-primary); padding: 10px 18px; z-index: 10000; border-radius: 0 0 8px 8px; text-decoration: none; font-family: var(--font-body); font-size: 0.875rem; font-weight: 600; transition: top 0.2s cubic-bezier(0.16,1,0.3,1); }
.skip-link:focus { top: 0; outline: 2px solid var(--accent-primary); outline-offset: 2px; }

/* TOUCH-TARGETS (WCAG 2.5.8) */
.footer-col a[aria-label], .footer-col a[href^="mailto:"], .footer-col a[href^="tel:"] { min-height: 44px; }

/* COOKIE-BANNER */
.cookie-banner {
  position: fixed; left: 16px; right: 16px; bottom: 16px;
  z-index: 9999;
  max-width: 540px;
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(20px) saturate(1.6);
  -webkit-backdrop-filter: blur(20px) saturate(1.6);
  border: 1px solid var(--outline-light-secondary);
  border-radius: 18px;
  padding: 20px 22px;
  box-shadow: 0 32px 80px -24px rgba(18,18,18,0.22), 0 12px 28px -10px rgba(18,18,18,0.10);
  transform: translateY(120%);
  opacity: 0;
  transition: transform 0.5s cubic-bezier(0.16,1,0.3,1), opacity 0.5s cubic-bezier(0.16,1,0.3,1);
  font-family: var(--font-body);
}
.cookie-banner.is-visible { transform: translateY(0); opacity: 1; }
.cookie-banner h2 { font-family: var(--font-heading); font-size: 1.0625rem; font-weight: 600; color: var(--font-light-primary); letter-spacing: -0.02em; margin-bottom: 6px; }
.cookie-banner p { font-size: 0.8125rem; line-height: 1.55; color: var(--font-light-secondary); margin-bottom: 14px; }
.cookie-banner p a { color: var(--accent-deep); text-decoration: underline; text-underline-offset: 3px; font-weight: 500; }
.cookie-banner p a:hover { text-decoration: underline; }
.cookie-banner-actions { display: flex; flex-wrap: wrap; gap: 8px; }
.cookie-banner button { padding: 10px 18px; border-radius: 999px; font-family: var(--font-body); font-size: 0.8125rem; font-weight: 500; cursor: pointer; border: 1px solid transparent; transition: background 0.2s, color 0.2s, border-color 0.2s, transform 0.2s; }
.cookie-banner .cookie-accept { background: var(--font-light-primary); color: var(--font-dark-primary); }
.cookie-banner .cookie-accept:hover { background: #2A2A2A; }
.cookie-banner .cookie-decline { background: var(--surface-light-primary); color: var(--font-light-primary); border-color: var(--outline-light-secondary); }
.cookie-banner .cookie-decline:hover { background: var(--surface-light-secondary); }

/* MOBILE BACKDROP-FILTER REDUKTION (Performance) */
@media (max-width: 1024px) {
  .glass-light, .glass-dark, .cookie-banner { backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); }
}

/* BUTTONS :active + :disabled */
.btn:active { transform: translateY(0) scale(0.98); transition-duration: 80ms; }
.btn:disabled, .btn[aria-disabled="true"] { opacity: 0.5; cursor: not-allowed; pointer-events: none; }

/* ============================================
   GLOBAL ARROW-ANIMATION (Stripe/Vercel-Detail)
   ============================================ */
.btn i.ti-arrow-right,
.btn i.ti-arrow-up-right,
.v6-cta i,
.v7-buttons .btn i,
.v7-msg .v7-bubble i.ti-arrow-right { transition: transform var(--dur-base) var(--ease-out-spring); }
.btn:hover i.ti-arrow-right,
.btn:hover i.ti-arrow-up-right,
.v6-cta:hover i,
.v7-buttons .btn:hover i,
.v7-msg .v7-bubble:hover i.ti-arrow-right { transform: translateX(4px); }
.v6-cta:hover i.ti-arrow-up-right { transform: translate(3px, -3px); }

/* ============================================
   HEARTBEAT — eine Brand-Pulsation für alle Live-Dots
   ============================================ */
@keyframes heartbeat {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.55; transform: scale(0.92); }
}
@keyframes heartbeat-glow {
  0%, 100% { box-shadow: 0 0 0 0 rgba(var(--accent-warm-rgb), 0.5); opacity: 1; }
  50% { box-shadow: 0 0 0 6px rgba(var(--accent-warm-rgb), 0); opacity: 0.7; }
}
.live-dot, [data-live-dot] {
  animation: heartbeat var(--beat) ease-in-out infinite;
}

/* ============================================
   SCROLL-PROGRESS-HAIRLINE (Premium Long-Scroll Detail)
   ============================================ */
body::before {
  content: '';
  position: fixed; top: 0; left: 0;
  height: 1.5px; width: calc(var(--scroll, 0) * 100%);
  background: linear-gradient(90deg, var(--accent-primary), var(--accent-warm));
  z-index: 9999; pointer-events: none;
  transition: width 0.05s linear;
}

/* ============================================
   BTN LOADING-STATE (Form-Spinner)
   ============================================ */
.btn.is-loading { color: transparent !important; pointer-events: none; position: relative; }
.btn.is-loading::after {
  content: ''; position: absolute; inset: 0; margin: auto; width: 16px; height: 16px;
  border: 2px solid currentColor; border-right-color: transparent; border-radius: 50%;
  color: var(--font-dark-primary); animation: btnSpin 0.7s linear infinite;
}
@keyframes btnSpin { to { transform: rotate(360deg); } }

/* PREFERS-REDUCED-MOTION (Universal) */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}

/* ============================================
   EVENT-TYPE GRID auf index.html
   (Cluster-Section mit 8 Kategorie-Tiles)
   ============================================ */
.evt-section { padding: 96px var(--page-pad-x); background: var(--surface-light-primary); border-top: 1px solid var(--outline-light-tertiary); border-bottom: 1px solid var(--outline-light-tertiary); position: relative; }
.evt-section .container { max-width: 1280px; }
.evt-head { text-align: center; max-width: 720px; margin: 0 auto 48px; }
.evt-head h2 { margin-top: 16px; }
.evt-head h2 .em { color: var(--accent-primary); font-style: italic; font-weight: 700; letter-spacing: -0.02em; }
.evt-head p { color: var(--font-light-secondary); margin-top: 12px; }
.evt-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.evt-tile { display: flex; flex-direction: column; gap: 14px; padding: 26px 24px; background: linear-gradient(180deg, #FFFFFF 0%, #FBFCFE 100%); border: 1px solid rgba(18,18,18,0.08); border-radius: 20px; text-decoration: none; color: inherit; position: relative; overflow: hidden; transition: transform 0.5s var(--ease-out-soft), border-color 0.4s, box-shadow 0.4s; }
.evt-tile::after { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 60% 50% at 50% 0%, rgba(55,150,255,0.10), transparent 70%); opacity: 0; transition: opacity 0.5s; pointer-events: none; }
.evt-tile:hover { transform: translateY(-4px); border-color: rgba(55,150,255,0.30); box-shadow: 0 20px 44px -22px rgba(55,150,255,0.28), 0 4px 12px -6px rgba(18,18,18,0.06); }
.evt-tile:hover::after { opacity: 1; }
.evt-tile > * { position: relative; z-index: 1; }
.evt-tile-icon { width: 44px; height: 44px; border-radius: 12px; background: rgba(55,150,255,0.10); border: 1px solid rgba(55,150,255,0.22); color: var(--accent-primary); display: inline-flex; align-items: center; justify-content: center; font-size: 1.25rem; }
.evt-tile-name { font-family: var(--font-heading); font-size: 1.0625rem; font-weight: 600; letter-spacing: -0.02em; color: var(--font-light-primary); }
.evt-tile-lead { font-family: var(--font-body); font-size: 0.875rem; line-height: 1.5; color: var(--font-light-secondary); flex: 1; }
.evt-tile-cta { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-body); font-size: 0.8125rem; font-weight: 600; color: var(--accent-primary); text-decoration: none; }
.evt-tile-cta i { transition: transform var(--dur-base) var(--ease-out-spring); }
.evt-tile:hover .evt-tile-cta i { transform: translateX(4px); }
@media (max-width: 1024px) { .evt-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 767px) { .evt-grid { grid-template-columns: 1fr; gap: 12px; } .evt-section { padding-top: 64px; padding-bottom: 64px; } }

/* ============================================
   LANDINGPAGE-SHELL (Gästemanagement-Subpages)
   Unter /gaestemanagement/ — gilt für alle 8 Kategorien
   ============================================ */

/* Hero */
.gm-hero { padding: 144px var(--page-pad-x) 72px; position: relative; overflow: hidden; background:
  radial-gradient(ellipse 50% 35% at 50% 0%, rgba(55,150,255,0.10) 0%, transparent 65%),
  radial-gradient(ellipse 35% 22% at 85% 25%, rgba(216,178,107,0.08) 0%, transparent 65%),
  var(--surface-light-primary);
}
.gm-hero::before { content: ''; position: absolute; inset: 0; background-image: radial-gradient(rgba(18,18,18,0.13) 1px, transparent 1px); background-size: 22px 22px; mask-image: radial-gradient(ellipse 70% 80% at 50% 30%, black 25%, transparent 85%); -webkit-mask-image: radial-gradient(ellipse 70% 80% at 50% 30%, black 25%, transparent 85%); opacity: 0.45; pointer-events: none; }
.gm-hero-grid { max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: 1.15fr 0.85fr; gap: 56px; align-items: center; position: relative; z-index: 1; }
.gm-hero h1 { font-family: var(--font-heading); font-size: clamp(2rem, 4.4vw, 3.4rem); font-weight: 700; line-height: 1.05; letter-spacing: -0.035em; color: var(--font-light-primary); margin: 18px 0 18px; text-wrap: balance; }
.gm-hero h1 .em { color: var(--accent-primary); }
.gm-hero .lead { font-family: var(--font-body); font-size: 1.0625rem; line-height: 1.55; color: var(--font-light-secondary); max-width: 560px; margin-bottom: 28px; }
.gm-hero .ctas { display: flex; gap: 12px; flex-wrap: wrap; }
.gm-hero .ctas .btn i { font-size: 1rem; }
.gm-hero-visual { position: relative; min-height: 320px; display: flex; align-items: center; justify-content: center; }
.gm-event-card { width: 100%; max-width: 380px; background: linear-gradient(180deg, #FFFFFF 0%, #F8FBFF 100%); border: 1px solid rgba(18,18,18,0.08); border-radius: 22px; padding: 26px; box-shadow: 0 32px 80px -36px rgba(55,150,255,0.32), 0 8px 24px -10px rgba(18,18,18,0.06); position: relative; overflow: hidden; }
.gm-event-card::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 60% 40% at 50% 0%, rgba(55,150,255,0.10), transparent 70%); pointer-events: none; }
.gm-event-card-head { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; position: relative; z-index: 1; }
.gm-event-card-icon { width: 44px; height: 44px; border-radius: 12px; background: rgba(55,150,255,0.10); border: 1px solid rgba(55,150,255,0.22); color: var(--accent-primary); display: inline-flex; align-items: center; justify-content: center; font-size: 1.3rem; flex-shrink: 0; }
.gm-event-card-title { font-family: var(--font-heading); font-size: 0.95rem; font-weight: 600; color: var(--font-light-primary); letter-spacing: -0.01em; }
.gm-event-card-sub { font-family: var(--font-body); font-size: 0.78rem; color: var(--font-light-tertiary); }
.gm-event-card-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; padding-top: 18px; border-top: 1px solid rgba(18,18,18,0.06); position: relative; z-index: 1; }
.gm-event-card-stat { display: flex; flex-direction: column; gap: 3px; }
.gm-event-card-stat .num { font-family: var(--font-heading); font-size: 1.35rem; font-weight: 700; letter-spacing: -0.02em; color: var(--font-light-primary); font-variant-numeric: tabular-nums; }
.gm-event-card-stat .lbl { font-family: var(--font-body); font-size: 0.72rem; color: var(--font-light-secondary); letter-spacing: 0.02em; }
.gm-event-card-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 14px; padding-top: 14px; border-top: 1px dashed rgba(18,18,18,0.08); position: relative; z-index: 1; font-family: var(--font-body); font-size: 0.78rem; color: var(--font-light-secondary); }
.gm-event-card-pill { display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px; border-radius: 999px; background: rgba(34,197,94,0.10); color: #15803D; border: 1px solid rgba(34,197,94,0.20); font-weight: 600; font-size: 0.7rem; }
.gm-event-card-pill i { font-size: 0.85rem; }
@media (max-width: 1024px) {
  .gm-hero { padding-top: 130px; padding-bottom: 56px; }
  .gm-hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .gm-hero-visual { min-height: 0; }
}
@media (max-width: 767px) {
  .gm-hero { padding-top: 116px; padding-bottom: 48px; }
  .gm-hero .lead { font-size: 1rem; }
}

/* Trust-Stripe (Logo-Marquee, gleiche Engine wie auf der Homepage) */
.gm-trust { padding: 56px 0; background: var(--surface-light-secondary); border-top: 1px solid var(--outline-light-tertiary); border-bottom: 1px solid var(--outline-light-tertiary); }
.gm-trust-eyebrow { text-align: center; font-family: var(--font-body); font-size: 0.7rem; font-weight: 600; color: var(--font-light-tertiary); letter-spacing: 0.16em; text-transform: uppercase; margin-bottom: 22px; }
.gm-trust .veltric-logo-marquee { max-width: 1280px; margin: 0 auto; }

/* Veltric Logo-Marquee (shared für Homepage und Landingpages) */
.veltric-logo-marquee { width: 100%; padding: 22px 0; }
.veltric-logo-marquee__viewport { width: 100%; overflow: hidden; mask-image: linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%); -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%); }
.veltric-logo-marquee__track { display: flex; align-items: center; gap: 0; width: max-content; will-change: transform; transform: translate3d(0,0,0); animation: veltricMarqueeMove var(--veltricDuration, 18s) linear infinite; animation-play-state: running; }
.veltric-logo-marquee__group { display: flex; align-items: center; gap: 56px; padding-right: 56px; width: max-content; }
.veltric-logo-marquee__item { display: flex; align-items: center; justify-content: center; height: 24px; text-decoration: none; }
.veltric-logo-marquee__item img { height: 100%; width: auto; display: block; object-fit: contain; filter: grayscale(100%) brightness(.85); opacity: .9; transition: filter .25s ease, opacity .25s ease, transform .25s ease; }
.veltric-logo-marquee__item:hover img { filter: grayscale(0%) brightness(1); opacity: 1; transform: translateY(-1px); }
@keyframes veltricMarqueeMove { from { transform: translate3d(0,0,0); } to { transform: translate3d(calc(-1px * var(--veltricMove, 0)),0,0); } }
@media (max-width: 768px) { .veltric-logo-marquee { padding: 16px 0; } .veltric-logo-marquee__group { gap: 34px; padding-right: 34px; } .veltric-logo-marquee__item { height: 20px; } }
@media (prefers-reduced-motion: reduce) { .veltric-logo-marquee__track { animation: none; transform: none; } }

/* Pain-Cards */
.gm-pain { padding: 96px var(--page-pad-x); }
.gm-pain .container { max-width: 1200px; }
.gm-pain-head { max-width: 760px; margin: 0 auto 48px; text-align: center; }
.gm-pain-head h2 { margin-top: 16px; }
.gm-pain-head p { color: var(--font-light-secondary); margin-top: 12px; }
.gm-pain-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.gm-pain-card { padding: 28px 26px; background: var(--surface-light-primary); border: 1px solid rgba(18,18,18,0.08); border-radius: 20px; display: flex; flex-direction: column; gap: 12px; transition: transform 0.4s var(--ease-out-soft), border-color 0.4s, box-shadow 0.4s; }
.gm-pain-card:hover { transform: translateY(-3px); border-color: rgba(216,178,107,0.45); box-shadow: 0 20px 44px -22px rgba(216,178,107,0.28), 0 4px 12px -6px rgba(18,18,18,0.06); }
.gm-pain-card .num { display: inline-flex; width: 32px; height: 32px; align-items: center; justify-content: center; border-radius: 999px; background: rgba(216,178,107,0.14); color: #8B6F2E; border: 1px solid rgba(216,178,107,0.34); font-family: var(--font-heading); font-size: 0.85rem; font-weight: 700; font-variant-numeric: tabular-nums; }
.gm-pain-card h3 { font-family: var(--font-heading); font-size: 1.0625rem; font-weight: 600; letter-spacing: -0.018em; color: var(--font-light-primary); }
.gm-pain-card p { font-family: var(--font-body); font-size: 0.9rem; line-height: 1.55; color: var(--font-light-secondary); }
@media (max-width: 1024px) { .gm-pain-grid { grid-template-columns: 1fr; } }
@media (max-width: 767px) { .gm-pain { padding-top: 64px; padding-bottom: 64px; } }

/* Feature-Cards */
.gm-features { padding: 96px var(--page-pad-x); background: var(--surface-light-secondary); border-top: 1px solid var(--outline-light-tertiary); border-bottom: 1px solid var(--outline-light-tertiary); }
.gm-features .container { max-width: 1200px; }
.gm-features-head { max-width: 760px; margin: 0 auto 48px; text-align: center; }
.gm-features-head h2 { margin-top: 16px; }
.gm-features-head p { color: var(--font-light-secondary); margin-top: 12px; }
.gm-features-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.gm-feature-card { padding: 28px 24px; background: var(--surface-light-primary); border: 1px solid rgba(18,18,18,0.08); border-radius: 20px; display: flex; flex-direction: column; gap: 12px; transition: transform 0.4s var(--ease-out-soft), border-color 0.4s, box-shadow 0.4s; position: relative; overflow: hidden; }
.gm-feature-card::after { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 60% 50% at 50% 0%, rgba(55,150,255,0.08), transparent 70%); opacity: 0; transition: opacity 0.5s; pointer-events: none; }
.gm-feature-card:hover { transform: translateY(-3px); border-color: rgba(55,150,255,0.30); box-shadow: 0 20px 44px -22px rgba(55,150,255,0.28), 0 4px 12px -6px rgba(18,18,18,0.06); }
.gm-feature-card:hover::after { opacity: 1; }
.gm-feature-card > * { position: relative; z-index: 1; }
.gm-feature-card .icon { width: 42px; height: 42px; border-radius: 12px; background: rgba(55,150,255,0.10); border: 1px solid rgba(55,150,255,0.22); color: var(--accent-primary); display: inline-flex; align-items: center; justify-content: center; font-size: 1.2rem; }
.gm-feature-card h3 { font-family: var(--font-heading); font-size: 1rem; font-weight: 600; letter-spacing: -0.018em; color: var(--font-light-primary); }
.gm-feature-card p { font-family: var(--font-body); font-size: 0.875rem; line-height: 1.55; color: var(--font-light-secondary); }
@media (max-width: 1024px) { .gm-features-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 767px) { .gm-features-grid { grid-template-columns: 1fr; } .gm-features { padding-top: 64px; padding-bottom: 64px; } }

/* Workflow */
.gm-flow { padding: 96px var(--page-pad-x); }
.gm-flow .container { max-width: 1200px; }
.gm-flow-head { max-width: 760px; margin: 0 auto 48px; text-align: center; }
.gm-flow-head h2 { margin-top: 16px; }
.gm-flow-head p { color: var(--font-light-secondary); margin-top: 12px; }
.gm-flow-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; position: relative; }
.gm-flow-step { padding: 28px 26px; background: var(--surface-light-primary); border: 1px solid rgba(18,18,18,0.08); border-radius: 20px; display: flex; flex-direction: column; gap: 14px; position: relative; }
.gm-flow-step .stepnum { display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-body); font-size: 0.7rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent-primary); }
.gm-flow-step .stepnum::before { content: ''; width: 28px; height: 1px; background: var(--accent-primary); }
.gm-flow-step h3 { font-family: var(--font-heading); font-size: 1.0625rem; font-weight: 600; letter-spacing: -0.018em; color: var(--font-light-primary); }
.gm-flow-step p { font-family: var(--font-body); font-size: 0.9rem; line-height: 1.55; color: var(--font-light-secondary); }
.gm-flow-step ul { list-style: none; display: flex; flex-direction: column; gap: 8px; padding-top: 12px; margin-top: 4px; border-top: 1px dashed rgba(18,18,18,0.08); }
.gm-flow-step li { display: flex; align-items: flex-start; gap: 8px; font-family: var(--font-body); font-size: 0.8125rem; color: var(--font-light-primary); }
.gm-flow-step li i { color: var(--accent-primary); font-size: 0.95rem; flex-shrink: 0; margin-top: 2px; }
@media (max-width: 1024px) { .gm-flow-steps { grid-template-columns: 1fr; } }
@media (max-width: 767px) { .gm-flow { padding-top: 64px; padding-bottom: 64px; } }

/* FAQ */
.gm-faq { padding: 96px var(--page-pad-x); background: var(--surface-light-secondary); border-top: 1px solid var(--outline-light-tertiary); border-bottom: 1px solid var(--outline-light-tertiary); }
.gm-faq .container-narrow { max-width: 820px; }
.gm-faq-head { text-align: center; margin-bottom: 40px; }
.gm-faq-head h2 { margin-top: 16px; }
.gm-faq-list { display: flex; flex-direction: column; gap: 12px; }
.gm-faq-item { background: var(--surface-light-primary); border: 1px solid rgba(18,18,18,0.08); border-radius: 16px; overflow: hidden; transition: border-color 0.3s, box-shadow 0.3s; }
.gm-faq-item[open] { border-color: rgba(55,150,255,0.30); box-shadow: 0 12px 32px -16px rgba(55,150,255,0.20); }
.gm-faq-item summary { list-style: none; padding: 20px 24px; display: flex; align-items: center; justify-content: space-between; gap: 16px; cursor: pointer; font-family: var(--font-heading); font-size: 1rem; font-weight: 600; color: var(--font-light-primary); letter-spacing: -0.015em; }
.gm-faq-item summary::-webkit-details-marker { display: none; }
.gm-faq-item summary::after { content: ''; width: 16px; height: 16px; flex-shrink: 0; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%233796FF' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: center; background-size: 16px; transition: transform 0.3s var(--ease-out-soft); }
.gm-faq-item[open] summary::after { transform: rotate(180deg); }
.gm-faq-item .gm-faq-body { padding: 0 24px 22px; font-family: var(--font-body); font-size: 0.9375rem; line-height: 1.6; color: var(--font-light-secondary); }
@media (max-width: 767px) { .gm-faq { padding-top: 64px; padding-bottom: 64px; } .gm-faq-item summary { padding: 18px 18px; font-size: 0.9375rem; } .gm-faq-item .gm-faq-body { padding: 0 18px 20px; } }

/* Cross-Links */
.gm-cross { padding: 96px var(--page-pad-x); }
.gm-cross .container { max-width: 1200px; }
.gm-cross-head { max-width: 720px; margin: 0 auto 36px; text-align: center; }
.gm-cross-head h2 { margin-top: 16px; }
.gm-cross-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
@media (max-width: 1024px) { .gm-cross-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 767px) { .gm-cross-grid { grid-template-columns: 1fr; } .gm-cross { padding-top: 64px; padding-bottom: 64px; } }

/* Final CTA */
.gm-cta { padding: 96px var(--page-pad-x) 128px; }
.gm-cta-block { max-width: 880px; margin: 0 auto; background: var(--surface-dark-primary); color: var(--font-dark-primary); border-radius: 32px; padding: 64px 56px; text-align: center; position: relative; overflow: hidden; }
.gm-cta-block::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 80% 60% at 50% 50%, rgba(55,150,255,0.20), transparent 70%); pointer-events: none; }
.gm-cta-block h2 { color: var(--font-dark-primary); margin-bottom: 16px; position: relative; z-index: 1; }
.gm-cta-block p { color: var(--font-dark-secondary); position: relative; z-index: 1; max-width: 560px; margin: 0 auto 32px; }
.gm-cta-block .cta-row { display: flex; justify-content: center; gap: 12px; flex-wrap: wrap; position: relative; z-index: 1; }
@media (max-width: 767px) { .gm-cta { padding-top: 64px; padding-bottom: 96px; } .gm-cta-block { padding: 48px 28px; border-radius: 24px; } }
