/* ============================================================
   Aksara Design — kado digital anak muda
   playful · romantis · ceria
   (vanilla rebuild — data via PocketBase)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,500;12..96,600;12..96,700;12..96,800&family=Plus+Jakarta+Sans:ital,wght@0,400;0,500;0,600;0,700;1,500&family=Caveat:wght@500;600;700&display=swap');

:root {
  /* soft hand-drawn sticker palette (from logo) */
  --bg:        #f4ecda;
  --bg-2:      #ece2cc;
  --paper:     #fdfbf3;
  --ink:       #313845;   /* dark slate */
  --ink-soft:  #6f7787;
  --ink-faint: #a9afbd;
  --outline:   #2f3640;   /* sticker outline */
  --line:      rgba(49, 56, 69, 0.12);
  --line-2:    rgba(49, 56, 69, 0.07);

  --rose:      #d18f82;   /* dusty rose — primary accent */
  --rose-deep: #bf786a;
  --rose-soft: #f1ded7;   /* tint */
  --slate:     #555f72;   /* deep slate blue */
  --peri:      #767c93;   /* periwinkle slate */
  --peach:     #ecc59c;

  /* legacy aliases kept so component rules still resolve */
  --sun:       #ecc59c;
  --grape:     #767c93;
  --mint:      #555f72;

  --shadow-rose: 0 14px 34px -16px rgba(191, 120, 106, .5);
  --shadow-soft: 0 16px 40px -22px rgba(49, 56, 69, .4);

  --display: 'Bricolage Grotesque', system-ui, sans-serif;
  --sans:    'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  --hand:    'Caveat', cursive;

  --maxw: 1280px;
  --gutter: clamp(20px, 5vw, 60px);
}

* { box-sizing: border-box; }
[hidden] { display: none !important; }
html { scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 17px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

::selection { background: var(--rose); color: #fff; }

/* visible keyboard focus for a11y */
:focus-visible { outline: 3px solid var(--rose); outline-offset: 2px; border-radius: 6px; }

/* hand-drawn sticker accent for key interactive bits */
.sticker-edge { border: 2px solid var(--outline); }

a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }

.wrap { max-width: var(--maxw); margin: 0 auto; padding-inline: var(--gutter); }
.display { font-family: var(--display); }
.hand { font-family: var(--hand); }

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.02em;
  color: var(--rose-deep);
  background: var(--rose-soft);
  padding: 7px 15px 7px 12px;
  border-radius: 999px;
}
.eyebrow .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--rose); }

/* pill button — hand-drawn sticker */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-family: var(--sans);
  font-weight: 700;
  font-size: 16px;
  padding: 13px 26px;
  border-radius: 999px;
  background: var(--rose);
  color: #fff;
  border: 2px solid var(--outline);
  box-shadow: 0 4px 0 0 var(--outline);
  transition: transform .2s cubic-bezier(.34,1.56,.64,1), background .25s, box-shadow .2s;
}
.btn:hover { transform: translateY(-2px); background: var(--rose-deep); box-shadow: 0 6px 0 0 var(--outline); }
.btn:active { transform: translateY(2px); box-shadow: 0 1px 0 0 var(--outline); }
.btn.ghost { background: var(--paper); color: var(--ink); }
.btn.ghost:hover { background: #fff; }

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: fixed; inset: 0 0 auto 0; z-index: 60;
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px var(--gutter);
  transition: background .35s, box-shadow .35s, padding .35s;
}
.nav.scrolled {
  background: rgba(244, 236, 218, .85);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 6px 24px -16px rgba(49,56,69,.45);
  padding-block: 11px;
}
.nav-brand { display: flex; align-items: center; gap: 10px; font-family: var(--display); font-weight: 800; font-size: 22px; letter-spacing: -0.02em; }
.nav-logo-img {
  height: 40px; width: auto;
  transform: rotate(-3deg);
  filter: drop-shadow(0 3px 5px rgba(49,56,69,.22));
}
.footer .fbrand .nav-logo-img { height: 34px; }
.nav-brand b { font-weight: 800; }
.nav-brand i { color: var(--rose); font-style: normal; }
.nav-links { display: flex; align-items: center; gap: 4px; }
.nav-links a:not(.btn) { font-weight: 600; font-size: 15px; padding: 9px 14px; border-radius: 999px; color: var(--ink-soft); transition: .2s; }
.nav-links a:not(.btn):hover { color: var(--ink); background: var(--paper); }
.nav .btn { padding: 11px 20px; font-size: 15px; }
@media (max-width: 780px) { .nav-links a:not(.btn) { display: none; } }
@media (max-width: 360px) { .nav-brand span { display: none; } }

/* ============================================================
   HERO
   ============================================================ */
.hero { position: relative; padding-top: clamp(130px, 20vh, 200px); padding-bottom: clamp(40px, 7vw, 90px); }
.hero-inner { position: relative; text-align: center; z-index: 2; }
.hero-logo {
  display: block;
  width: min(460px, 78%);
  margin: 0 auto 4px;
  filter: drop-shadow(0 16px 26px rgba(49,56,69,.18));
  opacity: 0; transform: scale(.85);
  animation: pop .8s .05s cubic-bezier(.34,1.56,.64,1) forwards;
}
.hero-eyebrow { opacity: 0; animation: pop .6s .1s cubic-bezier(.34,1.56,.64,1) forwards; }

.hero-title {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(38px, 7vw, 88px);
  line-height: 0.96;
  letter-spacing: -0.035em;
  margin: 8px 0 0;
}
.hero-title .line { display: block; }
.hero-title .w {
  display: inline-block;
  margin-inline: 0.16em;
  opacity: 0;
  transform: translateY(40px) rotate(-4deg);
  animation: wordIn .7s cubic-bezier(.34,1.56,.64,1) forwards;
}
.hero-title .rose { color: var(--rose); }

.hero-note { font-family: var(--hand); font-size: clamp(24px, 3.4vw, 38px); color: var(--rose); transform: rotate(-3deg); display: inline-block; margin-top: 6px; opacity: 0; animation: pop .6s .9s cubic-bezier(.34,1.56,.64,1) forwards; }

.hero-lede { max-width: 42ch; margin: 26px auto 0; font-size: clamp(17px, 1.9vw, 20px); color: var(--ink-soft); opacity: 0; animation: rise .7s 1s ease forwards; }
.hero-cta { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; margin-top: 34px; opacity: 0; animation: rise .7s 1.15s ease forwards; }

/* floating stickers */
.sticker {
  position: absolute;
  font-size: clamp(28px, 4vw, 52px);
  filter: drop-shadow(0 10px 18px rgba(49,56,69,.18));
  z-index: 1;
  opacity: 0;
  animation: pop .7s ease forwards, floaty 5s ease-in-out infinite;
  user-select: none;
}
.sticker.s1 { top: 14%;  left: 7%;  animation-delay: 1.2s, 1.9s; transform: rotate(-12deg); }
.sticker.s2 { top: 22%;  right: 8%; animation-delay: 1.35s, 2.1s; transform: rotate(10deg); }
.sticker.s3 { top: 54%;  left: 12%; animation-delay: 1.5s, 1.6s; }
.sticker.s4 { top: 60%;  right: 11%;animation-delay: 1.45s, 2.4s; transform: rotate(8deg); }
.sticker.s5 { top: 6%;   right: 26%;animation-delay: 1.6s, 2.0s; font-size: clamp(20px,2.6vw,34px); }
.sticker.s6 { bottom: 4%; left: 24%; animation-delay: 1.55s, 1.7s; font-size: clamp(20px,2.6vw,34px); }
@media (max-width: 720px) { .sticker.s3, .sticker.s4, .sticker.s5, .sticker.s6 { display: none; } }

/* confetti dots in hero bg */
.confetti { position: absolute; inset: 0; z-index: 0; pointer-events: none; overflow: hidden; }
.confetti i { position: absolute; border-radius: 2px; opacity: .8; animation: floaty 6s ease-in-out infinite; }

/* ============================================================
   SECTION SHELL
   ============================================================ */
.section { padding-block: clamp(64px, 10vw, 120px); position: relative; }
.section-head { text-align: center; max-width: 30ch; margin: 0 auto clamp(38px, 5vw, 60px); }
.section-head h2 {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(32px, 5.5vw, 64px);
  line-height: 1.02;
  letter-spacing: -0.03em;
  margin: 16px 0 0;
}
.section-head h2 .rose { color: var(--rose); }
.section-head p { color: var(--ink-soft); margin: 14px auto 0; max-width: 46ch; }

/* ============================================================
   KATEGORI KADO
   ============================================================ */
.cats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
@media (max-width: 900px) { .cats { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .cats { grid-template-columns: 1fr; } }
.cat {
  background: var(--paper);
  border: 1.5px solid var(--line);
  border-radius: 24px;
  padding: 26px 24px 24px;
  box-shadow: var(--shadow-soft);
  transition: transform .3s cubic-bezier(.34,1.56,.64,1), box-shadow .3s;
  position: relative;
  overflow: hidden;
}
.cat:hover { transform: translateY(-6px) rotate(-1deg); }
.cat-emoji { font-size: 40px; display: inline-block; transition: transform .3s; }
.cat:hover .cat-emoji { transform: scale(1.15) rotate(-8deg); }
.cat h3 { font-family: var(--display); font-weight: 700; font-size: 21px; margin: 16px 0 6px; }
.cat p { color: var(--ink-soft); font-size: 14.5px; margin: 0; }
.cat .blob { position: absolute; width: 120px; height: 120px; border-radius: 50%; right: -40px; top: -40px; opacity: .14; filter: blur(6px); }

/* ============================================================
   WORK (phone-style previews)
   ============================================================ */
.work-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(20px, 3vw, 38px); }
@media (max-width: 900px) { .work-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .work-grid { grid-template-columns: 1fr; max-width: 360px; margin-inline: auto; } }

.pcard { display: block; }
.phone {
  position: relative;
  border-radius: 38px;
  background: var(--outline);
  padding: 9px;
  box-shadow: var(--shadow-soft);
  transition: transform .4s cubic-bezier(.34,1.56,.64,1);
}
.pcard:hover .phone { transform: translateY(-10px) rotate(-1.5deg); }
.phone::before {
  content: ""; position: absolute; top: 17px; left: 50%; transform: translateX(-50%);
  width: 74px; height: 7px; border-radius: 999px; background: rgba(255,255,255,.22); z-index: 4;
}
.phone-screen {
  position: relative; border-radius: 30px; overflow: hidden;
  aspect-ratio: 10 / 18; background: var(--bg-2);
}
.phone-screen img, .phone-shot { width: 100%; height: 100%; object-fit: cover; transition: transform 1s cubic-bezier(.2,.8,.2,1); }
.pcard:hover .phone-screen img, .pcard:hover .phone-shot { transform: scale(1.07); }

.phone-shot { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 14px;
  background-image: repeating-linear-gradient(45deg, var(--bg-2) 0 12px, #e6dcc4 12px 24px); }
.phone-shot .big { font-size: 46px; }
.phone-shot .lbl { font-family: var(--sans); font-weight: 600; font-size: 12px; color: var(--ink-soft); background: var(--paper); border-radius: 999px; padding: 6px 12px; }

.phone-tag {
  position: absolute; top: 14px; right: 14px; z-index: 5;
  font-weight: 700; font-size: 11px; color: #fff;
  background: var(--rose); padding: 5px 11px; border-radius: 999px;
  border: 1.5px solid var(--outline);
}
.phone-visit {
  position: absolute; left: 12px; right: 12px; bottom: 12px; z-index: 5;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  font-weight: 700; font-size: 14px; color: var(--ink);
  background: rgba(255,255,255,.92); backdrop-filter: blur(4px);
  padding: 12px; border-radius: 16px;
  opacity: 0; transform: translateY(12px); transition: .35s;
}
.pcard:hover .phone-visit { opacity: 1; transform: translateY(0); }

.pcard-body { text-align: center; padding: 18px 8px 0; }
.pcard-title { font-family: var(--display); font-weight: 700; font-size: 22px; margin: 0 0 4px; }
.pcard-desc { color: var(--ink-soft); font-size: 14.5px; margin: 0; }
.pcard-demo { display: inline-flex; align-items: center; gap: 6px; margin-top: 12px; font-weight: 700; font-size: 14px; color: #fff; background: var(--rose); border: 2px solid var(--outline); border-radius: 999px; padding: 9px 18px; box-shadow: 0 3px 0 0 var(--outline); transition: transform .2s, box-shadow .2s, background .2s; }
.pcard-demo:hover { transform: translateY(-2px); background: var(--rose-deep); box-shadow: 0 5px 0 0 var(--outline); }
.pcard-demo:active { transform: translateY(1px); box-shadow: 0 1px 0 0 var(--outline); }

/* swipeable gallery inside phone screen */
.gallery { position: absolute; inset: 0; }
.gallery-track {
  display: flex; height: 100%; width: 100%;
  overflow-x: auto; overflow-y: hidden;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.gallery-track::-webkit-scrollbar { display: none; }
.gallery-track img {
  flex: 0 0 100%; width: 100%; height: 100%;
  object-fit: cover; scroll-snap-align: center;
  user-select: none; -webkit-user-drag: none;
}
.gallery-nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 32px; height: 32px; border-radius: 50%;
  display: grid; place-items: center; z-index: 6;
  font-size: 20px; font-weight: 700; line-height: 1; color: var(--ink);
  background: rgba(255,255,255,.86); border: 1.5px solid var(--outline);
  box-shadow: 0 3px 8px -2px rgba(49,56,69,.4);
  opacity: 0; transition: opacity .25s, background .2s;
}
.phone:hover .gallery-nav { opacity: 1; }
.gallery-nav:hover { background: #fff; }
.gallery-prev { left: 8px; }
.gallery-next { right: 8px; }
@media (hover: none) { .gallery-nav { opacity: .9; } }
.gallery-dots { position: absolute; left: 0; right: 0; bottom: 10px; z-index: 6; display: flex; justify-content: center; gap: 6px; }
.gallery-dot { width: 7px; height: 7px; border-radius: 50%; background: rgba(255,255,255,.55); border: 1px solid rgba(49,56,69,.25); transition: width .25s, background .2s; padding: 0; }
.gallery-dot.on { width: 18px; border-radius: 4px; background: #fff; }

/* ============================================================
   STRIP marquee
   ============================================================ */
.strip { background: var(--slate); color: var(--paper); padding-block: 15px; overflow: hidden; transform: rotate(-1.4deg); margin-block: clamp(20px,5vw,50px); width: 110%; margin-left: -5%; border-block: 2px solid var(--outline); }
.strip-track { display: flex; width: max-content; animation: scrollX 26s linear infinite; }
.strip-item { font-family: var(--display); font-weight: 700; font-size: clamp(20px, 2.6vw, 30px); padding-inline: 26px; display: flex; align-items: center; gap: 26px; white-space: nowrap; }
.strip-item::after { content: "♡"; color: var(--rose); opacity: .9; }

/* ============================================================
   ABOUT / how it works
   ============================================================ */
.about { background: var(--bg-2); }
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(18px, 3vw, 34px); }
@media (max-width: 760px) { .steps { grid-template-columns: 1fr; max-width: 440px; margin-inline: auto; } }
.step { background: var(--paper); border: 1.5px solid var(--line); border-radius: 24px; padding: 30px 28px; box-shadow: var(--shadow-soft); position: relative; }
.step-no { font-family: var(--display); font-weight: 800; font-size: 17px; width: 44px; height: 44px; border-radius: 14px; display: grid; place-items: center; color: #fff; background: var(--rose); border: 2px solid var(--outline); box-shadow: 0 3px 0 0 var(--outline); margin-bottom: 18px; }
.step:nth-child(2) .step-no { background: var(--slate); }
.step:nth-child(3) .step-no { background: var(--peri); }
.step h3 { font-family: var(--display); font-weight: 700; font-size: 22px; margin: 0 0 8px; }
.step p { color: var(--ink-soft); font-size: 15px; margin: 0; }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.quotes { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(16px, 2.5vw, 26px); }
@media (max-width: 900px) { .quotes { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .quotes { grid-template-columns: 1fr; } }
.quote { background: var(--paper); border: 1.5px solid var(--line); border-radius: 24px; padding: 26px 26px 22px; box-shadow: var(--shadow-soft); display: flex; flex-direction: column; gap: 18px; }
.quote:nth-child(2) { transform: rotate(1deg); }
.quote:nth-child(3) { transform: rotate(-1deg); }
.quote-stars { color: var(--rose); font-size: 16px; letter-spacing: 2px; }
.quote-text { font-size: 16.5px; line-height: 1.5; flex: 1; }
.quote-by { display: flex; align-items: center; gap: 12px; }
.quote-ava { width: 44px; height: 44px; border-radius: 50%; display: grid; place-items: center; font-family: var(--display); font-weight: 700; font-size: 18px; color: #fff; border: 2px solid var(--outline); }
.quote-name { font-weight: 700; font-size: 14.5px; }
.quote-role { color: var(--ink-soft); font-size: 13px; }

/* ============================================================
   CONTACT
   ============================================================ */
.contact { position: relative; }
.contact-card {
  background: linear-gradient(140deg, #6e7589, var(--slate));
  border-radius: 36px;
  padding: clamp(40px, 7vw, 80px) clamp(28px, 5vw, 70px);
  text-align: center;
  color: var(--paper);
  border: 2px solid var(--outline);
  box-shadow: 0 18px 40px -22px rgba(49,56,69,.6);
  position: relative;
  overflow: hidden;
}
.contact-card::after { content: ""; position: absolute; inset: 12px; border: 2px dashed rgba(253,251,243,.4); border-radius: 26px; pointer-events: none; }
.contact-card .eyebrow { background: rgba(255,255,255,.2); color: #fff; }
.contact-card .eyebrow .dot { background: #fff; }
.contact-big { font-family: var(--display); font-weight: 800; font-size: clamp(34px, 6vw, 72px); line-height: 1.0; letter-spacing: -0.03em; margin: 18px 0 0; }
.contact-sub { color: rgba(255,255,255,.85); margin: 14px auto 0; max-width: 40ch; }
.contact-row { display: flex; gap: 13px; justify-content: center; flex-wrap: wrap; margin-top: 34px; position: relative; z-index: 2; }
.clink { display: inline-flex; align-items: center; gap: 10px; font-weight: 700; font-size: 16px; padding: 14px 24px; border-radius: 999px; background: rgba(255,255,255,.15); color: #fff; border: 1.5px solid rgba(255,255,255,.35); transition: transform .25s cubic-bezier(.34,1.56,.64,1), background .25s, color .25s; }
.clink:hover { transform: translateY(-3px); background: var(--paper); color: var(--slate); }
.clink svg { width: 20px; height: 20px; }
.clink small { font-weight: 500; opacity: .7; font-size: 12px; }
.contact-card .c-sticker { position: absolute; font-size: clamp(40px,7vw,90px); opacity: .22; }
.contact-card .c-sticker.a { top: -10px; left: 4%; transform: rotate(-15deg); }
.contact-card .c-sticker.b { bottom: -16px; right: 5%; transform: rotate(12deg); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { text-align: center; padding: 40px var(--gutter) 50px; color: var(--ink-soft); font-size: 14px; }
.footer .fbrand { font-family: var(--display); font-weight: 800; font-size: 20px; color: var(--ink); display: inline-flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.footer-admin { display: inline-block; margin-top: 10px; font-size: 12px; color: var(--ink-faint); }
.footer-admin:hover { color: var(--rose); }

/* reveal */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .7s ease, transform .7s cubic-bezier(.34,1.4,.64,1); }
.reveal.in { opacity: 1; transform: none; }

/* keyframes */
@keyframes wordIn { to { opacity: 1; transform: none; } }
@keyframes pop { from { opacity: 0; transform: scale(.7); } to { opacity: 1; transform: scale(1); } }
@keyframes rise { from { opacity: 0; transform: translateY(18px); } to { opacity: 1; transform: none; } }
@keyframes scrollX { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes floaty { 0%,100% { transform: translateY(0) rotate(var(--r,0deg)); } 50% { transform: translateY(-14px) rotate(var(--r,0deg)); } }
@keyframes spin { to { transform: rotate(360deg); } }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .hero-title .w, .hero-eyebrow, .hero-note, .hero-lede, .hero-cta, .sticker, .hero-logo { animation: none !important; opacity: 1 !important; transform: none !important; }
  .reveal { opacity: 1 !important; transform: none !important; }
  .strip-track, .confetti i { animation: none !important; }
}

/* ============================================================
   STATE: loading / empty / error / toast
   ============================================================ */
.work-empty, .quotes-empty { text-align: center; color: var(--ink-soft); font-size: 16px; padding: 40px 0; grid-column: 1 / -1; }

.spinner { width: 26px; height: 26px; border-radius: 50%; border: 3px solid var(--line); border-top-color: var(--rose); animation: spin .8s linear infinite; }
.loading-row { display: flex; align-items: center; justify-content: center; gap: 12px; color: var(--ink-soft); padding: 30px 0; grid-column: 1 / -1; }

.site-banner {
  position: fixed; left: 50%; bottom: 18px; transform: translateX(-50%) translateY(120%);
  z-index: 120; max-width: min(540px, 92vw);
  background: var(--ink); color: var(--paper);
  border: 2px solid var(--outline); border-radius: 16px;
  padding: 13px 18px; font-size: 14px; font-weight: 600;
  box-shadow: 0 12px 30px -12px rgba(49,56,69,.6);
  transition: transform .3s cubic-bezier(.34,1.56,.64,1), opacity .3s;
  opacity: 0; text-align: center;
}
.site-banner.show { transform: translateX(-50%) translateY(0); opacity: 1; }
.site-banner.err { background: #c8584b; border-color: #a8443a; }

/* ============================================================
   ADMIN PAGE (Admin.html) — login + full-page shell
   ============================================================ */
.admin-body { background: var(--bg-2); min-height: 100vh; }

/* lock / login screen */
.lock { min-height: 100vh; display: grid; place-items: center; padding: 24px; }
.lock-card {
  width: min(420px, 100%);
  background: var(--bg);
  border: 2px solid var(--outline);
  border-radius: 24px;
  box-shadow: 8px 10px 0 rgba(47,53,67,.16);
  padding: 34px 30px 26px;
  text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 4px;
}
.lock-logo { width: 150px; margin-bottom: 4px; filter: drop-shadow(0 10px 18px rgba(49,56,69,.16)); }
.lock-title { font-family: var(--display); font-weight: 800; font-size: 25px; line-height: 1.15; margin: 4px 0 0; }
.lock-sub { color: var(--ink-soft); font-size: 14px; margin: 12px 0 18px; max-width: 32ch; }
.lock-form { width: 100%; }
.lock-input {
  width: 100%; font-family: var(--sans); font-size: 15px; color: var(--ink);
  background: var(--paper); border: 1.5px solid var(--line); border-radius: 12px;
  padding: 13px 15px; margin-bottom: 10px; transition: border-color .2s, box-shadow .2s;
}
.lock-input:focus { outline: none; border-color: var(--rose); box-shadow: 0 0 0 3px rgba(207,138,124,.18); }
.lock-err { color: #c8584b; font-size: 13px; font-weight: 600; margin-bottom: 8px; min-height: 1px; }
.lock-btn {
  width: 100%; font-family: var(--sans); font-weight: 700; font-size: 16px; color: #fff;
  background: var(--rose); border: 2px solid var(--outline); border-radius: 12px;
  box-shadow: 3px 3px 0 var(--outline); padding: 13px; margin-top: 6px;
  transition: transform .2s, box-shadow .2s;
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
}
.lock-btn:hover:not(:disabled) { transform: translate(-1px,-1px); box-shadow: 4px 4px 0 var(--outline); }
.lock-btn:disabled { opacity: .6; cursor: default; }
.lock-btn .spinner { width: 18px; height: 18px; border-width: 2px; border-top-color: #fff; border-color: rgba(255,255,255,.4); border-top-color: #fff; }
.lock-back { margin-top: 16px; font-size: 13px; color: var(--ink-soft); font-weight: 600; }
.lock-back:hover { color: var(--rose); }

/* page shell */
.ap { max-width: 880px; margin: 0 auto; padding: clamp(14px, 3vw, 30px); }
.ap-top {
  display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap;
  background: var(--bg); border: 2px solid var(--outline); border-radius: 18px;
  box-shadow: 5px 6px 0 rgba(47,53,67,.14);
  padding: 14px 18px; margin-bottom: 16px;
}
.ap-brand { display: flex; align-items: center; gap: 12px; }
.ap-brand .nav-logo-img { height: 42px; }
.ap-brand-name { font-family: var(--display); font-weight: 800; font-size: 19px; line-height: 1; }
.ap-brand-sub { font-size: 12.5px; color: var(--ink-soft); margin-top: 3px; }
.ap-top-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.ap-saved { font-size: 13px; font-weight: 600; color: var(--mint); opacity: 0; transition: opacity .25s; }
.ap-saved.show { opacity: 1; }
.ap-saved.err { color: #c8584b; }
.ap-link { font-size: 13.5px; font-weight: 600; color: var(--slate); padding: 9px 14px; border-radius: 999px; border: 1.5px solid var(--line); transition: .2s; }
.ap-link:hover { background: var(--slate); color: #fff; border-color: var(--slate); }
.ap-logout { font-size: 13.5px; font-weight: 700; color: var(--ink); background: var(--bg-2); border: 1.5px solid var(--line); border-radius: 999px; padding: 9px 16px; transition: .2s; }
.ap-logout:hover { background: #c8584b; color: #fff; border-color: #c8584b; }

.ap-tabs { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 16px; }
.ap-main { background: var(--bg); border: 2px solid var(--outline); border-radius: 18px; box-shadow: 5px 6px 0 rgba(47,53,67,.14); padding: clamp(16px, 3vw, 26px); }
.ap-main .adm-tabpane > .adm-section-title:first-child { margin-top: 0; }
@media (max-width: 600px) { .ap-top-actions { width: 100%; } }

/* tabs */
.adm-tab { display: inline-flex; align-items: center; gap: 7px; font-weight: 600; font-size: 13.5px; color: var(--ink-soft); padding: 9px 14px; border-radius: 999px; transition: .2s; background: var(--bg); border: 1.5px solid var(--line); }
.adm-tab:hover { background: var(--bg-2); color: var(--ink); }
.adm-tab.on { background: var(--ink); color: var(--paper); border-color: var(--ink); }

.adm-pane-head { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-bottom: 16px; flex-wrap: wrap; }
.adm-pane-head p { margin: 0; font-size: 14px; color: var(--ink-soft); max-width: 46ch; }
.adm-add { font-weight: 700; font-size: 14px; color: #fff; background: var(--rose); padding: 11px 18px; border-radius: 999px; border: 2px solid var(--outline); box-shadow: 3px 3px 0 var(--outline); transition: transform .2s; }
.adm-add:hover { transform: translate(-1px,-1px); box-shadow: 4px 4px 0 var(--outline); }
.adm-add:disabled { opacity: .5; cursor: default; }

.adm-empty { text-align: center; color: var(--ink-soft); padding: 30px; font-size: 14.5px; }

/* editor card */
.adm-card { border: 1.5px solid var(--line); border-radius: 16px; background: var(--paper); margin-bottom: 14px; overflow: hidden; }
.adm-card-top { display: flex; align-items: center; gap: 10px; padding: 11px 14px; background: var(--bg-2); border-bottom: 1.5px solid var(--line); }
.adm-card-no { font-family: monospace; font-size: 12px; color: var(--ink-soft); font-weight: 700; }
.adm-card-name { flex: 1; font-size: 14.5px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.adm-card-tools { display: flex; gap: 5px; }
.adm-icon { width: 30px; height: 30px; border-radius: 8px; border: 1.5px solid var(--line); background: var(--paper); color: var(--ink); font-size: 13px; transition: .15s; }
.adm-icon:hover:not(:disabled) { background: var(--slate); color: #fff; border-color: var(--slate); }
.adm-icon.danger:hover:not(:disabled) { background: #c8584b; color: #fff; border-color: #c8584b; }
.adm-icon:disabled { opacity: .35; cursor: default; }

.adm-card-body { display: grid; grid-template-columns: 150px 1fr; gap: 16px; padding: 16px; }
.adm-card-pbody { display: flex; flex-direction: column; gap: 14px; padding: 16px; }
.adm-card-fields { display: flex; flex-direction: column; gap: 11px; }
.adm-card-fields.full { padding: 16px; }

/* admin multi-image gallery */
.adm-gallery-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(96px, 1fr)); gap: 10px; padding: 4px; border-radius: 12px; transition: background .2s; }
.adm-gallery-grid.over { background: rgba(207,138,124,.1); outline: 2px dashed var(--rose); outline-offset: 2px; }
.adm-thumb { position: relative; aspect-ratio: 10/14; border-radius: 12px; overflow: hidden; border: 1.5px solid var(--line); background: var(--bg); }
.adm-thumb > img { width: 100%; height: 100%; object-fit: cover; display: block; }
.adm-thumb-no { position: absolute; top: 5px; left: 5px; z-index: 2; font-size: 11px; font-weight: 700; color: #fff; background: rgba(47,53,67,.7); border-radius: 6px; padding: 1px 7px; }
.adm-thumb-tools { position: absolute; inset: auto 0 0 0; display: flex; gap: 3px; padding: 4px; justify-content: center; background: linear-gradient(transparent, rgba(47,53,67,.55)); }
.adm-thumb-btn { width: 26px; height: 26px; border-radius: 7px; font-size: 13px; font-weight: 700; line-height: 1; color: var(--ink); background: rgba(255,255,255,.92); border: 1px solid var(--outline); display: grid; place-items: center; transition: .15s; }
.adm-thumb-btn:hover:not(:disabled) { background: var(--slate); color: #fff; }
.adm-thumb-btn.del:hover { background: #c8584b; color: #fff; }
.adm-thumb-btn:disabled { opacity: .35; cursor: default; }
.adm-thumb-add { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px; aspect-ratio: 10/14; border: 2px dashed var(--line); border-radius: 12px; background: var(--bg); color: var(--ink-soft); font-size: 12px; font-weight: 600; transition: .2s; }
.adm-thumb-add:hover:not(:disabled) { border-color: var(--rose); color: var(--rose); background: rgba(207,138,124,.06); }
.adm-thumb-add .big { font-size: 24px; }
.adm-thumb-add.busy { opacity: .7; cursor: default; }
@media (max-width: 560px) { .adm-card-body { grid-template-columns: 1fr; } }

.adm-field { display: flex; flex-direction: column; gap: 5px; }
.adm-label { font-size: 12.5px; font-weight: 700; color: var(--ink); display: flex; gap: 7px; align-items: baseline; }
.adm-label em { font-style: normal; font-weight: 500; color: var(--ink-faint); font-size: 11.5px; }
.adm-input { font-family: var(--sans); font-size: 14px; color: var(--ink); background: var(--bg); border: 1.5px solid var(--line); border-radius: 10px; padding: 9px 12px; width: 100%; transition: border-color .2s, box-shadow .2s; resize: vertical; }
.adm-input:focus { outline: none; border-color: var(--rose); box-shadow: 0 0 0 3px rgba(207,138,124,.18); }
.adm-row { display: grid; grid-template-columns: 1fr 1fr; gap: 11px; }
@media (max-width: 480px) { .adm-row { grid-template-columns: 1fr; } }

/* image picker */
.adm-img { display: flex; flex-direction: column; gap: 8px; }
.adm-drop { aspect-ratio: 10/14; border: 2px dashed var(--line); border-radius: 12px; background: var(--bg); overflow: hidden; cursor: pointer; display: grid; place-items: center; transition: border-color .2s, background .2s; position: relative; }
.adm-drop.over { border-color: var(--rose); background: rgba(207,138,124,.08); }
.adm-drop.has { border-style: solid; }
.adm-drop img { width: 100%; height: 100%; object-fit: cover; }
.adm-drop-empty { display: flex; flex-direction: column; align-items: center; gap: 8px; color: var(--ink-faint); font-size: 11.5px; text-align: center; padding: 10px; }
.adm-drop-empty .big { font-size: 26px; }
.adm-drop-busy { position: absolute; inset: 0; display: grid; place-items: center; background: rgba(253,251,243,.7); }
.adm-img-actions { display: flex; gap: 6px; }
.adm-mini { flex: 1; font-size: 12px; font-weight: 600; color: var(--ink); background: var(--bg-2); border: 1.5px solid var(--line); border-radius: 8px; padding: 7px; transition: .15s; }
.adm-mini:hover { background: var(--slate); color: #fff; border-color: var(--slate); }
.adm-mini.danger:hover { background: #c8584b; border-color: #c8584b; }
.adm-err { font-size: 12px; color: #c8584b; }

.adm-swatches { display: flex; gap: 8px; }
.adm-swatch { width: 30px; height: 30px; border-radius: 50%; border: 2px solid var(--line); cursor: pointer; transition: transform .15s; }
.adm-swatch:hover { transform: scale(1.12); }
.adm-swatch.on { border-color: var(--ink); box-shadow: 0 0 0 3px var(--bg), 0 0 0 5px var(--ink); }

.adm-section-title { font-family: var(--display); font-weight: 700; font-size: 16px; margin: 6px 0 12px; padding-bottom: 8px; border-bottom: 1.5px solid var(--line); }
.adm-tabpane > .adm-section-title:not(:first-child) { margin-top: 24px; }
.adm-tabpane > .adm-field { margin-bottom: 11px; }
.adm-tabpane > .adm-row { margin-bottom: 11px; }
.adm-save-row { margin-top: 18px; display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }

.adm-note, .adm-msg, .adm-usage { font-size: 13px; line-height: 1.5; }
.adm-note { background: var(--bg-2); border: 1.5px solid var(--line); border-radius: 12px; padding: 13px 15px; color: var(--ink-soft); margin-bottom: 16px; }
.adm-note b { color: var(--ink); }
.adm-msg { color: var(--mint); font-weight: 600; }
.adm-msg.err { color: #c8584b; }

.adm-loading { display: flex; align-items: center; justify-content: center; gap: 12px; color: var(--ink-soft); padding: 60px 0; }

/* ============================================================
   REVISI: harga, filter katalog, musik, order-web, fix blur HP
   ============================================================ */

/* harga di kartu karya */
.pcard-price { display: flex; gap: 8px; justify-content: center; align-items: stretch; margin-top: 12px; flex-wrap: wrap; }
.price-cell { display: flex; flex-direction: column; align-items: center; gap: 1px; background: var(--rose-soft); border: 1.5px solid var(--line); border-radius: 12px; padding: 6px 14px; }
.price-cell.month { background: var(--bg-2); }
.price-val { font-family: var(--display); font-weight: 800; font-size: 15px; color: var(--ink); line-height: 1.1; }
.price-label { font-size: 10px; font-weight: 700; color: var(--ink-soft); text-transform: uppercase; letter-spacing: .04em; }

/* filter katalog karya (tap-tap) */
.cat-filter { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; margin: -18px auto 30px; max-width: 760px; }
.cat-chip { font-weight: 700; font-size: 13.5px; color: var(--ink-soft); background: var(--paper); border: 1.5px solid var(--line); border-radius: 999px; padding: 8px 16px; box-shadow: 0 2px 0 0 rgba(49,56,69,.12); transition: transform .15s, color .2s, background .2s, border-color .2s; }
.cat-chip:hover { color: var(--ink); border-color: var(--rose); transform: translateY(-1px); }
.cat-chip.on { background: var(--ink); color: var(--paper); border-color: var(--ink); }

/* order-web di testimoni */
.quote-order { margin-top: 2px; font-size: 12px; font-weight: 700; color: var(--rose-deep); background: var(--rose-soft); border: 1.5px solid var(--line); border-radius: 999px; padding: 5px 12px; align-self: flex-start; }
.quote-order-ico { margin-right: 2px; }

/* tombol musik */
.music-toggle { position: fixed; left: 16px; bottom: 16px; z-index: 90; width: 46px; height: 46px; border-radius: 50%; background: var(--paper); color: var(--rose-deep); border: 2px solid var(--outline); box-shadow: 0 4px 0 0 var(--outline); display: grid; place-items: center; font-size: 20px; transition: transform .2s, background .2s, color .2s, box-shadow .2s; }
.music-toggle:hover { transform: translateY(-2px); box-shadow: 0 6px 0 0 var(--outline); }
.music-toggle:active { transform: translateY(2px); box-shadow: 0 1px 0 0 var(--outline); }
.music-toggle.on { background: var(--rose); color: #fff; }
.music-ico { line-height: 1; }

/* ---- FIX BLUR DI HP ----
   Elemen yang dianimasikan/di-transform di-compose jadi layer GPU yang
   di-raster pada DPR rendah => blur di layar retina HP. Setelah animasi
   masuk selesai, lepaskan transform agar di-cat ulang tajam. */
body.anim-done .hero-logo,
body.anim-done .hero-title .w,
body.anim-done .hero-eyebrow,
body.anim-done .hero-note,
body.anim-done .hero-lede,
body.anim-done .hero-cta { animation: none !important; opacity: 1 !important; transform: none !important; }

/* marquee: render layer pada resolusi device + hindari blur sub-pixel */
.strip-track { will-change: transform; -webkit-backface-visibility: hidden; backface-visibility: hidden; transform: translateZ(0); }
.strip-item { -webkit-font-smoothing: antialiased; transform: translateZ(0); }
