/* ═══════════════════════════════════════════════════════════
   NordPrax Portal Shell — portal-shell.css
   Layout für alle Frontend-Portale (lp-* Klassen).
   Benötigt /_np/nordprax-design.css für --np-* Variablen.
   ═══════════════════════════════════════════════════════════ */

:root {
  --ps-sidebar-w: 240px;
  --ps-header-h: 64px;
}

/* ── Body ── */
body { margin: 0; background: #dff0ed; }
[data-theme="dark"] body { background: #0d1b2a; }
#bg-canvas {
  position: fixed; inset: 0; z-index: 0;
  width: 100%; height: 100%;
  pointer-events: none; display: block;
}

/* ═══════════════════════════════════════════════════════════
   HEADER
   ═══════════════════════════════════════════════════════════ */
.lp-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 200;
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border-bottom: 2px solid var(--np-primary, #279989);
  box-shadow: 0 1px 8px rgba(0,0,0,.08);
}
[data-theme="dark"] .lp-header {
  background: rgba(13,27,42,.88);
}
.lp-header-inner {
  padding: 0 20px;
  height: var(--ps-header-h);
  display: flex; align-items: center; gap: 12px;
}
.lp-logo {
  display: flex; align-items: center; text-decoration: none; flex-shrink: 0;
  border-right: 1px solid var(--np-border, #d4d4d4);
  padding-right: 16px; margin-right: 4px;
}
.lp-logo img { height: 34px; width: auto; display: block; }
.lp-portal-label {
  font-size: 14px; font-weight: 700; color: var(--np-text, #1a1a1a);
  white-space: nowrap; flex-shrink: 0; display: flex; align-items: center; gap: 6px;
}
[data-theme="dark"] .lp-portal-label { color: rgba(255,255,255,.9); }

/* Nav (center) */
.lp-nav { display: flex; align-items: center; gap: 4px; flex: 1; }
.lp-nav-link {
  padding: 6px 14px; border-radius: 6px;
  font-size: 13px; font-weight: 600; color: var(--np-muted, #757575);
  text-decoration: none; border: 1px solid transparent;
  transition: all .15s;
}
.lp-nav-link:hover, .lp-nav-link.active {
  background: var(--np-primary-light, #e8f5f3);
  color: var(--np-primary-dark, #1d7a6d);
  border-color: var(--np-primary, #279989);
}

/* ── Kontext-Chip (aktiver Kunde / ausgewählter Datensatz) ── */
#np-ctx-chip {
  display: none;
  align-items: center;
  gap: 6px;
  padding: 4px 12px;
  background: rgba(39,153,137,.12);
  border: 1px solid rgba(39,153,137,.3);
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
  color: var(--np-primary, #279989);
  cursor: default;
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
#np-ctx-chip::before {
  content: '👤';
  font-size: 11px;
}
[data-theme="dark"] #np-ctx-chip {
  background: rgba(39,153,137,.2);
  border-color: rgba(39,153,137,.4);
}

/* Header Right */
.lp-header-right { display: flex; align-items: center; gap: 8px; margin-left: auto; }

/* Dark Mode Toggle */
.lp-dm-toggle {
  background: none; border: 1.5px solid var(--np-border, #d4d4d4);
  border-radius: 6px; cursor: pointer; padding: 4px 8px;
  font-size: 15px; line-height: 1; transition: all .15s; flex-shrink: 0;
}
.lp-dm-toggle:hover { background: var(--np-primary-light, #e8f5f3); border-color: var(--np-primary, #279989); }

/* User Dropdown */
.lp-user-dd { position: relative; }
.lp-user-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 5px 10px 5px 5px; border-radius: 999px;
  background: none; border: 1.5px solid var(--np-border, #d4d4d4);
  cursor: pointer; font-family: var(--np-font, 'Inter', sans-serif);
  transition: all .15s;
}
.lp-user-btn:hover { border-color: var(--np-primary, #279989); background: var(--np-primary-light, #e8f5f3); }
.lp-avatar {
  width: 30px; height: 30px; border-radius: 50%;
  background: var(--np-primary, #279989); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 700; flex-shrink: 0;
}
.lp-uname {
  font-size: 13px; font-weight: 500; color: var(--np-text, #1a1a1a);
  max-width: 120px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
[data-theme="dark"] .lp-uname { color: rgba(255,255,255,.85); }
.lp-dd-caret { font-size: 10px; color: var(--np-muted, #757575); margin-left: 2px; }

.lp-user-menu {
  display: none; position: absolute; top: calc(100% + 8px); right: 0;
  background: var(--np-card, #fff); border: 1px solid var(--np-border, #d4d4d4);
  border-radius: 8px; box-shadow: 0 8px 24px rgba(0,0,0,.14);
  min-width: 210px; overflow: hidden; z-index: 300;
  animation: ps-dd-in .15s ease;
}
.lp-user-menu.open { display: block; }
@keyframes ps-dd-in { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: translateY(0); } }
.lp-user-menu-header {
  padding: 10px 16px 8px; display: flex; align-items: center; gap: 8px;
}
.lp-user-menu-email {
  font-size: 13px; font-weight: 600; color: var(--np-text, #1a1a1a);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex: 1;
}
.lp-admin-badge {
  font-size: 10px; font-weight: 700; letter-spacing: .04em;
  background: var(--np-primary, #279989); color: #fff;
  padding: 1px 6px; border-radius: 4px; flex-shrink: 0;
}
.lp-user-menu-sep { height: 1px; background: var(--np-border, #d4d4d4); margin: 4px 0; }
.lp-user-menu-item {
  display: flex; align-items: center; gap: 8px;
  padding: 9px 16px; font-size: 14px; color: var(--np-text, #1a1a1a);
  text-decoration: none; transition: background .1s; white-space: nowrap;
}
.lp-user-menu-item:hover { background: var(--np-primary-light, #e8f5f3); color: var(--np-primary-dark, #1d7a6d); }
.lp-user-menu-danger { color: #dc3545; }
.lp-user-menu-danger:hover { background: rgba(220,53,69,.08); color: #dc3545; }

/* ═══════════════════════════════════════════════════════════
   PORTAL LAYOUT: Sidebar + Main
   ═══════════════════════════════════════════════════════════ */
.lp-portal-wrap {
  display: flex; padding-top: var(--ps-header-h);
  min-height: 100vh; position: relative; z-index: 1;
}
.lp-portal-full {
  padding-top: var(--ps-header-h);
  min-height: 100vh; position: relative; z-index: 1;
}

/* Sidebar */
.lp-sidebar {
  width: var(--ps-sidebar-w); flex-shrink: 0;
  background: rgba(26,35,50,.96);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  min-height: calc(100vh - var(--ps-header-h));
  position: sticky; top: var(--ps-header-h);
  height: calc(100vh - var(--ps-header-h));
  overflow-y: auto; overflow-x: hidden;
  padding: 12px 0; display: flex; flex-direction: column;
  scrollbar-width: thin; scrollbar-color: rgba(255,255,255,.15) transparent;
}
.lp-sidebar::-webkit-scrollbar { width: 4px; }
.lp-sidebar::-webkit-scrollbar-thumb { background: rgba(255,255,255,.15); border-radius: 2px; }
.lp-sidebar-foot {
  padding: 12px 16px; border-top: 1px solid rgba(255,255,255,.08);
  font-size: 12px; color: rgba(255,255,255,.4);
  margin-top: auto; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

/* Main area */
.lp-portal-main {
  flex: 1; overflow-y: auto; overflow-x: hidden;
  padding: 24px 28px; min-width: 0;
}

/* Topbar */
.lp-topbar {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 20px; padding-bottom: 16px;
  border-bottom: 1px solid var(--np-border, #d4d4d4);
  flex-wrap: wrap; gap: 8px;
}
.lp-page-title { font-size: 22px; font-weight: 700; color: var(--np-primary-dark, #1d7a6d); margin: 0; }

/* Sidebar overlay (mobile) */
.lp-sidebar-overlay {
  display: none; position: fixed; inset: 0; background: rgba(0,0,0,.4); z-index: 149;
}

/* ═══════════════════════════════════════════════════════════
   SIDEBAR NAV ITEMS
   ═══════════════════════════════════════════════════════════ */
.sb-item {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 12px; margin: 1px 8px; border-radius: 6px;
  font-size: 13px; font-weight: 500; color: rgba(255,255,255,.72);
  text-decoration: none; transition: background .12s, color .12s;
  white-space: nowrap; overflow: hidden;
}
.sb-item:hover { background: rgba(255,255,255,.08); color: #fff; }
.sb-item.active { background: var(--np-primary, #279989); color: #fff; font-weight: 600; }
.sb-item-logout { color: rgba(255,100,100,.7); }
.sb-item-logout:hover { background: rgba(220,53,69,.12); color: #ff8888; }
.sb-section-label {
  font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em;
  color: rgba(255,255,255,.35); padding: 12px 20px 6px; user-select: none;
}
.sb-sep { height: 1px; background: rgba(255,255,255,.08); margin: 8px 16px; }
.sb-icon { width: 20px; text-align: center; font-size: 15px; flex-shrink: 0; }
.sb-cta {
  display: flex; align-items: center; justify-content: center; gap: 6px;
  margin: 8px 12px; padding: 10px 14px; border-radius: 6px;
  background: var(--np-primary, #279989); color: #fff;
  font-size: 13px; font-weight: 600; text-decoration: none;
  transition: background .12s, box-shadow .12s;
}
.sb-cta:hover { background: var(--np-primary-dark, #1d7a6d); box-shadow: 0 4px 12px rgba(39,153,137,.35); }

/* ═══════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════ */
.lp-footer {
  position: relative; z-index: 1;
  background: rgba(255,255,255,.70);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  border-top: 1px solid var(--np-border, #d4d4d4);
  padding: 14px 24px; text-align: center;
  font-size: 12px; color: var(--np-muted, #757575);
}
[data-theme="dark"] .lp-footer {
  background: rgba(13,27,42,.75); border-top-color: rgba(255,255,255,.08);
}
.lp-footer a { color: var(--np-muted, #757575); text-decoration: none; }
.lp-footer a:hover { color: var(--np-primary, #279989); }
.lp-footer-inner { max-width: 1200px; margin: 0 auto; }

/* ═══════════════════════════════════════════════════════════
   BG SWITCH
   ═══════════════════════════════════════════════════════════ */
#bgSwitch {
  position: fixed; top: calc(var(--ps-header-h) + 12px); left: 16px; z-index: 99;
  width: 30px; height: 30px; display: flex; align-items: center; justify-content: center;
  background: rgba(39,153,137,.08); border: 1px solid rgba(39,153,137,.25);
  border-radius: 50%; cursor: pointer; padding: 0; transition: all .25s;
}
#bgSwitch:hover {
  background: rgba(39,153,137,.18); border-color: rgba(39,153,137,.6);
  box-shadow: 0 0 10px rgba(39,153,137,.3); transform: rotate(45deg);
}

/* ═══════════════════════════════════════════════════════════
   PORTAL SELECTION (portals/index.html)
   ═══════════════════════════════════════════════════════════ */
.pa-wrap {
  min-height: calc(100vh - var(--ps-header-h) - 52px);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 40px 24px; position: relative; z-index: 1;
}
.pa-greeting { text-align: center; margin-bottom: 48px; }
.pa-greeting h1 { font-size: clamp(1.5rem, 3vw, 2.2rem); font-weight: 800; color: #fff; margin: 0 0 8px; text-shadow: 0 2px 14px rgba(0,0,0,.3); }
.pa-greeting p { font-size: 15px; color: rgba(255,255,255,.88); margin: 0; text-shadow: 0 1px 8px rgba(0,0,0,.25); }
.pa-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 20px; width: 100%; max-width: 960px;
}
.pa-card {
  display: flex; flex-direction: column; align-items: flex-start; gap: 10px;
  padding: 28px 24px; background: rgba(255,255,255,.82);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(255,255,255,.6); border-top: 4px solid var(--np-primary, #279989);
  border-radius: 10px; box-shadow: 0 2px 8px rgba(0,0,0,.06), 0 8px 24px rgba(0,0,0,.08);
  text-decoration: none; color: var(--np-text, #1a1a1a);
  transition: box-shadow .15s, transform .15s; cursor: pointer;
}
.pa-card:hover {
  box-shadow: 0 4px 16px rgba(0,0,0,.10), 0 12px 32px rgba(39,153,137,.14);
  transform: translateY(-3px); text-decoration: none; color: var(--np-text, #1a1a1a);
}
.pa-card-icon {
  width: 48px; height: 48px; background: var(--np-primary-light, #e8f5f3);
  border-radius: 8px; display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem; flex-shrink: 0;
}
.pa-card h3 { margin: 0; font-size: 1rem; font-weight: 800; }
.pa-card p  { margin: 0; font-size: 13px; color: var(--np-muted, #757575); line-height: 1.5; flex: 1; }
.pa-arrow   { margin-top: auto; align-self: flex-end; font-size: 18px; color: var(--np-primary, #279989); opacity: 0; transition: opacity .15s, transform .15s; }
.pa-card:hover .pa-arrow { opacity: 1; transform: translateX(4px); }
.pa-card.pa-admin { border-top-color: #dc3545; }
.pa-card.pa-admin .pa-card-icon { background: rgba(220,53,69,.1); }
.pa-card.pa-ext { border-top-color: #15779b; }
.pa-card.pa-ext .pa-card-icon { background: rgba(21,119,155,.1); }

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE — Mobile
   ═══════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  .lp-sidebar {
    position: fixed; left: 0; top: var(--ps-header-h);
    height: calc(100vh - var(--ps-header-h)); z-index: 150;
    transform: translateX(-100%); transition: transform .25s ease;
  }
  .lp-sidebar.open { transform: translateX(0); }
  .lp-sidebar-overlay.open { display: block; }
  .lp-portal-main { padding: 16px; }
  .lp-uname { display: none; }
}
