:root {
  --upkc-bg: #071527;
  --upkc-card: rgba(255, 255, 255, 0.94);
  --upkc-text: #142033;
  --upkc-muted: #627084;
  --upkc-primary: #6d5dfc;
  --upkc-secondary: #0ea5e9;
  --upkc-accent: #22c55e;
  --upkc-border: rgba(20, 32, 51, 0.12);
  --upkc-radius: 22px;
}

.upkc-wrap {
  width: min(1180px, 100%);
  margin: 0 auto;
}

.upkc-filters {
  display: grid;
  grid-template-columns: minmax(220px, 1.5fr) minmax(160px, 1fr) minmax(160px, 1fr) minmax(120px, 0.7fr) auto;
  gap: 12px;
  align-items: end;
  padding: 18px;
  margin: 0 0 22px;
  border: 1px solid var(--upkc-border);
  border-radius: var(--upkc-radius);
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 18px 50px rgba(15, 23, 42, 0.08);
}

.upkc-filter-field label {
  display: block;
  margin: 0 0 7px;
  font-size: 0.84rem;
  font-weight: 700;
  color: var(--upkc-text);
}

.upkc-filter-field input,
.upkc-filter-field select {
  width: 100%;
  min-height: 44px;
  padding: 10px 12px;
  border: 1px solid var(--upkc-border);
  border-radius: 14px;
  background: #fff;
  color: var(--upkc-text);
}

.upkc-filter-actions {
  display: flex;
  gap: 8px;
  align-items: center;
}

.upkc-filter-actions button,
.upkc-link-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 10px 16px;
  border: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--upkc-primary), var(--upkc-secondary));
  color: #fff !important;
  font-weight: 800;
  text-decoration: none !important;
  cursor: pointer;
}

.upkc-filter-actions a,
.upkc-link-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid var(--upkc-border);
  color: var(--upkc-text) !important;
  font-weight: 700;
  text-decoration: none !important;
  background: #fff;
}

.upkc-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.upkc-card {
  overflow: hidden;
  border: 1px solid var(--upkc-border);
  border-radius: var(--upkc-radius);
  background: var(--upkc-card);
  color: var(--upkc-text);
  box-shadow: 0 18px 50px rgba(15, 23, 42, 0.1);
}

.upkc-card-media {
  display: flex;
  position: relative;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  align-items: center;
  justify-content: center;
  background: radial-gradient(circle at 30% 20%, rgba(109, 93, 252, 0.34), transparent 34%), linear-gradient(135deg, #071527, #10213a);
  text-decoration: none !important;
}

.upkc-card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .25s ease;
}

.upkc-card:hover .upkc-card-media img {
  transform: scale(1.03);
}

.upkc-card-placeholder {
  color: rgba(255, 255, 255, 0.78);
  font-size: 1.6rem;
  font-weight: 900;
  letter-spacing: 0.12em;
}

.upkc-card-body {
  padding: 18px;
}

.upkc-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 10px;
}

.upkc-badges span {
  display: inline-flex;
  padding: 5px 9px;
  border-radius: 999px;
  background: rgba(109, 93, 252, 0.1);
  color: #4f46e5;
  font-size: 0.75rem;
  font-weight: 800;
}

.upkc-card h3 {
  margin: 0 0 8px;
  font-size: 1.12rem;
  line-height: 1.32;
}

.upkc-card h3 a {
  color: var(--upkc-text) !important;
  text-decoration: none !important;
}

.upkc-author,
.upkc-prodi,
.upkc-excerpt {
  margin: 0 0 8px;
  color: var(--upkc-muted);
  line-height: 1.55;
}

.upkc-author {
  color: var(--upkc-text);
  font-weight: 800;
}

.upkc-prodi {
  font-size: 0.9rem;
  font-weight: 700;
}

.upkc-excerpt {
  min-height: 50px;
  font-size: 0.92rem;
}

.upkc-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

.upkc-pagination {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  margin-top: 26px;
}

.upkc-pagination .page-numbers {
  display: inline-flex;
  min-width: 40px;
  min-height: 40px;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  border: 1px solid var(--upkc-border);
  border-radius: 999px;
  background: #fff;
  color: var(--upkc-text) !important;
  font-weight: 800;
  text-decoration: none !important;
}

.upkc-pagination .current {
  background: linear-gradient(135deg, var(--upkc-primary), var(--upkc-secondary));
  color: #fff !important;
  border-color: transparent;
}

.upkc-empty {
  padding: 28px;
  border-radius: var(--upkc-radius);
  border: 1px dashed var(--upkc-border);
  background: rgba(255, 255, 255, 0.84);
  text-align: center;
}

.upkc-empty h3 {
  margin: 0 0 8px;
}

@media (max-width: 1024px) {
  .upkc-filters {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .upkc-filter-actions {
    grid-column: 1 / -1;
  }
  .upkc-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .upkc-filters,
  .upkc-grid {
    grid-template-columns: 1fr;
  }
  .upkc-filter-actions,
  .upkc-actions {
    align-items: stretch;
    flex-direction: column;
  }
  .upkc-filter-actions button,
  .upkc-filter-actions a,
  .upkc-link-primary,
  .upkc-link-secondary {
    width: 100%;
  }
}

/* Auth & Dashboard */
.upkc-auth-wrap,
.upkc-dashboard {
  width: min(920px, 100%);
  margin: 0 auto;
}

.upkc-auth-card,
.upkc-dashboard-head,
.upkc-table-wrap {
  border: 1px solid var(--upkc-border);
  border-radius: var(--upkc-radius);
  background: rgba(255, 255, 255, 0.94);
  color: var(--upkc-text);
  box-shadow: 0 18px 50px rgba(15, 23, 42, 0.1);
}

.upkc-auth-card {
  width: min(520px, 100%);
  margin: 0 auto;
  padding: 28px;
}

.upkc-auth-card-wide {
  width: min(860px, 100%);
}

.upkc-auth-card h2,
.upkc-dashboard h2 {
  margin: 0 0 10px;
  color: var(--upkc-text);
  font-size: clamp(1.5rem, 3vw, 2.1rem);
}

.upkc-auth-intro,
.upkc-help,
.upkc-auth-links,
.upkc-dashboard-head p {
  color: var(--upkc-muted);
  line-height: 1.6;
}

.upkc-auth-card label {
  display: block;
  margin: 0 0 7px;
  color: var(--upkc-text);
  font-size: 0.92rem;
  font-weight: 800;
}

.upkc-auth-card input[type="text"],
.upkc-auth-card input[type="email"],
.upkc-auth-card input[type="password"],
.upkc-auth-card select {
  width: 100%;
  min-height: 46px;
  padding: 11px 13px;
  border: 1px solid var(--upkc-border);
  border-radius: 14px;
  background: #fff;
  color: var(--upkc-text);
}

.upkc-auth-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px 14px;
}

.upkc-check {
  display: flex !important;
  gap: 8px;
  align-items: center;
  margin: 10px 0 18px !important;
  font-weight: 700 !important;
}

.upkc-submit {
  display: inline-flex;
  width: 100%;
  min-height: 48px;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--upkc-primary), var(--upkc-secondary));
  color: #fff;
  font-weight: 900;
  cursor: pointer;
}

.upkc-alert {
  margin: 14px 0;
  padding: 12px 14px;
  border-radius: 14px;
  font-weight: 700;
}

.upkc-alert-error {
  border: 1px solid rgba(239, 68, 68, 0.28);
  background: rgba(239, 68, 68, 0.08);
  color: #991b1b;
}

.upkc-alert-success {
  border: 1px solid rgba(34, 197, 94, 0.3);
  background: rgba(34, 197, 94, 0.1);
  color: #166534;
}

.upkc-dashboard-head {
  display: flex;
  gap: 18px;
  justify-content: space-between;
  align-items: center;
  padding: 24px;
  margin-bottom: 18px;
}

.upkc-kicker {
  margin: 0 0 6px !important;
  color: var(--upkc-primary) !important;
  font-size: 0.8rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.upkc-table-wrap {
  overflow-x: auto;
  padding: 8px;
}

.upkc-table {
  width: 100%;
  border-collapse: collapse;
}

.upkc-table th,
.upkc-table td {
  padding: 12px 14px;
  border-bottom: 1px solid var(--upkc-border);
  text-align: left;
}

.upkc-table th {
  color: var(--upkc-text);
  font-size: 0.82rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .05em;
}

.upkc-status {
  display: inline-flex;
  padding: 4px 9px;
  border-radius: 999px;
  background: rgba(109, 93, 252, 0.1);
  color: #4f46e5;
  font-size: .78rem;
  font-weight: 900;
}

@media (max-width: 640px) {
  .upkc-auth-card {
    padding: 22px;
  }
  .upkc-auth-grid,
  .upkc-dashboard-head {
    grid-template-columns: 1fr;
    flex-direction: column;
    align-items: stretch;
  }
}

/* v1.2.0 stronger form contrast + submit karya */
.upkc-auth-wrap *,
.upkc-submit-wrap *,
.upkc-dashboard * {
  box-sizing: border-box;
}

.upkc-auth-card,
.upkc-auth-card *,
.upkc-form-card,
.upkc-form-card *,
.upkc-dashboard,
.upkc-dashboard * {
  color: var(--upkc-text);
}

.upkc-auth-card h1,
.upkc-auth-card h2,
.upkc-auth-card h3,
.upkc-form-card h1,
.upkc-form-card h2,
.upkc-form-card h3 {
  color: #0f172a !important;
}

.upkc-auth-card p,
.upkc-auth-card .upkc-auth-intro,
.upkc-auth-card .upkc-help,
.upkc-auth-card .upkc-auth-links,
.upkc-form-card p,
.upkc-form-card .upkc-help-text,
.upkc-form-card .upkc-form-head p {
  color: #475569 !important;
}

.upkc-auth-card label,
.upkc-form-card label,
.upkc-filter-field label {
  color: #1e293b !important;
  opacity: 1 !important;
  text-shadow: none !important;
}

.upkc-auth-card input[type="text"],
.upkc-auth-card input[type="email"],
.upkc-auth-card input[type="password"],
.upkc-auth-card select,
.upkc-form-card input[type="text"],
.upkc-form-card input[type="email"],
.upkc-form-card input[type="url"],
.upkc-form-card input[type="number"],
.upkc-form-card input[type="password"],
.upkc-form-card input[type="file"],
.upkc-form-card select,
.upkc-form-card textarea,
.upkc-filter-field input,
.upkc-filter-field select {
  width: 100%;
  border: 1px solid rgba(15, 23, 42, 0.18) !important;
  background: #ffffff !important;
  color: #0f172a !important;
  opacity: 1 !important;
  box-shadow: none !important;
  -webkit-text-fill-color: #0f172a !important;
}

.upkc-auth-card input::placeholder,
.upkc-form-card input::placeholder,
.upkc-form-card textarea::placeholder,
.upkc-filter-field input::placeholder {
  color: #94a3b8 !important;
  opacity: 1 !important;
}

.upkc-auth-card select option,
.upkc-form-card select option {
  color: #0f172a !important;
  background: #ffffff !important;
}

.upkc-check,
.upkc-check * {
  color: #475569 !important;
}

.upkc-submit-wrap {
  width: min(980px, 100%);
  margin: 0 auto;
}

.upkc-form-card {
  width: 100%;
  padding: clamp(22px, 4vw, 34px);
  border: 1px solid var(--upkc-border);
  border-radius: var(--upkc-radius);
  background: rgba(255, 255, 255, 0.96);
  color: var(--upkc-text);
  box-shadow: 0 18px 50px rgba(15, 23, 42, 0.1);
}

.upkc-form-head {
  margin-bottom: 20px;
}

.upkc-form-head h2 {
  margin: 0 0 8px;
  font-size: clamp(1.55rem, 3vw, 2.15rem);
}

.upkc-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px 16px;
}

.upkc-field {
  margin: 0;
}

.upkc-field-full {
  grid-column: 1 / -1;
}

.upkc-field label {
  display: block;
  margin: 0 0 7px;
  font-size: 0.92rem;
  font-weight: 900;
}

.upkc-field label span {
  color: #dc2626 !important;
}

.upkc-form-card input[type="text"],
.upkc-form-card input[type="email"],
.upkc-form-card input[type="url"],
.upkc-form-card input[type="number"],
.upkc-form-card input[type="password"],
.upkc-form-card input[type="file"],
.upkc-form-card select,
.upkc-form-card textarea {
  min-height: 48px;
  padding: 11px 13px;
  border-radius: 14px;
  line-height: 1.4;
}

.upkc-form-card textarea {
  min-height: 130px;
  resize: vertical;
}

.upkc-help-text {
  display: block;
  margin-top: 7px;
  font-size: 0.86rem;
  line-height: 1.45;
}

.upkc-dashboard-actions {
  margin-top: 0;
  justify-content: flex-end;
}

@media (max-width: 700px) {
  .upkc-form-grid {
    grid-template-columns: 1fr;
  }
}

/* v1.3.0 dashboard and settings refinements */
.upkc-table-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.upkc-table-actions a,
.upkc-table-actions span {
  display: inline-flex;
  min-height: 32px;
  align-items: center;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, 0.12);
  background: #ffffff;
  color: #334155 !important;
  font-size: .82rem;
  font-weight: 800;
  text-decoration: none !important;
}

.upkc-status-publish {
  background: rgba(34, 197, 94, 0.12) !important;
  color: #166534 !important;
}

.upkc-status-pending {
  background: rgba(245, 158, 11, 0.14) !important;
  color: #92400e !important;
}

.upkc-status-draft {
  background: rgba(100, 116, 139, 0.12) !important;
  color: #334155 !important;
}

/* v1.4.0 full width pages + review statuses */
.upkc-fullwidth-page .site-content .ast-container,
.upkc-fullwidth-page .ast-container,
.upkc-fullwidth-page .entry-content,
.upkc-fullwidth-page .content-area,
.upkc-fullwidth-page .site-main {
  width: 100% !important;
  max-width: none !important;
}

.upkc-fullwidth-page .site-content .ast-container,
.upkc-fullwidth-page .ast-container {
  padding-left: clamp(14px, 3vw, 34px) !important;
  padding-right: clamp(14px, 3vw, 34px) !important;
}

.upkc-fullwidth-page .entry-content > .upkc-auth-wrap,
.upkc-fullwidth-page .entry-content > .upkc-submit-wrap,
.upkc-fullwidth-page .entry-content > .upkc-dashboard,
.upkc-fullwidth-page .entry-content > .upkc-wrap {
  margin-top: 24px;
  margin-bottom: 36px;
}

.upkc-fullwidth-page .upkc-auth-wrap,
.upkc-fullwidth-page .upkc-dashboard {
  width: min(1120px, 100%);
}

.upkc-fullwidth-page .upkc-submit-wrap,
.upkc-fullwidth-page .upkc-wrap {
  width: min(1280px, 100%);
}

.upkc-status-upkc_revisi,
.upkc-status-revisi {
  background: rgba(14, 165, 233, 0.14) !important;
  color: #075985 !important;
}

.upkc-status-upkc_ditolak,
.upkc-status-ditolak {
  background: rgba(239, 68, 68, 0.12) !important;
  color: #991b1b !important;
}

.upkc-form-card select:required:invalid,
.upkc-auth-card select:required:invalid {
  color: #64748b !important;
}

/* v1.5.0 Google Drive + detail karya */
.upkc-detail-box {
  margin: 32px auto 0;
  padding: clamp(20px, 3vw, 32px);
  border-radius: 24px;
  border: 1px solid rgba(148, 163, 184, 0.22);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 18px 45px rgba(15, 23, 42, 0.10);
  color: #0f172a;
}

.upkc-detail-box h2 {
  margin: 0 0 18px;
  font-size: clamp(1.35rem, 2.2vw, 1.9rem);
  color: #0f172a;
}

.upkc-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin: 0;
}

.upkc-detail-grid > div {
  padding: 14px 16px;
  border-radius: 18px;
  background: #f8fafc;
  border: 1px solid rgba(148, 163, 184, 0.18);
}

.upkc-detail-grid dt {
  margin: 0 0 4px;
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .02em;
  color: #64748b;
  text-transform: uppercase;
}

.upkc-detail-grid dd {
  margin: 0;
  font-size: .98rem;
  color: #0f172a;
  font-weight: 700;
}

.upkc-detail-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 22px;
}

.upkc-detail-file-note {
  margin: 12px 0 0;
  color: #64748b;
  font-size: .9rem;
}

@media (max-width: 700px) {
  .upkc-detail-grid {
    grid-template-columns: 1fr;
  }
}

/* v1.5.6 - Detail Karya + Logo Luaran card */
.upkc-card-v2 {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(125, 99, 255, 0.35);
  background:
    radial-gradient(circle at 15% 0%, rgba(109, 93, 252, 0.18), transparent 34%),
    radial-gradient(circle at 100% 0%, rgba(34, 197, 94, 0.10), transparent 30%),
    rgba(9, 19, 34, 0.92);
  color: #f8fafc;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.22);
}

.upkc-card-v2 .upkc-card-body {
  padding: 18px;
}

.upkc-card-topline {
  position: absolute;
  z-index: 3;
  top: 14px;
  left: 14px;
  right: 14px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  pointer-events: none;
}

.upkc-logo-luaran {
  width: 58px;
  height: 58px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.22);
  background: rgba(2, 6, 23, 0.58);
  backdrop-filter: blur(8px);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.20);
  overflow: hidden;
  text-decoration: none !important;
  pointer-events: auto;
}

.upkc-logo-luaran img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 8px;
  background: #fff;
}

.upkc-logo-luaran span,
.upkc-detail-logo span {
  display: block;
  color: rgba(255, 255, 255, 0.8);
  font-size: 0.56rem;
  line-height: 1.05;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-align: center;
  text-transform: uppercase;
}

.upkc-status-badge {
  display: inline-flex;
  min-height: 30px;
  align-items: center;
  padding: 6px 10px;
  border-radius: 999px;
  color: #dcfce7;
  background: rgba(34, 197, 94, 0.18);
  border: 1px solid rgba(34, 197, 94, 0.38);
  font-size: 0.72rem;
  font-weight: 900;
  backdrop-filter: blur(8px);
}

.upkc-card-v2 .upkc-card-media {
  aspect-ratio: 16 / 10.5;
  border-bottom: 1px solid rgba(255, 255, 255, 0.10);
  background:
    radial-gradient(circle at 20% 10%, rgba(109, 93, 252, 0.35), transparent 32%),
    linear-gradient(135deg, #08111f, #14233a 48%, #08111f);
}

.upkc-card-v2 .upkc-badges span {
  color: #ddd6fe;
  background: rgba(109, 93, 252, 0.22);
  border: 1px solid rgba(167, 139, 250, 0.20);
}

.upkc-card-v2 h3 a,
.upkc-card-v2 h3,
.upkc-card-v2 .upkc-author {
  color: #ffffff !important;
}

.upkc-card-v2 .upkc-author,
.upkc-card-v2 .upkc-prodi,
.upkc-card-v2 .upkc-excerpt {
  color: rgba(226, 232, 240, 0.82);
}

.upkc-card-meta-list {
  display: grid;
  gap: 7px;
  margin: 12px 0;
}

.upkc-card-meta-list p {
  display: grid;
  grid-template-columns: 108px 1fr;
  gap: 8px;
  margin: 0;
  color: rgba(226, 232, 240, 0.84);
  font-size: 0.86rem;
}

.upkc-card-meta-list strong {
  color: rgba(255, 255, 255, 0.76);
  font-weight: 900;
}

.upkc-card-meta-list span {
  min-width: 0;
}

.upkc-card-v2 .upkc-link-secondary {
  background: rgba(255, 255, 255, 0.08);
  color: #f8fafc !important;
  border-color: rgba(255, 255, 255, 0.18);
}

.upkc-card-v2 .upkc-link-primary,
.upkc-card-v2 .upkc-link-secondary {
  flex: 1 1 120px;
}

.upkc-detail-box-v2 {
  color: #f8fafc;
  border-color: rgba(125, 99, 255, 0.30);
  background:
    radial-gradient(circle at 0% 0%, rgba(109, 93, 252, 0.18), transparent 36%),
    radial-gradient(circle at 100% 0%, rgba(34, 197, 94, 0.12), transparent 34%),
    rgba(9, 19, 34, 0.94);
}

.upkc-detail-hero-row {
  display: flex;
  gap: 18px;
  align-items: center;
  margin: 0 0 22px;
}

.upkc-detail-logo {
  flex: 0 0 92px;
  width: 92px;
  height: 92px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 26px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: rgba(2, 6, 23, 0.46);
  overflow: hidden;
}

.upkc-detail-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 12px;
  background: #fff;
}

.upkc-detail-box-v2 .upkc-kicker {
  margin: 0 0 4px;
  color: #a5b4fc;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 900;
  font-size: .8rem;
}

.upkc-detail-box-v2 h2 {
  color: #ffffff;
  margin: 0;
}

.upkc-detail-subtitle {
  margin: 8px 0 0;
  color: rgba(226, 232, 240, 0.76);
  font-weight: 700;
}

.upkc-detail-box-v2 .upkc-detail-grid > div {
  background: rgba(255, 255, 255, 0.07);
  border-color: rgba(255, 255, 255, 0.11);
}

.upkc-detail-box-v2 .upkc-detail-grid dt {
  color: rgba(203, 213, 225, 0.74);
}

.upkc-detail-box-v2 .upkc-detail-grid dd {
  color: #ffffff;
}

.upkc-detail-box-v2 .upkc-detail-file-note {
  color: rgba(226, 232, 240, 0.74);
}

@media (max-width: 700px) {
  .upkc-detail-hero-row {
    align-items: flex-start;
    flex-direction: column;
  }
  .upkc-card-meta-list p {
    grid-template-columns: 1fr;
    gap: 2px;
  }
}

/* =========================================================
   UNKAHA v1.5.9 - Astra Layout Fix moved from Additional CSS
   Astra + UNKAHA Child + Portal Karya Plugin
========================================================= */

/* Paksa area konten Astra menjadi full width */
body.unkaha-astra-portal .site-content > .ast-container,
body.unkaha-astra-portal .site-content .ast-container,
body.unkaha-astra-portal #content .ast-container {
  width: 100% !important;
  max-width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Hilangkan layout sidebar Astra yang bikin konten hanya sebagian kiri */
body.unkaha-astra-portal #primary,
body.unkaha-astra-portal .content-area,
body.unkaha-astra-portal .site-main {
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Sembunyikan sidebar jika Astra masih menyisakan area sidebar */
body.unkaha-astra-portal #secondary,
body.unkaha-astra-portal .widget-area {
  display: none !important;
}

/* Hilangkan margin bawaan article/page */
body.unkaha-astra-portal article,
body.unkaha-astra-portal .entry-content,
body.unkaha-astra-portal .entry-content > * {
  max-width: none !important;
}

/* Canvas halaman portal full width */
body.unkaha-astra-portal .unkaha-portal-page,
body.unkaha-astra-portal .unkaha-home-wrap,
body.unkaha-astra-portal .unkaha-page-wrap,
body.unkaha-astra-portal .unkaha-archive-wrap,
body.unkaha-astra-portal .unkaha-prodi-wrap,
body.unkaha-astra-portal .unkaha-tentang-wrap {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Section background full layar */
body.unkaha-astra-portal .unkaha-hero,
body.unkaha-astra-portal .unkaha-section,
body.unkaha-astra-portal .unkaha-page-hero {
  width: 100% !important;
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* Isi section tetap center, tidak mentok layar */
body.unkaha-astra-portal .unkaha-wrap,
body.unkaha-astra-portal .unkaha-section__head,
body.unkaha-astra-portal .unkaha-karya-grid,
body.unkaha-astra-portal .unkaha-prodi-grid,
body.unkaha-astra-portal .unkaha-card-grid,
body.unkaha-astra-portal .upkc-wrap,
body.unkaha-astra-portal .upkc-dashboard,
body.unkaha-astra-portal .upkc-submit-wrap,
body.unkaha-astra-portal .upkc-auth-wrap {
  width: min(1180px, calc(100% - 48px)) !important;
  max-width: 1180px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Khusus form submit bisa sedikit lebih lebar */
body.unkaha-astra-portal .upkc-submit-wrap {
  max-width: 1280px !important;
}

/* Matikan padding fullwidth bawaan plugin v1.4.0 yang bisa bikin aneh */
body.unkaha-astra-portal.upkc-fullwidth-page .site-content .ast-container,
body.unkaha-astra-portal.upkc-fullwidth-page .ast-container {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Header background full width */
body.unkaha-astra-portal .site-header,
body.unkaha-astra-portal .ast-primary-header-bar,
body.unkaha-astra-portal .ast-main-header-wrap {
  width: 100% !important;
  max-width: 100% !important;
}

/* Header isi dibuat lebih melebar dan rapi */
body.unkaha-astra-portal .site-header .ast-container,
body.unkaha-astra-portal .ast-primary-header-bar .ast-container,
body.unkaha-astra-portal .ast-main-header-wrap .ast-container {
  width: 100% !important;
  max-width: 100% !important;
  padding-left: 36px !important;
  padding-right: 36px !important;
}

body.unkaha-astra-portal .ast-builder-grid-row {
  width: min(1280px, calc(100% - 48px)) !important;
  max-width: 1280px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Footer full width */
body.unkaha-astra-portal .site-footer,
body.unkaha-astra-portal .site-primary-footer-wrap,
body.unkaha-astra-portal .site-below-footer-wrap {
  width: 100% !important;
  max-width: 100% !important;
}

/* Featured image card daftar karya: gambar utuh, center horizontal + vertikal */
body.unkaha-astra-portal .upkc-card-v2 .upkc-card-media {
  aspect-ratio: 16 / 8 !important;
  background: #eaf8fb !important;
}

body.unkaha-astra-portal .upkc-card-v2 .upkc-card-media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
  padding: 10px !important;
  background: #eaf8fb !important;
  transform: none !important;
}

body.unkaha-astra-portal .upkc-card:hover .upkc-card-media img,
body.unkaha-astra-portal .upkc-card-v2:hover .upkc-card-media img {
  transform: none !important;
}

/* Featured image single/detail karya: gambar utuh dan tidak terlalu tinggi */
body.single-karya.unkaha-astra-portal .post-thumb,
body.single-karya.unkaha-astra-portal .ast-single-post-featured-section {
  max-height: 420px !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: #eaf8fb !important;
  border-radius: 22px !important;
}

body.single-karya.unkaha-astra-portal .post-thumb img,
body.single-karya.unkaha-astra-portal .wp-post-image,
body.single-karya.unkaha-astra-portal .ast-single-post-featured-section img {
  width: 100% !important;
  max-height: 420px !important;
  object-fit: contain !important;
  object-position: center center !important;
  background: #eaf8fb !important;
  display: block !important;
}

/* Mobile */
@media (max-width: 768px) {
  body.unkaha-astra-portal .unkaha-wrap,
  body.unkaha-astra-portal .unkaha-section__head,
  body.unkaha-astra-portal .unkaha-karya-grid,
  body.unkaha-astra-portal .unkaha-prodi-grid,
  body.unkaha-astra-portal .unkaha-card-grid,
  body.unkaha-astra-portal .upkc-wrap,
  body.unkaha-astra-portal .upkc-dashboard,
  body.unkaha-astra-portal .upkc-submit-wrap,
  body.unkaha-astra-portal .upkc-auth-wrap {
    width: calc(100% - 24px) !important;
  }

  body.unkaha-astra-portal .site-header .ast-container,
  body.unkaha-astra-portal .ast-primary-header-bar .ast-container,
  body.unkaha-astra-portal .ast-main-header-wrap .ast-container {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  body.unkaha-astra-portal .ast-builder-grid-row {
    width: 100% !important;
  }

  body.unkaha-astra-portal .upkc-card-v2 .upkc-card-media {
    aspect-ratio: 16 / 9 !important;
  }

  body.single-karya.unkaha-astra-portal .post-thumb,
  body.single-karya.unkaha-astra-portal .ast-single-post-featured-section,
  body.single-karya.unkaha-astra-portal .post-thumb img,
  body.single-karya.unkaha-astra-portal .wp-post-image,
  body.single-karya.unkaha-astra-portal .ast-single-post-featured-section img {
    max-height: 320px !important;
  }
}


.upkc-turnstile-wrap {
    margin: 16px 0;
}
