/* Developer Portal Layout */
.portal-container {
  grid-template-columns: 1fr;
}

/* profile card */
.portal-profile-card {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  align-items: stretch;
}

.portal-profile-main {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  flex: 2 1 260px;
}

.portal-profile-avatar {
  width: 80px;
  height: 80px;
  border-radius: 999px;
  object-fit: cover;
  border: 2px solid var(--accent1);
  box-shadow: 0 0 0 3px rgba(0, 186, 255, 0.24);
}

.portal-profile-main h2 {
  margin: 0 0 4px 0;
}

.portal-profile-main h2 span {
  color: var(--accent1);
}

.portal-profile-meta {
  margin-top: 6px;
  display: flex;
  flex-direction: row;       /* Default: horizontal */
  flex-wrap: wrap;           /* Allows wrapping to next line if long */
  gap: 6px 12px;             /* Better spacing for row layout */
  font-size: 13px;
  color: var(--muted);
}

.portal-profile-meta i {
  margin-right: 6px;
  color: var(--accent1);
}

/* 📱 Mobile + Slim Tablet → Stack vertically */
@media (max-width: 768px) {
  .portal-profile-meta {
    flex-direction: column;  /* switch to vertical stacking */
    gap: 8px;
  }
}

.portal-profile-side {
  flex: 1 1 220px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: flex-start;
  justify-content: space-between;
}

.portal-badge-owned {
  font-size: 13px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.35);
  border: 1px solid var(--glass-border);
  display: inline-flex;
  gap: 8px;
  align-items: center;
}

.portal-badge-owned i {
  color: var(--accent2);
}

.portal-profile-stats {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}

.portal-profile-stats>div {
  min-width: 90px;
}

.portal-stat-value {
  font-weight: 700;
}

.portal-stat-label {
  font-size: 12px;
  color: var(--muted);
}

/* generic portal section */
.portal-section {
  grid-column: 1/-1;
  margin-top: 18px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.02), transparent);
  padding: 16px;
  border-radius: 12px;
  border: 1px solid var(--glass-border);
}

.portal-section-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}

.portal-section-header h3 {
  margin: 0;
}

.portal-section-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}

.portal-chip {
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  background: rgba(0, 0, 0, 0.35);
  border: 1px solid var(--glass-border);
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.portal-chip.small {
  font-size: 11px;
  padding: 4px 8px;
}

/* 2-col grid */
.portal-grid-2 {
  display: grid;
  grid-template-columns: minmax(0, 1.7fr) minmax(0, 1.3fr);
  gap: 16px;
}

@media(max-width:900px) {
  .portal-grid-2 {
    grid-template-columns: 1fr;
  }
}

/* extension cards */
.portal-ext-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.portal-ext-card {
  border-radius: 12px;
  border: 1px solid var(--glass-border);
  background: var(--glass);
  padding: 12px;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.6);
}

.portal-ext-card-header {
  display: flex;
  gap: 12px;
  align-items: flex-start;
}

.portal-ext-icon {
  width: 64px;
  height: 64px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  object-fit: cover;
}

.portal-ext-headings {
  flex: 1;
  min-width: 0;
}

.portal-ext-title-row {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: space-between;
}

.portal-ext-title-row h4 {
  margin: 0;
}

.portal-owned-pill {
  font-size: 12px;
  padding: 4px 10px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--accent1), var(--accent2));
  color: #fff;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.portal-ext-meta,
.portal-ext-dates {
  font-size: 12px;
  color: var(--muted);
  margin: 2px 0;
}

.portal-ext-description {
  margin: 8px 0 10px 0;
  font-size: 13px;
  color: var(--text);
}

.portal-ext-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

/* feature grid */
.portal-feature-grid {
  border-radius: 12px;
  border: 1px solid var(--glass-border);
  background: var(--glass);
  padding: 12px;
}

.portal-feature-title {
  margin: 0 0 8px 0;
}

.portal-feature-grid-inner {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

@media(max-width:900px) {
  .portal-feature-grid-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media(max-width:640px) {
  .portal-feature-grid-inner {
    grid-template-columns: 1fr;
  }
}

.portal-feature-card {
  border-radius: 10px;
  border: 1px solid var(--glass-border);
  padding: 10px;
  background: rgba(0, 0, 0, 0.25);
  font-size: 13px;
}

.portal-feature-card h5 {
  margin: 4px 0 4px 0;
  font-size: 14px;
}

.portal-feature-card p {
  margin: 0;
  color: var(--muted);
}

.portal-feature-icon {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.35);
  color: var(--accent1);
}

/* assets section */
.portal-assets-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(0, 1.4fr);
  gap: 16px;
}

@media(max-width:900px) {
  .portal-assets-layout {
    grid-template-columns: 1fr;
  }
}

.portal-poster-panel {
  border-radius: 12px;
  border: 1px solid var(--glass-border);
  background: var(--glass);
  padding: 12px;
}

.portal-poster-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 8px;
}

.portal-poster-header h4 {
  margin: 0 0 4px 0;
}

.portal-poster-meta {
  margin: 0;
  font-size: 12px;
  color: var(--muted);
}

.portal-poster-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.portal-poster-actions .btn.small {
  padding-inline: 8px;
}

.portal-poster-body {
  margin-top: 10px;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(0, 0, 0, 0.4);
}

.portal-poster-body img {
  width: 100%;
  height: 100%;
  max-height: 600px;
  object-fit: cover;
}

.portal-assets-side {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.portal-thumbs-strip {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 4px;
}

.portal-thumb-btn {
  border-radius: 10px;
  border: 1px solid var(--glass-border);
  background: rgba(0, 0, 0, 0.4);
  padding: 4px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: flex-start;
  min-width: 120px;
  width: 200px;
  max-width: 100%;
  cursor: pointer;
  opacity: 0.5;
  transition: opacity .16s ease, transform .16s ease;
}

.portal-thumb-btn img {
  width: 100%;
  height: 150px;
  object-fit: cover;
  border-radius: 6px;
}

.portal-thumb-btn span {
  font-size: 11px;
  color: var(--muted);
}

.portal-thumb-btn.thumb-selected {
  opacity: 1;
  transform: translateY(-2px);
  border-color: var(--accent1);
}

/* promo tiles */
.portal-tiles-wrap {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

@media(max-width:640px) {
  .portal-tiles-wrap {
    grid-template-columns: 1fr;
  }
}

.portal-tile-card {
  border-radius: 10px;
  border: 1px solid var(--glass-border);
  background: var(--glass);
  padding: 8px;
  font-size: 12px;
}

.portal-tile-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 6px;
}

.portal-tile-header h5 {
  margin: 0;
  font-size: 13px;
}

.portal-tile-body {
  margin-top: 6px;
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.06);
}

.portal-tile-body img {
  width: 100%;
  height: 250px;
  object-fit: cover;
}

.portal-tile-meta {
  margin-top: 6px;
  color: var(--muted);
}

/* source explorer */
.portal-source-layout {
  display: grid;
grid-template-columns: minmax(0, 0.7fr) minmax(0, 1.3fr);
  gap: 14px;
}

@media(max-width:900px) {
  .portal-source-layout {
    grid-template-columns: 1fr;
  }
}

.portal-tree-panel {
  border-radius: 12px;
  border: 1px solid var(--glass-border);
  background: var(--glass);
  padding: 10px;
  font-size: 13px;
}

.portal-tree-title {
  font-weight: 600;
  margin-bottom: 6px;
}

.portal-tree-group {
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.04);
  padding: 4px 6px;
  margin-bottom: 4px;
}

.portal-tree-group summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 6px;
}

.portal-tree-group summary::-webkit-details-marker {
  display: none;
}

.portal-tree-group i {
  color: var(--accent1);
}

.portal-tree-group ul {
  margin: 4px 0 4px 16px;
  padding: 0;
  list-style: none;
}

.portal-tree-group li {
  margin: 2px 0;
  display: flex;
  gap: 6px;
  align-items: center;
}

.portal-tree-footer {
  margin-top: 8px;
  color: var(--muted);
  font-size: 12px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.portal-preview-panel {
  border-radius: 12px;
  border: 1px solid var(--glass-border);
  background: var(--glass);
  padding: 10px;
}

.portal-preview-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 8px;
}

.portal-preview-header h4 {
  margin: 0 0 2px 0;
}

.portal-preview-meta {
  margin: 0;
  font-size: 12px;
  color: var(--muted);
}

.portal-preview-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.portal-preview-body {
  margin-top: 8px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.portal-code-block {
  background: rgba(0, 0, 0, 0.55);
  border-radius: 8px;
  padding: 10px;
  font-size: 12px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  overflow: auto;
}

.portal-code-block code {
  font-family: Menlo, Consolas, monospace;
  white-space: pre;
}

/* image preview inside source block */
.portal-image-preview {
  border-radius: 8px;
  border: 1px solid var(--glass-border);
  background: rgba(0, 0, 0, 0.3);
  padding: 8px;
}

.portal-image-preview-header h5 {
  margin: 0 0 2px 0;
  font-size: 13px;
}

.portal-image-preview-header p {
  margin: 0;
  font-size: 12px;
  color: var(--muted);
}

.portal-image-preview-body {
  margin-top: 6px;
  border-radius: 6px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.06);
}

.portal-image-preview-body img {
  width: 100%;
  height: 200px;
  object-fit: cover;
}

/* premium assets */
.portal-premium-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr);
  gap: 16px;
}

@media(max-width:980px) {
  .portal-premium-layout {
    grid-template-columns: 1fr;
  }
}

.portal-premium-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

@media(max-width:640px) {
  .portal-premium-grid {
    grid-template-columns: 1fr;
  }
}

.portal-premium-card {
  border-radius: 10px;
  border: 1px solid var(--glass-border);
  background: var(--glass);
  padding: 10px;
  font-size: 13px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.portal-premium-icon {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.35);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent2);
}

.portal-premium-card h4 {
  margin: 2px 0;
  font-size: 14px;
}

.portal-premium-meta {
  margin: 0;
  font-size: 12px;
  color: var(--muted);
}

.portal-premium-desc {
  margin: 4px 0;
}

.portal-premium-actions {
  margin-top: auto;
}

/* certificate */
.portal-certificate-card {
  border-radius: 12px;
  border: 1px solid var(--glass-border);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.01));
  padding: 12px;
  font-size: 13px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
}

.portal-certificate-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}

.portal-certificate-header h4 {
  margin: 0;
}

.portal-certificate-body p {
  margin: 8px 0;
}

.portal-certificate-meta {
  margin: 6px 0 10px 0;
  padding-left: 18px;
}

.portal-certificate-meta li {
  margin-bottom: 2px;
}

.portal-certificate-signature-row {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 10px;
}

.portal-signature-block {
  flex: 1 1 140px;
}

.portal-signature-line {
  height: 1px;
  background: rgba(255, 255, 255, 0.3);
  margin-bottom: 4px;
}

.portal-signature-label {
  font-size: 12px;
  color: var(--muted);
}

.portal-certificate-footer {
  font-size: 11px;
  color: var(--muted);
  margin-top: 8px;
}

/* Portal logout label smaller on narrow screens */
@media(max-width:480px) {
  .portal-logout-label {
    display: none;
  }
}