:root{
  --krem:#FDF0E0;
  --hijau:#2D6A4F;
  --hijau-light:#40916C;
  --terakota:#F4A261;
  --mint:#74C69D;
  --lavender:#7B6FA0;
  --biru:#4A7C9E;
  --kuning:#E9A234;
  --cokelat:#7B4F2E;
  --teks:#2C1810;
  --teks2:#5A5A5A;
  --krem-dark:#F5E6CC;
  --merah:#C0392B;
}


/* ── Skip Navigation Link (aksesibilitas) ─────────────────────────── */
.skip-link {
  position: absolute;
  top: -100%;
  left: 1rem;
  background: var(--hijau);
  color: var(--krem);
  font-family: 'Quicksand', sans-serif;
  font-weight: 700;
  font-size: .9rem;
  padding: .6rem 1.25rem;
  border-radius: 0 0 12px 12px;
  text-decoration: none;
  z-index: 9999;
  transition: top .15s ease;
  border: 2px dashed rgba(253,240,224,.4);
}
.skip-link:focus {
  top: 0;
  outline: 3px solid var(--terakota);
  outline-offset: 2px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Quicksand',sans-serif;
  background:var(--krem);
  color:var(--teks);
  overflow-x:hidden;
}
body::before{
  content:'';
  position:fixed;
  inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events:none;
  z-index:0;
  opacity:.5;
}

/* NAV */
nav{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:100;
  background:rgba(253,240,224,.92);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:2px dashed rgba(45,106,79,.3);
  padding:0 2rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:64px;
}
.nav-logo{
  font-family:'Nunito',sans-serif;
  font-weight:900;
  font-size:1.3rem;
  color:var(--hijau);
  text-decoration:none;
  letter-spacing:-.5px;
  display:flex;
  align-items:center;
  gap:10px;
}
.nav-logo img{width:38px;height:38px;border-radius:50%;object-fit:cover;flex-shrink:0}
.nav-logo span{color:var(--terakota)}
.nav-links{display:flex;align-items:center;gap:2rem;list-style:none}
.nav-links a{
  font-family:'Quicksand',sans-serif;
  font-weight:600;
  font-size:.9rem;
  color:var(--teks2);
  text-decoration:none;
  transition:color .2s;
}
.nav-links a:hover,.nav-links a.active-link{color:var(--hijau);font-weight:700}
.nav-cta{
  background:var(--hijau);
  color:var(--krem)!important;
  padding:.5rem 1.25rem;
  border-radius:50px;
  transition:background .2s!important;
}
.nav-cta:hover{background:var(--hijau-light)!important;color:var(--krem)!important}
.nav-hamburger{
  display:none;
  flex-direction:column;
  justify-content:center;
  gap:5px;
  background:none;
  border:none;
  cursor:pointer;
  padding:6px;
  z-index:101;
}
.nav-hamburger span{
  display:block;
  width:24px;
  height:3px;
  background:var(--hijau);
  border-radius:3px;
  transition:all .3s ease;
}
.nav-hamburger.active span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-hamburger.active span:nth-child(2){opacity:0}
.nav-hamburger.active span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
.nav-links.open{
  display:flex!important;
  flex-direction:column;
  position:fixed;
  top:64px;
  left:0;
  right:0;
  background:rgba(253,240,224,.98);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:2px dashed rgba(45,106,79,.3);
  padding:1.5rem 2rem;
  gap:1.25rem;
  z-index:99;
  animation:slideDown .25s ease;
  align-items:center;
  text-align:center;
}
@keyframes slideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}

/* HERO */
.page-hero{padding:100px 2rem 3rem;text-align:center;position:relative}
.hero-felt-bg{position:fixed;inset:0;z-index:0;pointer-events:none}
.felt-blob{position:absolute;border-radius:60% 40% 50% 60%/50% 60% 40% 50%;opacity:.12}
.blob-1{width:500px;height:500px;background:var(--hijau);top:-100px;right:-100px;animation:float1 8s ease-in-out infinite}
.blob-2{width:350px;height:350px;background:var(--terakota);bottom:50px;left:-80px;animation:float2 10s ease-in-out infinite;border-radius:40% 60% 55% 45%/55% 45% 60% 40%}
.blob-3{width:250px;height:250px;background:var(--mint);top:40%;left:30%;animation:float3 7s ease-in-out infinite}
@keyframes float1{0%,100%{transform:translate(0,0) rotate(0deg)}50%{transform:translate(-20px,30px) rotate(5deg)}}
@keyframes float2{0%,100%{transform:translate(0,0) rotate(0deg)}50%{transform:translate(25px,-20px) rotate(-4deg)}}
@keyframes float3{0%,100%{transform:translate(0,0)}50%{transform:translate(-15px,20px)}}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.stitch-circle{position:absolute;border-radius:50%;border:3px dashed;opacity:.15}
.sc-1{width:300px;height:300px;border-color:var(--hijau);top:10%;left:5%;animation:spin 30s linear infinite}
.sc-2{width:180px;height:180px;border-color:var(--terakota);bottom:15%;right:8%;animation:spin 20s linear infinite reverse}
.hero-content{position:relative;z-index:1;max-width:720px;margin:0 auto}
.hero-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:var(--krem-dark);
  border:2px dashed var(--hijau);
  border-radius:50px;
  padding:.4rem 1.25rem;
  font-size:.85rem;
  font-weight:600;
  color:var(--hijau);
  margin-bottom:1.5rem;
  animation:fadeUp .8s ease both;
}
.badge-dot{width:8px;height:8px;background:var(--terakota);border-radius:50%;display:inline-block}
.hero-title{
  font-family:'Nunito',sans-serif;
  font-weight:900;
  font-size:clamp(2rem,5vw,3.5rem);
  line-height:1.1;
  color:var(--teks);
  margin-bottom:.75rem;
  letter-spacing:-1px;
  animation:fadeUp .8s .15s ease both;
}
.hero-title .accent{color:var(--hijau);position:relative}
.hero-title .accent::after{
  content:'';
  position:absolute;
  bottom:4px;
  left:0;
  right:0;
  height:5px;
  background:var(--terakota);
  opacity:.4;
  border-radius:3px;
  z-index:-1;
}
.hero-desc{font-size:1rem;color:var(--teks2);line-height:1.8;max-width:560px;margin:0 auto 1rem;animation:fadeUp .8s .25s ease both}
.hero-reg{display:inline-flex;align-items:center;gap:6px;background:rgba(45,106,79,.1);border:1.5px solid rgba(45,106,79,.3);border-radius:50px;padding:.35rem 1rem;font-size:.82rem;font-weight:600;color:var(--hijau);animation:fadeUp .8s .35s ease both}

/* PATCH v1.22 — Cegah blob background Catatan terpotong
   Catatan memakai .page-hero, sedangkan homepage memakai #hero.
   Background felt pada .page-hero dibuat fixed dan overflow visible
   agar tidak ikut terpotong oleh style khusus homepage. */
.page-hero{
  position:relative;
  overflow:visible;
}
.page-hero .hero-felt-bg{
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  overflow:visible;
}

/* LAYOUT */
.main-wrap{max-width:1100px;margin:0 auto;padding:2rem 2rem 5rem;position:relative;z-index:1}
.tool-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:1.5rem;align-items:start}
.input-panel{display:flex;flex-direction:column;gap:1.25rem}
.result-panel{min-width:0}

/* SECTION LABEL */
.sec-label{display:inline-flex;align-items:center;gap:8px;font-size:.72rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--hijau);margin-bottom:.7rem}
.sec-label::before{content:'';display:inline-block;width:20px;height:3px;background:var(--terakota);border-radius:2px}

/* CARDS */
.card{background:var(--krem-dark);border:2.5px dashed rgba(45,106,79,.35);border-radius:24px;padding:2rem;position:relative}
.card-title{font-family:'Nunito',sans-serif;font-weight:900;font-size:1.1rem;color:var(--teks);margin-bottom:1.5rem;display:flex;align-items:center;gap:10px}
.small-title{margin-bottom:.75rem}
.card p{font-size:.88rem;color:var(--teks2);line-height:1.8}

/* FORM */
label{display:block;font-size:.88rem;font-weight:600;color:var(--teks2);margin-bottom:.4rem}
input[type=number],input[type=text],select,textarea{
  width:100%;
  padding:.7rem 1rem;
  border:2px solid rgba(45,106,79,.25);
  border-radius:12px;
  background:var(--krem);
  font-family:'Quicksand',sans-serif;
  font-size:.95rem;
  font-weight:600;
  color:var(--teks);
  outline:none;
  transition:border-color .2s,box-shadow .2s;
}
input:focus,select:focus,textarea:focus{border-color:var(--hijau);box-shadow:0 0 0 3px rgba(45,106,79,.1)}
.pfx{position:relative;display:flex;align-items:center}
.pfx-txt{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-weight:700;font-size:.88rem;color:var(--teks2);pointer-events:none}
.pfx input{padding-left:46px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.fg{display:flex;flex-direction:column;gap:.5rem}
.mt-1{margin-top:1rem}

/* TOGGLE */
.tgl-group{display:flex;gap:.5rem;flex-wrap:wrap}
.tgl-btn{flex:1;min-width:120px;padding:.6rem .5rem;border-radius:10px;border:2px solid rgba(45,106,79,.25);background:var(--krem);font-family:'Quicksand',sans-serif;font-weight:700;font-size:.84rem;color:var(--teks2);cursor:pointer;transition:all .2s;text-align:center}
.tgl-btn.on{background:var(--hijau);border-color:var(--hijau);color:var(--krem)}

/* RESULT */
#result-box{background:var(--hijau);border-radius:24px;padding:2rem;color:var(--krem);position:sticky;top:90px;display:none;flex-direction:column;gap:1rem;animation:fadeUp .4s ease}
#result-box.show{display:flex}
.res-label{font-size:.78rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;opacity:.7}
.res-main{font-family:'Nunito',sans-serif;font-weight:900;font-size:1.1rem;line-height:1.3;border-bottom:1.5px dashed rgba(253,240,224,.3);padding-bottom:1rem}
.res-total{font-family:'Nunito',sans-serif;font-weight:900;font-size:2rem;line-height:1;letter-spacing:-1px}
.res-note{font-size:.82rem;line-height:1.7;opacity:.8}
.res-breakdown{display:flex;flex-direction:column;gap:.5rem;margin-top:.25rem}
.res-row{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;font-size:.85rem}
.res-row span:first-child{opacity:.8;flex:1}
.res-row span:last-child{font-weight:700;text-align:right;white-space:nowrap}
.res-divider{height:1px;background:rgba(253,240,224,.2);margin:.25rem 0}
.res-catatan{display:none;background:rgba(253,240,224,.12);border-left:3px solid rgba(244,162,97,.7);border-radius:0 10px 10px 0;padding:.75rem 1rem;font-size:.8rem;line-height:1.7;color:rgba(253,240,224,.85)}
.res-dasar-hukum{display:none;background:rgba(253,240,224,.08);border-left:3px solid rgba(253,240,224,.3);border-radius:0 10px 10px 0;padding:.75rem 1rem;font-size:.78rem;line-height:1.7;color:rgba(253,240,224,.65)}
.res-catatan strong,.res-dasar-hukum strong{color:var(--krem)}

/* EMPTY */
#empty-state{background:var(--krem-dark);border:2.5px dashed rgba(45,106,79,.2);border-radius:24px;padding:2rem;display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center;position:sticky;top:90px}
.empty-icon{width:64px;height:64px;background:rgba(45,106,79,.08);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.8rem}
.empty-title{font-family:'Nunito',sans-serif;font-weight:900;font-size:1rem;color:var(--teks)}
.empty-desc{font-size:.85rem;color:var(--teks2);line-height:1.7}

/* INFO */
.info-box{background:rgba(45,106,79,.07);border:1.5px dashed rgba(45,106,79,.3);border-radius:16px;padding:1.25rem 1.5rem;font-size:.84rem;line-height:1.75;color:var(--teks2);margin-top:1rem}
.info-box strong{color:var(--hijau)}
.info-box ul{padding-left:1.2rem;margin-top:.5rem}
.info-box li{margin-bottom:.25rem}
.wide-info{margin-top:2rem;border-radius:20px}
.disclaimer-box{margin-top:2rem;border-radius:20px;background:rgba(244,162,97,.08);border-color:var(--terakota)}
.disclaimer-box strong{color:var(--terakota)}
.warn-box{background:rgba(244,162,97,.1);border:1.5px dashed var(--terakota);border-radius:16px;padding:1rem 1.25rem;font-size:.83rem;line-height:1.7;color:var(--teks2);margin-top:1rem;display:none}
.warn-box.show{display:block}

/* BUTTONS */
.btn-hitung{width:100%;background:var(--hijau);color:var(--krem);font-family:'Nunito',sans-serif;font-weight:800;font-size:1.05rem;padding:1rem 2rem;border-radius:50px;border:none;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:.75rem}
.btn-hitung:hover{background:var(--hijau-light);transform:translateY(-2px);box-shadow:0 8px 24px rgba(45,106,79,.25)}
.btn-row{display:flex;gap:.75rem;margin-top:.75rem}
.btn-sec{flex:1;background:transparent;color:var(--teks2);font-family:'Quicksand',sans-serif;font-weight:600;font-size:.85rem;padding:.65rem;border-radius:50px;border:2px dashed rgba(90,90,90,.3);cursor:pointer;transition:all .2s}
.btn-sec:hover{border-color:var(--terakota);color:var(--terakota)}
.btn-pdf{flex:1;background:var(--biru);color:white;font-family:'Quicksand',sans-serif;font-weight:700;font-size:.85rem;padding:.65rem;border-radius:50px;border:none;cursor:pointer;transition:all .2s;display:none;align-items:center;justify-content:center;gap:6px}
.btn-pdf.show{display:flex}
.btn-pdf:hover{background:#3a6b8a;transform:translateY(-1px)}

/* GUIDE */
.guide-section{margin-top:3rem}
.guide-section h2{font-family:'Nunito',sans-serif;font-weight:900;font-size:1.5rem;margin-bottom:1.5rem;letter-spacing:-.5px}
.guide-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}
.back-cta-wrap{text-align:center;margin-top:2rem}
.back-cta{display:inline-flex;align-items:center;gap:8px;color:var(--hijau);font-weight:700;font-size:.95rem;text-decoration:none;border:2px dashed var(--hijau);padding:.75rem 1.75rem;border-radius:50px;transition:all .2s}
.back-cta:hover{background:rgba(45,106,79,.08)}

/* FOOTER */
footer{background:var(--teks);padding:3rem 2rem;text-align:center;position:relative;z-index:1}
.footer-logo{font-family:'Nunito',sans-serif;font-weight:900;font-size:1.5rem;color:var(--krem);margin-bottom:.5rem}
.footer-logo span{color:var(--terakota)}
.footer-tagline{font-size:.85rem;color:rgba(253,240,224,.5);letter-spacing:3px;margin-bottom:1.5rem;font-weight:400}
.footer-links{display:flex;gap:1.5rem;justify-content:center;list-style:none;margin-bottom:1.5rem;flex-wrap:wrap}
.footer-links a{color:rgba(253,240,224,.6);text-decoration:none;font-size:.85rem;font-weight:500;transition:color .2s}
.footer-links a:hover{color:var(--terakota)}
.footer-copy{font-size:.78rem;color:rgba(253,240,224,.3)}

/* ANIMATION */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.animate-1{animation:fadeUp .7s .1s ease both}
.animate-2{animation:fadeUp .7s .2s ease both}

/* RESPONSIVE */
@media(max-width:900px){
  .nav-links{display:none}
  .nav-hamburger{display:flex}
  .nav-links.open{display:flex!important;top:64px;align-items:center;text-align:center}
  .tool-grid{grid-template-columns:1fr}
  #result-box,#empty-state{position:static}
}
@media(max-width:480px){
  nav{padding:0 1rem}
  .nav-logo{font-size:1.08rem}
  .nav-logo img{width:36px;height:36px}
  .page-hero{padding:92px 1rem 2rem}
  .main-wrap{padding:1.5rem 1rem 4rem}
  .card{padding:1.5rem}
  .frow{grid-template-columns:1fr}
  .btn-row{flex-direction:column}
}


/* =====================================================
   HOMEPAGE — index.html specific styles
   (migrated from inline <style> tag)
   ===================================================== */

/* ---- HERO ---- */
  #hero {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 80px 2rem 4rem;
    position: relative;
    overflow: hidden;
  }

  #hero .hero-felt-bg {
    position: absolute;
    inset: 0;
    overflow: hidden;
    z-index: 0;
  }

  #hero .felt-blob {
    position: absolute;
    border-radius: 60% 40% 50% 60% / 50% 60% 40% 50%;
    opacity: 0.12;
  }

  #hero .blob-1 { width: 500px; height: 500px; background: var(--hijau); top: -100px; right: -100px; animation: float1 8s ease-in-out infinite; }
  #hero .blob-2 { width: 350px; height: 350px; background: var(--terakota); bottom: 50px; left: -80px; animation: float2 10s ease-in-out infinite; border-radius: 40% 60% 55% 45% / 55% 45% 60% 40%; }
  #hero .blob-3 { width: 250px; height: 250px; background: var(--mint); top: 40%; left: 30%; animation: float3 7s ease-in-out infinite; }

  @keyframes float1 { 0%,100%{transform:translate(0,0) rotate(0deg)} 50%{transform:translate(-20px,30px) rotate(5deg)} }
  @keyframes float2 { 0%,100%{transform:translate(0,0) rotate(0deg)} 50%{transform:translate(25px,-20px) rotate(-4deg)} }
  @keyframes float3 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(-15px,20px)} }

  #hero .stitch-circle {
    position: absolute;
    border-radius: 50%;
    border: 3px dashed;
    opacity: 0.15;
  }

  .sc-1 { width: 300px; height: 300px; border-color: var(--hijau); top: 10%; left: 5%; animation: spin 30s linear infinite; }
  .sc-2 { width: 180px; height: 180px; border-color: var(--terakota); bottom: 15%; right: 8%; animation: spin 20s linear infinite reverse; }

  @keyframes spin { from{transform:rotate(0deg)} to{transform:rotate(360deg)} }

  #hero .hero-content {
    position: relative;
    z-index: 1;
    max-width: 800px;
  }

  #hero .hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--krem-dark);
    border: 2px dashed var(--hijau);
    border-radius: 50px;
    padding: 0.4rem 1.25rem;
    font-family: 'Quicksand', sans-serif;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--hijau);
    margin-bottom: 1.5rem;
    animation: fadeUp 0.8s ease both;
  }

  #hero .badge-dot {
    width: 8px;
    height: 8px;
    background: var(--terakota);
    border-radius: 50%;
    display: inline-block;
  }

  #hero .hero-title {
    font-family: 'Nunito', sans-serif;
    font-weight: 900;
    font-size: clamp(2.8rem, 7vw, 5.5rem);
    line-height: 1.05;
    color: var(--teks);
    margin-bottom: 0.75rem;
    letter-spacing: -1px;
    animation: fadeUp 0.8s 0.15s ease both;
  }

  #hero .hero-title .accent { color: var(--hijau); position: relative; }
  #hero .hero-title .accent::after {
    content: '';
    position: absolute;
    bottom: 4px; left: 0; right: 0;
    height: 6px;
    background: var(--terakota);
    opacity: 0.4;
    border-radius: 3px;
    z-index: -1;
  }

  .hero-tagline {
    font-family: 'Nunito', sans-serif;
    font-size: clamp(1rem, 2.5vw, 1.4rem);
    font-weight: 700;
    color: var(--terakota);
    letter-spacing: 4px;
    margin-bottom: 1.5rem;
    animation: fadeUp 0.8s 0.25s ease both;
  }

  #hero .hero-desc {
    font-size: 1.05rem;
    color: var(--teks2);
    line-height: 1.8;
    max-width: 600px;
    margin: 0 auto 2.5rem;
    animation: fadeUp 0.8s 0.35s ease both;
  }

  .hero-btns {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
    animation: fadeUp 0.8s 0.45s ease both;
  }

  .btn-primary {
    background: var(--hijau);
    color: var(--krem);
    font-family: 'Nunito', sans-serif;
    font-weight: 700;
    font-size: 1rem;
    padding: 0.85rem 2rem;
    border-radius: 50px;
    text-decoration: none;
    border: 3px dashed transparent;
    transition: all 0.2s;
    display: inline-flex;
    align-items: center;
    gap: 8px;
  }

  .btn-primary:hover {
    background: var(--hijau-light);
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(45,106,79,0.25);
  }

  .btn-secondary {
    background: transparent;
    color: var(--teks);
    font-family: 'Nunito', sans-serif;
    font-weight: 700;
    font-size: 1rem;
    padding: 0.85rem 2rem;
    border-radius: 50px;
    text-decoration: none;
    border: 3px dashed var(--hijau);
    transition: all 0.2s;
  }

  .btn-secondary:hover {
    background: var(--krem-dark);
    transform: translateY(-2px);
  }
/* ---- FAMILY ILLUSTRATION PLACEHOLDER ---- */
  .hero-family {
    margin-top: 3.5rem;
    position: relative;
    animation: fadeUp 0.8s 0.55s ease both;
  }

  .family-felt-card {
    background: var(--krem-dark);
    border: 3px dashed var(--hijau);
    border-radius: 32px;
    padding: 2.5rem 3rem;
    display: inline-flex;
    gap: 1.5rem;
    align-items: flex-end;
    justify-content: center;
    flex-wrap: wrap;
    position: relative;
    max-width: 600px;
    margin: 0 auto;
  }

  .family-felt-card::before {
    content: '🧶 Sadariksa Family';
    position: absolute;
    top: -14px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--krem);
    border: 2px dashed var(--hijau);
    border-radius: 50px;
    padding: 0.2rem 1rem;
    font-family: 'Quicksand', sans-serif;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--hijau);
    white-space: nowrap;
  }

  .char-pill {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
  }

  .char-avatar {
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    position: relative;
    border: 3px dashed;
  }

  .char-avatar::after {
    content: '';
    position: absolute;
    inset: -6px;
    border-radius: 50%;
    border: 2px dashed;
    opacity: 0.3;
    animation: spin 12s linear infinite;
  }

  .char-ayah { width: 80px; height: 80px; background: rgba(74,124,158,0.15); border-color: var(--biru); }
  .char-ayah::after { border-color: var(--biru); }
  .char-ibu { width: 80px; height: 80px; background: rgba(123,111,160,0.15); border-color: var(--lavender); }
  .char-ibu::after { border-color: var(--lavender); }
  .char-kakak { width: 68px; height: 68px; background: rgba(244,162,97,0.15); border-color: var(--terakota); }
  .char-kakak::after { border-color: var(--terakota); }
  .char-adik { width: 56px; height: 56px; background: rgba(116,198,157,0.15); border-color: var(--mint); }
  .char-adik::after { border-color: var(--mint); }

  .char-name {
    font-family: 'Quicksand', sans-serif;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--teks2);
  }
/* ---- TENTANG ---- */
  #tentang {
    padding: 6rem 2rem;
    max-width: 1100px;
    margin: 0 auto;
  }

  .section-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: 'Quicksand', sans-serif;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--hijau);
    margin-bottom: 1rem;
  }

  .section-label::before {
    content: '';
    display: inline-block;
    width: 24px;
    height: 3px;
    background: var(--terakota);
    border-radius: 2px;
  }

  .section-title {
    font-family: 'Nunito', sans-serif;
    font-weight: 900;
    font-size: clamp(1.8rem, 4vw, 3rem);
    color: var(--teks);
    line-height: 1.2;
    margin-bottom: 1rem;
    letter-spacing: -0.5px;
  }

  .tentang-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    align-items: center;
    margin-top: 3rem;
  }

  .tentang-text p {
    font-size: 1.02rem;
    color: var(--teks2);
    line-height: 1.85;
    margin-bottom: 1.25rem;
  }

  .tentang-text p strong { color: var(--teks); font-weight: 600; }

  .keunggulan-list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-top: 1.5rem;
  }

  .keunggulan-list li {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    font-size: 0.95rem;
    color: var(--teks2);
    line-height: 1.5;
  }

  .keunggulan-list li::before {
    content: '';
    flex-shrink: 0;
    width: 20px;
    height: 20px;
    background: var(--hijau);
    border-radius: 50%;
    margin-top: 2px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpath d='M7 10l2.5 2.5L14 7' stroke='%23FDF0E0' stroke-width='2.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  }

  .tentang-cards {
    display: flex;
    flex-direction: column;
    gap: 1rem;
  }

  .stat-felt {
    background: var(--krem-dark);
    border: 2px dashed;
    border-radius: 20px;
    padding: 1.25rem 1.5rem;
    display: flex;
    align-items: center;
    gap: 1rem;
    transition: transform 0.2s;
  }

  .stat-felt:hover { transform: translateX(6px); }

  .stat-felt:nth-child(1) { border-color: var(--biru); }
  .stat-felt:nth-child(2) { border-color: var(--lavender); }
  .stat-felt:nth-child(3) { border-color: var(--terakota); }

  .stat-icon {
    width: 52px;
    height: 52px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    flex-shrink: 0;
  }

  .stat-felt:nth-child(1) .stat-icon { background: rgba(74,124,158,0.15); }
  .stat-felt:nth-child(2) .stat-icon { background: rgba(123,111,160,0.15); }
  .stat-felt:nth-child(3) .stat-icon { background: rgba(244,162,97,0.15); }

  .stat-text strong {
    display: block;
    font-family: 'Nunito', sans-serif;
    font-weight: 800;
    font-size: 1.1rem;
    color: var(--teks);
  }

  .stat-text span {
    font-size: 0.85rem;
    color: var(--teks2);
  }
/* ---- PILAR ---- */
  #pilar {
    padding: 6rem 2rem;
    background: var(--krem-dark);
    border-top: 3px dashed rgba(45,106,79,0.2);
    border-bottom: 3px dashed rgba(45,106,79,0.2);
  }

  .pilar-inner {
    max-width: 1100px;
    margin: 0 auto;
  }

  .pilar-header {
    text-align: center;
    margin-bottom: 3.5rem;
  }

  .pilar-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 1rem;
  }

  .pilar-card {
    background: var(--krem);
    border: 3px dashed;
    border-radius: 20px;
    padding: 1.5rem 1rem;
    text-align: center;
    cursor: pointer;
    transition: all 0.25s;
    position: relative;
    overflow: hidden;
  }

  .pilar-card::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 18px;
    opacity: 0;
    transition: opacity 0.25s;
  }

  .pilar-card:hover { transform: translateY(-6px); }
  .pilar-card:hover::after { opacity: 0.08; }

  .pilar-card:nth-child(1) { border-color: var(--hijau); }
  .pilar-card:nth-child(1)::after { background: var(--hijau); }
  .pilar-card:nth-child(2) { border-color: var(--lavender); }
  .pilar-card:nth-child(2)::after { background: var(--lavender); }
  .pilar-card:nth-child(3) { border-color: var(--biru); }
  .pilar-card:nth-child(3)::after { background: var(--biru); }
  .pilar-card:nth-child(4) { border-color: var(--kuning); }
  .pilar-card:nth-child(4)::after { background: var(--kuning); }
  .pilar-card:nth-child(5) { border-color: var(--cokelat); }
  .pilar-card:nth-child(5)::after { background: var(--cokelat); }

  .pilar-num {
    font-family: 'Nunito', sans-serif;
    font-size: 2rem;
    font-weight: 900;
    line-height: 1;
    margin-bottom: 0.5rem;
  }

  .pilar-card:nth-child(1) .pilar-num { color: var(--hijau); }
  .pilar-card:nth-child(2) .pilar-num { color: var(--lavender); }
  .pilar-card:nth-child(3) .pilar-num { color: var(--biru); }
  .pilar-card:nth-child(4) .pilar-num { color: var(--kuning); }
  .pilar-card:nth-child(5) .pilar-num { color: var(--cokelat); }

  .pilar-emoji { font-size: 1.8rem; margin-bottom: 0.5rem; display: block; }

  .pilar-name {
    font-family: 'Nunito', sans-serif;
    font-weight: 800;
    font-size: 0.85rem;
    color: var(--teks);
    margin-bottom: 0.4rem;
    line-height: 1.3;
  }

  .pilar-star {
    position: absolute;
    top: 10px;
    right: 10px;
    background: var(--terakota);
    color: white;
    font-size: 0.65rem;
    font-weight: 700;
    font-family: 'Quicksand', sans-serif;
    padding: 2px 7px;
    border-radius: 50px;
  }
/* ---- PLATFORM ---- */
  #platform {
    padding: 6rem 2rem;
    max-width: 1100px;
    margin: 0 auto;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .platform-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.25rem;
    margin-top: 3rem;
    width: 100%;
  }

  .platform-card {
    background: var(--krem-dark);
    border: 2px dashed rgba(45,106,79,0.3);
    border-radius: 20px;
    padding: 2rem 1rem;
    text-decoration: none;
    color: var(--teks);
    transition: all 0.2s;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
  }

  .platform-card:hover {
    border-color: var(--hijau);
    background: var(--krem);
    transform: translateY(-4px);
  }

  .platform-icon {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 14px;
    transition: transform 0.2s;
  }

  .platform-icon svg {
    width: 28px;
    height: 28px;
  }

  .platform-icon--instagram { background: rgba(193,53,132,0.12); color: #C13584; }
  .platform-icon--tiktok    { background: rgba(0,0,0,0.08); color: #2C1810; }
  .platform-icon--youtube   { background: rgba(255,0,0,0.1); color: #FF0000; }
  .platform-icon--linktree  { background: rgba(67,186,72,0.12); color: #43BA48; }

  .platform-card:hover .platform-icon { transform: scale(1.1); }

  .platform-name {
    font-family: 'Nunito', sans-serif;
    font-weight: 800;
    font-size: 1rem;
    color: var(--teks);
  }

  .platform-handle {
    font-size: 0.8rem;
    color: var(--hijau);
    font-weight: 600;
  }
/* ---- CTA ---- */
  #cta {
    padding: 5rem 2rem;
    background: var(--hijau);
    position: relative;
    overflow: hidden;
    text-align: center;
  }

  #cta::before {
    content: '';
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(
      45deg,
      transparent,
      transparent 30px,
      rgba(255,255,255,0.03) 30px,
      rgba(255,255,255,0.03) 31px
    );
    pointer-events: none;
  }

  .cta-stitch {
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 4px;
    background: repeating-linear-gradient(
      90deg,
      rgba(253,240,224,0.5) 0, rgba(253,240,224,0.5) 12px,
      transparent 12px, transparent 20px
    );
  }

  .cta-stitch-b {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 4px;
    background: repeating-linear-gradient(
      90deg,
      rgba(253,240,224,0.5) 0, rgba(253,240,224,0.5) 12px,
      transparent 12px, transparent 20px
    );
  }

  .cta-inner {
    position: relative;
    z-index: 1;
    max-width: 620px;
    margin: 0 auto;
  }

  .cta-title {
    font-family: 'Nunito', sans-serif;
    font-weight: 900;
    font-size: clamp(1.8rem, 4vw, 2.8rem);
    color: var(--krem);
    line-height: 1.2;
    margin-bottom: 1rem;
  }

  .cta-title span { color: var(--terakota); }

  .cta-desc {
    color: rgba(253,240,224,0.8);
    font-size: 1.05rem;
    line-height: 1.7;
    margin-bottom: 2rem;
  }

  .cta-btns {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
  }

  .btn-krem {
    background: var(--krem);
    color: var(--hijau);
    font-family: 'Nunito', sans-serif;
    font-weight: 800;
    font-size: 1rem;
    padding: 0.85rem 2rem;
    border-radius: 50px;
    text-decoration: none;
    border: 3px dashed transparent;
    transition: all 0.2s;
  }

  .btn-krem:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.15);
  }

  .btn-outline-krem {
    background: transparent;
    color: var(--krem);
    font-family: 'Nunito', sans-serif;
    font-weight: 700;
    font-size: 1rem;
    padding: 0.85rem 2rem;
    border-radius: 50px;
    text-decoration: none;
    border: 3px dashed rgba(253,240,224,0.5);
    transition: all 0.2s;
  }

  .btn-outline-krem:hover {
    border-color: var(--krem);
    background: rgba(253,240,224,0.1);
  }
/* ---- TOOLS ---- */
  #tools {
    padding: 6rem 2rem;
    max-width: 1100px;
    margin: 0 auto;
  }

  .tools-header {
    text-align: center;
    margin-bottom: 3.5rem;
  }

  .tools-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
  }

  .tool-card {
    background: var(--krem-dark);
    border: 3px dashed var(--hijau);
    border-radius: 24px;
    padding: 2rem 1.75rem;
    text-decoration: none;
    color: var(--teks);
    transition: all 0.25s;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    position: relative;
    overflow: hidden;
  }

  .tool-card::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 22px;
    background: var(--hijau);
    opacity: 0;
    transition: opacity 0.25s;
  }

  .tool-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 16px 40px rgba(45,106,79,0.15);
  }

  .tool-card:hover::before { opacity: 0.04; }

  .tool-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
  }

  .tool-icon-wrap {
    width: 56px;
    height: 56px;
    border-radius: 16px;
    background: rgba(45,106,79,0.12);
    border: 2px dashed rgba(45,106,79,0.3);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
  }

  .tool-badge {
    font-family: 'Quicksand', sans-serif;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    padding: 3px 10px;
    border-radius: 50px;
    position: relative;
    z-index: 1;
  }

  .tool-badge.live {
    background: rgba(45,106,79,0.12);
    color: var(--hijau);
    border: 1.5px solid rgba(45,106,79,0.3);
  }

  .tool-badge.coming {
    background: rgba(233,162,52,0.12);
    color: var(--kuning);
    border: 1.5px solid rgba(233,162,52,0.3);
  }

  .tool-name {
    font-family: 'Nunito', sans-serif;
    font-weight: 900;
    font-size: 1.15rem;
    color: var(--teks);
    line-height: 1.2;
    position: relative;
    z-index: 1;
  }

  .tool-desc {
    font-size: 0.88rem;
    color: var(--teks2);
    line-height: 1.7;
    position: relative;
    z-index: 1;
    flex: 1;
  }

  .tool-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 1rem;
    border-top: 2px dashed rgba(45,106,79,0.2);
    position: relative;
    z-index: 1;
  }

  .tool-tag {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--hijau);
    background: rgba(45,106,79,0.08);
    padding: 3px 10px;
    border-radius: 50px;
  }

  .tool-arrow {
    width: 32px;
    height: 32px;
    background: var(--hijau);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.2s;
    flex-shrink: 0;
  }

  .tool-card:hover .tool-arrow { transform: translateX(4px); }

  .tool-arrow svg { display: block; }

  /* Coming soon card style */
  .tool-card.coming-soon {
    border-color: rgba(45,106,79,0.2);
    opacity: 0.72;
    cursor: default;
  }

  .tool-card.coming-soon:hover {
    transform: none;
    box-shadow: none;
  }

  .tool-card.coming-soon .tool-arrow {
    background: rgba(90,90,90,0.15);
  }

  .tool-card.coming-soon .tool-icon-wrap {
    background: rgba(90,90,90,0.06);
    border-color: rgba(90,90,90,0.15);
  }
/* ---- BTN LIHAT TOOLS ---- */
  .btn-lihat-tools {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: var(--krem-dark);
    border: 2px dashed var(--hijau);
    color: var(--hijau);
    font-family: 'Quicksand', sans-serif;
    font-weight: 700;
    font-size: .95rem;
    text-decoration: none;
    padding: .8rem 2rem;
    border-radius: 50px;
    transition: background .2s;
  }
  .btn-lihat-tools:hover { background: rgba(45,106,79,.1); }
/* ---- HOMEPAGE RESPONSIVE ---- */
  @media (max-width: 900px) {
    .nav-links { display: none; }
    .nav-hamburger { display: flex; }
  }

  @media (max-width: 768px) {
    .tentang-grid { grid-template-columns: 1fr; gap: 2rem; }
    .pilar-grid { grid-template-columns: 1fr 1fr; }
    .pilar-card:nth-child(5) { grid-column: span 2; }
    .platform-grid { grid-template-columns: repeat(2, 1fr); }
    .tools-grid { grid-template-columns: 1fr; }
    #hero { padding-top: 90px; }
  }

  @media (max-width: 480px) {
    .pilar-grid { grid-template-columns: 1fr; }
    .pilar-card:nth-child(5) { grid-column: span 1; }
  }

  @media (max-width: 375px) {
    /* Nav */
    nav { padding: 0 1rem; }

    /* Hero */
    #hero { padding: 70px 1rem 3rem; }
    #hero .hero-title { font-size: 2.2rem; letter-spacing: -.5px; }
    .hero-tagline { font-size: .85rem; letter-spacing: 2px; }
    #hero .hero-desc { font-size: .9rem; }

    /* Buttons: stack vertikal full-width */
    .hero-btns { flex-direction: column; align-items: stretch; gap: .75rem; }
    .btn-primary, .btn-secondary {
      text-align: center;
      justify-content: center;
      padding: .8rem 1.5rem;
      font-size: .95rem;
    }

    /* Family felt card */
    .family-felt-card { padding: 2rem 1.5rem; gap: 1rem; }

    /* Platform: 1 kolom agar tidak sempit */
    .platform-grid { grid-template-columns: 1fr; }

    /* Main wrap */
    .main-wrap { padding-left: 1rem; padding-right: 1rem; }
  }

  @media (prefers-reduced-motion: reduce) {
    .felt-blob,
    .stitch-circle,
    .char-avatar::after {
      animation: none;
    }
    #hero .hero-badge,
    #hero .hero-title,
    .hero-tagline,
    #hero .hero-desc,
    .hero-btns,
    .hero-family {
      animation: none;
      opacity: 1;
      transform: none;
    }
    .reveal {
      opacity: 1;
      transform: none;
      transition: none;
    }
    .nav-links.open {
      animation: none;
    }
  }