/*
Theme Name: Berdaya Desa
Theme URI: https://example.com
Author: [Nama Anda]
Author URI: https://example.com
Description: Tema satu halaman untuk konsultan pemberdayaan Koperasi & UMKM Desa bersertifikasi BNSP. Nuansa earthy (hijau hutan, terakota, krem) dengan animasi halus dan tampilan responsif.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: berdaya-desa
*/

:root{
    --green:#1e3a2b;        /* hijau hutan dalam */
    --green-2:#2f5440;
    --clay:#c25e3a;         /* terakota / tanah liat */
    --clay-soft:#d98c6a;
    --gold:#d9a441;         /* panen / emas */
    --cream:#f5ede0;        /* krem hangat */
    --cream-2:#efe4d3;
    --sand:#e7d9c2;
    --ink:#23201a;
    --muted:#6f6857;
    --line:rgba(35,32,26,.14);
    --shadow:0 26px 60px -28px rgba(30,58,43,.45);
    --display:'Fraunces',Georgia,serif;
    --body:'Plus Jakarta Sans',system-ui,sans-serif;
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    font-family:var(--body);
    background:var(--cream);
    color:var(--ink);
    line-height:1.6;
    overflow-x:hidden;
    -webkit-font-smoothing:antialiased;
  }
  /* tekstur grain halus */
  body::before{
    content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.04;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  }
  ::selection{background:var(--clay);color:var(--cream)}
  a{color:inherit;text-decoration:none}
  .wrap{max-width:1180px;margin:0 auto;padding:0 28px}

  /* ---------- NAV ---------- */
  nav{
    position:fixed;top:0;left:0;right:0;z-index:1000;
    display:flex;align-items:center;justify-content:space-between;
    padding:18px 40px;transition:.4s;
  }
  nav.scrolled{background:rgba(245,237,224,.86);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line);padding:12px 40px}
  .brand{display:flex;align-items:center;gap:11px;font-family:var(--display);font-weight:700;font-size:1.32rem;letter-spacing:-.02em;color:var(--green)}
  .brand .mark{width:34px;height:34px;flex:none;display:grid;place-items:center;background:var(--green);border-radius:11px}
  .brand .mark svg{width:19px;height:19px}
  .nav-links{display:flex;gap:30px;align-items:center}
  .nav-links a{font-size:.92rem;font-weight:500;color:var(--ink);position:relative;transition:.25s}
  .nav-links a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:2px;background:var(--clay);transition:.3s}
  .nav-links a:hover{color:var(--clay)}
  .nav-links a:hover::after{width:100%}
  .btn{
    display:inline-flex;align-items:center;gap:9px;background:var(--clay);color:var(--cream);
    padding:12px 24px;border-radius:50px;font-weight:600;font-size:.92rem;
    transition:.3s;border:none;cursor:pointer;box-shadow:0 10px 24px -12px var(--clay);
  }
  .btn:hover{transform:translateY(-2px);background:#a94e2f;box-shadow:0 16px 30px -12px var(--clay)}
  .btn.ghost{background:transparent;color:var(--green);border:1.5px solid var(--green);box-shadow:none}
  .btn.ghost:hover{background:var(--green);color:var(--cream)}
  .hamb{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none}
  .hamb span{width:26px;height:2.5px;background:var(--green);border-radius:3px;transition:.3s}

  /* ---------- HERO ---------- */
  header{position:relative;padding:170px 0 90px;overflow:hidden}
  .hero-bg{position:absolute;inset:0;z-index:-1}
  .hero-bg .blob{position:absolute;border-radius:50%;filter:blur(70px);opacity:.5}
  .blob.b1{width:540px;height:540px;background:radial-gradient(circle,#cfe0cf,transparent 70%);top:-160px;right:-120px}
  .blob.b2{width:460px;height:460px;background:radial-gradient(circle,#f0d2bf,transparent 70%);bottom:-180px;left:-140px;opacity:.55}
  .topo{position:absolute;inset:0;opacity:.5;background-image:radial-gradient(var(--sand) 1.4px,transparent 1.4px);background-size:26px 26px;-webkit-mask-image:linear-gradient(180deg,transparent,#000 30%,#000 70%,transparent)}
  .hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:54px;align-items:center}
  .pill{
    display:inline-flex;align-items:center;gap:10px;background:var(--cream-2);border:1px solid var(--line);
    padding:8px 16px 8px 8px;border-radius:50px;font-size:.82rem;font-weight:600;color:var(--green-2);margin-bottom:26px;
  }
  .pill .seal{background:var(--green);color:var(--gold);font-weight:700;font-size:.72rem;letter-spacing:.06em;padding:4px 10px;border-radius:50px}
  h1{font-family:var(--display);font-weight:600;font-size:clamp(2.6rem,5.6vw,4.5rem);line-height:1.02;letter-spacing:-.03em;color:var(--green);margin-bottom:22px}
  h1 em{font-style:italic;color:var(--clay);font-weight:500}
  .lead{font-size:1.16rem;color:var(--muted);max-width:520px;margin-bottom:34px}
  .hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
  .trust{margin-top:34px;display:flex;gap:26px;flex-wrap:wrap;font-size:.85rem;color:var(--muted)}
  .trust b{color:var(--green);font-weight:700}

  /* kartu kredensial di hero */
  .cred-card{
    background:linear-gradient(155deg,var(--green),var(--green-2));color:var(--cream);
    border-radius:26px;padding:34px;box-shadow:var(--shadow);position:relative;overflow:hidden;
  }
  .cred-card::after{content:"";position:absolute;width:200px;height:200px;background:radial-gradient(circle,rgba(217,164,65,.4),transparent 70%);top:-60px;right:-50px}
  .cred-card .ribbon{display:inline-flex;align-items:center;gap:8px;background:rgba(217,164,65,.18);color:var(--gold);padding:6px 14px;border-radius:50px;font-size:.78rem;font-weight:700;letter-spacing:.04em;margin-bottom:22px}
  .cred-card h3{font-family:var(--display);font-size:1.5rem;font-weight:600;line-height:1.2;margin-bottom:14px}
  .cred-card p{font-size:.95rem;opacity:.82;margin-bottom:24px}
  .cred-stats{display:grid;grid-template-columns:1fr 1fr;gap:18px;border-top:1px solid rgba(245,237,224,.18);padding-top:22px}
  .cred-stats .num{font-family:var(--display);font-size:1.9rem;font-weight:700;color:var(--gold);line-height:1}
  .cred-stats .lbl{font-size:.78rem;opacity:.78;margin-top:4px}

  /* ---------- STRIP STATISTIK ---------- */
  .strip{background:var(--green);color:var(--cream);padding:46px 0}
  .strip-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
  .strip .num{font-family:var(--display);font-size:2.7rem;font-weight:700;color:var(--gold);line-height:1}
  .strip .lbl{font-size:.86rem;opacity:.82;margin-top:6px}

  /* ---------- SECTION DASAR ---------- */
  section{padding:96px 0}
  .eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:.8rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--clay);margin-bottom:16px}
  .eyebrow::before{content:"";width:26px;height:2px;background:var(--clay)}
  h2{font-family:var(--display);font-weight:600;font-size:clamp(2rem,3.8vw,3rem);line-height:1.08;letter-spacing:-.02em;color:var(--green);margin-bottom:18px}
  .sec-intro{max-width:620px;color:var(--muted);font-size:1.06rem;margin-bottom:54px}

  /* ABOUT */
  #tentang{background:var(--cream-2)}
  .about-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:center}
  .about-visual{position:relative}
  .about-visual .frame{aspect-ratio:4/5;border-radius:24px;background:linear-gradient(155deg,var(--sand),var(--clay-soft));display:grid;place-items:center;box-shadow:var(--shadow);overflow:hidden;position:relative}
  .about-visual .frame svg{width:46%;opacity:.92}
  .about-visual .tag{position:absolute;bottom:24px;left:-22px;background:var(--cream);border:1px solid var(--line);border-radius:16px;padding:16px 20px;box-shadow:var(--shadow);max-width:230px}
  .about-visual .tag .t{font-family:var(--display);font-weight:700;color:var(--green);font-size:1.05rem}
  .about-visual .tag .s{font-size:.8rem;color:var(--muted)}
  .about-text p{color:var(--muted);margin-bottom:18px;font-size:1.05rem}
  .about-text p strong{color:var(--ink)}
  .check-list{list-style:none;margin-top:26px;display:grid;gap:14px}
  .check-list li{display:flex;gap:13px;align-items:flex-start;font-size:1rem;color:var(--ink)}
  .check-list .ic{flex:none;width:25px;height:25px;border-radius:50%;background:var(--green);color:var(--gold);display:grid;place-items:center;font-size:.8rem;margin-top:2px}

  /* SERVICES */
  .cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .card{
    background:var(--cream);border:1px solid var(--line);border-radius:22px;padding:34px 30px;
    transition:.35s;position:relative;overflow:hidden;
  }
  .card::before{content:"";position:absolute;left:0;top:0;height:4px;width:100%;background:var(--clay);transform:scaleX(0);transform-origin:left;transition:.4s}
  .card:hover{transform:translateY(-7px);box-shadow:var(--shadow);border-color:transparent}
  .card:hover::before{transform:scaleX(1)}
  .card .ico{width:56px;height:56px;border-radius:16px;background:linear-gradient(155deg,var(--green),var(--green-2));display:grid;place-items:center;margin-bottom:22px}
  .card .ico svg{width:27px;height:27px}
  .card h3{font-family:var(--display);font-size:1.3rem;font-weight:600;color:var(--green);margin-bottom:11px}
  .card p{font-size:.96rem;color:var(--muted)}
  .card .more{margin-top:18px;font-size:.86rem;font-weight:600;color:var(--clay);display:inline-flex;align-items:center;gap:6px;transition:.3s}
  .card:hover .more{gap:11px}

  /* PROSES */
  #proses{background:var(--green);color:var(--cream)}
  #proses .eyebrow{color:var(--gold)}#proses .eyebrow::before{background:var(--gold)}
  #proses h2{color:var(--cream)}
  #proses .sec-intro{color:rgba(245,237,224,.78)}
  .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;counter-reset:s}
  .step{position:relative;padding-top:30px}
  .step::before{counter-increment:s;content:"0" counter(s);font-family:var(--display);font-size:3.4rem;font-weight:700;color:rgba(217,164,65,.22);position:absolute;top:-20px;left:0;line-height:1}
  .step .line{height:2px;background:rgba(217,164,65,.3);margin:18px 0;position:relative}
  .step .line::after{content:"";position:absolute;left:0;top:-3px;width:8px;height:8px;border-radius:50%;background:var(--gold)}
  .step h4{font-family:var(--display);font-size:1.18rem;font-weight:600;margin-bottom:8px}
  .step p{font-size:.92rem;opacity:.78}

  /* SEKTOR */
  .sector-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
  .sector{background:var(--cream-2);border:1px solid var(--line);border-radius:18px;padding:26px;transition:.3s;display:flex;gap:16px;align-items:center}
  .sector:hover{background:var(--green);color:var(--cream);transform:translateY(-4px)}
  .sector:hover .s-ic{background:var(--gold)}
  .sector .s-ic{flex:none;width:46px;height:46px;border-radius:12px;background:var(--clay);display:grid;place-items:center;transition:.3s}
  .sector .s-ic svg{width:22px;height:22px}
  .sector b{font-family:var(--display);font-weight:600;font-size:1.05rem;display:block}
  .sector span{font-size:.85rem;opacity:.75}

  /* TESTIMONI */
  #testimoni{background:var(--cream-2)}
  .quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .quote{background:var(--cream);border-radius:22px;padding:32px;border:1px solid var(--line);position:relative}
  .quote .mk{font-family:var(--display);font-size:4rem;line-height:.6;color:var(--clay-soft);height:34px}
  .quote p{font-size:1rem;color:var(--ink);margin-bottom:22px;font-style:italic}
  .quote .who{display:flex;align-items:center;gap:13px}
  .quote .av{width:46px;height:46px;border-radius:50%;background:linear-gradient(155deg,var(--green),var(--clay));display:grid;place-items:center;color:var(--cream);font-weight:700;font-family:var(--display)}
  .quote .who b{display:block;font-weight:700;color:var(--green)}
  .quote .who span{font-size:.82rem;color:var(--muted)}

  /* CTA */
  .cta-box{background:linear-gradient(155deg,var(--clay),#a94e2f);color:var(--cream);border-radius:30px;padding:64px 56px;text-align:center;position:relative;overflow:hidden}
  .cta-box::before{content:"";position:absolute;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(217,164,65,.4),transparent 70%);top:-120px;left:-80px}
  .cta-box::after{content:"";position:absolute;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(30,58,43,.4),transparent 70%);bottom:-120px;right:-60px}
  .cta-box h2{color:var(--cream);position:relative;margin-bottom:16px}
  .cta-box p{position:relative;opacity:.92;max-width:560px;margin:0 auto 32px;font-size:1.08rem}
  .cta-box .btn{background:var(--cream);color:var(--clay);position:relative}
  .cta-box .btn:hover{background:var(--green);color:var(--cream)}

  /* FOOTER */
  footer{background:var(--green);color:rgba(245,237,224,.8);padding:64px 0 30px}
  .foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(245,237,224,.15)}
  footer .brand{color:var(--cream);margin-bottom:16px}
  footer .brand .mark{background:var(--gold)}
  footer .brand .mark svg path{stroke:var(--green)}
  .foot-about{max-width:330px;font-size:.95rem}
  .foot-col h5{font-family:var(--display);color:var(--cream);font-size:1.05rem;margin-bottom:16px;font-weight:600}
  .foot-col a,.foot-col p{display:block;font-size:.92rem;margin-bottom:10px;transition:.25s}
  .foot-col a:hover{color:var(--gold);transform:translateX(3px)}
  .copy{padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.84rem;opacity:.7}

  /* reveal */
  .reveal{opacity:0;transform:translateY(34px);transition:.8s cubic-bezier(.16,1,.3,1)}
  .reveal.in{opacity:1;transform:none}

  /* ---------- RESPONSIVE ---------- */
  @media(max-width:920px){
    .hero-grid,.about-grid{grid-template-columns:1fr;gap:40px}
    .cred-card{order:-1}
    .cards,.quotes{grid-template-columns:1fr 1fr}
    .steps{grid-template-columns:1fr 1fr;gap:34px}
    .strip-grid{grid-template-columns:1fr 1fr;gap:36px}
    .foot-grid{grid-template-columns:1fr 1fr}
  }
  @media(max-width:640px){
    nav{padding:14px 20px}nav.scrolled{padding:10px 20px}
    .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--cream);flex-direction:column;padding:24px;gap:18px;box-shadow:var(--shadow)}
    .nav-links.open{display:flex}
    .hamb{display:flex}
    .cards,.quotes,.steps,.strip-grid,.foot-grid{grid-template-columns:1fr}
    .cta-box{padding:44px 26px}
    section{padding:70px 0}
    .about-visual .tag{left:0}
  }
