:root {
  --portal-hero: linear-gradient(135deg, rgba(30,58,138,0.12), rgba(59,130,246,0.06));
  --portal-border: 1px solid var(--border);
}

.portal-page {
  max-width: 1200px;
  margin: 0 auto;
  padding: var(--spacing-lg) var(--spacing-md) var(--spacing-xl);
}

.portal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-md);
  margin-bottom: var(--spacing-lg);
}

.portal-title h1 {
  margin-bottom: 0.35rem;
}

.portal-title p {
  color: var(--text-light);
}

.portal-actions {
  display: flex;
  gap: var(--spacing-sm);
  flex-wrap: wrap;
}

.portal-hero {
  background: var(--portal-hero);
  border-radius: var(--radius-lg);
  padding: var(--spacing-lg);
  border: var(--portal-border);
  box-shadow: var(--shadow-sm);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-lg);
  flex-wrap: wrap;
}

.portal-hero .hero-tags {
  display: flex;
  gap: var(--spacing-xs);
  flex-wrap: wrap;
}

.portal-hero .hero-tags span {
  background: var(--surface);
  border: var(--portal-border);
  border-radius: var(--radius-full);
  padding: 0.3rem 0.75rem;
  font-size: 0.85rem;
  color: var(--text-light);
}

.office-grid {
  margin-top: var(--spacing-lg);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--spacing-md);
}

.office-card {
  background: var(--surface);
  border-radius: var(--radius-lg);
  border: var(--portal-border);
  padding: var(--spacing-md);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
  text-decoration: none;
  color: var(--text);
  transition: all 0.2s ease;
}

.office-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.office-card h3 {
  color: var(--text);
  font-size: 1.1rem;
}

.office-head {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.office-logo {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-md);
  border: var(--portal-border);
  background: var(--background);
  object-fit: contain;
  flex-shrink: 0;
}

.office-logo.fallback {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  color: var(--primary);
}

.section-title {
  margin: var(--spacing-lg) 0 var(--spacing-md);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-md);
}

.section-title h2 {
  font-size: 1.5rem;
}

.empty-state {
  background: var(--surface);
  border-radius: var(--radius-lg);
  border: 1px dashed var(--border);
  padding: var(--spacing-lg);
  text-align: center;
  color: var(--text-light);
}

.profile-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--spacing-md);
}

.list-stack {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
}

.list-item {
  background: var(--surface);
  border-radius: var(--radius-lg);
  border: var(--portal-border);
  padding: var(--spacing-md);
  box-shadow: var(--shadow-sm);
}

.list-item h4 {
  color: var(--text);
  margin-bottom: 0.35rem;
}

.list-meta {
  display: flex;
  gap: var(--spacing-sm);
  flex-wrap: wrap;
  color: var(--text-light);
  font-size: 0.9rem;
}

.badge {
  display: inline-flex;
  align-items: center;
  padding: 0.2rem 0.6rem;
  border-radius: var(--radius-full);
  font-size: 0.75rem;
  font-weight: 600;
  background: var(--background);
  border: var(--portal-border);
  color: var(--text);
}

.badge.success {
  background: var(--success-light);
  color: var(--success);
  border-color: rgba(22,163,74,0.2);
}

.badge.warning {
  background: #fef3c7;
  color: #b45309;
  border-color: #fcd34d;
}

.badge.neutral {
  background: #e5e7eb;
  color: #374151;
}

.text-muted {
  color: var(--text-light);
}

@media (max-width: 768px) {
  .portal-header {
    flex-direction: column;
    align-items: flex-start;
  }
  .portal-actions {
    width: 100%;
  }
  .portal-actions .btn {
    flex: 1 1 auto;
    justify-content: center;
  }
}
