/* Portal Layout */
.sf-portal-layout { display: flex; min-height: 100vh; }

.sf-portal-nav {
  width: 220px;
  flex-shrink: 0;
  background: var(--bg2);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  padding: 24px 16px;
  gap: 8px;
  position: sticky;
  top: 0;
  height: 100vh;
}
.sf-nav-brand { padding: 8px 0 24px; }
.sf-nav-logo { height: 28px; }
.sf-nav-links { list-style: none; flex: 1; display: flex; flex-direction: column; gap: 2px; }
.sf-nav-links a {
  display: block;
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  color: var(--text-muted);
  font-size: .9rem;
  font-weight: 500;
  transition: background .15s, color .15s;
}
.sf-nav-links a:hover { background: var(--bg3); color: #fff; text-decoration: none; }
.sf-nav-links a.active { background: rgba(0,200,150,.1); color: var(--accent); }
.sf-nav-logout { font-size: .82rem; color: var(--text-muted); padding: 10px 14px; text-align: center; }
.sf-nav-logout:hover { color: var(--danger); text-decoration: none; }

.sf-portal-main {
  flex: 1;
  padding: 40px 48px;
  max-width: 900px;
}
.sf-portal-heading {
  font-family: var(--font-display);
  font-size: 1.8rem;
  font-weight: 800;
  color: #fff;
  margin-bottom: 32px;
}

/* Login-Seite */
.sf-portal-login { min-height: 100vh; display: flex; align-items: center; justify-content: center;
                   background: var(--bg); padding: 24px; }
.sf-login-box { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius-lg);
                padding: 40px; max-width: 420px; width: 100%; }
.sf-login-logo { height: 32px; margin-bottom: 24px; }
.sf-login-box h1 { font-family: var(--font-display); font-size: 1.4rem; font-weight: 800;
                   color: #fff; margin-bottom: 24px; }
.sf-login-hint { font-size: .82rem; color: var(--text-muted); margin-top: 12px; text-align: center; }

/* Stats */
.sf-stats-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
                 gap: 16px; margin-bottom: 32px; }
.sf-stat-card { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius);
                padding: 20px; display: flex; flex-direction: column; gap: 4px; }
.sf-stat-value { font-family: var(--font-display); font-size: 1.5rem; font-weight: 800; color: #fff; }
.sf-stat-label { font-size: .78rem; color: var(--text-muted); text-transform: uppercase; }
.sf-status-ok { color: var(--accent); }
.sf-status-warn { color: var(--warn); }

/* Info / Shop-Link */
.sf-shop-link-box { background: rgba(0,200,150,.05); border: 1px solid rgba(0,200,150,.2);
                    border-radius: var(--radius); padding: 14px 20px; margin-bottom: 28px;
                    display: flex; align-items: center; gap: 12px; font-size: .9rem; }
.sf-info-box { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius);
               padding: 20px; margin-bottom: 28px; }

/* Section header with action */
.sf-section-header { display: flex; align-items: center; justify-content: space-between;
                     margin-bottom: 16px; }

/* Portal Artikel-Cards */
.sf-artikel-cards { display: flex; flex-direction: column; gap: 12px; }
.sf-pa-card { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius);
              padding: 14px 16px; display: flex; align-items: center; gap: 14px; }
.sf-pa-card--inaktiv { opacity: .5; }
.sf-pa-bild { width: 48px; height: 48px; background: var(--bg3); border-radius: var(--radius-sm);
              flex-shrink: 0; display: flex; align-items: center; justify-content: center;
              overflow: hidden; font-size: 1.5rem; }
.sf-pa-bild img { width: 100%; height: 100%; object-fit: cover; }
.sf-pa-info { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.sf-pa-info strong { font-size: .95rem; color: #fff; }
.sf-pa-info span { font-size: .82rem; color: var(--text-muted); }
.sf-pa-actions { display: flex; gap: 8px; flex-shrink: 0; }

/* Form extras */
.sf-form-group--check label { flex-direction: row; align-items: center; gap: 8px;
                               font-size: .9rem; cursor: pointer; }
.sf-form-actions { display: flex; gap: 12px; align-items: center; margin-top: 8px; }
