/* =========================
   Pulih Hati — Base Styles
   ========================= */

/* Design Tokens */
:root{
  --bg:#ffffff;
  --text:#0f172a;
  --muted:#64748b;
  --card:#f8fafc;
  --border:#e2e8f0;
  --accent:#d946ef;      /* pink-magenta */
  --accent-2:#f0abfc;    /* soft pink */
  --good:#16a34a;
  --bad:#dc2626;
  --warn:#d97706;

  --radius:14px;
  --shadow:0 6px 24px rgba(15,23,42,.06);
}

/* Reset ringkas + aksesibiliti */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
}
body{
  margin:0;
  font:16px/1.65 system-ui,-apple-system,"Segoe UI",Roboto,Inter,Ubuntu,Helvetica,Arial,sans-serif;
  color:var(--text);
  background:var(--bg);
}
img{max-width:100%;height:auto}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.screen-reader-text,
.sr-only{
  position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;
}

/* Layout helpers */
.wrap{max-width:1100px;margin:auto;padding:28px 18px}
.grid{display:grid;gap:16px}
.g2{grid-template-columns:repeat(2,minmax(0,1fr))}
.g3{grid-template-columns:repeat(1,minmax(0,1fr))}
@media (min-width:720px){.g3{grid-template-columns:repeat(3,minmax(0,1fr))}}
.box{
  display:grid;gap:24px;align-items:center
}
@media (min-width:900px){
  .box{grid-template-columns:1.1fr .9fr}
}

/* Cards */
.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:16px;
  box-shadow:var(--shadow);
}
.card h3{margin:6px 0 8px;font-size:18px}

/* Pills/Tags/Badges */
.pill{
  display:inline-block;
  padding:6px 10px;
  border-radius:999px;
  background:#fff;
  border:1px solid var(--border);
  color:var(--text);
  font-size:13px;
}
.tag{
  display:inline-block;
  font-size:12px;
  color:#fff;
  background:var(--accent);
  padding:4px 8px;
  border-radius:999px;
}
.badge{
  display:inline-block;
  font-size:12px;
  color:var(--accent);
  background:#fff;
  border:1px solid var(--accent-2);
  padding:4px 8px;
  border-radius:999px;
}

/* Buttons + ripple */
.btn{
  --btn-bg:#fff;
  --btn-bd:var(--border);
  --btn-fg:var(--text);
  display:inline-flex;align-items:center;justify-content:center;
  gap:8px;
  padding:10px 14px;
  border:1px solid var(--btn-bd);
  background:var(--btn-bg);
  color:var(--btn-fg);
  border-radius:12px;
  cursor:pointer;
  text-decoration:none;
  transition:transform .05s ease, background .2s ease, border-color .2s ease;
  position:relative;overflow:hidden;isolation:isolate;
}
.btn:hover{transform:translateY(-1px)}
.btn.primary{
  --btn-bg:linear-gradient(135deg,var(--accent),#fb7185);
  --btn-bd:transparent;
  --btn-fg:#fff;
}
.btn.ripple::after{
  content:"";
  position:absolute;inset:auto;
  width:0;height:0;border-radius:50%;
  opacity:.25;background:#fff;
  transform:translate(-50%,-50%);
  pointer-events:none;
}
.btn.ripple:active::after{
  width:220px;height:220px;opacity:.15;transition:width .25s ease,height .25s ease,opacity .4s ease;
  left:var(--x,50%);top:var(--y,50%);
}

/* Header */
.header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--border);
}
.header .nav{
  display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;
}
.brand{display:flex;align-items:center;gap:8px;font-weight:800}
.brand .dot{
  width:10px;height:10px;border-radius:50%;
  background:conic-gradient(from 120deg,var(--accent),#fb7185,var(--accent));
  box-shadow:0 0 0 3px rgba(248,113,113,.15);
}

/* Primary Menu (wp_nav_menu fallback supported) */
.menu{display:flex;align-items:center;justify-content:center}
.menu-list, .menu ul{display:flex;gap:12px;list-style:none;margin:0;padding:0;flex-wrap:wrap}
.menu a{
  display:block;padding:8px 10px;border-radius:10px;color:var(--text);
}
.menu a:hover{background:#fff;border:1px solid var(--border);text-decoration:none}

/* CTA area */
.cta{display:flex;gap:8px;align-items:center}
@media (max-width:880px){
  .menu{display:none}
  .menu.is-open{display:block}
  .header .nav{grid-template-columns:auto auto 1fr}
}

/* Hero */
.hero{
  background:linear-gradient(135deg,#fff,#ffe4f3 60%);
  border-bottom:1px solid var(--border);
}
.hero .kicker{letter-spacing:.08em;color:var(--muted);font-weight:700;font-size:12px}
.hero h1{font-size:34px;line-height:1.15;margin:8px 0 10px}
.hero .sub{color:var(--muted)}

/* Section headers */
.sec-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:10px}
.sec-title{font-size:22px;font-weight:800}
.link{color:var(--muted)}
.link:hover{color:var(--text);text-decoration:none}

/* Pricing bits */
.price{font-size:24px;font-weight:800;margin:6px 0 8px}

/* Footer */
.footer{
  border-top:1px solid var(--border);
  background:#fff;
  margin-top:24px;
}
.foot-grid{display:grid;gap:16px}
@media (min-width:780px){.foot-grid{grid-template-columns:1.2fr .8fr .8fr}}
.copy{border-top:1px solid var(--border);padding:14px 0;color:var(--muted);font-size:14px}

/* Forms */
input,textarea{
  font:inherit;color:inherit;background:#fff;
  border:1px solid var(--border);border-radius:10px;padding:10px;
}
label .muted{color:var(--muted)}

/* Utilities */
.muted{color:var(--muted)}
.hero-card .hero-grid{display:grid;gap:14px}
@media (min-width:560px){.hero-card .hero-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
.thumb{background:#fff;border:1px solid var(--border);border-radius:10px}

/* Anchor fixes when header sticky */
:target{scroll-margin-top:96px}

/* Make space for admin bar if present (value injected inline) */
body{--ph-adminbar:0}
@media (min-width:782px){
  body{padding-top:calc(var(--ph-adminbar))}
}

/* WP default alignment helpers (for editor content) */
.alignwide{margin-inline:calc(50% - 50vw);max-width:100vw}
.alignfull{margin-inline:calc(50% - 50vw);max-width:100vw}
.wp-block-image img{border-radius:12px}
