/* ============================================================
   KKN Desa Pucanganak — Opening Animation + Landing Page
   Recreated from the Claude Design handoff prototype.
   ============================================================ */

* { box-sizing: border-box; }
html, body { margin: 0; height: 100%; background: #eef6e6; }
body { font-family: 'Plus Jakarta Sans', sans-serif; color: #234d26; }
a { color: inherit; text-decoration: none; }

/* ---------------------------- Keyframes ---------------------------- */
@keyframes heroIn { from { opacity: 0; transform: scale(1.06); } to { opacity: 1; transform: scale(1); } }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes burst { 0% { opacity: 1; transform: translate(-50%,-50%) translate(0,0) scale(.2); } 100% { opacity: 0; transform: translate(-50%,-50%) translate(var(--tx),var(--ty)) scale(var(--s)); } }
@keyframes sunRise { 0% { opacity: 0; transform: translateY(170px) scale(.4); } 55% { opacity: 1; } 100% { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes sunRiseBig { 0% { opacity: 0; transform: translateY(240px) scale(.45); } 55% { opacity: 1; } 100% { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes riseUp { from { opacity: 0; transform: translateY(130px); } to { opacity: 1; transform: translateY(0); } }
@keyframes pop { 0% { opacity: 0; transform: scale(0) rotate(-12deg); } 55% { opacity: 1; transform: scale(1.14) rotate(4deg); } 75% { transform: scale(.94) rotate(-2deg); } 100% { opacity: 1; transform: scale(1) rotate(0); } }
@keyframes logoIn { 0% { opacity: 0; transform: scale(.3) rotate(-18deg); } 60% { opacity: 1; transform: scale(1.13) rotate(5deg); } 80% { transform: scale(.96); } 100% { opacity: 1; transform: scale(1) rotate(0); } }
@keyframes ringPulse { 0% { opacity: .55; transform: scale(.5); } 100% { opacity: 0; transform: scale(2.5); } }
@keyframes fadeUp { 0% { opacity: 0; transform: translateY(26px); } 100% { opacity: 1; transform: translateY(0); } }
@keyframes draw { from { stroke-dashoffset: 760; } to { stroke-dashoffset: 0; } }
@keyframes iris { 0% { opacity: .3; clip-path: circle(0% at 50% 50%); } 100% { opacity: 1; clip-path: circle(72% at 50% 50%); } }
@keyframes sparkle { 0% { opacity: 0; transform: scale(0); } 40% { opacity: 1; transform: scale(1.25); } 100% { opacity: 0; transform: scale(0); } }
@keyframes hillUp { from { transform: translateY(115%); } to { transform: translateY(0); } }
@keyframes raysSpin { from { transform: rotate(0); } to { transform: rotate(360deg); } }
@keyframes glow { 0%,100% { filter: drop-shadow(0 8px 24px rgba(47,93,49,.22)); } 50% { filter: drop-shadow(0 12px 34px rgba(240,169,30,.45)); } }
@keyframes drawA { from { stroke-dashoffset: 1; } to { stroke-dashoffset: 0; } }
@keyframes calloutIn { 0% { opacity: 0; transform: translateY(14px) scale(.92); } 60% { opacity: 1; transform: translateY(0) scale(1.04); } 100% { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes haloPulse { 0% { opacity: .5; transform: translate(-50%,-50%) scale(.7); } 100% { opacity: 0; transform: translate(-50%,-50%) scale(2.1); } }
@keyframes bob { 0%,100% { transform: translateY(0); } 50% { transform: translateY(7px); } }

/* ============================================================
   INTRO (opening animation)
   ============================================================ */
.intro {
  position: fixed;
  inset: 0;
  overflow: hidden;
  z-index: 9999;
  background: radial-gradient(120% 100% at 50% 18%, #f6fbef 0%, #e6f2da 50%, #d3e7c1 100%);
}
.intro[hidden] { display: none; }

/* layered, centred stage helpers */
.intro__layer { position: absolute; inset: 0; display: grid; place-items: center; pointer-events: none; }

/* --- shared intro logo + title --- */
.intro__logo { height: auto; border-radius: 50%; }
.intro__title {
  position: absolute; left: 0; right: 0;
  display: grid; place-items: center;
  z-index: 6; text-align: center; pointer-events: none;
}
.intro__title-inner { opacity: 0; }
.intro__title-name {
  font: 800 clamp(22px,4.4vmin,36px)/1 'Outfit', sans-serif;
  letter-spacing: 1px;
}
.intro__title-sub {
  margin-top: 10px;
  font: 600 clamp(11px,2vmin,15px) 'Plus Jakarta Sans', sans-serif;
  letter-spacing: 4px;
  text-transform: uppercase;
}

/* particles + sparkles */
.intro__burst   { position: absolute; inset: 0; pointer-events: none; z-index: 5; }
.intro__sparkles { position: absolute; inset: 0; pointer-events: none; z-index: 6; }
.particle { position: absolute; left: 50%; top: 50%; opacity: 0; }
.sparkle  { position: absolute; background: #f7c948; border-radius: 50%; box-shadow: 0 0 8px 2px rgba(247,201,72,.7); opacity: 0; }

/* ---- Variation 1: "Pesta Pop" ---- */
.v1__hill {
  position: absolute; left: 50%; bottom: -4%; transform: translateX(-50%);
  width: 160%; height: 46%;
  background: linear-gradient(180deg,#4f9136,#2f5d31);
  border-radius: 50% 50% 0 0 / 100% 100% 0 0;
  z-index: 1; animation: riseUp 1s ease both;
}
.v1__sun {
  width: min(30vmin,240px); aspect-ratio: 1; border-radius: 50%;
  background: radial-gradient(circle at 50% 42%,#ffd766,#f0a91e);
  box-shadow: 0 0 80px 26px rgba(240,169,30,.5);
  animation: sunRise 1.1s ease both;
}
.v1__ring {
  width: min(42vmin,340px); aspect-ratio: 1; border-radius: 50%;
  border: 3px solid rgba(240,169,30,.6);
  animation: ringPulse 1.1s ease .65s both;
}
.v1__logo { width: min(42vmin,340px); animation: pop .9s cubic-bezier(.2,.8,.3,1.3) .5s both, glow 3.6s ease-in-out 1.6s infinite; }
.v1 .intro__title { bottom: 8%; }
.v1 .intro__title-inner { animation: fadeUp .7s ease 1.35s both; }
.v1 .intro__title-name { color: #fff; text-shadow: 0 2px 14px rgba(47,93,49,.35); }
.v1 .intro__title-sub  { color: #eaf6dd; }

/* ---- Variation 2: "Terbentuk" (default) ---- */
.v2__sun {
  width: min(26vmin,210px); aspect-ratio: 1; border-radius: 50%;
  background: radial-gradient(circle at 50% 42%,#ffd766,#f0a91e);
  box-shadow: 0 0 70px 22px rgba(240,169,30,.42);
  animation: sunRise 1.2s ease .2s both;
}
.v2__rings { width: min(48vmin,388px); height: auto; transform: rotate(-90deg); }
.v2__rings .ring-base  { animation: draw 1.2s ease both; }
.v2__rings .ring-accent { animation: draw 1.3s ease .12s both; }
.v2__logo { width: min(40vmin,322px); animation: iris 1.2s ease .35s both, glow 3.6s ease-in-out 1.7s infinite; }
.v2 .intro__title { bottom: 9%; }
.v2 .intro__title-inner { animation: fadeUp .7s ease 1.5s both; }
.v2 .intro__title-name { color: #2f5d31; }
.v2 .intro__title-sub  { color: #5d9c3f; }

/* ---- Variation 3: "Matahari Terbit" ---- */
.v3__rays-wrap { overflow: hidden; }
.v3__rays {
  width: 170vmax; height: 170vmax;
  background: repeating-conic-gradient(from 0deg, rgba(247,201,72,.16) 0deg 6deg, transparent 6deg 18deg);
  -webkit-mask: radial-gradient(circle,#000 6%,transparent 52%);
  mask: radial-gradient(circle,#000 6%,transparent 52%);
  animation: raysSpin 22s linear infinite, fadeIn 1.1s ease .3s both;
}
.v3__sun {
  width: min(40vmin,320px); aspect-ratio: 1; border-radius: 50%;
  background: radial-gradient(circle at 50% 42%,#ffd766,#f0a91e);
  box-shadow: 0 0 100px 34px rgba(240,169,30,.5);
  animation: sunRiseBig 1.6s ease both;
}
.v3__hills { position: absolute; left: 0; right: 0; bottom: 0; height: 52%; z-index: 3; pointer-events: none; }
.v3__hill { position: absolute; border-radius: 50% 50% 0 0 / 100% 100% 0 0; }
.v3__hill-1 { left: -12%; bottom: -26%; width: 78%; height: 120%; background: #7cb84a; animation: hillUp 1s ease .1s both; }
.v3__hill-2 { right: -14%; bottom: -30%; width: 80%; height: 130%; background: #4f9136; animation: hillUp 1s ease .28s both; }
.v3__hill-3 { left: 50%; transform: translateX(-50%); bottom: -34%; width: 130%; height: 120%; background: linear-gradient(180deg,#357032,#2f5d31); animation: hillUp 1s ease .46s both; }
.v3__logo { width: min(40vmin,322px); animation: logoIn 1s cubic-bezier(.2,.8,.3,1.3) 2.1s both, glow 3.6s ease-in-out 3.2s infinite; }
.v3 .intro__title { bottom: 7%; }
.v3 .intro__title-inner { animation: fadeUp .7s ease 3s both; }
.v3 .intro__title-name { color: #fff; text-shadow: 0 2px 16px rgba(0,0,0,.3); }
.v3 .intro__title-sub  { color: #eaf6dd; }

/* ============================================================
   SITE
   ============================================================ */
.site {
  position: fixed; inset: 0; z-index: 50;
  overflow-y: auto; overflow-x: hidden;
  scroll-behavior: smooth;
  background: linear-gradient(160deg,#f5faef 0%,#e6f2d9 52%,#d6e9c3 100%);
  font-family: 'Plus Jakarta Sans', sans-serif;
}
.site[hidden] { display: none; }
.site.is-entering { animation: heroIn .8s cubic-bezier(.2,.7,.2,1) both; }

/* shared button base */
.btn { border: none; cursor: pointer; font-family: 'Plus Jakarta Sans', sans-serif; transition: background .18s ease, transform .18s ease, box-shadow .18s ease; }
.btn--solid { padding: 11px 22px; border-radius: 999px; background: #2f5d31; color: #fff; font: 700 14px 'Plus Jakarta Sans', sans-serif; }
.btn--solid:hover { background: #3f7d3f; }
.btn--amber { padding: 14px 26px; border-radius: 999px; background: #f0a91e; color: #fff; font: 700 15px 'Plus Jakarta Sans', sans-serif; box-shadow: 0 8px 22px rgba(240,169,30,.35); }
.btn--amber:hover { background: #d8950f; }
.btn--outline { padding: 14px 26px; border: 1.5px solid #2f5d31; border-radius: 999px; background: transparent; color: #2f5d31; font: 700 15px 'Plus Jakarta Sans', sans-serif; }
.btn--outline:hover { background: rgba(47,93,49,.08); }
.btn--ghost { display: inline-flex; align-items: center; gap: 8px; padding: 11px 20px; border-radius: 999px; background: #fff; border: 1px solid rgba(47,93,49,.18); color: #2f5d31; font: 700 13.5px 'Plus Jakarta Sans', sans-serif; }
.btn--ghost:hover { background: #f3faea; }

/* pills */
.pill { display: inline-flex; align-items: center; gap: 8px; border-radius: 999px; }
.pill--amber { padding: 7px 15px; background: rgba(240,169,30,.16); border: 1px solid rgba(240,169,30,.4); font: 700 12px 'Plus Jakarta Sans', sans-serif; color: #b97a08; letter-spacing: .5px; }
.pill--green { padding: 7px 15px; background: rgba(47,93,49,.1); font: 700 12px 'Plus Jakarta Sans', sans-serif; color: #2f5d31; letter-spacing: 1px; }

/* shared section headings */
.sec__title { font: 800 clamp(28px,4vw,46px)/1.1 'Outfit', sans-serif; color: #234d26; margin: 16px 0 0; text-wrap: balance; }
.sec__lead { font: 400 clamp(14px,1.4vw,17px)/1.6 'Plus Jakarta Sans', sans-serif; color: #52704c; margin: 12px 0 0; }

/* ---------------- HERO ---------------- */
.hero { position: relative; min-height: 100dvh; display: flex; flex-direction: column; overflow: hidden; }
.hero__glow { position: absolute; left: -12%; right: -12%; bottom: -10%; height: 44%; background: radial-gradient(120% 100% at 50% 100%,#bcdc9d,transparent 72%); pointer-events: none; }
.hero__watermark { position: absolute; right: -90px; bottom: -90px; width: 400px; height: 400px; opacity: .07; pointer-events: none; }

.nav { position: relative; z-index: 2; display: flex; align-items: center; justify-content: space-between; padding: 22px clamp(24px,5vw,64px); }
.brand { display: flex; align-items: center; gap: 12px; }
.brand__logo { width: 46px; height: 46px; border-radius: 50%; }
.brand__text { line-height: 1.15; }
.brand__name { display: block; font: 800 16px 'Outfit', sans-serif; color: #2f5d31; }
.brand__loc  { display: block; font: 600 10.5px 'Plus Jakarta Sans', sans-serif; color: #5d9c3f; letter-spacing: 1.5px; }
.nav__right { display: flex; align-items: center; gap: 30px; }
.nav__links { display: flex; gap: 26px; font: 600 14px 'Plus Jakarta Sans', sans-serif; color: #2f5d31; }
.nav__links a { cursor: pointer; transition: color .15s ease; }
.nav__links a:hover, .nav__links a.is-active { color: #f0a91e; }
.nav__toggle { display: none; width: 42px; height: 42px; border: 1px solid rgba(47,93,49,.2); border-radius: 10px; background: rgba(255,255,255,.7); color: #2f5d31; font-size: 18px; cursor: pointer; }

.hero__grid {
  position: relative; z-index: 2; flex: 1;
  display: grid; grid-template-columns: 1fr; gap: 30px;
  align-items: center; align-content: center;
  padding: 24px clamp(20px,5vw,40px) 40px;
}
.hero__title { font: 800 clamp(34px,5.2vw,60px)/1.04 'Outfit', sans-serif; color: #234d26; margin: 18px 0 0; text-wrap: balance; }
.hero__lead { font: 400 clamp(15px,1.5vw,18px)/1.65 'Plus Jakarta Sans', sans-serif; color: #41603f; max-width: 540px; margin: 18px 0 0; text-wrap: pretty; }
.hero__cta { display: flex; gap: 14px; margin-top: 30px; }
.stats { display: flex; gap: 40px; margin-top: 44px; }
.stat__num { font: 800 30px 'Outfit', sans-serif; color: #2f5d31; }
.stat__label { font: 500 13px 'Plus Jakarta Sans', sans-serif; color: #5d7a55; }

.hero__card {
  position: relative; aspect-ratio: 4/3.4; border-radius: 20px; overflow: hidden;
  box-shadow: 0 24px 60px rgba(47,93,49,.22); border: 1px solid rgba(47,93,49,.12);
  background: repeating-linear-gradient(135deg,#dcebcb 0 14px,#d2e3bd 14px 28px);
}
.hero__card-ph { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 8px; }
.hero__card-icon { width: 54px; height: 54px; border-radius: 50%; border: 2px dashed #7d9a6a; display: grid; place-items: center; color: #7d9a6a; font-size: 22px; }
.hero__card-cap { font: 500 12px ui-monospace, Menlo, monospace; color: #6e8a5d; letter-spacing: .5px; }
.hero__chip { position: absolute; left: 16px; bottom: 16px; right: 16px; background: rgba(255,255,255,.9); backdrop-filter: blur(6px); border-radius: 12px; padding: 12px 14px; display: flex; align-items: center; gap: 10px; }
.hero__chip-icon { width: 34px; height: 34px; border-radius: 9px; background: #2f5d31; display: grid; place-items: center; color: #ffd766; font-size: 16px; }
.hero__chip-text { line-height: 1.2; }
.hero__chip-title { font: 700 13px 'Plus Jakarta Sans', sans-serif; color: #2f5d31; }
.hero__chip-sub { font: 500 11.5px 'Plus Jakarta Sans', sans-serif; color: #6e8a5d; }
.hero__card-photo { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }

.scrollhint { position: relative; z-index: 2; display: flex; flex-direction: column; align-items: center; gap: 6px; padding: 14px 0 30px; color: #5d7a55; }
.scrollhint__label { font: 600 12px 'Plus Jakarta Sans', sans-serif; letter-spacing: 1.5px; }
.scrollhint__arrow { font-size: 20px; animation: bob 1.8s ease-in-out infinite; }

/* ---------------- MAKNA ---------------- */
.makna {
  position: relative; min-height: 100dvh;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 64px 24px 84px; overflow: visible;
  background: linear-gradient(180deg,#ffffff 0%,#f1f8e8 100%);
}
.makna__head { text-align: center; max-width: 660px; flex: none; }

/* shared logo + halos */
.makna__logo { height: auto; border-radius: 50%; }
.halo { position: absolute; left: 50%; top: 50%; border-radius: 50%; transform: translate(-50%,-50%); opacity: 0; }
.halo--amber { border: 3px solid rgba(240,169,30,.5); }
.halo--green { border: 3px solid rgba(47,93,49,.4); }

/* radial layout */
.makna__radial { position: relative; width: min(94vw,1040px); height: min(72vh,560px); margin-top: 20px; flex: none; }
.makna__arrows { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); width: min(86vmin,860px); height: auto; pointer-events: none; z-index: 3; }
.makna__center {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%,-50%);
  z-index: 2;
  display: grid;
  place-items: center;
  width: calc(min(86vmin, 860px) * 0.3125);
  height: calc(min(86vmin, 860px) * 0.3125);
}
.makna__center .halo { width: 100%; height: 100%; }
.makna__center .makna__logo { width: 100%; height: 100%; }

.callout { position: absolute; width: 225px; max-width: 30vw; z-index: 4; opacity: 0; }
.callout p { margin: 10px 0 0; font: 600 13.5px/1.5 'Plus Jakarta Sans', sans-serif; color: #3f5e3c; }
.callout .tag { display: inline-block; padding: 7px 16px; border-radius: 999px; color: #fff; font: 800 15px 'Outfit', sans-serif; }
.callout--tl { top: 0; left: 0; text-align: left; }
.callout--ml { top: 50%; left: 0; transform: translateY(-50%); text-align: left; }
.callout--bl { bottom: 0; left: 0; text-align: left; }
.callout--tr { top: 0; right: 0; text-align: right; }
.callout--mr { top: 50%; right: 0; transform: translateY(-50%); text-align: right; }
.callout--br { bottom: 0; right: 0; text-align: right; }

/* stacked layout */
.makna__stack { display: flex; flex-direction: column; align-items: center; gap: 16px; width: min(94vw,440px); margin-top: 26px; flex: none; }
.makna__stack-logo { position: relative; display: grid; place-items: center; margin-bottom: 4px; }
.makna__stack-logo .halo--sm { width: 148px; height: 148px; }
.makna__logo--sm { width: 148px; }
.mcard { width: 100%; background: #fff; border: 1px solid rgba(47,93,49,.1); border-radius: 16px; padding: 15px 18px; box-shadow: 0 6px 18px rgba(47,93,49,.08); border-left: 5px solid var(--bar); opacity: 0; }
.mcard__tag { display: inline-block; font: 800 15px 'Outfit', sans-serif; }
.mcard p { margin: 6px 0 0; font: 600 13.5px/1.5 'Plus Jakarta Sans', sans-serif; color: #3f5e3c; }

/* responsive toggle between radial and stacked */
.makna__radial { display: none; }
.makna__stack { display: flex; }
@media (min-width: 900px) {
  .makna__radial { display: block; }
  .makna__stack { display: none; }
}

/* reveal gating — animations only run once the group is revealed on scroll */
.reveal-group .arrow { stroke-dasharray: 1; stroke-dashoffset: 1; opacity: 0; }
.reveal-group.revealed .arrow { animation: drawA .7s ease var(--d) forwards, fadeIn .25s ease var(--d) forwards; }
.reveal-group.revealed .callout { animation: calloutIn .6s cubic-bezier(.2,.8,.3,1.2) var(--d) both; }
.reveal-group.revealed .mcard { animation: calloutIn .55s cubic-bezier(.2,.8,.3,1.2) var(--d) both; }
.reveal-group.revealed .makna__center .makna__logo,
.reveal-group.revealed .makna__stack-logo .makna__logo { animation: pop .9s cubic-bezier(.2,.8,.3,1.3) .1s both, glow 3.8s ease-in-out 1.2s infinite; }
.reveal-group.revealed .halo--amber { animation: haloPulse 2.6s ease-out .6s infinite; }
.reveal-group.revealed .halo--green { animation: haloPulse 2.6s ease-out 1.9s infinite; }

/* ---------------- GALLERY ---------------- */
.gallery {
  position: relative; min-height: 100dvh;
  display: flex; flex-direction: column; align-items: center;
  padding: 72px clamp(20px,5vw,64px) 96px; overflow: hidden;
  background: linear-gradient(180deg,#f1f8e8 0%,#e6f2d9 100%);
}
.gallery__head { text-align: center; max-width: 660px; }

.tabs { display: flex; flex-wrap: wrap; justify-content: center; gap: 8px; margin-top: 28px; }
.tab { border-radius: 999px; cursor: pointer; font-family: 'Plus Jakarta Sans', sans-serif; }
.tab--idle { padding: 9px 20px; border: 1px solid rgba(47,93,49,.22); background: #fff; color: #2f5d31; font: 600 13.5px 'Plus Jakarta Sans', sans-serif; }
.tab--active { padding: 9px 20px; border: none; background: #2f5d31; color: #fff; font: 700 13.5px 'Plus Jakarta Sans', sans-serif; box-shadow: 0 6px 16px rgba(47,93,49,.25); }

.media { width: 100%; max-width: 1080px; margin-top: 34px; display: grid; grid-template-columns: repeat(auto-fill, minmax(min(100%,250px),1fr)); gap: 20px; }
.card { position: relative; aspect-ratio: 4/3; border-radius: 16px; overflow: hidden; cursor: pointer; box-shadow: 0 8px 24px rgba(47,93,49,.14); border: 1px solid rgba(47,93,49,.1); transition: transform .18s ease, box-shadow .18s ease; }
.card:hover { transform: translateY(-4px); box-shadow: 0 16px 34px rgba(47,93,49,.22); }
.card__watermark { position: absolute; right: -26px; bottom: -26px; width: 130px; height: 130px; opacity: .12; pointer-events: none; }
.card__badge { position: absolute; top: 12px; left: 12px; padding: 5px 11px; border-radius: 999px; font: 800 11px 'Plus Jakarta Sans', sans-serif; color: #fff; letter-spacing: .3px; background: rgba(0,0,0,.42); backdrop-filter: blur(4px); box-shadow: 0 2px 8px rgba(0,0,0,.25); }
.card__type { position: absolute; top: 12px; right: 12px; padding: 5px 10px; border-radius: 999px; font: 700 10.5px 'Plus Jakarta Sans', sans-serif; color: #fff; background: rgba(255,255,255,.18); backdrop-filter: blur(4px); }
.card__glyph { position: absolute; left: 50%; top: 46%; transform: translate(-50%,-50%); width: 54px; height: 54px; border-radius: 50%; background: rgba(255,255,255,.94); display: grid; place-items: center; box-shadow: 0 6px 18px rgba(0,0,0,.28); font-size: 19px; color: #2f5d31; }
.card__title { position: absolute; left: 0; right: 0; bottom: 0; padding: 30px 14px 13px; background: linear-gradient(180deg,transparent,rgba(0,0,0,.66)); color: #fff; font: 700 14px/1.3 'Plus Jakarta Sans', sans-serif; }

.socials { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; margin-top: 38px; }

/* ---------------- PAGE TRANSITIONS ---------------- */
.intro {
  transition: opacity 0.5s ease;
  opacity: 1;
}
.intro.intro--fade-out {
  opacity: 0;
  pointer-events: none;
}
.intro.intro--fade-in {
  opacity: 1;
}
body.subpage > *:not(#intro) {
  opacity: 0;
}
body.subpage.is-revealed > *:not(#intro) {
  opacity: 1;
  transition: opacity 0.5s ease;
}

/* ---------------- KONTAK / FOOTER ---------------- */
.contact { background: linear-gradient(160deg,#1f4a22 0%,#143018 100%); color: #eaf6dd; padding: 66px clamp(20px,5vw,64px) 44px; }
.contact__inner { max-width: 760px; margin: 0 auto; text-align: center; }
.contact__brand { display: inline-flex; align-items: center; gap: 14px; text-align: left; }
.contact__logo { width: 56px; height: 56px; border-radius: 50%; }
.contact__name { font: 800 20px 'Outfit', sans-serif; color: #fff; }
.contact__loc { font: 600 11px 'Plus Jakarta Sans', sans-serif; color: #9fc98c; letter-spacing: 1.5px; margin-top: 2px; }
.contact__tagline { font: 400 15px/1.6 'Plus Jakarta Sans', sans-serif; color: #cfe6bf; max-width: 520px; margin: 18px auto 0; }
.contact__rows { display: flex; flex-wrap: wrap; justify-content: center; gap: 14px; margin-top: 30px; }
.contact__row { display: flex; align-items: center; gap: 12px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); border-radius: 14px; padding: 14px 18px; min-width: 240px; text-align: left; color: inherit; transition: background .15s ease; }
a.contact__row { cursor: pointer; }
a.contact__row:hover { background: rgba(255,255,255,.12); }
.contact__icon { width: 38px; height: 38px; flex: none; border-radius: 10px; background: rgba(240,169,30,.18); color: #ffd766; display: grid; place-items: center; font-size: 18px; }
.contact__row-text { display: flex; flex-direction: column; line-height: 1.3; min-width: 0; }
.contact__row-label { font: 700 11px 'Plus Jakarta Sans', sans-serif; letter-spacing: 1px; text-transform: uppercase; color: #9fc98c; }
.contact__row-val { font: 600 14px 'Plus Jakarta Sans', sans-serif; color: #f3faec; word-break: break-word; }
.contact__socials { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; margin-top: 30px; }
.social { display: inline-flex; align-items: center; gap: 8px; padding: 10px 20px; border-radius: 999px; background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.16); color: #fff; font: 700 13.5px 'Plus Jakarta Sans', sans-serif; cursor: pointer; transition: background .15s ease, transform .15s ease; }
.social:hover { background: rgba(255,255,255,.2); transform: translateY(-2px); }
.contact__copy { margin-top: 34px; font: 500 12px 'Plus Jakarta Sans', sans-serif; color: #86b377; }

/* ---------------- responsive: hero columns + nav links ---------------- */
@media (max-width: 759.98px) {
  .nav { position: relative; flex-wrap: wrap; }
  .nav__toggle { display: inline-flex; align-items: center; justify-content: center; }
  .nav__right {
    display: none; position: absolute; top: calc(100% + 6px); left: 0; right: 0;
    flex-direction: column; align-items: stretch; gap: 14px;
    background: rgba(248,252,243,.98); backdrop-filter: blur(10px);
    padding: 16px clamp(20px,5vw,40px) 20px;
    border: 1px solid rgba(47,93,49,.12); border-radius: 14px;
    box-shadow: 0 18px 44px rgba(47,93,49,.18); z-index: 40;
  }
  .nav--open .nav__right { display: flex; }
  .nav__links { flex-direction: column; gap: 14px; }
  .nav__right .btn--solid { align-self: flex-start; }
}
@media (min-width: 860px) {
  .hero__grid { grid-template-columns: 1.08fr .92fr; gap: 48px; padding: clamp(16px,3vw,44px) clamp(24px,5vw,64px); }
}

/* ---------------- sub-page chrome (program / galeri) ---------------- */
body.subpage { min-height: 100%; background: linear-gradient(160deg,#f5faef 0%,#e6f2d9 52%,#d6e9c3 100%); }
.page-nav { position: sticky; top: 0; z-index: 30; background: rgba(245,250,239,.92); backdrop-filter: blur(10px); border-bottom: 1px solid rgba(47,93,49,.1); }
.page-nav .nav { padding-top: 14px; padding-bottom: 14px; }

/* makna -> next page buttons (home) */
.makna__more { display: flex; flex-wrap: wrap; justify-content: center; gap: 14px; margin-top: 30px; flex: none; }

/* empty-state text */
.media__empty { grid-column: 1 / -1; text-align: center; padding: 40px; color: #6e8a5d; font: 600 14px 'Plus Jakarta Sans', sans-serif; }

/* small button modifier */
.btn--sm { padding: 9px 16px; font-size: 13px; }

/* ---------------- PROGRAM page ---------------- */
.program { padding: 40px clamp(20px,5vw,64px) 96px; background: linear-gradient(180deg,#f5faef 0%,#e9f4dd 100%); min-height: 100dvh; }
.program__head { text-align: center; max-width: 680px; margin: 8px auto 0; }
.prog-grid { max-width: 1080px; margin: 36px auto 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(min(100%,300px),1fr)); gap: 22px; }
.prog-card { background: #fff; border: 1px solid rgba(47,93,49,.1); border-top: 4px solid var(--accent); border-radius: 18px; overflow: hidden; box-shadow: 0 10px 28px rgba(47,93,49,.10); display: flex; flex-direction: column; transition: transform .18s ease, box-shadow .18s ease; }
.prog-card:hover { transform: translateY(-4px); box-shadow: 0 18px 38px rgba(47,93,49,.18); }
.prog-card__media { aspect-ratio: 16 / 10; background-size: cover; background-position: center; background-color: #eef4e4; }
.prog-card__media--ph { display: grid; place-items: center; background: repeating-linear-gradient(135deg,#e7f1d8 0 14px,#dfeccd 14px 28px); }
.prog-card__media--ph img { width: 84px; height: 84px; opacity: .16; }
.prog-card__body { padding: 16px 18px 20px; display: flex; flex-direction: column; gap: 9px; }
.prog-card__cat { align-self: flex-start; padding: 4px 12px; border-radius: 999px; background: var(--accent); color: #fff; font: 800 11px 'Plus Jakarta Sans', sans-serif; letter-spacing: .4px; }
.prog-card__title { font: 800 18px/1.25 'Outfit', sans-serif; color: #234d26; margin: 0; }
.prog-card__desc { font: 400 14px/1.55 'Plus Jakarta Sans', sans-serif; color: #52704c; margin: 0; }
.program__cta { display: flex; flex-wrap: wrap; justify-content: center; gap: 14px; margin-top: 44px; }

/* ---------------- ADMIN panel ---------------- */
/* ---------------- ADMIN panel ---------------- */
body.admin {
  background: #0d1410;
  color: #c4d7c7;
  height: auto;
  min-height: 100vh;
  font-family: 'Plus Jakarta Sans', sans-serif;
  background-image: radial-gradient(circle at 10% 20%, rgba(47, 93, 49, 0.15) 0%, transparent 60%),
                    radial-gradient(circle at 90% 80%, rgba(240, 169, 30, 0.06) 0%, transparent 60%);
}

/* Glassmorphic Login Screen */
.adm-lock {
  position: fixed;
  inset: 0;
  z-index: 100;
  background: radial-gradient(circle at center, #16241c 0%, #090f0c 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.adm-lock__card {
  background: rgba(255, 255, 255, 0.02);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 24px;
  padding: 40px 32px;
  width: min(100%, 420px);
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.6), 
              0 0 40px rgba(47, 93, 49, 0.15);
  text-align: center;
  animation: heroIn 0.8s cubic-bezier(0.2, 0.7, 0.2, 1) both;
}

.adm-lock__logo {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  border: 2px solid #2f5d31;
  background: rgba(47, 93, 49, 0.2);
  padding: 6px;
  margin-bottom: 18px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
}

.adm-lock__title {
  font: 800 24px 'Outfit', sans-serif;
  color: #fff;
  margin: 0;
  letter-spacing: 0.5px;
}

.adm-lock__subtitle {
  font: 500 13px 'Plus Jakarta Sans', sans-serif;
  color: #7d9685;
  margin: 8px 0 28px;
}

.adm-lock__form {
  display: flex;
  flex-direction: column;
  gap: 18px;
  text-align: left;
}

.adm-lock__submit {
  width: 100%;
  padding: 13px;
  font-size: 14.5px;
  border-radius: 10px;
  background: #2f5d31;
  color: #fff;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 8px 20px rgba(47, 93, 49, 0.3);
  transition: transform 0.2s, background 0.2s, box-shadow 0.2s;
}

.adm-lock__submit:hover {
  background: #3f7d3f;
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(47, 93, 49, 0.4);
}

.adm-lock__error {
  color: #ff8b8b;
  font-size: 12.5px;
  font-weight: 700;
  text-align: center;
  background: rgba(255, 139, 139, 0.08);
  border: 1px solid rgba(255, 139, 139, 0.2);
  padding: 10px;
  border-radius: 8px;
  margin-top: 6px;
  animation: fadeIn 0.3s ease both;
}

/* Admin Dashboard Chrome */
.admin__bar {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  align-items: center;
  justify-content: space-between;
  padding: 14px clamp(16px, 4vw, 32px);
  background: rgba(13, 20, 16, 0.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  color: #eaf6dd;
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.25);
}

.admin__brand {
  display: flex;
  align-items: center;
  gap: 12px;
  font: 800 17px 'Outfit', sans-serif;
  letter-spacing: 0.5px;
}

.admin__brand img {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1.5px solid rgba(255, 255, 255, 0.15);
}

.admin__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}

.admin__status {
  font: 600 12.5px 'Plus Jakarta Sans', sans-serif;
  color: #cfe6bf;
  max-width: 320px;
}

.admin__status--ok { color: #bdf0a8; }
.admin__status--err { color: #ffb4a8; }

.admin__main {
  max-width: 960px;
  margin: 0 auto;
  padding: 28px clamp(16px, 4vw, 32px) 96px;
}

.admin__note {
  font: 400 13.5px/1.6 'Plus Jakarta Sans', sans-serif;
  color: #b8c9bd;
  background: rgba(240, 169, 30, 0.05);
  border: 1px solid rgba(240, 169, 30, 0.18);
  border-left: 4px solid #f0a91e;
  border-radius: 12px;
  padding: 14px 18px;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.08);
}

.admin__note b {
  color: #ffd766;
}

.admin__note code {
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.08);
  padding: 1px 6px;
  border-radius: 6px;
  font-size: .92em;
  color: #e2ecc5;
}

/* Glassmorphic Panel Cards */
.adm-card {
  background: rgba(255, 255, 255, 0.015);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 20px;
  padding: 24px 26px;
  margin-top: 20px;
  box-shadow: 0 10px 32px rgba(0, 0, 0, 0.15);
  transition: border-color 0.25s, box-shadow 0.25s;
}

.adm-card:hover {
  border-color: rgba(47, 93, 49, 0.35);
  box-shadow: 0 12px 40px rgba(47, 93, 49, 0.08);
}

.adm-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 18px;
}

.adm-card__title {
  font: 800 19px 'Outfit', sans-serif;
  color: #ffd766;
  margin: 0;
}

.adm-card__head .adm-card__title {
  margin: 0;
}

.adm-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.adm-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.adm-field--wide {
  grid-column: 1 / -1;
}

.adm-field__label {
  font: 700 12px 'Plus Jakarta Sans', sans-serif;
  color: #7d9685;
  letter-spacing: 0.3px;
}

.adm-input {
  width: 100%;
  padding: 11px 14px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 10px;
  font: 500 14px 'Plus Jakarta Sans', sans-serif;
  color: #fff;
  background: rgba(0, 0, 0, 0.24);
  transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
}

.adm-input::placeholder {
  color: rgba(255, 255, 255, 0.25);
}

.adm-input:focus {
  outline: none;
  border-color: #4f9136;
  box-shadow: 0 0 0 3px rgba(79, 145, 54, 0.25);
  background: rgba(0, 0, 0, 0.35);
}

.adm-textarea {
  resize: vertical;
  min-height: 60px;
}

.adm-imgfield {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.adm-imgfield__controls {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}

.adm-imgfield__controls .adm-input {
  flex: 1;
  min-width: 200px;
}

.adm-imgfield__preview {
  display: none;
  margin-top: 8px;
  max-width: 180px;
  max-height: 120px;
  border-radius: 12px;
  border: 1.5px solid rgba(255, 255, 255, 0.1);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
  object-fit: cover;
}

/* List Items Container */
.adm-list {
  display: flex;
  flex-direction: column;
  gap: 18px;
  margin-top: 8px;
}

.adm-item {
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 16px;
  padding: 16px 18px;
  background: rgba(255, 255, 255, 0.005);
  transition: background 0.2s, border-color 0.2s;
}

.adm-item:hover {
  background: rgba(255, 255, 255, 0.015);
  border-color: rgba(255, 255, 255, 0.1);
}

.adm-item__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 12px;
  border-bottom: 1px dashed rgba(255, 255, 255, 0.06);
  padding-bottom: 8px;
}

.adm-item__idx {
  font: 700 13px 'Plus Jakarta Sans', sans-serif;
  color: #9fc98c;
}

.adm-item__tools {
  display: flex;
  gap: 8px;
}

.adm-iconbtn {
  width: 32px;
  height: 32px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(0, 0, 0, 0.15);
  border-radius: 8px;
  cursor: pointer;
  color: #cfe6bf;
  font-size: 14px;
  line-height: 1;
  display: grid;
  place-items: center;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}

.adm-iconbtn:hover {
  background: #2f5d31;
  color: #fff;
  border-color: #2f5d31;
}

.adm-iconbtn[title="Hapus"]:hover {
  background: #903c3c;
  color: #fff;
  border-color: #903c3c;
}

.adm-empty {
  color: #7d9685;
  font: 600 13.5px 'Plus Jakarta Sans', sans-serif;
  padding: 12px 0;
}

/* Custom import labels */
.adm-import-label {
  cursor: pointer;
}

/* Dashboard Sidebar Layout */
.admin__container {
  display: flex;
  gap: 32px;
  margin-top: 24px;
  align-items: flex-start;
}

.admin__sidebar {
  width: 240px;
  flex-shrink: 0;
  position: sticky;
  top: 90px;
}

.admin__content {
  flex-grow: 1;
  min-width: 0;
}

.admin__nav {
  display: flex;
  flex-direction: column;
  gap: 8px;
  background: rgba(255, 255, 255, 0.01);
  border: 1px solid rgba(255, 255, 255, 0.05);
  padding: 12px;
  border-radius: 20px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.admin__nav-btn {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 12px 16px;
  border: 1px solid transparent;
  border-radius: 12px;
  background: transparent;
  color: #7d9685;
  font: 700 14px 'Plus Jakarta Sans', sans-serif;
  text-align: left;
  cursor: pointer;
  transition: background 0.2s, color 0.2s, border-color 0.2s, box-shadow 0.2s;
  outline: none;
}

.admin__nav-btn:hover {
  background: rgba(255, 255, 255, 0.02);
  color: #fff;
  border-color: rgba(255, 255, 255, 0.05);
}

.admin__nav-btn.is-active {
  background: rgba(47, 93, 49, 0.15);
  color: #9fc98c;
  border-color: rgba(47, 93, 49, 0.3);
  box-shadow: 0 4px 15px rgba(47, 93, 49, 0.08);
}

.admin__nav-icon {
  font-size: 16px;
}

@media (max-width: 768px) {
  .admin__container {
    flex-direction: column;
    gap: 20px;
  }
  
  .admin__sidebar {
    width: 100%;
    position: relative;
    top: 0;
  }
  
  .admin__nav {
    flex-direction: row;
    flex-wrap: wrap;
    padding: 8px;
    border-radius: 16px;
    gap: 6px;
  }
  
  .admin__nav-btn {
    width: auto;
    flex: 1;
    min-width: 120px;
    justify-content: center;
    padding: 10px 12px;
    font-size: 13px;
  }
}

@media (max-width: 620px) {
  .adm-grid {
    grid-template-columns: 1fr;
  }
}

/* ---------------- reduced motion ---------------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; }
}


