
:root {
  --primary: #1A3A6B;
  --accent: #FFCA1A;
  --bg: var(--primary);
  --bg-2: #102744;
  --panel: rgba(16, 39, 68, 0.82);
  --panel-strong: rgba(16, 39, 68, 0.94);
  --panel-soft: rgba(255,255,255,0.05);
  --line: rgba(228, 196, 122, 0.22);
  --line-strong: rgba(228, 196, 122, 0.5);
  --gold: var(--accent);
  --gold-soft: #ffe48a;
  --emerald: var(--primary);
  --emerald-2: #25528f;
  --text: #eef4ef;
  --text-soft: rgba(238, 244, 239, 0.78);
  --muted: rgba(238, 244, 239, 0.58);
  --shadow: 0 24px 70px rgba(0,0,0,0.34);
  --radius: 28px;
  --radius-lg: 38px;
  --arabic-font: "Reem Kufi", "Noto Kufi Arabic", "Noto Naskh Arabic", Tahoma, Arial, sans-serif;
  --safe-bottom: env(safe-area-inset-bottom, 0px);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-height: 100vh;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at 50% -15%, rgba(255,202,26,0.18), transparent 26%),
    radial-gradient(circle at 0 20%, rgba(255,202,26,0.10), transparent 18%),
    radial-gradient(circle at 100% 14%, rgba(37, 82, 143, 0.35), transparent 22%),
    linear-gradient(180deg, #1A3A6B 0%, #102744 52%, #081a33 100%);
  overflow-x: hidden;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: .18;
  background-image:
    radial-gradient(circle at center, rgba(227,190,113,.62) 0 1px, transparent 2px),
    linear-gradient(60deg, transparent 46%, rgba(227,190,113,.18) 47% 53%, transparent 54%),
    linear-gradient(-60deg, transparent 46%, rgba(227,190,113,.12) 47% 53%, transparent 54%);
  background-size: 36px 36px, 64px 64px, 64px 64px;
}
body::after {
  content: "";
  position: fixed;
  inset: auto 0 0;
  height: 28vh;
  pointer-events: none;
  background: linear-gradient(to top, rgba(0,0,0,.35), transparent 75%);
}
button, input, textarea, select { font: inherit; }
button { cursor: pointer; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.hidden { display: none !important; }
#app { min-height: 100vh; }

.loading-screen,
.not-found-screen {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 28px;
}
.spinner {
  width: 48px;
  height: 48px;
  border: 4px solid rgba(227,190,113,.2);
  border-top-color: var(--gold);
  border-radius: 50%;
  margin: 0 auto 14px;
  animation: spin .8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

.public-page {
  min-height: 100svh;
  position: relative;
  padding: 20px 0 112px;
  overflow: hidden;
}
.public-page::before,
.public-page::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
}
.public-page::before {
  opacity: .14;
  background:
    radial-gradient(circle at 12% 20%, rgba(255,255,255,.10), transparent 8%),
    radial-gradient(circle at 85% 30%, rgba(255,255,255,.10), transparent 10%),
    radial-gradient(circle at 40% 80%, rgba(255,255,255,.08), transparent 12%);
}
.public-page::after {
  opacity: .2;
  background:
    linear-gradient(90deg, rgba(0,0,0,0) 0 2%, rgba(255,255,255,.02) 2% 2.2%, transparent 2.2%),
    linear-gradient(180deg, rgba(0,0,0,0) 0 2%, rgba(255,255,255,.02) 2% 2.2%, transparent 2.2%);
  background-size: 20px 20px;
  mask-image: linear-gradient(180deg, rgba(0,0,0,.65), transparent 70%);
}

.stage {
  width: min(100%, 1080px);
  margin: 0 auto;
  padding: clamp(16px, 3.2vw, 30px);
  position: relative;
  z-index: 1;
}
.turkish-frame {
  position: absolute;
  inset: 8px 8px auto;
  height: min(78vh, 1080px);
  pointer-events: none;
  border: 1px solid rgba(227,190,113,.18);
  border-radius: 42px;
  background:
    linear-gradient(180deg, rgba(227,190,113,.05), rgba(227,190,113,0)),
    radial-gradient(circle at top center, rgba(227,190,113,.08), transparent 42%);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.03);
}
.turkish-frame::before,
.turkish-frame::after {
  content: "";
  position: absolute;
  inset: 18px;
  border-radius: 34px;
  border: 1px solid rgba(227,190,113,.12);
}
.turkish-frame::after {
  inset: 32px;
  border-style: dashed;
  opacity: .45;
}

.hero-panel {
  position: relative;
  overflow: hidden;
  min-height: clamp(620px, 72vh, 1180px);
  padding: clamp(24px, 4vw, 42px);
  border-radius: 34px;
  border: 1px solid rgba(227,190,113,.18);
  background:
    linear-gradient(135deg, rgba(198,31,47,.16) 0 14%, transparent 14% 100%),
    linear-gradient(225deg, rgba(15,78,68,.35) 0 18%, transparent 18% 100%),
    linear-gradient(180deg, rgba(10,26,23,.84), rgba(10,26,23,.96)),
    linear-gradient(90deg, rgba(255,255,255,.03), rgba(255,255,255,0));
  box-shadow: var(--shadow);
}
.hero-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 0, rgba(227,190,113,.22), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.04), transparent 18%),
    radial-gradient(circle at 50% 26%, rgba(255,255,255,.05), transparent 48%);
  pointer-events: none;
}
.hero-panel::after {
  content: "";
  position: absolute;
  inset: auto 22px 18px;
  height: 120px;
  border-radius: 120px;
  background: radial-gradient(ellipse at center, rgba(227,190,113,.12), transparent 70%);
  pointer-events: none;
}
.hero-ornament {
  position: absolute;
  top: 0;
  bottom: 0;
  width: min(16vw, 128px);
  opacity: .55;
  pointer-events: none;
  border-inline: 1px solid rgba(227,190,113,.18);
}
.ornament-left {
  left: 0;
  background:
    linear-gradient(180deg, rgba(198,31,47,.45), rgba(198,31,47,0) 28%),
    linear-gradient(180deg, rgba(15,78,68,0) 0 28%, rgba(15,78,68,.55) 28% 62%, rgba(0,0,0,0) 62%),
    linear-gradient(180deg, rgba(0,0,0,0) 0 62%, rgba(15,15,15,.8) 62% 100%);
  clip-path: polygon(0 0, 100% 10%, 42% 100%, 0 100%);
}
.ornament-right {
  right: 0;
  background:
    linear-gradient(180deg, rgba(198,31,47,.45), rgba(198,31,47,0) 28%),
    linear-gradient(180deg, rgba(15,78,68,0) 0 28%, rgba(15,78,68,.55) 28% 62%, rgba(0,0,0,0) 62%),
    linear-gradient(180deg, rgba(0,0,0,0) 0 62%, rgba(15,15,15,.8) 62% 100%);
  clip-path: polygon(0 10%, 100% 0, 100% 100%, 58% 100%);
}
.lantern {
  position: absolute;
  top: 22px;
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  color: var(--gold);
  border-radius: 50%;
  border: 1px solid rgba(227,190,113,.38);
  background: rgba(8, 23, 20, .65);
  box-shadow: 0 0 18px rgba(227,190,113,.12), inset 0 0 0 1px rgba(255,255,255,.04);
}
.lantern-left { left: 24px; }
.lantern-right { right: 24px; }

.logo-aura {
  position: relative;
  width: clamp(160px, 22vw, 260px);
  height: clamp(160px, 22vw, 260px);
  margin: 12px auto 14px;
  display: grid;
  place-items: center;
  animation: logoFloat 6s ease-in-out infinite;
}
.logo-aura::before,
.logo-aura::after {
  content: "";
  position: absolute;
  inset: -8%;
  border-radius: 50%;
  border: 1px solid rgba(227,190,113,.34);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.04), 0 0 22px rgba(227,190,113,.12);
}
.logo-aura::after {
  inset: -20%;
  opacity: .55;
  border-style: dashed;
}
.brand-logo {
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: drop-shadow(0 8px 20px rgba(0,0,0,.38));
  animation: logoZoom 6s ease-in-out infinite;
}
@keyframes logoFloat { 0%,100%{transform: translateY(0);} 50%{transform: translateY(-4px);} }
@keyframes logoZoom { 0%,100%{transform: scale(.96);} 50%{transform: scale(1.03);} }
.logo-caption {
  margin: 0;
  text-transform: uppercase;
  letter-spacing: .28em;
  font-size: clamp(11px, 1.6vw, 14px);
  color: var(--gold);
  opacity: .95;
}
.brand-title {
  margin: 12px auto 10px;
  max-width: 14ch;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(34px, 6.3vw, 74px);
  line-height: 1.02;
  text-wrap: balance;
}
.gold-divider,
.mini-divider {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  color: var(--gold);
}
.gold-divider::before,
.gold-divider::after,
.mini-divider::before,
.mini-divider::after {
  content: "";
  width: min(18vw, 120px);
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(227,190,113,.7), transparent);
}
.arabic-script {
  font-family: var(--arabic-font);
  font-weight: 500;
  margin: 16px auto 8px;
  font-size: clamp(26px, 4.5vw, 48px);
  color: var(--gold-soft);
  line-height: 1.45;
}
.script-translation {
  margin: 10px auto 0;
  max-width: 36ch;
  color: var(--text-soft);
  font-size: clamp(15px, 2vw, 18px);
  line-height: 1.7;
}
.hero-desc {
  margin: 18px auto 0;
  max-width: 56ch;
  color: var(--text-soft);
  font-size: clamp(15px, 2vw, 19px);
  line-height: 1.8;
}
.demo-alert {
  margin: 0 auto 16px;
  width: min(100%, 840px);
  padding: 12px 16px;
  border-radius: 16px;
  background: rgba(198,31,47,.16);
  border: 1px solid rgba(198,31,47,.24);
  color: #ffe8d8;
  text-align: center;
}

.mission-card {
  display: grid;
  grid-template-columns: 84px 1fr;
  gap: 16px;
  align-items: center;
  width: min(100%, 820px);
  margin: -38px auto 24px;
  padding: 18px 20px;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  border: 1px solid rgba(227,190,113,.2);
  backdrop-filter: blur(12px);
  box-shadow: 0 20px 44px rgba(0,0,0,.24);
}
.mission-medallion {
  width: 84px;
  height: 84px;
  border-radius: 24px;
  display: grid;
  place-items: center;
  font-size: 34px;
  color: var(--gold);
  background: radial-gradient(circle at 30% 30%, rgba(227,190,113,.22), rgba(255,255,255,.04));
  border: 1px solid rgba(227,190,113,.24);
}
.mission-copy h2 {
  margin: 0 0 10px;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(24px, 3.5vw, 42px);
  line-height: 1.1;
}
.mission-copy p {
  margin: 10px 0 0;
  color: var(--text-soft);
  line-height: 1.7;
}

.link-list {
  display: grid;
  gap: 14px;
  width: min(100%, 860px);
  margin: 0 auto;
}
.bio-link {
  position: relative;
  display: grid;
  grid-template-columns: 68px 1fr 22px;
  align-items: center;
  gap: 14px;
  padding: 14px 18px 14px 14px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.10);
  color: var(--btn-text, #fff);
  background:
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.02)),
    var(--btn-bg, var(--primary));
  box-shadow: 0 12px 28px rgba(0,0,0,.18);
  overflow: hidden;
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.bio-link::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, rgba(255,255,255,.18), transparent 26%),
    linear-gradient(45deg, transparent 72%, rgba(255,255,255,.09) 72% 78%, transparent 78%);
  pointer-events: none;
}
.bio-link:hover,
.bio-link:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(227,190,113,.42);
  box-shadow: 0 16px 32px rgba(0,0,0,.24);
}
.link-medallion {
  width: 54px;
  height: 54px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  font-size: 28px;
  background: rgba(0,0,0,.18);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.06);
}
.link-copy { display: grid; gap: 4px; }
.link-copy strong {
  font-size: clamp(20px, 2.5vw, 28px);
  font-weight: 800;
  line-height: 1.1;
}
.link-copy small {
  font-size: clamp(12px, 1.6vw, 16px);
  color: rgba(255,255,255,.84);
}
.link-arrow {
  font-size: 34px;
  line-height: 1;
  opacity: .9;
}
.empty-links {
  padding: 24px;
  border-radius: 18px;
  text-align: center;
  background: rgba(255,255,255,.04);
  border: 1px dashed rgba(227,190,113,.26);
  color: var(--text-soft);
}
.footer {
  text-align: center;
  color: var(--muted);
  padding: 28px 0 12px;
  font-size: 14px;
}
.audio-fab,
.share-fab {
  position: fixed;
  right: max(16px, calc(16px + env(safe-area-inset-right)));
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: 1px solid rgba(227,190,113,.38);
  background: rgba(10,26,23,.88);
  color: var(--gold);
  box-shadow: 0 16px 30px rgba(0,0,0,.25), inset 0 0 0 1px rgba(255,255,255,.04);
  backdrop-filter: blur(10px);
  z-index: 20;
}
.audio-fab { bottom: calc(16px + var(--safe-bottom)); font-size: 22px; }
.audio-fab.is-playing { color: #fff4cf; box-shadow: 0 0 0 4px rgba(227,190,113,.08), 0 16px 30px rgba(0,0,0,.25); }
.share-fab { bottom: calc(80px + var(--safe-bottom)); font-size: 18px; }
.toast {
  position: fixed;
  left: 50%;
  bottom: calc(18px + var(--safe-bottom));
  transform: translate(-50%, 140%);
  padding: 12px 16px;
  border-radius: 999px;
  background: rgba(10, 26, 23, .94);
  border: 1px solid rgba(227,190,113,.26);
  color: #fff;
  transition: transform .25s ease;
  z-index: 25;
  white-space: nowrap;
}
.toast.show { transform: translate(-50%, 0); }
.snow-layer {
  position: fixed;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 2;
}
.snow-layer span {
  position: absolute;
  top: -10%;
  color: rgba(255,255,255,.48);
  animation: snowFall linear infinite;
}
@keyframes snowFall {
  from { transform: translate3d(0, -10vh, 0) rotate(0deg); }
  to { transform: translate3d(22px, 110vh, 0) rotate(260deg); }
}

.admin-page { min-height: 100vh; padding: 24px; }
.admin-shell { width: min(100%, 1320px); margin: 0 auto; }
.panel {
  border-radius: 28px;
  border: 1px solid rgba(227,190,113,.16);
  background: rgba(10,26,23,.78);
  box-shadow: var(--shadow);
  backdrop-filter: blur(14px);
}
.admin-topbar {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: center;
  padding: 20px 24px;
  margin-bottom: 22px;
  border-radius: 28px;
  border: 1px solid rgba(227,190,113,.16);
  background: rgba(10,26,23,.82);
  box-shadow: var(--shadow);
}
.admin-brand { display: flex; gap: 16px; align-items: center; }
.admin-brand img,
.login-logo { width: 72px; aspect-ratio: 1; object-fit: contain; }
.admin-title,
.login-title {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(28px, 3vw, 40px);
}
.gradient-text {
  background: linear-gradient(135deg, #fff, var(--gold-soft) 35%, var(--gold) 70%, #fff);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.admin-subtitle,
.login-desc,
.panel-desc { margin: 6px 0 0; color: var(--text-soft); line-height: 1.6; }
.admin-grid { display: grid; grid-template-columns: minmax(0, 1.12fr) minmax(320px, .88fr); gap: 22px; }
.panel-header { padding: 22px 24px 0; }
.panel-title { margin: 0; font-size: 22px; }
.panel-body { padding: 22px 24px 24px; }
.preview-sticky { position: sticky; top: 16px; align-self: start; }
.preview-phone {
  margin: 0 auto;
  width: min(100%, 390px);
  min-height: 760px;
  padding: 12px;
  border-radius: 40px;
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.02));
  border: 1px solid rgba(227,190,113,.16);
}
.preview-screen {
  overflow: hidden;
  border-radius: 28px;
  border: 1px solid rgba(227,190,113,.12);
  min-height: 736px;
}
.preview-screen .public-page { padding: 6px 0 88px; }
.preview-screen .stage { padding: 10px; }
.preview-screen .turkish-frame { inset: 2px 2px auto; height: 95%; }
.preview-screen .hero-panel { min-height: 560px; }
.preview-screen .mission-card { margin-top: -28px; }
.preview-screen .audio-fab,
.preview-screen .share-fab,
.preview-screen .toast,
.preview-screen .snow-layer { display: none !important; }
.login-card { width: min(100%, 520px); margin: 8vh auto 0; padding: 26px; text-align: center; }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.field-full { grid-column: 1 / -1; }
.label { display: block; margin: 0 0 8px; color: var(--text-soft); }
.input, .select {
  width: 100%;
  padding: 13px 14px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: #fff;
  outline: none;
}
.input::placeholder { color: rgba(255,255,255,.38); }
.input:focus, .select:focus {
  border-color: rgba(227,190,113,.4);
  box-shadow: 0 0 0 4px rgba(227,190,113,.08);
}
.check-row {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--text-soft);
  padding-top: 4px;
}
.button-row { display: flex; flex-wrap: wrap; gap: 10px; }
.admin-actions { margin-top: 18px; }
.primary-button,
.secondary-button,
.outline-button,
.ghost-button,
.danger-button,
.pill-button {
  border: 0;
  border-radius: 14px;
  padding: 12px 16px;
  color: #fff;
  background: rgba(255,255,255,.08);
}
.primary-button { background: linear-gradient(135deg, #c31f2f, #8c1724); }
.secondary-button { background: linear-gradient(135deg, var(--emerald-2), var(--primary)); }
.outline-button { border: 1px solid rgba(227,190,113,.3); background: transparent; }
.ghost-button { background: rgba(255,255,255,.05); }
.danger-button { background: linear-gradient(135deg, #8c1724, #5f1118); }
.pill-button {
  padding: 8px 12px;
  font-size: 12px;
  color: var(--gold-soft);
  background: rgba(227,190,113,.08);
  border: 1px solid rgba(227,190,113,.18);
}
.message {
  margin-top: 12px;
  padding: 12px 14px;
  border-radius: 14px;
  background: rgba(255,255,255,.05);
  color: var(--text-soft);
}
.message-success { background: rgba(10, 120, 72, .18); color: #cffff0; }
.message-error { background: rgba(175, 40, 53, .2); color: #ffe5e5; }
.form-section + .form-section { margin-top: 24px; }
.form-section-title { margin: 0 0 14px; font-size: 18px; color: var(--gold-soft); }
.link-editor-list { display: grid; gap: 14px; }
.link-editor-card {
  padding: 16px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
}
.link-card-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: start;
  margin-bottom: 12px;
}
.link-card-title { margin: 0; font-size: 18px; }
.link-card-url { margin: 6px 0 0; color: var(--muted); word-break: break-word; font-size: 14px; }

@media (max-width: 980px) {
  .admin-grid { grid-template-columns: 1fr; }
  .preview-sticky { position: static; }
}
@media (max-width: 720px) {
  .admin-page { padding: 16px; }
  .admin-topbar { padding: 18px; align-items: start; flex-direction: column; }
  .form-grid { grid-template-columns: 1fr; }
  .hero-panel { min-height: 520px; }
  .mission-card { grid-template-columns: 1fr; text-align: center; }
  .mission-medallion { margin: 0 auto; }
  .bio-link { grid-template-columns: 54px 1fr 20px; padding: 12px 14px; }
  .link-medallion { width: 46px; height: 46px; font-size: 24px; }
}


/* =========================================================
   Admin UI v5 - disesuaikan dengan referensi dashboard
   ========================================================= */
.admin-page.admin-light {
  min-height: 100vh;
  padding: clamp(16px, 2.4vw, 30px);
  color: #3a2a21;
  background:
    radial-gradient(circle at 15% 4%, rgba(190, 70, 20, .14), transparent 22%),
    radial-gradient(circle at 86% 18%, rgba(99, 16, 120, .12), transparent 24%),
    linear-gradient(135deg, #fffdf8, #f9f1ee 52%, #f5edf7);
}
.admin-light .loading-screen { color: #3d2242; }
.admin-light .admin-reference-shell { width: min(100%, 1560px); }
.admin-light .admin-reference-header,
.admin-light .admin-card,
.admin-light .admin-login-card {
  background: rgba(255,255,255,.86);
  border: 1px solid #eaddee;
  box-shadow: 0 24px 60px rgba(87, 38, 81, .10);
  backdrop-filter: blur(14px);
}
.admin-light .admin-reference-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
  padding: 20px 24px;
  border-radius: 30px;
  margin-bottom: 24px;
}
.admin-light .admin-reference-brand {
  display: flex;
  align-items: center;
  gap: 16px;
}
.admin-light .admin-reference-brand img {
  width: 72px;
  height: 72px;
  object-fit: contain;
  border-radius: 22px;
  background: linear-gradient(135deg, #3e124c, #c34d17);
  padding: 10px;
}
.admin-light .eyebrow {
  margin: 0 0 5px;
  color: #4e0e63;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.admin-light .admin-reference-brand h1,
.admin-light .admin-login-card h1 {
  margin: 0;
  color: #3a0a4b;
  font-family: inherit;
  font-size: clamp(26px, 3vw, 42px);
  line-height: 1.05;
}
.admin-light .admin-reference-brand p:not(.eyebrow),
.admin-light .login-desc {
  margin: 8px 0 0;
  color: #7a665d;
  line-height: 1.55;
}
.admin-light .admin-reference-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.65fr) minmax(380px, .85fr);
  gap: 24px;
  align-items: start;
}
.admin-light .admin-reference-main { display: grid; gap: 20px; }
.admin-light .admin-card {
  border-radius: 30px;
  padding: clamp(20px, 2.4vw, 28px);
}
.admin-light .admin-card h2 {
  margin: 0 0 18px;
  color: #4e0e63;
  font-size: clamp(20px, 2vw, 26px);
  line-height: 1.15;
}
.admin-light .action-strip {
  display: flex;
  gap: 14px;
  align-items: center;
  padding: 18px;
}
.admin-light .reference-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}
.admin-light .field-full { grid-column: 1 / -1; }
.admin-light .optional-field { display: block; }
.admin-light .label {
  color: #71605a;
  font-weight: 900;
  font-size: 13px;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.admin-light .input,
.admin-light .select {
  background: rgba(255,255,255,.92);
  color: #37241f;
  border: 1px solid #dfcde6;
  border-radius: 18px;
  padding: 15px 16px;
  min-height: 58px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.8);
}
.admin-light .input::placeholder { color: #9a8c88; }
.admin-light .input:focus,
.admin-light .select:focus {
  border-color: #7b1a83;
  box-shadow: 0 0 0 4px rgba(123, 26, 131, .08);
}
.admin-light .color-input {
  padding: 8px 12px;
  height: 58px;
}
.admin-light .reference-check {
  grid-column: 1 / -1;
  color: #6b574e;
  font-weight: 800;
  font-size: 16px;
}
.admin-light .reference-check input { width: 20px; height: 20px; accent-color: #6b1a80; }
.admin-light .button-row { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.admin-light .primary-button,
.admin-light .secondary-button,
.admin-light .outline-button,
.admin-light .ghost-button,
.admin-light .soft-button,
.admin-light .warning-button,
.admin-light .danger-button {
  border-radius: 18px;
  border: 0;
  padding: 14px 20px;
  font-weight: 900;
  text-decoration: none;
  transition: transform .16s ease, box-shadow .16s ease, opacity .16s ease;
}
.admin-light .primary-button {
  background: linear-gradient(135deg, #c85116, #641068);
  color: #fff;
  box-shadow: 0 16px 32px rgba(100, 16, 104, .18);
}
.admin-light .secondary-button {
  background: linear-gradient(135deg, var(--emerald-2), var(--primary));
  color: #fff;
}
.admin-light .outline-button {
  border: 1px solid #dfcde6;
  color: #4e0e63;
  background: rgba(255,255,255,.7);
}
.admin-light .ghost-button,
.admin-light .soft-button {
  color: #4e0e63;
  background: #f3ecf6;
}
.admin-light .warning-button {
  color: #9d2a17;
  background: #fff0ea;
}
.admin-light .danger-button {
  color: #fff;
  background: linear-gradient(135deg, #9f1f2c, #68101c);
}
.admin-light button:hover,
.admin-light .outline-button:hover { transform: translateY(-1px); }
.admin-light .reference-link-list { display: grid; gap: 14px; }
.admin-light .reference-link-card {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 14px;
  align-items: start;
  padding: 18px;
  border-radius: 24px;
  border: 1px solid #eaddee;
  background: rgba(255,255,255,.78);
}
.admin-light .reference-link-card.is-inactive { opacity: .68; }
.admin-light .link-card-main {
  display: flex;
  gap: 12px;
  min-width: 0;
}
.admin-light .link-card-icon {
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: #f3ecf6;
  color: #6b1a80;
  flex: 0 0 auto;
}
.admin-light .reference-link-card h3 {
  margin: 0 0 5px;
  color: #34231d;
  font-size: 18px;
}
.admin-light .reference-link-card p {
  margin: 0;
  color: #7a665d;
  word-break: break-word;
  font-size: 14px;
}
.admin-light .reference-link-card small {
  display: block;
  margin-top: 5px;
  color: #8b6e88;
}
.admin-light .link-card-side {
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: end;
}
.admin-light .number-badge,
.admin-light .status-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 54px;
  min-height: 38px;
  padding: 8px 12px;
  border-radius: 999px;
  font-weight: 900;
  background: rgba(255,255,255,.9);
  border: 1px solid #dfcde6;
  color: #34231d;
}
.admin-light .status-badge.on { color: #0f6d4e; background: #e9fff4; border-color: #c9f0dd; }
.admin-light .status-badge.off { color: #a02d28; background: #fff0ee; border-color: #f2d3ce; }
.admin-light .link-card-actions { grid-column: 1 / -1; }
.admin-light .stats-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.admin-light .stat-card {
  min-height: 98px;
  padding: 18px;
  border-radius: 22px;
  border: 1px solid #eaddee;
  background: rgba(255,255,255,.78);
}
.admin-light .stat-card strong {
  display: block;
  color: #34231d;
  font-size: 32px;
  line-height: 1;
  margin-bottom: 10px;
}
.admin-light .stat-card span {
  color: #71605a;
  font-weight: 900;
}
.admin-light .admin-reference-preview {
  position: sticky;
  top: 18px;
  min-height: calc(100svh - 36px);
  display: grid;
  place-items: start center;
}
.admin-light .phone-shell {
  width: min(100%, 430px);
  height: min(89vh, 920px);
  padding: 12px;
  border-radius: 42px;
  background: #151515;
  box-shadow: 0 32px 70px rgba(35, 13, 44, .22);
  border: 1px solid rgba(255,255,255,.18);
}
.admin-light .preview-screen {
  height: 100%;
  min-height: 0;
  overflow: auto;
  border-radius: 32px;
  background: var(--primary);
  border: 0;
}
.admin-light .preview-screen .public-page { padding: 4px 0 84px; }
.admin-light .preview-screen .stage { padding: 10px; }
.admin-light .preview-screen .hero-panel { min-height: 600px; }
.admin-light .preview-screen .brand-title { font-size: 34px; }
.admin-light .preview-screen .arabic-script { font-size: 30px; }
.admin-light .preview-screen .mission-card { margin-top: -26px; grid-template-columns: 1fr; text-align: center; }
.admin-light .preview-screen .mission-medallion { margin: 0 auto; }
.admin-light .preview-screen .bio-link { grid-template-columns: 52px 1fr 18px; }
.admin-light .preview-screen .audio-fab,
.admin-light .preview-screen .share-fab,
.admin-light .preview-screen .toast,
.admin-light .preview-screen .snow-layer { display: none !important; }
.admin-light .admin-login-card {
  width: min(100%, 560px);
  margin: 8vh auto 0;
  padding: 34px;
  border-radius: 32px;
  text-align: center;
}
.admin-light .admin-login-brand {
  width: 96px;
  height: 96px;
  display: grid;
  place-items: center;
  margin: 0 auto 16px;
  border-radius: 28px;
  background: linear-gradient(135deg, #3e124c, #c34d17);
  box-shadow: 0 22px 44px rgba(100,16,104,.16);
}
.admin-light .admin-login-brand img { width: 78px; height: 78px; object-fit: contain; }
.admin-light .login-form { margin-top: 22px; text-align: left; }
.admin-light .message {
  color: #654f47;
  background: #fbf5fb;
  border: 1px solid #eaddee;
}
.admin-light .message-success { color: #0f6d4e; background: #ecfff6; border-color: #c9f0dd; }
.admin-light .message-error { color: #9f1f2c; background: #fff0ee; border-color: #f2d3ce; }
.admin-light .empty-links {
  color: #7a665d;
  border-color: #eaddee;
  background: rgba(255,255,255,.62);
}

@media (max-width: 1120px) {
  .admin-light .admin-reference-grid { grid-template-columns: 1fr; }
  .admin-light .admin-reference-preview { position: static; min-height: auto; }
  .admin-light .phone-shell { height: 760px; }
}
@media (max-width: 760px) {
  .admin-page.admin-light { padding: 12px; }
  .admin-light .admin-reference-header { flex-direction: column; align-items: stretch; }
  .admin-light .admin-reference-brand { align-items: flex-start; }
  .admin-light .reference-form-grid,
  .admin-light .stats-grid { grid-template-columns: 1fr; }
  .admin-light .reference-link-card { grid-template-columns: 1fr; }
  .admin-light .link-card-side { flex-direction: row; align-items: center; }
  .admin-light .phone-shell { width: 100%; height: 720px; }
}


/* v6: elemen pada kotak merah dihapus: caption, judul besar, dan mission card. */
.logo-caption,
.brand-title,
.mission-card {
  display: none !important;
}
.compact-divider {
  margin-top: 18px;
  margin-bottom: 8px;
}
.hero-panel {
  min-height: clamp(560px, 61vh, 980px);
  padding-bottom: clamp(26px, 4vw, 48px);
}
.link-list {
  margin-top: 24px;
}
.preview-screen .hero-panel {
  min-height: 500px;
}
.preview-screen .link-list {
  margin-top: 18px;
}
@media (max-width: 720px) {
  .hero-panel {
    min-height: 500px;
  }
  .link-list {
    margin-top: 18px;
  }
}

/* v7: penyempurnaan tampilan mobile - ayat diperkecil, logo diperkecil, dan layout lebih compact. */
.public-page {
  padding-top: 10px;
  padding-bottom: 104px;
}
.stage {
  padding: clamp(10px, 2.6vw, 22px);
}
.hero-panel {
  min-height: auto !important;
  padding: clamp(22px, 5vw, 46px) clamp(18px, 5vw, 48px) clamp(24px, 5vw, 44px) !important;
  border-radius: 30px;
  text-align: center;
}
.logo-aura {
  width: clamp(108px, 24vw, 178px) !important;
  height: clamp(108px, 24vw, 178px) !important;
  margin: 4px auto 14px !important;
}
.logo-aura::before {
  inset: -6%;
}
.logo-aura::after {
  inset: -16%;
  opacity: .42;
}
.brand-logo {
  width: 96% !important;
  height: 96% !important;
}
.compact-divider {
  margin-top: 8px !important;
  margin-bottom: 10px !important;
}
.gold-divider::before,
.gold-divider::after {
  width: min(14vw, 76px);
}
.arabic-script {
  font-family: var(--arabic-font);
  font-weight: 500;
  width: min(100%, 680px);
  margin: 12px auto 8px !important;
  text-align: center !important;
  font-size: clamp(24px, 6vw, 38px) !important;
  line-height: 1.42 !important;
  letter-spacing: 0;
  color: #fff1c4;
  text-wrap: balance;
}
.script-translation {
  max-width: 34ch !important;
  margin: 8px auto 0 !important;
  text-align: center !important;
  font-size: clamp(13px, 3.25vw, 16px) !important;
  line-height: 1.65 !important;
  color: rgba(238,244,239,.76);
}
.hero-desc {
  max-width: 36ch !important;
  margin: 16px auto 0 !important;
  text-align: center !important;
  font-size: clamp(13px, 3.2vw, 16px) !important;
  line-height: 1.75 !important;
  color: rgba(238,244,239,.70);
}
.link-list {
  width: min(100%, 760px);
  margin-top: 18px !important;
  gap: 12px;
}
.bio-link {
  min-height: 72px;
  border-radius: 20px;
  grid-template-columns: 58px 1fr 20px;
  padding: 12px 16px 12px 12px;
}
.link-medallion {
  width: 48px;
  height: 48px;
  border-radius: 16px;
  font-size: 24px;
}
.link-copy strong {
  font-size: clamp(17px, 4.2vw, 24px);
}
.link-copy small {
  font-size: clamp(11px, 2.9vw, 14px);
  line-height: 1.35;
}
.lantern {
  width: 36px;
  height: 36px;
  top: 18px;
  font-size: 18px;
}
.lantern-left { left: 18px; }
.lantern-right { right: 18px; }
.audio-fab,
.share-fab {
  width: 46px;
  height: 46px;
}
.share-fab { bottom: calc(72px + var(--safe-bottom)); }
.audio-fab { font-size: 20px; }

.preview-screen .logo-aura {
  width: 116px !important;
  height: 116px !important;
}
.preview-screen .hero-panel {
  min-height: auto !important;
  padding: 28px 18px 24px !important;
}
.preview-screen .arabic-script {
  font-size: 25px !important;
  line-height: 1.38 !important;
}
.preview-screen .script-translation,
.preview-screen .hero-desc {
  font-size: 12px !important;
  line-height: 1.55 !important;
}
.preview-screen .link-list {
  margin-top: 14px !important;
}

@media (max-width: 720px) {
  .public-page { padding-top: 8px; }
  .stage { padding: 10px; }
  .hero-panel {
    padding: 24px 18px 22px !important;
    border-radius: 28px;
  }
  .logo-aura {
    width: clamp(104px, 30vw, 142px) !important;
    height: clamp(104px, 30vw, 142px) !important;
    margin-bottom: 10px !important;
  }
  .arabic-script {
    font-size: clamp(23px, 7.4vw, 32px) !important;
    line-height: 1.4 !important;
    max-width: 10.5em;
  }
  .script-translation {
    max-width: 28ch !important;
    font-size: clamp(13px, 3.7vw, 15px) !important;
  }
  .hero-desc {
    max-width: 30ch !important;
    font-size: clamp(13px, 3.7vw, 15px) !important;
  }
  .link-list {
    margin-top: 14px !important;
    gap: 10px;
  }
  .bio-link {
    min-height: 68px;
    grid-template-columns: 50px 1fr 18px;
    padding: 10px 14px 10px 10px;
    border-radius: 18px;
  }
  .link-medallion {
    width: 44px;
    height: 44px;
    border-radius: 14px;
    font-size: 22px;
  }
}

@media (max-width: 390px) {
  .hero-panel { padding-inline: 14px !important; }
  .arabic-script { font-size: 24px !important; }
  .script-translation,
  .hero-desc { font-size: 13px !important; }
}


/* v10: presisi logo dalam lingkaran + akses admin tersembunyi berbentuk bulan. */
.logo-aura {
  width: clamp(118px, 26vw, 176px) !important;
  height: clamp(118px, 26vw, 176px) !important;
  margin-top: 2px !important;
  margin-bottom: 12px !important;
}
.brand-logo {
  width: 76% !important;
  height: 76% !important;
  object-fit: contain !important;
  object-position: center center !important;
  margin: auto !important;
  transform-origin: center center;
}
.logo-aura::before {
  inset: -3% !important;
}
.logo-aura::after {
  inset: -14% !important;
  opacity: .38 !important;
}
.admin-moon-button {
  text-decoration: none;
  width: 34px !important;
  height: 34px !important;
  top: 16px !important;
  right: 16px !important;
  left: auto !important;
  display: grid;
  place-items: center;
  font-size: 17px !important;
  line-height: 1;
  color: rgba(249, 232, 191, .74);
  opacity: .42;
  border-color: rgba(227,190,113,.22);
  background: rgba(6, 15, 13, .42);
  backdrop-filter: blur(8px);
  transition: opacity .2s ease, transform .2s ease, border-color .2s ease;
  z-index: 4;
}
.admin-moon-button:hover,
.admin-moon-button:focus-visible {
  opacity: .9;
  transform: translateY(-1px) scale(1.03);
  border-color: rgba(227,190,113,.52);
  outline: none;
}

@media (max-width: 720px) {
  .logo-aura {
    width: clamp(112px, 30vw, 136px) !important;
    height: clamp(112px, 30vw, 136px) !important;
    margin-top: 0 !important;
    margin-bottom: 10px !important;
  }
  .brand-logo {
    width: 74% !important;
    height: 74% !important;
  }
  .admin-moon-button {
    width: 32px !important;
    height: 32px !important;
    top: 14px !important;
    right: 14px !important;
    font-size: 16px !important;
    opacity: .36;
  }
}

.preview-screen .logo-aura {
  width: 112px !important;
  height: 112px !important;
}
.preview-screen .brand-logo {
  width: 74% !important;
  height: 74% !important;
}
.preview-screen .admin-moon-button {
  width: 28px !important;
  height: 28px !important;
  top: 12px !important;
  right: 12px !important;
  font-size: 14px !important;
  pointer-events: none;
}


/* v11: bingkai khusus area ayat dan arti agar lebih rapi, fokus, dan islami. */
.ayah-frame {
  width: min(100%, 560px);
  margin: 12px auto 0;
  padding: 16px 18px 18px;
  position: relative;
  text-align: center;
  border: 1px solid rgba(227, 190, 113, .28);
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.018)),
    radial-gradient(circle at 50% 0%, rgba(227,190,113,.10), transparent 58%),
    rgba(4, 17, 14, .24);
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.035),
    0 18px 42px rgba(0,0,0,.16);
  backdrop-filter: blur(4px);
}
.ayah-frame::before,
.ayah-frame::after {
  content: "۞";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 26px;
  height: 26px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  color: rgba(227,190,113,.70);
  font-size: 13px;
  background: rgba(6,15,13,.42);
  border: 1px solid rgba(227,190,113,.20);
}
.ayah-frame::before { left: -13px; }
.ayah-frame::after { right: -13px; }
.ayah-frame .compact-divider {
  margin: 0 auto 8px !important;
  opacity: .78;
}
.ayah-frame .arabic-script {
  margin: 4px auto 6px !important;
}
.ayah-frame .script-translation {
  margin-top: 8px !important;
}

@media (max-width: 720px) {
  .ayah-frame {
    width: min(100%, 340px);
    margin-top: 10px;
    padding: 12px 14px 14px;
    border-radius: 20px;
  }
  .ayah-frame::before,
  .ayah-frame::after {
    width: 22px;
    height: 22px;
    font-size: 11px;
  }
  .ayah-frame::before { left: -9px; }
  .ayah-frame::after { right: -9px; }
  .ayah-frame .arabic-script {
    font-size: clamp(20px, 6.8vw, 29px) !important;
    max-width: 10.8em;
  }
  .ayah-frame .script-translation {
    max-width: 27ch !important;
    font-size: clamp(12px, 3.45vw, 14px) !important;
    line-height: 1.7 !important;
  }
}

@media (max-width: 390px) {
  .ayah-frame {
    width: min(100%, 318px);
    padding: 11px 12px 13px;
  }
  .ayah-frame .arabic-script { font-size: 22px !important; }
  .ayah-frame .script-translation { font-size: 12px !important; }
}

.preview-screen .ayah-frame {
  width: min(100%, 300px);
  padding: 10px 12px 12px;
  border-radius: 18px;
}
.preview-screen .ayah-frame::before,
.preview-screen .ayah-frame::after {
  width: 18px;
  height: 18px;
  font-size: 9px;
}
.preview-screen .ayah-frame::before { left: -8px; }
.preview-screen .ayah-frame::after { right: -8px; }


/* v12: mengganti deskripsi yayasan menjadi jadwal shalat, mengikuti pola komponen waktu shalat pada pentest-djpb. */
.prayer-card {
  width: min(100%, 430px);
  margin: 16px auto 0;
  padding: 14px 14px 13px;
  text-align: center;
  border-radius: 24px;
  border: 1px solid rgba(227, 190, 113, .25);
  background:
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.02)),
    radial-gradient(circle at 50% 0%, rgba(227,190,113,.12), transparent 64%),
    rgba(4, 17, 14, .28);
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.03),
    0 16px 34px rgba(0,0,0,.16);
  backdrop-filter: blur(5px);
}
.prayer-kicker {
  margin: 0;
  color: rgba(249,232,191,.74);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.prayer-city {
  margin: 4px 0 11px;
  color: var(--gold-soft);
  font-family: Inter, ui-sans-serif, system-ui, sans-serif;
  font-size: clamp(14px, 2vw, 17px);
  line-height: 1.25;
}
.prayer-next {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 10px;
  margin: 0 auto 10px;
  padding: 10px 12px;
  border-radius: 18px;
  background: rgba(0,0,0,.18);
  border: 1px solid rgba(227,190,113,.18);
  text-align: left;
}
.prayer-next small {
  display: block;
  margin-bottom: 2px;
  color: rgba(238,244,239,.56);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.prayer-next strong {
  display: block;
  color: #fff;
  font-size: 18px;
  line-height: 1.1;
}
.prayer-next b {
  color: var(--gold-soft);
  font-size: 26px;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.prayer-times {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 6px;
}
.prayer-chip {
  display: grid;
  gap: 2px;
  min-width: 0;
  padding: 8px 4px 7px;
  border-radius: 14px;
  background: rgba(255,255,255,.035);
  border: 1px solid rgba(255,255,255,.07);
}
.prayer-chip small {
  color: rgba(238,244,239,.66);
  font-size: 10px;
  font-weight: 800;
  overflow: hidden;
  text-overflow: ellipsis;
}
.prayer-chip b {
  color: rgba(255,255,255,.9);
  font-size: 12px;
  font-variant-numeric: tabular-nums;
}
.prayer-chip.is-next {
  background: linear-gradient(180deg, rgba(227,190,113,.20), rgba(227,190,113,.07));
  border-color: rgba(227,190,113,.42);
  box-shadow: 0 0 0 1px rgba(227,190,113,.06);
}
.prayer-chip.is-next b,
.prayer-chip.is-next small { color: #fff4cf; }
.prayer-date {
  margin: 9px 0 0;
  color: rgba(238,244,239,.54);
  font-size: 11px;
  line-height: 1.45;
}
.prayer-card.is-error .prayer-next b { font-size: 18px; }

@media (max-width: 720px) {
  .prayer-card {
    width: min(100%, 332px);
    margin-top: 12px;
    padding: 12px 12px 11px;
    border-radius: 20px;
  }
  .prayer-city {
    margin-bottom: 9px;
    font-size: 13px;
  }
  .prayer-next {
    padding: 8px 10px;
    border-radius: 16px;
  }
  .prayer-next strong { font-size: 16px; }
  .prayer-next b { font-size: 22px; }
  .prayer-times { gap: 5px; }
  .prayer-chip {
    padding: 7px 3px 6px;
    border-radius: 12px;
  }
  .prayer-chip small { font-size: 9px; }
  .prayer-chip b { font-size: 11px; }
  .link-list { margin-top: 14px !important; }
}

@media (max-width: 390px) {
  .prayer-card { width: min(100%, 306px); }
  .prayer-kicker { font-size: 9px; letter-spacing: .14em; }
  .prayer-next b { font-size: 20px; }
  .prayer-chip small { font-size: 8.5px; }
  .prayer-chip b { font-size: 10.5px; }
}

.preview-screen .prayer-card {
  width: min(100%, 286px);
  margin-top: 10px;
  padding: 10px 10px 9px;
  border-radius: 18px;
}
.preview-screen .prayer-kicker { font-size: 8px; }
.preview-screen .prayer-city { font-size: 11px; margin-bottom: 7px; }
.preview-screen .prayer-next { padding: 7px 8px; margin-bottom: 8px; }
.preview-screen .prayer-next small { font-size: 8px; }
.preview-screen .prayer-next strong { font-size: 13px; }
.preview-screen .prayer-next b { font-size: 18px; }
.preview-screen .prayer-chip { padding: 5px 2px 4px; border-radius: 9px; }
.preview-screen .prayer-chip small { font-size: 7.5px; }
.preview-screen .prayer-chip b { font-size: 9px; }
.preview-screen .prayer-date { font-size: 8px; margin-top: 6px; }


/* v13: hilangkan area ayat/arti, alert fallback publik, dan ikon ornamen kiri. Rapikan logo dengan glow tanpa lingkaran. */
.demo-alert,
.lantern-left,
.ayah-frame {
  display: none !important;
}

.hero-panel {
  min-height: clamp(500px, 64vh, 900px) !important;
}

.logo-aura {
  width: clamp(118px, 24vw, 166px) !important;
  height: clamp(118px, 24vw, 166px) !important;
  margin-top: 4px !important;
  margin-bottom: 16px !important;
  isolation: isolate;
}
.logo-aura::before {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  inset: -42% !important;
  border: 0 !important;
  border-radius: 50% !important;
  background:
    radial-gradient(circle at center, rgba(255, 248, 218, .34) 0%, rgba(227, 190, 113, .21) 24%, rgba(89, 119, 91, .12) 46%, transparent 70%) !important;
  box-shadow: none !important;
  filter: blur(2px);
  opacity: .95 !important;
  z-index: -1;
}
.logo-aura::after {
  content: none !important;
  display: none !important;
}
.brand-logo {
  width: 72% !important;
  height: 72% !important;
  filter: drop-shadow(0 14px 24px rgba(0,0,0,.38)) drop-shadow(0 0 18px rgba(255,248,218,.10)) !important;
}

.prayer-card {
  margin-top: 10px !important;
}

@media (max-width: 720px) {
  .hero-panel {
    min-height: 500px !important;
    padding-top: 32px !important;
  }
  .logo-aura {
    width: clamp(108px, 28vw, 126px) !important;
    height: clamp(108px, 28vw, 126px) !important;
    margin-bottom: 12px !important;
  }
  .brand-logo {
    width: 72% !important;
    height: 72% !important;
  }
  .prayer-card {
    margin-top: 8px !important;
  }
}

.preview-screen .logo-aura {
  width: 104px !important;
  height: 104px !important;
}
.preview-screen .brand-logo {
  width: 72% !important;
  height: 72% !important;
}
.preview-screen .hero-panel {
  min-height: 540px !important;
}


/* Slug manager */
.slug-manager { display: grid; gap: 14px; }
.slug-current-card {
  display: grid;
  gap: 6px;
  padding: 16px 18px;
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(15, 78, 68, .12), rgba(227, 190, 113, .08));
  border: 1px solid rgba(90, 23, 109, .12);
}
.slug-current-card .slug-label {
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: 11px;
  font-weight: 800;
  color: rgba(70, 42, 18, .62);
}
.slug-current-card strong {
  font-size: 26px;
  color: #3b0751;
}
.slug-current-card a {
  font-size: 14px;
  color: #8a3d0b;
  word-break: break-all;
}
.slug-help {
  margin: -2px 0 0;
  color: rgba(56, 42, 34, .70);
  font-size: 14px;
  line-height: 1.55;
}
.slug-form-grid { align-items: end; }


/* v15: rapikan jarak hero agar tidak ada ruang kosong besar antara jadwal shalat dan link. */
.hero-panel {
  min-height: auto !important;
  padding-bottom: clamp(24px, 4vw, 36px) !important;
}
.link-list {
  margin-top: clamp(10px, 2vw, 16px) !important;
}
@media (max-width: 720px) {
  .hero-panel {
    min-height: auto !important;
    padding-top: 28px !important;
    padding-bottom: 22px !important;
  }
  .prayer-card {
    margin-bottom: 0 !important;
  }
  .link-list {
    margin-top: 10px !important;
  }
}
.preview-screen .hero-panel {
  min-height: auto !important;
  padding-bottom: 18px !important;
}
.preview-screen .link-list {
  margin-top: 8px !important;
}


/* v16: final mobile-first polish 1080x1920 + proporsional public view */
:root {
  --mobile-content: min(100%, 780px);
}

.public-page {
  min-height: 100svh !important;
  padding: clamp(10px, 1.8vh, 22px) 0 calc(78px + var(--safe-bottom)) !important;
  display: flex !important;
  align-items: flex-start !important;
  justify-content: center !important;
}

.stage {
  width: min(100%, 980px) !important;
  padding: clamp(12px, 2.6vw, 28px) !important;
}

.turkish-frame {
  inset: 10px 10px auto !important;
  height: auto !important;
  bottom: 10px !important;
  border-radius: 34px !important;
  opacity: .76 !important;
}

.hero-panel {
  width: var(--mobile-content) !important;
  margin: 0 auto !important;
  min-height: auto !important;
  padding: clamp(34px, 5.5vh, 72px) clamp(18px, 4vw, 44px) clamp(30px, 4.4vh, 52px) !important;
  border-radius: clamp(28px, 4vw, 44px) !important;
  background:
    radial-gradient(circle at 50% 18%, rgba(241, 222, 158, .18), transparent 27%),
    linear-gradient(135deg, rgba(183, 48, 46, .22) 0 11%, transparent 11% 100%),
    linear-gradient(225deg, rgba(20, 100, 86, .25) 0 17%, transparent 17% 100%),
    linear-gradient(180deg, rgba(7, 22, 18, .72), rgba(7, 20, 17, .92)) !important;
  box-shadow:
    0 26px 80px rgba(0, 0, 0, .34),
    inset 0 0 0 1px rgba(255,255,255,.035) !important;
}

.hero-panel::before {
  background:
    radial-gradient(circle at 50% 20%, rgba(255, 247, 207, .12), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.035), transparent 20%) !important;
}

.logo-aura {
  width: clamp(140px, 18vw, 190px) !important;
  height: clamp(140px, 18vw, 190px) !important;
  margin: 0 auto clamp(24px, 3.2vh, 38px) !important;
}

.logo-aura::before {
  inset: -58% !important;
  background:
    radial-gradient(circle at center,
      rgba(255, 250, 220, .42) 0%,
      rgba(225, 196, 112, .25) 26%,
      rgba(59, 91, 73, .14) 46%,
      transparent 72%) !important;
  filter: blur(3px) !important;
}

.brand-logo {
  width: 80% !important;
  height: 80% !important;
  object-fit: contain !important;
  transform-origin: center !important;
}

.prayer-card {
  width: min(100%, 560px) !important;
  margin: 0 auto !important;
  padding: clamp(18px, 3.2vw, 26px) !important;
  border-radius: clamp(22px, 3.4vw, 30px) !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.022)),
    rgba(6, 20, 17, .50) !important;
  border: 1px solid rgba(226, 196, 122, .26) !important;
  box-shadow: 0 18px 45px rgba(0,0,0,.24), inset 0 0 0 1px rgba(255,255,255,.03) !important;
}

.prayer-kicker {
  margin-bottom: 6px !important;
  font-size: clamp(10px, 1.45vw, 14px) !important;
  letter-spacing: .28em !important;
}

.prayer-city {
  margin-bottom: clamp(14px, 2.2vh, 20px) !important;
  font-size: clamp(19px, 2.8vw, 27px) !important;
  line-height: 1.18 !important;
}

.prayer-next {
  padding: clamp(13px, 2.2vw, 18px) clamp(16px, 2.7vw, 22px) !important;
  margin-bottom: clamp(12px, 1.9vh, 18px) !important;
  border-radius: 20px !important;
}

.prayer-next small {
  font-size: clamp(10px, 1.5vw, 13px) !important;
  letter-spacing: .12em !important;
}

.prayer-next strong {
  font-size: clamp(19px, 3vw, 26px) !important;
}

.prayer-next b {
  font-size: clamp(30px, 5vw, 44px) !important;
}

.prayer-times {
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  gap: clamp(7px, 1.3vw, 10px) !important;
}

.prayer-chip {
  min-height: 62px !important;
  padding: 10px 4px 9px !important;
  border-radius: 16px !important;
}

.prayer-chip small {
  font-size: clamp(10px, 1.45vw, 12px) !important;
}

.prayer-chip b {
  font-size: clamp(14px, 2.1vw, 17px) !important;
}

.prayer-date {
  margin-top: 14px !important;
  font-size: clamp(12px, 1.75vw, 15px) !important;
}

.link-list {
  width: min(100%, 720px) !important;
  margin: clamp(18px, 2.5vh, 28px) auto 0 !important;
  gap: clamp(12px, 1.9vh, 18px) !important;
}

.bio-link {
  min-height: clamp(82px, 8vh, 104px) !important;
  grid-template-columns: clamp(58px, 7vw, 74px) 1fr 24px !important;
  gap: clamp(14px, 2.4vw, 20px) !important;
  padding: clamp(13px, 2.2vw, 17px) clamp(18px, 3vw, 26px) clamp(13px, 2.2vw, 17px) clamp(14px, 2.5vw, 18px) !important;
  border-radius: clamp(22px, 3.4vw, 30px) !important;
  box-shadow: 0 18px 42px rgba(0,0,0,.22), inset 0 0 0 1px rgba(255,255,255,.06) !important;
}

.link-medallion {
  width: clamp(54px, 6.7vw, 68px) !important;
  height: clamp(54px, 6.7vw, 68px) !important;
  border-radius: 20px !important;
  font-size: clamp(24px, 3.6vw, 32px) !important;
}

.link-copy strong {
  font-size: clamp(24px, 3.3vw, 34px) !important;
  line-height: 1.04 !important;
  letter-spacing: -.02em !important;
}

.link-copy small {
  font-size: clamp(14px, 2vw, 18px) !important;
  line-height: 1.35 !important;
}

.link-arrow {
  font-size: clamp(32px, 4.2vw, 42px) !important;
}

.footer {
  width: var(--mobile-content) !important;
  margin: clamp(14px, 2vh, 22px) auto 0 !important;
  padding: 8px 0 0 !important;
  font-size: clamp(13px, 1.8vw, 16px) !important;
}

.admin-moon-button {
  top: clamp(14px, 2vw, 22px) !important;
  right: clamp(14px, 2vw, 22px) !important;
  width: 44px !important;
  height: 44px !important;
  font-size: 19px !important;
  opacity: .54 !important;
}

.audio-fab,
.share-fab {
  width: clamp(52px, 7vw, 64px) !important;
  height: clamp(52px, 7vw, 64px) !important;
  right: max(16px, calc(16px + env(safe-area-inset-right))) !important;
}
.share-fab { bottom: calc(86px + var(--safe-bottom)) !important; }
.audio-fab { bottom: calc(18px + var(--safe-bottom)) !important; }

@media (max-width: 720px) {
  .public-page {
    padding-top: 8px !important;
  }
  .stage {
    padding: 10px !important;
  }
  .turkish-frame {
    inset: 6px 6px auto !important;
    bottom: 6px !important;
    border-radius: 28px !important;
  }
  .hero-panel {
    padding: 30px 14px 24px !important;
    border-radius: 26px !important;
  }
  .logo-aura {
    width: clamp(118px, 31vw, 145px) !important;
    height: clamp(118px, 31vw, 145px) !important;
    margin-bottom: 20px !important;
  }
  .brand-logo {
    width: 78% !important;
    height: 78% !important;
  }
  .prayer-card {
    width: min(100%, 352px) !important;
    padding: 14px 12px 13px !important;
    border-radius: 22px !important;
  }
  .prayer-kicker {
    font-size: 9px !important;
    letter-spacing: .17em !important;
  }
  .prayer-city {
    font-size: 16px !important;
    margin-bottom: 11px !important;
  }
  .prayer-next {
    padding: 10px 12px !important;
    border-radius: 16px !important;
    margin-bottom: 10px !important;
  }
  .prayer-next small { font-size: 9px !important; }
  .prayer-next strong { font-size: 17px !important; }
  .prayer-next b { font-size: 27px !important; }
  .prayer-times { gap: 6px !important; }
  .prayer-chip {
    min-height: 52px !important;
    padding: 8px 2px 7px !important;
    border-radius: 13px !important;
  }
  .prayer-chip small { font-size: 8.5px !important; }
  .prayer-chip b { font-size: 11.5px !important; }
  .prayer-date {
    font-size: 10px !important;
    margin-top: 9px !important;
  }
  .link-list {
    width: min(100%, 354px) !important;
    margin-top: 12px !important;
    gap: 10px !important;
  }
  .bio-link {
    min-height: 74px !important;
    grid-template-columns: 52px 1fr 18px !important;
    gap: 11px !important;
    padding: 11px 13px 11px 11px !important;
    border-radius: 20px !important;
  }
  .link-medallion {
    width: 48px !important;
    height: 48px !important;
    border-radius: 16px !important;
    font-size: 24px !important;
  }
  .link-copy strong {
    font-size: 22px !important;
  }
  .link-copy small {
    font-size: 14px !important;
  }
  .link-arrow { font-size: 31px !important; }
  .footer {
    width: min(100%, 354px) !important;
    margin-top: 12px !important;
    font-size: 12px !important;
  }
  .admin-moon-button {
    width: 38px !important;
    height: 38px !important;
    font-size: 17px !important;
  }
}

.preview-screen .hero-panel {
  padding: 20px 10px 16px !important;
  border-radius: 24px !important;
}
.preview-screen .logo-aura {
  width: 92px !important;
  height: 92px !important;
  margin-bottom: 12px !important;
}
.preview-screen .prayer-card {
  width: min(100%, 300px) !important;
}
.preview-screen .link-list {
  width: min(100%, 300px) !important;
  margin-top: 10px !important;
}
.preview-screen .bio-link {
  min-height: 64px !important;
}


/* v17: slimmer link buttons */
.link-list {
  width: min(100%, 700px) !important;
  margin: clamp(14px, 2vh, 22px) auto 0 !important;
  gap: clamp(10px, 1.4vh, 14px) !important;
}

.bio-link {
  min-height: clamp(66px, 6.4vh, 84px) !important;
  grid-template-columns: clamp(48px, 5.7vw, 60px) 1fr 18px !important;
  gap: clamp(10px, 1.8vw, 14px) !important;
  padding: clamp(10px, 1.6vw, 14px) clamp(16px, 2.2vw, 20px) clamp(10px, 1.6vw, 14px) clamp(12px, 1.8vw, 14px) !important;
  border-radius: clamp(18px, 2.4vw, 24px) !important;
  box-shadow: 0 12px 28px rgba(0,0,0,.18), inset 0 0 0 1px rgba(255,255,255,.05) !important;
}

.link-medallion {
  width: clamp(42px, 5vw, 52px) !important;
  height: clamp(42px, 5vw, 52px) !important;
  border-radius: 15px !important;
  font-size: clamp(19px, 2.4vw, 24px) !important;
}

.link-copy { gap: 2px !important; }

.link-copy strong {
  font-size: clamp(18px, 2.35vw, 24px) !important;
  line-height: 1.05 !important;
}

.link-copy small {
  font-size: clamp(11px, 1.5vw, 14px) !important;
  line-height: 1.28 !important;
  opacity: .92 !important;
}

.link-arrow {
  font-size: clamp(24px, 2.8vw, 30px) !important;
}

@media (max-width: 720px) {
  .link-list {
    width: min(100%, 350px) !important;
    margin-top: 10px !important;
    gap: 8px !important;
  }

  .bio-link {
    min-height: 62px !important;
    grid-template-columns: 44px 1fr 16px !important;
    gap: 10px !important;
    padding: 9px 12px 9px 10px !important;
    border-radius: 18px !important;
  }

  .link-medallion {
    width: 40px !important;
    height: 40px !important;
    border-radius: 14px !important;
    font-size: 20px !important;
  }

  .link-copy strong {
    font-size: 16px !important;
    line-height: 1.04 !important;
  }

  .link-copy small {
    font-size: 10.5px !important;
    line-height: 1.24 !important;
  }

  .link-arrow {
    font-size: 24px !important;
  }

  .footer {
    margin-top: 10px !important;
  }
}

.preview-screen .link-list {
  margin-top: 10px !important;
  gap: 8px !important;
}
.preview-screen .bio-link {
  min-height: 58px !important;
  grid-template-columns: 42px 1fr 16px !important;
  gap: 8px !important;
  padding: 8px 10px 8px 8px !important;
  border-radius: 16px !important;
}
.preview-screen .link-medallion {
  width: 36px !important;
  height: 36px !important;
  border-radius: 12px !important;
  font-size: 18px !important;
}
.preview-screen .link-copy strong { font-size: 15px !important; }
.preview-screen .link-copy small { font-size: 10px !important; }
.preview-screen .link-arrow { font-size: 20px !important; }


/* v18: editable activity title between prayer card and link list */
.activity-title {
  width: min(100%, 720px) !important;
  margin: clamp(10px, 1.8vh, 18px) auto clamp(8px, 1.4vh, 14px) !important;
  text-align: center !important;
  position: relative;
  z-index: 2;
}

.activity-title span {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: clamp(38px, 4.6vh, 52px) !important;
  max-width: 100% !important;
  padding: clamp(8px, 1.4vw, 12px) clamp(18px, 2.5vw, 28px) !important;
  border-radius: 999px !important;
  border: 1px solid rgba(227,190,113,.26) !important;
  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.025)), rgba(10,26,23,.70) !important;
  color: var(--gold-soft) !important;
  box-shadow: 0 14px 34px rgba(0,0,0,.18), inset 0 0 0 1px rgba(255,255,255,.04) !important;
  font-weight: 800 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  font-size: clamp(15px, 2.15vw, 22px) !important;
  line-height: 1.15 !important;
}

@media (max-width: 720px) {
  .activity-title {
    width: min(100%, 350px) !important;
    margin: 8px auto 7px !important;
  }

  .activity-title span {
    min-height: 34px !important;
    padding: 7px 14px !important;
    font-size: 12px !important;
    letter-spacing: .06em !important;
  }
}

.preview-screen .activity-title {
  width: min(100%, 330px) !important;
  margin: 8px auto 7px !important;
}

.preview-screen .activity-title span {
  min-height: 32px !important;
  padding: 6px 12px !important;
  font-size: 11px !important;
}

/* v18: ensure prayer title uses Kota Bekasi */
.prayer-city[data-city="dki"]::after {
  content: "Kota Bekasi dan Sekitarnya";
}

/* v19: final palette alignment for inner public card */
.hero-panel {
  background:
    linear-gradient(135deg, rgba(255,202,26,.13) 0 14%, transparent 14% 100%),
    linear-gradient(225deg, rgba(37,82,143,.44) 0 18%, transparent 18% 100%),
    linear-gradient(180deg, rgba(26,58,107,.92), rgba(8,26,51,.97)),
    linear-gradient(90deg, rgba(255,255,255,.035), rgba(255,255,255,0)) !important;
  border-color: rgba(255,202,26,.24) !important;
}

.ornament-left {
  background:
    linear-gradient(180deg, rgba(255,202,26,.34), rgba(255,202,26,0) 28%),
    linear-gradient(180deg, rgba(26,58,107,0) 0 28%, rgba(37,82,143,.64) 28% 62%, rgba(0,0,0,0) 62%),
    linear-gradient(180deg, rgba(0,0,0,0) 0 62%, rgba(8,26,51,.84) 62% 100%) !important;
}

.ornament-right {
  background:
    linear-gradient(180deg, rgba(255,202,26,.34), rgba(255,202,26,0) 28%),
    linear-gradient(180deg, rgba(26,58,107,0) 0 28%, rgba(37,82,143,.64) 28% 62%, rgba(0,0,0,0) 62%),
    linear-gradient(180deg, rgba(0,0,0,0) 0 62%, rgba(8,26,51,.84) 62% 100%) !important;
}

.logo-aura::before {
  background:
    radial-gradient(circle at center,
      rgba(255,202,26,.36) 0%,
      rgba(255,202,26,.17) 30%,
      rgba(26,58,107,.08) 58%,
      transparent 76%) !important;
}

.admin-moon-button,
.audio-fab,
.share-toast,
.share-fab {
  background: rgba(16,39,68,.86) !important;
  border-color: rgba(255,202,26,.28) !important;
  color: var(--accent) !important;
}

.prayer-card {
  background:
    linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.025)),
    rgba(16,39,68,.78) !important;
  border-color: rgba(255,202,26,.28) !important;
}

.prayer-next,
.prayer-chip {
  background: rgba(8,26,51,.54) !important;
  border-color: rgba(255,202,26,.16) !important;
}

.prayer-chip.is-next {
  background: linear-gradient(180deg, rgba(255,202,26,.22), rgba(255,202,26,.08)) !important;
  border-color: rgba(255,202,26,.52) !important;
}

.activity-title span {
  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.025)), rgba(16,39,68,.78) !important;
  border-color: rgba(255,202,26,.28) !important;
}
