/* ═══════════════════════════════════════════════════════════
   NordPrax Design System — nordprax-design.css
   Einheitliches Fundament für alle NordPrax-Portale.
   Pfad: /_np/nordprax-design.css
   ═══════════════════════════════════════════════════════════ */

/* ── Self-hosted Inter (kein Google Fonts CDN) ── */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url('/_np/fonts/inter-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url('/_np/fonts/inter-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* ── Design Tokens ── */
:root {
  /* Farben — einheitlich */
  --np-primary: #279989;
  --np-primary-dark: #1d7a6d;
  --np-primary-deep: #155e54;
  --np-primary-light: #e8f5f3;
  --np-primary-ghost: rgba(39,153,137,.08);

  --np-bg: #f4f4f4;
  --np-card: #ffffff;
  --np-text: #1a2b2a;
  --np-muted: #5f7a77;
  --np-border: #d4dedd;
  --np-line: rgba(26,43,42,.10);

  --np-danger: #dc3545;
  --np-danger-light: #fef2f2;
  --np-warning: #f59e0b;
  --np-warning-light: #fffbeb;
  --np-success: #22c55e;
  --np-success-light: #f0fdf4;

  /* Typografie */
  --np-font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  --np-mono: ui-monospace, 'Cascadia Code', 'JetBrains Mono', monospace;

  /* Spacing (4px Raster) */
  --np-1: 4px;
  --np-2: 8px;
  --np-3: 12px;
  --np-4: 16px;
  --np-5: 20px;
  --np-6: 24px;
  --np-8: 32px;
  --np-10: 40px;
  --np-12: 48px;

  /* Radii */
  --np-radius-sm: 6px;
  --np-radius: 10px;
  --np-radius-lg: 16px;
  --np-radius-xl: 20px;
  --np-radius-full: 999px;

  /* Shadows */
  --np-shadow-sm: 0 1px 2px rgba(0,0,0,.05);
  --np-shadow: 0 2px 8px rgba(0,0,0,.08);
  --np-shadow-md: 0 4px 16px rgba(0,0,0,.10);
  --np-shadow-lg: 0 12px 40px rgba(0,0,0,.12);

  /* Motion */
  --np-fast: 80ms;
  --np-normal: 180ms;
  --np-slow: 320ms;
  --np-ease: cubic-bezier(.25,.1,.25,1);

  /* Nav */
  --np-nav-h: 56px;
}

/* ── Dark Mode ── */
[data-theme="dark"] {
  --np-bg: #0a1614;
  --np-card: rgba(14,30,26,.92);
  --np-text: #e4f0ed;
  --np-muted: rgba(228,240,237,.60);
  --np-border: rgba(228,240,237,.12);
  --np-line: rgba(228,240,237,.10);
  --np-shadow-sm: 0 1px 2px rgba(0,0,0,.20);
  --np-shadow: 0 2px 8px rgba(0,0,0,.30);
  --np-shadow-md: 0 4px 16px rgba(0,0,0,.35);
  --np-shadow-lg: 0 12px 40px rgba(0,0,0,.45);
}

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; }
body {
  margin: 0;
  font-family: var(--np-font);
  background: var(--np-bg);
  color: var(--np-text);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ── Accessibility ── */
:focus-visible {
  outline: 3px solid var(--np-primary);
  outline-offset: 2px;
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

/* ══════════════════════════════════════
   Top-Navigation (Portal-Leiste)
   ══════════════════════════════════════ */
.np-nav {
  position: sticky;
  top: 0;
  z-index: 200;
  background: var(--np-card);
  border-bottom: 2px solid var(--np-primary);
  box-shadow: var(--np-shadow);
  height: var(--np-nav-h);
}
.np-nav-inner {
  max-width: 1200px;
  margin: 0 auto;
  height: 100%;
  display: flex;
  align-items: center;
  gap: var(--np-3);
  padding: 0 var(--np-5);
}

/* Brand */
.np-nav-brand {
  display: flex;
  align-items: center;
  gap: var(--np-2);
  text-decoration: none;
  color: var(--np-text);
  flex-shrink: 0;
  margin-right: var(--np-4);
}
.np-nav-brand img {
  height: 24px;
  width: auto;
}
.np-nav-brand span {
  font-weight: 700;
  font-size: 15px;
  letter-spacing: .01em;
}

/* Portal-Links */
.np-nav-links {
  display: flex;
  align-items: center;
  gap: var(--np-1);
}
.np-nav-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: var(--np-radius-sm);
  text-decoration: none;
  font-size: 13px;
  font-weight: 500;
  color: var(--np-muted);
  transition: background var(--np-fast), color var(--np-fast);
  white-space: nowrap;
}
.np-nav-link:hover {
  background: var(--np-primary-ghost);
  color: var(--np-primary-dark);
}
.np-nav-link[aria-current="page"],
.np-nav-link.active {
  background: var(--np-primary-light);
  color: var(--np-primary-dark);
  font-weight: 600;
}
.np-nav-link .np-ext {
  font-size: 10px;
  opacity: .6;
}

/* Rechte Seite (User, Theme, etc) */
.np-nav-right {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: var(--np-2);
}

/* Mobile: Links ausblenden, Hamburger zeigen */
@media (max-width: 640px) {
  .np-nav-links { display: none; }
  .np-nav-hamburger { display: flex; }
}
@media (min-width: 641px) {
  .np-nav-hamburger { display: none; }
}

/* ══════════════════════════════════════
   Layout
   ══════════════════════════════════════ */
.np-wrap {
  max-width: 1000px;
  margin: 0 auto;
  padding: var(--np-5);
}
.np-wrap--narrow { max-width: 720px; }
.np-wrap--wide { max-width: 1200px; }

/* ══════════════════════════════════════
   Grid
   ══════════════════════════════════════ */
.np-grid {
  display: grid;
  gap: var(--np-4);
}
.np-grid--2 { grid-template-columns: 1fr 1fr; }
.np-grid--3 { grid-template-columns: repeat(3, 1fr); }
.np-grid--4 { grid-template-columns: repeat(4, 1fr); }
.np-grid--auto { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }

@media (max-width: 1024px) {
  .np-grid--3, .np-grid--4 { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .np-grid--2, .np-grid--3, .np-grid--4 { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════
   Cards
   ══════════════════════════════════════ */
.np-card {
  background: var(--np-card);
  border: 1px solid var(--np-border);
  border-radius: var(--np-radius-lg);
  box-shadow: var(--np-shadow);
  padding: var(--np-5);
}
.np-card h2,
.np-card h3 {
  margin: 0 0 var(--np-2) 0;
  font-weight: 700;
}
.np-card p {
  margin: 0 0 var(--np-2) 0;
  font-size: 13px;
  color: var(--np-muted);
  line-height: 1.5;
}

/* Klickbare Karte */
a.np-card {
  text-decoration: none;
  color: inherit;
  transition: transform var(--np-normal) var(--np-ease),
              box-shadow var(--np-normal) var(--np-ease),
              border-color var(--np-normal) var(--np-ease);
}
a.np-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--np-shadow-lg);
  border-color: var(--np-primary);
}

/* ══════════════════════════════════════
   Buttons
   ══════════════════════════════════════ */
.np-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 8px 16px;
  border-radius: var(--np-radius);
  border: 1px solid var(--np-border);
  background: var(--np-card);
  color: var(--np-text);
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  transition: background var(--np-fast), border-color var(--np-fast), transform var(--np-fast);
}
.np-btn:hover { background: #f0f0f0; }
.np-btn:active { transform: translateY(1px); }

.np-btn--primary {
  background: var(--np-primary);
  border-color: var(--np-primary-dark);
  color: #fff;
}
.np-btn--primary:hover { background: var(--np-primary-dark); }

.np-btn--ghost {
  background: transparent;
  border-color: transparent;
  color: var(--np-muted);
}
.np-btn--ghost:hover {
  background: var(--np-primary-ghost);
  color: var(--np-primary-dark);
}

/* ══════════════════════════════════════
   Badges / Pills
   ══════════════════════════════════════ */
.np-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: var(--np-radius-full);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .02em;
}
.np-badge--primary {
  background: var(--np-primary-light);
  color: var(--np-primary-dark);
  border: 1px solid #c6ede6;
}
.np-badge--success {
  background: var(--np-success-light);
  color: #16a34a;
  border: 1px solid #86efac;
}
.np-badge--danger {
  background: var(--np-danger-light);
  color: var(--np-danger);
  border: 1px solid #fca5a5;
}
.np-badge--muted {
  background: #f5f5f5;
  color: var(--np-muted);
  border: 1px solid var(--np-border);
}

/* ══════════════════════════════════════
   Icon-Kasten (Portal-Karten)
   ══════════════════════════════════════ */
.np-icon-box {
  width: 52px;
  height: 52px;
  border-radius: var(--np-radius);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: transform var(--np-normal) var(--np-ease);
}
.np-icon-box svg {
  width: 24px;
  height: 24px;
  stroke-width: 1.8;
  fill: none;
  stroke: currentColor;
}
a.np-card:hover .np-icon-box { transform: scale(1.08) rotate(-2deg); }

.np-icon-box--teal    { background: linear-gradient(135deg, #e8f5f3, #c6ede6); color: var(--np-primary-dark); }
.np-icon-box--purple  { background: linear-gradient(135deg, #ede8f5, #d6c6ed); color: #6b4d9e; }
.np-icon-box--blue    { background: linear-gradient(135deg, #e8eef5, #c6d6ed); color: #4d6d9e; }
.np-icon-box--amber   { background: linear-gradient(135deg, #f5ede8, #edd6c6); color: #9e6b4d; }

/* ══════════════════════════════════════
   Hero Section (Landing)
   ══════════════════════════════════════ */
.np-hero {
  text-align: center;
  padding: var(--np-12) var(--np-5) var(--np-8);
  animation: np-fadeUp .4s var(--np-ease);
}
.np-hero h1 {
  font-size: clamp(26px, 4vw, 44px);
  font-weight: 800;
  color: var(--np-primary-deep);
  line-height: 1.15;
  margin: 0 0 var(--np-3);
  letter-spacing: -.02em;
}
.np-hero h1 em {
  font-style: normal;
  color: var(--np-primary);
}
.np-hero p {
  font-size: clamp(14px, 1.8vw, 17px);
  color: var(--np-muted);
  max-width: 520px;
  margin: 0 auto;
  line-height: 1.6;
}

@keyframes np-fadeUp {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ══════════════════════════════════════
   Section Titles
   ══════════════════════════════════════ */
.np-section-title {
  font-size: 12px;
  font-weight: 700;
  color: var(--np-muted);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin: 0 0 var(--np-3);
}

/* ══════════════════════════════════════
   Status Dot (pulsierend)
   ══════════════════════════════════════ */
.np-status-dot {
  width: 8px;
  height: 8px;
  background: var(--np-success);
  border-radius: 50%;
  display: inline-block;
  margin-right: 6px;
  animation: np-pulse 2s ease-in-out infinite;
}
@keyframes np-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: .5; transform: scale(.85); }
}

/* ══════════════════════════════════════
   Footer
   ══════════════════════════════════════ */
.np-footer {
  text-align: center;
  padding: var(--np-5);
  font-size: 12px;
  color: var(--np-muted);
}
.np-footer a {
  color: var(--np-primary-dark);
  text-decoration: none;
}
.np-footer a:hover { text-decoration: underline; }

/* ══════════════════════════════════════
   Info-Cards (Systemstatus etc.)
   ══════════════════════════════════════ */
.np-info-card {
  background: var(--np-card);
  border: 1px solid var(--np-border);
  border-radius: var(--np-radius);
  padding: var(--np-5);
  box-shadow: var(--np-shadow-sm);
}
.np-info-card h4 {
  font-size: 14px;
  font-weight: 700;
  color: var(--np-primary-dark);
  margin: 0 0 var(--np-2);
  display: flex;
  align-items: center;
  gap: var(--np-2);
}
.np-info-card p,
.np-info-card li {
  font-size: 13px;
  color: var(--np-muted);
  line-height: 1.6;
}
.np-info-card ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.np-info-card li {
  padding: var(--np-1) 0;
  padding-left: 18px;
  position: relative;
}
.np-info-card li::before {
  content: '\203A';
  position: absolute;
  left: 0;
  color: var(--np-primary);
  font-weight: 700;
}

/* ══════════════════════════════════════
   Ambient Background (Orbs, Dots, Lines)
   Klasse .np-ambient auf <body> aktiviert den Effekt.
   ══════════════════════════════════════ */
.np-ambient {
  background: linear-gradient(180deg, #e8f5f3 0%, #f0f8f6 30%, var(--np-bg) 100%);
  overflow-x: hidden;
}
.np-ambient::before {
  content: ''; position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(ellipse at 20% 80%, rgba(39,153,137,.22) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 20%, rgba(21,119,155,.18) 0%, transparent 50%),
    radial-gradient(ellipse at 50% 50%, rgba(39,153,137,.10) 0%, transparent 70%);
  animation: np-ambient-bg 20s ease-in-out infinite alternate;
  filter: blur(6px);
}
@keyframes np-ambient-bg {
  0%   { transform: scale(1)    translate(0,0); }
  33%  { transform: scale(1.06) translate(-2%,1%); }
  66%  { transform: scale(1.03) translate(1.5%,-1.5%); }
  100% { transform: scale(1.02) translate(.5%,.5%); }
}

/* Orbs */
.np-orb {
  position: fixed; border-radius: 50%; z-index: 0; pointer-events: none;
  filter: blur(clamp(30px, 5vmin, 60px));
}
.np-orb-1 {
  width: clamp(280px, 38vmin, 600px); height: clamp(280px, 38vmin, 600px);
  top: -10vmin; right: -8vmin;
  background: radial-gradient(ellipse at 40% 40%, rgba(39,153,137,.35) 0%, rgba(21,119,155,.18) 50%, transparent 70%);
  animation: np-orb1 22s ease-in-out infinite alternate;
}
.np-orb-2 {
  width: clamp(240px, 32vmin, 500px); height: clamp(240px, 32vmin, 500px);
  bottom: -8vmin; left: -6vmin;
  background: radial-gradient(ellipse at 60% 60%, rgba(21,119,155,.32) 0%, rgba(39,153,137,.14) 50%, transparent 70%);
  animation: np-orb2 28s ease-in-out infinite alternate;
}
.np-orb-3 {
  width: clamp(180px, 22vmin, 340px); height: clamp(180px, 22vmin, 340px);
  top: 28%; left: 3%;
  background: radial-gradient(ellipse at 50% 50%, rgba(39,153,137,.24) 0%, transparent 70%);
  animation: np-orb3 18s ease-in-out infinite alternate;
}
.np-orb-4 {
  width: clamp(120px, 15vmin, 240px); height: clamp(120px, 15vmin, 240px);
  bottom: 15%; right: 8%;
  background: radial-gradient(ellipse at 50% 50%, rgba(21,119,155,.20) 0%, transparent 70%);
  animation: np-orb3 24s ease-in-out infinite alternate-reverse;
}
@keyframes np-orb1 {
  0%   { transform: translate(0,0) scale(1); }
  50%  { transform: translate(3vmin,-2vmin) scale(1.10); }
  100% { transform: translate(-2vmin,2vmin) scale(.93); }
}
@keyframes np-orb2 {
  0%   { transform: translate(0,0) scale(1); }
  50%  { transform: translate(-2vmin,1.5vmin) scale(1.12); }
  100% { transform: translate(2vmin,-2.5vmin) scale(.90); }
}
@keyframes np-orb3 {
  0%   { transform: translate(0,0) scale(1); opacity: .8; }
  50%  { transform: translate(1.5vmin,2vmin) scale(1.15); opacity: 1; }
  100% { transform: translate(-1vmin,-1.5vmin) scale(.88); opacity: .7; }
}

/* Dots */
.np-dot {
  position: fixed; width: 6px; height: 6px; border-radius: 50%;
  background: var(--np-primary); opacity: .25; z-index: 0; pointer-events: none;
}
.np-dot:nth-child(n+5):nth-child(-n+8) { animation: np-dot-pulse 3s ease-in-out infinite; }
.np-dot:nth-child(5) { top: 12%; left: 18%; }
.np-dot:nth-child(6) { top: 65%; right: 12%; animation-delay: .5s; animation-duration: 4s; }
.np-dot:nth-child(7) { top: 38%; right: 28%; animation-delay: 1s; animation-duration: 3.5s; }
.np-dot:nth-child(8) { bottom: 22%; left: 32%; animation-delay: 1.5s; animation-duration: 4.5s; }
@keyframes np-dot-pulse {
  0%,100% { opacity: .12; transform: scale(1); }
  50%     { opacity: .40; transform: scale(3); }
}

/* Sweep Lines */
.np-lines { position: fixed; inset: 0; z-index: 0; pointer-events: none; overflow: hidden; }
.np-line {
  position: absolute; left: -10%; width: 120%; height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(39,153,137,.10) 15%, rgba(39,153,137,.38) 48%, rgba(21,119,155,.22) 72%, transparent 100%);
  animation: np-line-sweep linear infinite;
}
.np-line:nth-child(1) { top: 18%; rotate: -1.5deg; animation-duration: 9s; }
.np-line:nth-child(2) { top: 42%; rotate: 1deg; animation-duration: 13s; animation-delay: -3s; height: 1.5px; opacity: .75; }
.np-line:nth-child(3) { top: 63%; rotate: -.8deg; animation-duration: 11s; animation-delay: -6s; }
@keyframes np-line-sweep {
  0%   { translate: -120% 0; opacity: 0; }
  6%   { opacity: 1; }
  90%  { opacity: 1; }
  100% { translate: 120% 0; opacity: 0; }
}

/* Content über Ambient-Elementen: alle direkten Body-Kinder über Orbs heben */
.np-ambient > *:not(.np-orb):not(.np-dot):not(.np-lines) {
  position: relative;
  z-index: 1;
}

/* Dark Mode Ambient */
[data-theme="dark"] .np-ambient {
  background: linear-gradient(180deg, #0a1614 0%, #0c1e1a 30%, var(--np-bg) 100%);
}
[data-theme="dark"] .np-ambient::before {
  background:
    radial-gradient(ellipse at 20% 80%, rgba(39,153,137,.15) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 20%, rgba(21,119,155,.12) 0%, transparent 50%),
    radial-gradient(ellipse at 50% 50%, rgba(39,153,137,.06) 0%, transparent 70%);
}
[data-theme="dark"] .np-orb-1 { background: radial-gradient(ellipse at 40% 40%, rgba(39,153,137,.20) 0%, rgba(21,119,155,.10) 50%, transparent 70%); }
[data-theme="dark"] .np-orb-2 { background: radial-gradient(ellipse at 60% 60%, rgba(21,119,155,.18) 0%, rgba(39,153,137,.08) 50%, transparent 70%); }
[data-theme="dark"] .np-orb-3 { background: radial-gradient(ellipse at 50% 50%, rgba(39,153,137,.14) 0%, transparent 70%); }
[data-theme="dark"] .np-orb-4 { background: radial-gradient(ellipse at 50% 50%, rgba(21,119,155,.12) 0%, transparent 70%); }
[data-theme="dark"] .np-dot { background: #4db8a8; opacity: .20; }
[data-theme="dark"] .np-line {
  background: linear-gradient(90deg, transparent 0%, rgba(39,153,137,.06) 15%, rgba(39,153,137,.22) 48%, rgba(21,119,155,.14) 72%, transparent 100%);
}

/* Ambient bei reduced-motion deaktivieren */
@media (prefers-reduced-motion: reduce) {
  .np-ambient::before, .np-orb, .np-dot, .np-line { animation: none !important; opacity: .5 !important; }
}

/* ══════════════════════════════════════
   Utilities
   ══════════════════════════════════════ */
.np-muted { color: var(--np-muted); }
.np-text-center { text-align: center; }
.np-sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }

/* ══════════════════════════════════════
   Touch-Optimierung
   ══════════════════════════════════════ */
@media (pointer: coarse) {
  .np-btn,
  .np-nav-link,
  a.np-card { min-height: 44px; }
  .np-nav-link { padding: 10px 14px; }
}

/* ══════════════════════════════════════
   Print
   ══════════════════════════════════════ */
@media print {
  .np-nav, .np-footer { display: none; }
  body { background: #fff; }
  .np-card { box-shadow: none; border: 1px solid #ccc; }
}
