:root{--blue:#145cff;--blue2:#2563eb;--green:#00b94f;--purple:#9d25ff;--pink:#ec3fb8;--orange:#ff6900;--red:#ff283c;--bg:#f6f7f9;--card:#fff;--text:#0f172a;--muted:#64748b;--border:#e7eaf0;--shadow:0 7px 20px rgba(15,23,42,.05);--radius:18px}*{box-sizing:border-box}body{margin:0;font-family:Inter,Arial,sans-serif;background:var(--bg);color:var(--text);padding-bottom:76px}a{text-decoration:none;color:inherit}button,input,textarea{font-family:inherit}.page{min-height:100vh}.container{padding:18px 18px 96px}.top-blue{background:linear-gradient(180deg,#145cff 0%,#0f5af3 100%);color:white;padding:28px 18px 32px}.brand-row{display:flex;align-items:center;justify-content:space-between}.brand{display:flex;align-items:center;gap:14px}.brand-icon{width:39px;height:39px;border-radius:14px;background:white;color:var(--blue);display:grid;place-items:center;font-size:22px}.brand h1{margin:0;font-size:19px;font-weight:600}.brand p{margin:4px 0 0;font-size:12px}.bell{width:39px;height:39px;border-radius:50%;background:rgba(255,255,255,.16);display:grid;place-items:center;font-size:19px}.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:28px}.stat{background:rgba(255,255,255,.08);border-radius:15px;min-height:86px;display:grid;place-items:center;text-align:center}.stat .ico{font-size:20px}.stat b{display:block;font-size:14px;margin-top:5px}.stat span{font-size:12px}.hero-card{margin:24px 16px 22px;background:linear-gradient(100deg,#a744ed,#ec329d,#ff2c6d);border-radius:15px;color:#fff;padding:28px 24px}.hero-card h2{margin:0 0 10px;font-size:21px}.hero-card p{margin:0 0 18px;font-size:14px}.white-action{display:flex;justify-content:center;align-items:center;width:100%;border:0;border-radius:13px;background:white;color:#8b21ff;font-weight:600;height:52px;cursor:pointer}.section-title{font-size:17px;font-weight:600;margin:24px 0 14px}.why-list{display:grid;gap:14px}.why-card,.card{background:var(--card);border:1px solid var(--border);border-radius:15px;box-shadow:var(--shadow)}.why-card{display:flex;gap:16px;align-items:center;padding:18px}.why-icon{width:45px;height:45px;border-radius:12px;display:grid;place-items:center;font-size:22px}.soft-blue{background:#e8f0ff;color:#2167ff}.soft-green{background:#dcffe8;color:#03b650}.soft-purple{background:#f0dcff;color:#9333ea}.why-card h3,.feature-card h3{margin:0 0 6px;font-size:16px}.why-card p,.feature-card p{margin:0;color:#334155;font-size:13px}.features{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.feature-card{min-height:139px;padding:20px;background:#fff;border:1px solid var(--border);border-radius:15px;box-shadow:var(--shadow)}.feature-icon{width:52px;height:52px;border-radius:14px;color:white;display:grid;place-items:center;font-size:25px;margin-bottom:18px}.bg-blue{background:#2264ff}.bg-green{background:#00b94f}.bg-purple{background:#9c27ff}.bg-orange{background:#ff5b00}.cta{margin:28px 16px 22px;background:linear-gradient(100deg,#ff6b00,#ff2f3d);border-radius:15px;color:white;text-align:center;padding:34px 26px}.cta h2{margin:0 0 14px}.cta p{margin:0 0 22px}.bottom-nav{position:fixed;left:0;right:0;bottom:0;height:76px;background:white;border-top:1px solid #e5e7eb;display:grid;grid-template-columns:repeat(5,1fr);z-index:50}.bottom-nav a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;font-size:12px;color:#657184}.bottom-nav a.active{color:var(--blue)}.bottom-nav .nav-icon{font-size:23px}.header{height:80px;background:white;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:18px;position:sticky;top:0;z-index:20}.back{font-size:28px;line-height:1}.header h1{margin:0;font-size:20px;font-weight:600}.header p{margin:4px 0 0;color:#475569;font-size:13px}.progress-steps{background:#f8fafc;border-bottom:1px solid var(--border);display:grid;grid-template-columns:repeat(4,1fr);padding:22px 24px 18px;align-items:start}.step{display:flex;align-items:center;gap:12px;color:#64748b}.circle{width:35px;height:35px;border-radius:50%;background:#e5e9ef;display:grid;place-items:center;font-weight:700}.step.active .circle{background:var(--blue);color:#fff}.step.done .circle{background:var(--green);color:#fff}.step span{font-size:13px}.grad-panel{background:linear-gradient(100deg,#2463ff,#a11cff);border-radius:15px;color:#fff;padding:26px 30px;margin:20px 0;display:flex;align-items:center;gap:16px}.question-card{padding:18px;margin:16px 0}.option{height:46px;border:1px solid var(--border);border-radius:13px;margin:10px 0;display:flex;align-items:center;gap:12px;padding:0 14px;cursor:pointer;font-weight:600}.option input{width:16px;height:16px}.full-btn{width:100%;height:56px;border:0;border-radius:12px;background:#cfd4dc;color:white;font-weight:700;font-size:16px;cursor:pointer}.full-btn.blue{background:var(--blue)}.full-btn.green{background:var(--green)}.full-btn.grad{background:linear-gradient(100deg,#145cff,#ab18ff)}.progress-card{padding:18px;margin:18px 0}.progress-line{height:8px;background:#e8eaee;border-radius:100px;overflow:hidden}.progress-line span{display:block;height:100%;background:var(--green);border-radius:100px}.module-card{padding:20px;margin:16px 0}.module-head{display:flex;align-items:center;gap:15px}.module-icon{width:48px;height:48px;border-radius:13px;background:#eceeff;display:grid;place-items:center;font-size:24px}.badges{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0 14px}.badge{display:inline-flex;align-items:center;gap:4px;border-radius:999px;background:#f1f5f9;color:#475569;padding:4px 9px;font-size:12px}.video-card{padding:18px;margin:18px 0}.video-frame{background:linear-gradient(120deg,#1f3b63,#2d2464);border-radius:13px;overflow:hidden;position:relative;min-height:430px;display:flex;align-items:center;justify-content:center}.video-frame iframe{width:100%;height:430px;border:0}.lesson-content{padding:22px;background:#f8fafc;border-radius:12px;min-height:300px;line-height:1.6}.lesson-list{padding:20px}.lesson-row{display:flex;align-items:center;gap:16px;padding:14px;border:1px solid #c9f2d6;background:#edfff3;border-radius:13px;margin:10px 0}.lesson-row.active{border-color:#2475ff;background:#eef5ff}.lesson-row .num{width:31px;height:31px;border-radius:50%;display:grid;place-items:center;background:#e9edf4;color:#475569;font-weight:700}.lesson-row.done .num{background:var(--green);color:white}.job-tabs{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:16px 0}.tab{height:42px;border-radius:9px;background:#eef1f6;display:grid;place-items:center;color:#475569}.tab.active{background:var(--blue);color:white}.search-box{padding:18px}.input-row{display:flex;gap:8px}.input{width:100%;border:1px solid #cfd6df;border-radius:11px;padding:13px 15px;background:white}.small-btn{border:0;border-radius:11px;background:var(--blue);color:#fff;padding:0 17px;font-size:20px;cursor:pointer}.chip{display:inline-flex;margin:8px 6px 0 0;background:#eef1f6;border-radius:999px;padding:7px 12px;color:#475569;font-size:13px}.empty-search{border:1px solid #b8d7ff;background:#edf6ff;border-radius:14px;min-height:200px;display:grid;place-items:center;text-align:center;color:#475569;margin:22px 0}.job-card{padding:18px;margin:14px 0}.job-card form{margin-top:12px}.alert-row{padding:13px 17px;border-radius:12px;margin:10px 0}.alert-yellow{background:#fffbdc;border:1px solid #f8cf4f}.alert-blue{background:#edf6ff;border:1px solid #93c5fd}.alert-green{background:#eafff0;border:1px solid #7ce7a4}.benefit-card{display:grid;grid-template-columns:56px 1fr 1fr;align-items:center;padding:18px;margin:14px 0;min-height:128px}.profile-hero{background:linear-gradient(100deg,#2463ff,#a11cff);color:white;border-radius:15px;margin:20px 0;padding:28px}.profile-top{display:flex;align-items:center;gap:18px}.profile-avatar{width:82px;height:82px;border-radius:50%;background:rgba(255,255,255,.22);display:grid;place-items:center;font-size:42px}.profile-stats{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid rgba(255,255,255,.18);margin-top:26px;padding-top:20px;text-align:center}.profile-stats b{font-size:25px}.profile-stats span{display:block;font-size:12px;margin-top:4px}.info-line{display:flex;gap:12px;margin:12px 0}.center-empty{display:grid;place-items:center;min-height:110px;color:#64748b}.auth-page{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#145cff,#9d25ff);padding:20px}.auth-card{width:min(430px,94vw);background:white;border-radius:24px;padding:30px;box-shadow:0 20px 70px rgba(15,23,42,.25)}.auth-logo{width:58px;height:58px;border-radius:18px;background:var(--blue);color:white;display:grid;place-items:center;font-size:28px;margin:0 auto 14px}.auth-card h1{text-align:center;margin:0 0 8px}.auth-card p{text-align:center;color:#64748b;margin:0 0 22px}.auth-card input{width:100%;height:50px;border:1px solid #d7dde6;border-radius:12px;padding:0 14px;margin:8px 0}.auth-actions{display:flex;justify-content:space-between;margin-top:14px;font-size:14px}.flash{position:fixed;top:12px;left:50%;transform:translateX(-50%);z-index:100;background:white;border-radius:12px;padding:12px 16px;box-shadow:0 12px 30px rgba(15,23,42,.15)}.flash.success{border-left:5px solid var(--green)}.flash.error{border-left:5px solid #ef4444}.quiz-grid{display:grid;gap:16px}.certificate{max-width:900px;margin:40px auto;background:white;border:12px solid #e9c46a;border-radius:22px;text-align:center;padding:55px;box-shadow:var(--shadow)}.certificate h1{font-size:42px;color:#7c3aed}.print-hide{margin-top:18px}.floating-logo{position:fixed;right:20px;bottom:88px;background:white;border-radius:99px;padding:10px 15px;box-shadow:var(--shadow);color:#64748b;font-size:12px}@media(max-width:720px){.stats,.features{grid-template-columns:1fr}.hero-card,.cta{margin-left:10px;margin-right:10px}.container{padding:14px 12px 92px}.progress-steps{padding:18px 10px}.step{gap:6px}.step span{font-size:11px}.benefit-card{grid-template-columns:56px 1fr}.benefit-card>div:last-child{grid-column:2}.video-frame,.video-frame iframe{min-height:240px;height:240px}.header{padding:0 14px}.top-blue{padding:22px 14px}.stats{gap:10px}.profile-stats b{font-size:20px}}@media(print){.bottom-nav,.header,.print-hide,.floating-logo{display:none}body{padding-bottom:0;background:white}.certificate{box-shadow:none;margin:0;border-color:#caa548}}


/* =============================
   LOGOUT DI HALAMAN PROFIL
   ============================= */
.logout-section{
  border:1px solid #fee2e2;
  background:#fff7f7;
}

.logout-section h3{
  color:#991b1b;
}

.logout-profile-btn{
  width:100%;
  height:52px;
  border:0;
  border-radius:12px;
  background:#ef4444;
  color:#fff;
  font-weight:800;
  font-size:16px;
  cursor:pointer;
  box-shadow:0 8px 18px rgba(239,68,68,.18);
  transition:.2s;
}

.logout-profile-btn:hover{
  background:#dc2626;
  transform:translateY(-1px);
}

.logout-profile-btn:active{
  transform:scale(.98);
}

/* =============================
   TOMBOL CARI LOWONGAN PRESISI
   ============================= */
a.full-btn,
button.full-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
}

.search-lowongan-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-height:40px;
  height:40px;
  padding:8px 12px;
  border-radius:12px;
  font-size:13px;
  font-weight:700;
  line-height:1.2;
  text-align:center;
  white-space:nowrap;
  background:var(--blue) !important;
  color:#fff !important;
}

.search-lowongan-btn .icon{
  font-size:13px;
  margin-right:6px;
  line-height:1;
}

.search-lowongan-btn:hover{
  background:#0f4ee8 !important;
}

/* =============================
   KLAIM PERLINDUNGAN SOSIAL
   ============================= */
.claim-empty-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:15px;
  box-shadow:var(--shadow);
  padding:22px;
  margin:14px 0;
}

.claim-empty-card h3{
  margin:0 0 8px;
  font-size:18px;
  color:var(--text);
}

.claim-empty-card p{
  margin:0 0 16px;
  color:var(--muted);
  line-height:1.5;
}

.claim-btn{
  width:100%;
  height:52px;
  border:0;
  border-radius:12px;
  background:var(--green);
  color:#fff;
  font-weight:800;
  font-size:15px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  box-shadow:0 8px 18px rgba(0,185,79,.18);
  transition:.2s;
}

.claim-btn:hover{
  background:#00a746;
  transform:translateY(-1px);
}

.claim-btn:active{
  transform:scale(.98);
}

.claim-status-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  background:#eafff0;
  border:1px solid #7ce7a4;
  color:#047835;
  border-radius:12px;
  padding:14px 17px;
  margin:10px 0;
}

.claim-status-card b{
  color:#047835;
}

.claim-status-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:#d9ffe5;
  color:#00a94c;
  padding:7px 12px;
  font-size:13px;
  font-weight:800;
  white-space:nowrap;
}

.claim-note{
  background:#fff7e6;
  border:1px solid #ffd27a;
  color:#7a4b00;
  border-radius:12px;
  padding:13px 17px;
  margin:10px 0;
}

@media(max-width:720px){
  .claim-status-card{
    align-items:flex-start;
    flex-direction:column;
  }

  .claim-btn{
    height:48px;
    font-size:14px;
  }
}


/* =============================
   STATUS BPJS BELUM AKTIF / AKTIF SETELAH KLAIM
   ============================= */
.benefit-inactive{
  opacity:.82;
}

.benefit-inactive .module-icon{
  filter:grayscale(1);
  opacity:.7;
}

.benefit-active{
  opacity:1;
}

.status-active{
  color:#00a94c;
  font-weight:700;
}

.status-inactive{
  color:#94a3b8;
  font-weight:700;
}

.claim-success-card{
  border:1px solid #86efac;
  background:#f0fdf4;
}

.claim-success-card h3{
  color:#047835;
}

.claim-icon{
  width:48px;
  height:48px;
  border-radius:13px;
  display:grid;
  place-items:center;
  background:#eef2ff;
  color:#145cff;
  font-size:24px;
  margin-bottom:12px;
}

.claim-icon.active{
  background:#dcffe8;
  color:#00b94f;
}

.benefit-inactive b{
  color:#94a3b8;
}

.benefit-inactive h3{
  color:#334155;
}

.benefit-inactive .status-inactive{
  display:inline-block;
}

@media(max-width:720px){
  .benefit-inactive,
  .benefit-active{
    grid-template-columns:56px 1fr;
  }

  .benefit-inactive > div:last-child,
  .benefit-active > div:last-child{
    grid-column:2;
  }
}

/* =============================
   FOTO PROFIL USER
   ============================= */
.profile-avatar-img{
  width:82px;
  height:82px;
  border-radius:50%;
  object-fit:cover;
  border:3px solid rgba(255,255,255,.35);
  background:rgba(255,255,255,.22);
  display:block;
  flex:0 0 auto;
}

.photo-edit-box{
  display:flex;
  align-items:center;
  gap:18px;
  margin-bottom:22px;
  padding:18px;
  border:1px dashed #cbd5e1;
  border-radius:16px;
  background:#f8fafc;
}

.photo-preview{
  width:88px;
  height:88px;
  border-radius:50%;
  overflow:hidden;
  display:grid;
  place-items:center;
  flex:0 0 auto;
  background:linear-gradient(100deg,#2463ff,#a11cff);
  color:white;
  font-size:42px;
}

.photo-preview img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.photo-label{
  display:block;
  font-weight:800;
  margin-bottom:8px;
}

.photo-input{
  display:block;
  width:100%;
  border:1px solid #cfd6df;
  border-radius:12px;
  padding:10px;
  background:white;
  color:#0f172a;
}

.photo-help{
  margin:8px 0 0;
  color:#64748b;
  font-size:13px;
  line-height:1.4;
}

@media(max-width:720px){
  .photo-edit-box{
    align-items:flex-start;
    flex-direction:column;
  }

  .profile-avatar-img,
  .photo-preview{
    width:76px;
    height:76px;
  }
}

/* =============================
   NOTIFIKASI POPUP BERANDA
   ============================= */
.notif-wrap{
  position:relative;
  display:inline-block;
}

.notif-wrap summary{
  list-style:none;
}

.notif-wrap summary::-webkit-details-marker{
  display:none;
}

.notif-bell{
  position:relative;
  cursor:pointer;
  user-select:none;
}

.notif-dot{
  position:absolute;
  top:7px;
  right:7px;
  width:9px;
  height:9px;
  border-radius:50%;
  background:#ef4444;
  border:2px solid #145cff;
}

.notif-popup{
  position:absolute;
  top:52px;
  right:0;
  width:330px;
  background:#fff;
  color:#0f172a;
  border:1px solid var(--border);
  border-radius:18px;
  box-shadow:0 18px 50px rgba(15,23,42,.22);
  padding:14px;
  z-index:200;
  animation:notifPop .18s ease;
}

.notif-popup::before{
  content:"";
  position:absolute;
  top:-8px;
  right:18px;
  width:16px;
  height:16px;
  background:#fff;
  border-left:1px solid var(--border);
  border-top:1px solid var(--border);
  transform:rotate(45deg);
}

.notif-popup-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:10px;
  padding-bottom:10px;
  border-bottom:1px solid #eef1f6;
}

.notif-popup-head h3{
  margin:0;
  font-size:16px;
  font-weight:800;
  color:#0f172a;
}

.notif-popup-head span{
  font-size:12px;
  color:#fff;
  background:var(--blue);
  padding:5px 9px;
  border-radius:999px;
  font-weight:800;
}

.notif-item{
  display:flex;
  gap:12px;
  padding:12px 8px;
  border-radius:12px;
  transition:.18s;
}

.notif-item:hover{
  background:#f8fafc;
}

.notif-icon{
  width:38px;
  height:38px;
  border-radius:12px;
  display:grid;
  place-items:center;
  flex:0 0 auto;
  font-size:18px;
}

.notif-icon.blue{
  background:#e8f0ff;
  color:#145cff;
}

.notif-icon.green{
  background:#dcffe8;
  color:#00b94f;
}

.notif-icon.yellow{
  background:#fff7d6;
  color:#ca8a04;
}

.notif-item b{
  display:block;
  font-size:14px;
  margin-bottom:4px;
  color:#0f172a;
}

.notif-item p{
  margin:0;
  color:#64748b;
  font-size:12px;
  line-height:1.4;
}

@keyframes notifPop{
  from{
    opacity:0;
    transform:translateY(-6px) scale(.98);
  }
  to{
    opacity:1;
    transform:translateY(0) scale(1);
  }
}

@media(max-width:720px){
  .notif-popup{
    position:fixed;
    top:82px;
    left:14px;
    right:14px;
    width:auto;
  }

  .notif-popup::before{
    display:none;
  }
}

/* =========================================================
   ICON SYSTEM - LINE ICON 1:1 TANPA EMOJI
   Paste ini untuk dashboard + bottom nav versi icon garis
   ========================================================= */

.icon{
  position:relative;
  display:inline-block;
  width:20px;
  height:20px;
  box-sizing:border-box;
  flex:0 0 auto;
}

.white{--icon-color:#ffffff;}
.blue-line{--icon-color:#145cff;}
.green-line{--icon-color:#00b94f;}
.purple-line{--icon-color:#9d25ff;}
.current-line{--icon-color:currentColor;}

.icon::before,
.icon::after{
  box-sizing:border-box;
}

/* ---------- Home ---------- */
.icon-home::before,
.icon-home::after{
  content:"";
  position:absolute;
}

.icon-home::before{
  left:3px;
  top:8px;
  width:14px;
  height:10px;
  border:2px solid var(--icon-color,#fff);
  border-top:none;
  border-radius:2px;
}

.icon-home::after{
  left:4px;
  top:3px;
  width:12px;
  height:12px;
  border-left:2px solid var(--icon-color,#fff);
  border-top:2px solid var(--icon-color,#fff);
  transform:rotate(45deg);
  border-radius:2px;
}

/* ---------- User ---------- */
.icon-user::before,
.icon-user::after{
  content:"";
  position:absolute;
}

.icon-user::before{
  top:1px;
  left:6px;
  width:8px;
  height:8px;
  border:2px solid var(--icon-color,#fff);
  border-radius:50%;
}

.icon-user::after{
  left:3px;
  bottom:1px;
  width:14px;
  height:8px;
  border:2px solid var(--icon-color,#fff);
  border-bottom:none;
  border-top-left-radius:10px;
  border-top-right-radius:10px;
}

/* ---------- Briefcase ---------- */
.icon-briefcase::before,
.icon-briefcase::after{
  content:"";
  position:absolute;
}

.icon-briefcase::before{
  left:2px;
  top:6px;
  width:16px;
  height:11px;
  border:2px solid var(--icon-color,#fff);
  border-radius:3px;
}

.icon-briefcase::after{
  left:6px;
  top:2px;
  width:8px;
  height:5px;
  border:2px solid var(--icon-color,#fff);
  border-bottom:none;
  border-top-left-radius:3px;
  border-top-right-radius:3px;
}

/* ---------- Shield ---------- */
.icon-shield::before{
  content:"";
  position:absolute;
  left:4px;
  top:2px;
  width:12px;
  height:15px;
  border:2px solid var(--icon-color,#fff);
  border-radius:4px 4px 8px 8px;
  clip-path:polygon(50% 100%,0 72%,0 0,100% 0,100% 72%);
}

/* ---------- Certificate ---------- */
.icon-certificate::before,
.icon-certificate::after{
  content:"";
  position:absolute;
}

.icon-certificate::before{
  left:5px;
  top:2px;
  width:10px;
  height:13px;
  border:2px solid var(--icon-color,#fff);
  border-radius:2px;
}

.icon-certificate::after{
  left:8px;
  top:6px;
  width:4px;
  height:4px;
  border-left:2px solid var(--icon-color,#fff);
  border-bottom:2px solid var(--icon-color,#fff);
  transform:rotate(-45deg);
}

/* ---------- Bell ---------- */
.icon-bell::before,
.icon-bell::after{
  content:"";
  position:absolute;
}

.icon-bell::before{
  left:4px;
  top:3px;
  width:12px;
  height:11px;
  border:2px solid var(--icon-color,#fff);
  border-bottom:none;
  border-top-left-radius:8px;
  border-top-right-radius:8px;
}

.icon-bell::after{
  left:6px;
  bottom:2px;
  width:8px;
  height:4px;
  border-bottom:2px solid var(--icon-color,#fff);
  border-radius:0 0 8px 8px;
}

/* ---------- Graduation Cap ---------- */
.icon-cap::before,
.icon-cap::after{
  content:"";
  position:absolute;
}

.icon-cap::before{
  left:1px;
  top:5px;
  width:18px;
  height:8px;
  border:2px solid var(--icon-color,#fff);
  transform:skewX(-18deg);
  border-radius:2px;
}

.icon-cap::after{
  left:6px;
  top:11px;
  width:8px;
  height:5px;
  border-left:2px solid var(--icon-color,#fff);
  border-right:2px solid var(--icon-color,#fff);
  border-bottom:2px solid var(--icon-color,#fff);
  border-radius:0 0 4px 4px;
}

/* ---------- Check ---------- */
.icon-check::before{
  content:"";
  position:absolute;
  left:4px;
  top:5px;
  width:10px;
  height:6px;
  border-left:2px solid var(--icon-color,#fff);
  border-bottom:2px solid var(--icon-color,#fff);
  transform:rotate(-45deg);
}

/* =========================================================
   HOLDER ICON BIAR SEMUA 1:1
   ========================================================= */

.brand-icon,
.ico,
.why-icon,
.feature-icon,
.notif-icon,
.nav-icon{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  box-sizing:border-box;
  line-height:1;
  font-size:0 !important;
}

.brand-icon{
  width:44px !important;
  height:44px !important;
  border-radius:14px !important;
  background:#fff !important;
  color:var(--blue) !important;
  flex:0 0 44px;
  box-shadow:0 6px 18px rgba(0,0,0,.12);
}

.brand-icon .icon{
  width:22px;
  height:22px;
}

.ico{
  width:30px;
  height:30px;
  margin:0 auto 8px;
}

.ico .icon{
  width:20px;
  height:20px;
}

.why-icon{
  width:46px !important;
  height:46px !important;
  border-radius:14px !important;
  flex:0 0 46px;
}

.why-icon .icon{
  width:21px;
  height:21px;
}

.feature-icon{
  width:56px !important;
  height:56px !important;
  border-radius:16px !important;
  margin-bottom:16px !important;
}

.feature-icon .icon{
  width:25px;
  height:25px;
}

.notif-icon{
  width:38px !important;
  height:38px !important;
  border-radius:12px !important;
  flex:0 0 38px;
}

.notif-icon .icon{
  width:18px;
  height:18px;
}

.nav-icon{
  width:23px !important;
  height:23px !important;
  font-size:0 !important;
}

.nav-icon .icon{
  width:19px;
  height:19px;
}

/* warna holder */
.soft-blue{background:#eaf1ff !important;}
.soft-green{background:#dcfce7 !important;}
.soft-purple{background:#f3e8ff !important;}
.bg-blue{background:#2563eb !important;}
.bg-green{background:#10b981 !important;}
.bg-purple{background:#9333ea !important;}
.bg-orange{background:#f97316 !important;}

.notif-icon.blue{background:#2563eb !important;}
.notif-icon.green{background:#16a34a !important;}
.notif-icon.yellow{background:#f59e0b !important;}

/* bottom nav versi icon garis */
.bottom-nav{
  position:fixed !important;
  left:0;
  right:0;
  bottom:0;
  height:76px;
  background:#fff;
  border-top:1px solid #e5e7eb;
  display:grid;
  grid-template-columns:repeat(5,1fr);
  align-items:center;
  z-index:50;
}

.bottom-nav .nav-item,
.bottom-nav a{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:5px;
  color:#64748b;
  font-size:12px;
  font-weight:500;
  text-decoration:none;
}

.bottom-nav .nav-item.active,
.bottom-nav a.active{
  color:var(--blue);
}

.bottom-nav .nav-item.active .nav-icon,
.bottom-nav a.active .nav-icon{
  transform:translateY(-1px);
}

/* bell header pakai icon garis */
.bell.notif-bell{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  font-size:0 !important;
}

.bell.notif-bell .icon{
  width:20px;
  height:20px;
}

.notif-dot{
  top:7px !important;
  right:7px !important;
}

/* =============================
   NOTIFIKASI DIBACA - HILANGKAN INDIKATOR MERAH
   ============================= */
.notif-wrap.notif-read .notif-dot{
  display:none !important;
}

/* =============================
   PROFILE SKILL CHIP HORIZONTAL
   ============================= */
.skill-empty-text{
  margin:8px 0 12px;
  color:#64748b;
  font-size:14px;
}

.skill-saran-title{
  margin:12px 0 8px;
  color:#475569;
  font-size:13px;
  font-weight:600;
}

.profile-skill-list,
.profile-skill-suggestions{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
}

.profile-skill-list{
  margin-bottom:10px;
}

.profile-chip-form{
  margin:0;
  padding:0;
  display:inline-flex;
}

.profile-skill-chip{
  border:2px solid #1f2937;
  background:#fff;
  color:#334155;
  border-radius:999px;
  padding:8px 14px;
  font-size:14px;
  font-weight:500;
  cursor:pointer;
  line-height:1;
  transition:.18s;
  white-space:nowrap;
}

.profile-skill-chip:hover{
  background:#f1f5f9;
  transform:translateY(-1px);
}

.profile-skill-chip:active{
  transform:scale(.97);
}

.profile-skill-input{
  margin-top:16px;
}

.active-chip{
  background:#e8f0ff !important;
  color:var(--blue) !important;
}

@media(max-width:720px){
  .profile-skill-suggestions{
    gap:7px;
  }

  .profile-skill-chip{
    font-size:13px;
    padding:7px 12px;
  }
}


/* =============================
   JOB SKILL CHIP HORIZONTAL
   ============================= */
.skill-chip-wrap{
  display:flex !important;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
  margin-top:8px;
}

.chip-form{
  display:inline-flex !important;
  margin:0 !important;
  padding:0 !important;
}

.chip-btn{
  border:2px solid #1f2937 !important;
  background:#fff !important;
  color:#334155 !important;
  border-radius:999px !important;
  padding:8px 14px !important;
  font-size:14px !important;
  font-weight:500 !important;
  cursor:pointer;
  line-height:1 !important;
  margin:0 !important;
  transition:.18s;
  white-space:nowrap;
}

.chip-btn:hover{
  background:#f1f5f9 !important;
  transform:translateY(-1px);
}

.chip-btn:active{
  transform:scale(.97);
}

.skill-chip-wrap .active-chip{
  margin:0 !important;
  background:#e8f0ff !important;
  color:var(--blue) !important;
  border:1px solid #bfdbfe;
}

.job-card .chip{
  margin:0 6px 8px 0;
}

.search-box .chip{
  margin:0 !important;
}

@media(max-width:720px){
  .skill-chip-wrap{
    gap:7px;
  }

  .chip-btn{
    font-size:13px !important;
    padding:7px 12px !important;
  }
}

/* =============================
   MOODLE STYLE LESSON LOCK
   ============================= */
.moodle-completion-card{
  border:1px solid #dbeafe;
  background:#f8fbff;
  border-radius:15px;
  padding:18px;
  box-shadow:var(--shadow);
}

.moodle-status-row{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:18px;
}

.moodle-status-icon{
  width:48px;
  height:48px;
  border-radius:14px;
  display:grid;
  place-items:center;
  font-size:22px;
  font-weight:900;
  flex:0 0 auto;
}

.moodle-status-icon.locked{
  background:#fff7ed;
  color:#f97316;
}

.moodle-status-icon.done{
  background:#dcffe8;
  color:#00b94f;
}

.moodle-complete-form{
  display:grid;
  gap:14px;
}

.moodle-check{
  display:flex;
  align-items:center;
  gap:12px;
  padding:14px;
  border:1px solid #dbeafe;
  background:#ffffff;
  border-radius:14px;
  cursor:pointer;
  font-weight:600;
  line-height:1.45;
}

.moodle-check input{
  width:18px;
  height:18px;
  flex:0 0 auto;
  accent-color:var(--green);
}

.moodle-next-btn:disabled{
  background:#cfd4dc !important;
  cursor:not-allowed;
  opacity:.8;
  transform:none !important;
}

.moodle-next-btn:not(:disabled){
  background:var(--green) !important;
}

.lesson-row.locked{
  background:#f8fafc !important;
  border-color:#e2e8f0 !important;
  opacity:.75;
  cursor:not-allowed;
}

.lesson-row.locked .num{
  background:#e2e8f0 !important;
  color:#64748b !important;
}

.lesson-row.locked b,
.lesson-row.locked p,
.lesson-row.locked span{
  color:#94a3b8;
}

.lesson-row.active{
  border-color:#2475ff !important;
  background:#eef5ff !important;
}

.lesson-row.done{
  border-color:#c9f2d6 !important;
  background:#edfff3 !important;
}

.lesson-row.done .num{
  background:var(--green) !important;
  color:#fff !important;
}

@media(max-width:720px){
  .moodle-status-row{
    align-items:flex-start;
  }

  .moodle-check{
    align-items:flex-start;
  }

  .moodle-status-icon{
    width:42px;
    height:42px;
    border-radius:12px;
    font-size:20px;
  }
}


/* =============================
   TOMBOL SERTIFIKAT CENTER
   ============================= */
.certificate-actions{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:14px;
  margin:24px auto 40px;
  max-width:560px;
}

.certificate-action-btn,
.certificate-home-btn{
  max-width:260px;
  height:52px;
}

.certificate-home-btn{
  background:#ffffff !important;
  color:var(--blue) !important;
  border:1px solid #bfdbfe;
}

.certificate-home-btn:hover{
  background:#eff6ff !important;
}

@media(max-width:720px){
  .certificate-actions{
    flex-direction:column;
    gap:10px;
  }

  .certificate-action-btn,
  .certificate-home-btn{
    max-width:100%;
  }
}
/* =============================
   HASIL KUIS
   ============================= */

.quiz-result-hero{
  border-radius:18px;
  padding:28px;
  margin:18px 0;
  text-align:center;
  color:#fff;
  box-shadow:var(--shadow);
}

.quiz-result-hero.passed{
  background:linear-gradient(100deg,#00b94f,#145cff);
}

.quiz-result-hero.failed{
  background:linear-gradient(100deg,#ef4444,#f97316);
}

.quiz-result-hero h2{
  margin:0 0 12px;
  font-size:26px;
}

.quiz-score{
  font-size:54px;
  font-weight:900;
  margin:12px 0;
  line-height:1;
}

.quiz-result-hero p{
  margin:8px 0;
}

.quiz-result-hero .full-btn{
  max-width:320px;
  margin:22px auto 0;
}

.quiz-review-card.correct{
  border-color:#86efac;
  background:#f0fdf4;
}

.quiz-review-card.wrong{
  border-color:#fecaca;
  background:#fff7f7;
}

.quiz-review-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:14px;
}

.quiz-status{
  border-radius:999px;
  padding:6px 12px;
  font-size:12px;
  font-weight:800;
  white-space:nowrap;
}

.quiz-status.correct{
  background:#dcffe8;
  color:#00a94c;
}

.quiz-status.wrong{
  background:#fee2e2;
  color:#dc2626;
}

.answer-box{
  border-radius:12px;
  padding:13px 15px;
  margin-top:10px;
  line-height:1.5;
}

.user-answer.correct{
  background:#dcffe8;
  color:#047835;
}

.user-answer.wrong{
  background:#fee2e2;
  color:#991b1b;
}

.correct-answer{
  background:#e8f0ff;
  color:#145cff;
  border:1px solid #bfdbfe;
}

.quiz-result-actions{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:14px;
  margin:26px auto 40px;
  max-width:620px;
}

.quiz-result-actions .full-btn{
  max-width:300px;
}

.quiz-home-btn{
  background:#ffffff !important;
  color:var(--blue) !important;
  border:1px solid #bfdbfe;
}

.quiz-home-btn:hover{
  background:#eff6ff !important;
}

@media(max-width:720px){
  .quiz-result-hero{
    padding:22px;
  }

  .quiz-result-hero h2{
    font-size:22px;
  }

  .quiz-score{
    font-size:42px;
  }

  .quiz-review-head{
    flex-direction:column;
  }

  .quiz-result-actions{
    flex-direction:column;
  }

  .quiz-result-actions .full-btn{
    max-width:100%;
  }
}

/* =============================
   FIX TOMBOL LOGIN GOOGLE
   ============================= */
.auth-card form{
  margin-bottom:12px !important;
}

.auth-card form .full-btn.blue{
  margin-top:8px !important;
  margin-bottom:0 !important;
}

.google-login-btn{
  width:100% !important;
  height:54px !important;
  margin-top:12px !important;
  margin-bottom:14px !important;
  border-radius:14px !important;
  border:1px solid #d8dee8 !important;
  background:#f1f5f9 !important;
  color:#0f172a !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:10px !important;
  font-size:16px !important;
  font-weight:800 !important;
  line-height:1 !important;
  text-align:center !important;
  text-decoration:none !important;
  box-shadow:none !important;
  cursor:pointer;
  transition:.18s ease;
}

.google-login-btn:hover{
  background:#e8edf5 !important;
  transform:translateY(-1px);
}

.google-login-btn:active{
  transform:scale(.98);
}

.google-icon{
  width:24px !important;
  height:24px !important;
  border-radius:50% !important;
  background:#ffffff !important;
  color:#145cff !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  font-size:14px !important;
  font-weight:900 !important;
  line-height:1 !important;
  flex:0 0 24px !important;
}

.auth-actions{
  margin-top:10px !important;
  display:flex !important;
  justify-content:space-between !important;
  align-items:center !important;
}


/* =============================
   ADMIN PANEL DI PROFIL
   ============================= */

.admin-profile-panel{
  padding:22px;
  margin:18px 0;
}

.admin-profile-head{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:18px;
}

.admin-profile-icon{
  width:52px;
  height:52px;
  border-radius:16px;
  background:linear-gradient(100deg,#145cff,#9d25ff);
  color:#fff;
  display:grid;
  place-items:center;
  font-size:24px;
  flex:0 0 auto;
}

.admin-profile-head h3{
  margin:0 0 5px;
  font-size:20px;
}

.admin-profile-head p{
  margin:0;
  color:#64748b;
  font-size:14px;
}

.admin-profile-stats{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}

.admin-profile-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:16px;
  padding:18px;
  box-shadow:var(--shadow);
  transition:.18s;
}

.admin-profile-card:hover{
  transform:translateY(-2px);
  border-color:#bfdbfe;
  background:#f8fbff;
}

.admin-card-icon{
  width:46px;
  height:46px;
  border-radius:14px;
  display:grid;
  place-items:center;
  color:#fff;
  font-size:22px;
  margin-bottom:14px;
}

.admin-profile-card h4{
  margin:0 0 6px;
  font-size:16px;
  color:#0f172a;
}

.admin-profile-card p{
  margin:0;
  color:#64748b;
  font-size:13px;
}

.admin-profile-summary{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-top:16px;
}

.admin-profile-summary div{
  background:#f8fafc;
  border:1px solid var(--border);
  border-radius:14px;
  padding:16px;
  text-align:center;
}

.admin-profile-summary b{
  display:block;
  font-size:26px;
  color:var(--blue);
  margin-bottom:4px;
}

.admin-profile-summary span{
  color:#64748b;
  font-size:13px;
}

@media(max-width:900px){
  .admin-profile-stats{
    grid-template-columns:repeat(2,1fr);
  }
}

@media(max-width:720px){
  .admin-profile-stats{
    grid-template-columns:1fr;
  }

  .admin-profile-summary{
    grid-template-columns:1fr;
  }
}


/* =============================
   ADMIN DASHBOARD ICON FIX
   ============================= */

.admin-dashboard-hero-icon{
  width:52px;
  height:52px;
  border-radius:16px;
  background:rgba(255,255,255,.16);
  color:#fff;
  display:grid;
  place-items:center;
  font-size:26px;
  flex:0 0 auto;
}

.admin-dashboard-card{
  text-decoration:none;
  color:inherit;
  transition:.18s ease;
}

.admin-dashboard-card:hover{
  transform:translateY(-2px);
  border-color:#bfdbfe;
  background:#f8fbff;
}

.admin-dashboard-icon{
  width:58px;
  height:58px;
  border-radius:16px;
  color:#fff;
  display:grid;
  place-items:center;
  font-size:28px !important;
  margin-bottom:18px;
  line-height:1;
}


/* =============================
   ADMIN STATUS ACTIONS
   ============================= */

.admin-status-actions{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:10px;
  margin-top:16px;
}

.admin-status-actions .full-btn{
  height:46px;
  min-height:46px;
  font-size:14px;
  border-radius:12px;
}

@media(max-width:720px){
  .admin-status-actions{
    grid-template-columns:1fr;
  }
}

/* =============================
   NOTIFIKASI STATUS USER
   ============================= */

.notif-icon.red{
  background:#ef4444 !important;
  color:#fff !important;
}

.notif-icon.orange{
  background:#f97316 !important;
  color:#fff !important;
}

.notif-item .notif-status-text{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-top:6px;
  padding:5px 9px;
  border-radius:999px;
  font-size:11px;
  font-weight:800;
}

.notif-status-text.process{
  background:#fff7ed;
  color:#f97316;
}

.notif-status-text.accepted{
  background:#dcffe8;
  color:#00a94c;
}

.notif-status-text.rejected{
  background:#fee2e2;
  color:#dc2626;
}

/* =============================
   ADMIN BPJS CARD
   ============================= */

.admin-bpjs-card{
  padding:18px;
  margin:14px 0;
}

.admin-bpjs-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
}

.admin-bpjs-user{
  margin:0 0 6px;
  color:#64748b;
  line-height:1.5;
}

@media(max-width:720px){
  .admin-bpjs-head{
    flex-direction:column;
  }
}


/* =============================
   LUCIDE ICON FIX
   ============================= */

[data-lucide] {
  width: 22px;
  height: 22px;
  stroke-width: 2.2;
}

.nav-icon [data-lucide] {
  width: 23px;
  height: 23px;
}

.nav-item.active [data-lucide] {
  color: #2563eb;
}

.module-icon [data-lucide],
.feature-icon [data-lucide],
.admin-card-icon [data-lucide],
.admin-dashboard-icon [data-lucide],
.notif-bell [data-lucide],
.bell [data-lucide] {
  width: 24px;
  height: 24px;
}

/* Lucide tetap muncul walaupun holder icon lama font-size:0 */
.nav-icon svg,
.brand-icon svg,
.ico svg,
.why-icon svg,
.feature-icon svg,
.notif-icon svg,
.admin-card-icon svg,
.admin-dashboard-icon svg,
.module-icon svg {
  display: block;
  flex: 0 0 auto;
}

/* Warna icon mengikuti container */
.nav-icon svg,
.brand-icon svg,
.ico svg,
.why-icon svg,
.feature-icon svg,
.notif-icon svg,
.admin-card-icon svg,
.admin-dashboard-icon svg,
.module-icon svg {
  color: currentColor;
  stroke: currentColor;
}


/* =============================
   NOTIF STATUS WARNA + ICON PUTIH
   ============================= */

/* DIPROSES = ORANYE */
.notif-icon.notif-processing,
.notif-item.notif-processing .notif-icon,
.notif-processing .user-notif-icon{
  background:#f97316 !important;
  color:#fff !important;
}

/* DITERIMA = HIJAU */
.notif-icon.notif-accepted,
.notif-item.notif-accepted .notif-icon,
.notif-accepted .user-notif-icon{
  background:#16a34a !important;
  color:#fff !important;
}

/* DITOLAK = MERAH */
.notif-icon.notif-rejected,
.notif-item.notif-rejected .notif-icon,
.notif-rejected .user-notif-icon{
  background:#dc2626 !important;
  color:#fff !important;
}

/* Paksa icon Lucide/SVG jadi putih */
.notif-icon.notif-processing svg,
.notif-icon.notif-accepted svg,
.notif-icon.notif-rejected svg,
.notif-item.notif-processing .notif-icon svg,
.notif-item.notif-accepted .notif-icon svg,
.notif-item.notif-rejected .notif-icon svg,
.notif-processing .user-notif-icon svg,
.notif-accepted .user-notif-icon svg,
.notif-rejected .user-notif-icon svg{
  color:#fff !important;
  stroke:#fff !important;
}

/* Rapikan posisi icon notifikasi */
.notif-icon{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:38px !important;
  height:38px !important;
  border-radius:12px !important;
  flex:0 0 38px !important;
  line-height:1 !important;
  font-size:0 !important;
}

/* Ukuran icon Lucide di notifikasi */
.notif-icon svg{
  width:20px !important;
  height:20px !important;
  stroke-width:2.4 !important;
}

/* Fallback kalau masih pakai teks/icon biasa */
.notif-icon i,
.notif-icon span{
  color:#fff !important;
  font-size:20px !important;
  line-height:1 !important;
}

/* Badge status optional jika dipakai */
.notif-status-text.process{
  background:#fff7ed !important;
  color:#f97316 !important;
}

.notif-status-text.accepted{
  background:#dcffe8 !important;
  color:#16a34a !important;
}

.notif-status-text.rejected{
  background:#fee2e2 !important;
  color:#dc2626 !important;
}


/* =============================
   CERTIFICATE DIGITAL MODERN
   ============================= */

.certificate-modern{
  margin:18px auto 22px;
  max-width:980px;
}

.certificate-frame{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at top left, rgba(255,215,128,.22), transparent 34%),
    radial-gradient(circle at bottom right, rgba(37,99,235,.10), transparent 34%),
    #fffdf8;
  border:8px solid #e7c15d;
  border-radius:28px;
  padding:52px 46px;
  text-align:center;
  box-shadow:0 18px 48px rgba(15,23,42,.12);
}

.certificate-frame::before{
  content:"";
  position:absolute;
  inset:18px;
  border:1px solid rgba(183,132,28,.25);
  border-radius:20px;
  pointer-events:none;
}

.certificate-corner{
  position:absolute;
  width:90px;
  height:90px;
  border:4px solid rgba(183,132,28,.28);
  pointer-events:none;
}

.certificate-corner.top-left{
  top:24px;
  left:24px;
  border-right:0;
  border-bottom:0;
  border-top-left-radius:18px;
}

.certificate-corner.top-right{
  top:24px;
  right:24px;
  border-left:0;
  border-bottom:0;
  border-top-right-radius:18px;
}

.certificate-corner.bottom-left{
  bottom:24px;
  left:24px;
  border-right:0;
  border-top:0;
  border-bottom-left-radius:18px;
}

.certificate-corner.bottom-right{
  bottom:24px;
  right:24px;
  border-left:0;
  border-top:0;
  border-bottom-right-radius:18px;
}

.certificate-badge{
  position:relative;
  z-index:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:9px;
  padding:10px 18px;
  border-radius:999px;
  background:#fff4d4;
  border:1px solid #e7c15d;
  color:#8a5a00;
  font-weight:800;
  margin-bottom:22px;
}

.certificate-badge svg{
  width:20px;
  height:20px;
}

.certificate-label{
  position:relative;
  z-index:1;
  margin:0 0 12px;
  color:#92400e;
  font-size:13px;
  font-weight:900;
  letter-spacing:.45em;
}

.certificate-title{
  position:relative;
  z-index:1;
  margin:0;
  font-size:46px;
  color:#111827;
  font-weight:900;
}

.certificate-subtitle{
  position:relative;
  z-index:1;
  margin:26px 0 8px;
  color:#64748b;
  font-size:17px;
}

.certificate-name{
  position:relative;
  z-index:1;
  margin:0;
  font-size:54px;
  line-height:1.1;
  font-weight:900;
  background:linear-gradient(90deg,#2563eb,#9333ea,#ec4899);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}

.certificate-desc{
  position:relative;
  z-index:1;
  margin:24px 0 8px;
  color:#334155;
  font-size:17px;
}

.certificate-course{
  position:relative;
  z-index:1;
  margin:0 0 26px;
  color:#0f172a;
  font-size:30px;
  font-weight:900;
}

.certificate-info-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  margin:24px auto 0;
}

.certificate-info{
  background:#fffaf0;
  border:1px solid #f1dfaa;
  border-radius:18px;
  padding:18px 14px;
}

.certificate-info-icon{
  width:42px;
  height:42px;
  border-radius:14px;
  background:#2563eb;
  color:#fff;
  display:grid;
  place-items:center;
  margin:0 auto 10px;
}

.certificate-info-icon svg{
  width:22px;
  height:22px;
}

.certificate-info span{
  display:block;
  color:#8b7355;
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.06em;
  margin-bottom:6px;
}

.certificate-info b{
  display:block;
  color:#111827;
  font-size:16px;
  overflow-wrap:anywhere;
}

.certificate-divider{
  position:relative;
  z-index:1;
  height:1px;
  width:75%;
  margin:34px auto 28px;
  background:linear-gradient(90deg,transparent,#d7c38a,transparent);
}

.certificate-footer{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:end;
  gap:24px;
}

.signature-line{
  width:170px;
  height:2px;
  background:#111827;
  margin:0 auto 10px;
}

.certificate-sign b{
  display:block;
  color:#111827;
  font-size:17px;
}

.certificate-sign span{
  display:block;
  color:#64748b;
  font-size:13px;
  margin-top:4px;
}

.certificate-seal{
  width:120px;
  height:120px;
  border-radius:50%;
  padding:8px;
  background:linear-gradient(135deg,#f4d36c,#c9981d);
  box-shadow:0 10px 24px rgba(201,152,29,.28);
}

.certificate-seal > div{
  width:100%;
  height:100%;
  border-radius:50%;
  border:3px dashed rgba(255,255,255,.75);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  color:#fff;
}

.certificate-seal svg{
  width:28px;
  height:28px;
  margin-bottom:4px;
}

.certificate-seal b{
  font-size:17px;
  letter-spacing:.08em;
}

.certificate-seal span{
  font-size:11px;
  margin-top:3px;
}

.certificate-note{
  position:relative;
  z-index:1;
  max-width:680px;
  margin:28px auto 0;
  color:#64748b;
  font-size:13px;
  line-height:1.7;
}

.certificate-actions .full-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}

@media(max-width:720px){
  .certificate-frame{
    padding:36px 18px;
    border-width:6px;
    border-radius:22px;
  }

  .certificate-title{
    font-size:32px;
  }

  .certificate-name{
    font-size:38px;
  }

  .certificate-course{
    font-size:23px;
  }

  .certificate-label{
    letter-spacing:.24em;
    font-size:11px;
  }

  .certificate-info-grid{
    grid-template-columns:1fr;
  }

  .certificate-footer{
    grid-template-columns:1fr;
    gap:22px;
  }

  .certificate-seal{
    margin:0 auto;
  }

  .certificate-divider{
    width:100%;
  }
}

@media print{
  .header,
  .progress-steps,
  .bottom-nav,
  .floating-logo,
  .certificate-actions,
  .flash{
    display:none !important;
  }

  body{
    background:white !important;
    padding-bottom:0 !important;
  }

  .container{
    padding:0 !important;
  }

  .certificate-modern{
    max-width:none;
    margin:0;
  }

  .certificate-frame{
    box-shadow:none !important;
    min-height:100vh;
    border-radius:0;
  }
}


/* =============================
   AUTH LUCIDE ICON
   ============================= */

.auth-logo{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  font-size:0 !important;
  color:#fff !important;
}

.auth-logo svg{
  width:28px !important;
  height:28px !important;
  color:#fff !important;
  stroke:#fff !important;
  stroke-width:2.4 !important;
}

.auth-logo [data-lucide]{
  width:28px !important;
  height:28px !important;
  color:#fff !important;
  stroke:#fff !important;
  stroke-width:2.4 !important;
}

/* =========================================================
   WORKERPRO UI HOTFIX - NAVBAR, NOTIFIKASI, PROGRESS
   ========================================================= */
html,
body{
  min-height:100%;
  transform:none !important;
}

body{
  padding-bottom:76px !important;
}

.bottom-nav{
  position:fixed !important;
  left:0 !important;
  right:0 !important;
  bottom:0 !important;
  width:100% !important;
  height:76px !important;
  background:#fff !important;
  border-top:1px solid #e5e7eb !important;
  display:grid !important;
  grid-template-columns:repeat(5,1fr) !important;
  align-items:center !important;
  z-index:99999 !important;
  transform:none !important;
  animation:none !important;
}

.bottom-nav .nav-item,
.bottom-nav a{
  height:76px !important;
}

.top-blue{
  position:relative !important;
  z-index:1000 !important;
  overflow:visible !important;
}

.brand-row{
  position:relative !important;
  z-index:1002 !important;
}

.notif-wrap{
  position:relative !important;
  z-index:1003 !important;
}

.notif-wrap[open]{
  z-index:100000 !important;
}

.notif-popup{
  z-index:100001 !important;
}

.hero-card{
  position:relative;
  z-index:1;
}

.progress-card .progress-value{
  color:var(--blue) !important;
}

.progress-line span{
  background:var(--green) !important;
}

@media(max-width:720px){
  .notif-popup{
    position:fixed !important;
    top:82px !important;
    left:14px !important;
    right:14px !important;
    width:auto !important;
    z-index:100001 !important;
  }
}

/* =============================
   FIX WARNA ANGKA PROGRESS
   Angka 15/15 tetap biru, bar progress tetap hijau
   ============================= */
.card.progress-card .progress-value,
.progress-card .progress-value,
.progress-card b.progress-value{
  color:var(--blue) !important;
}

/* =============================
   DESKTOP WIDTH FIX
   Biar UI tidak terlalu melebar di layar besar
   ============================= */
@media (min-width:1024px){
  .top-blue{
    padding-left:24px !important;
    padding-right:24px !important;
  }

  .brand-row,
  .stats,
  .container{
    max-width:1280px !important;
    margin-left:auto !important;
    margin-right:auto !important;
  }

  .container{
    padding-left:24px !important;
    padding-right:24px !important;
  }

  .hero-card,
  .cta{
    max-width:1280px !important;
    width:calc(100% - 48px) !important;
    margin-left:auto !important;
    margin-right:auto !important;
  }

  .bottom-nav{
    padding-left:max(0px,calc((100vw - 1280px) / 2)) !important;
    padding-right:max(0px,calc((100vw - 1280px) / 2)) !important;
  }
}



/* =========================================================
   FORCE MOBILE STATS 3 KOLOM - CPANEL SAFE
   Tambahan saja, tidak mengubah CSS lama
   ========================================================= */
.top-blue .stats{
  display:grid !important;
  grid-template-columns:1fr 1fr 1fr !important;
  gap:14px !important;
  width:100% !important;
}

.top-blue .stats .stat{
  width:100% !important;
}

@media(max-width:720px){
  .top-blue .stats{
    display:grid !important;
    grid-template-columns:1fr 1fr 1fr !important;
    gap:8px !important;
    margin-top:22px !important;
  }

  .top-blue .stats .stat{
    min-height:74px !important;
    border-radius:14px !important;
    padding:9px 5px !important;
  }

  .top-blue .stats .stat .ico{
    width:22px !important;
    height:22px !important;
    margin:0 auto 6px !important;
  }

  .top-blue .stats .stat .ico svg,
  .top-blue .stats .stat .ico [data-lucide]{
    width:17px !important;
    height:17px !important;
  }

  .top-blue .stats .stat b{
    font-size:13px !important;
    margin-top:2px !important;
    line-height:1.15 !important;
  }

  .top-blue .stats .stat span{
    font-size:11px !important;
    line-height:1.2 !important;
  }
}

/* =============================
   PELATIHAN PAGE CONSISTENT WIDTH
   Tambahan saja: header dan progress step ikut lebar konten desktop
   ============================= */
@media (min-width:1281px){
  .header{
    padding-left:calc((100vw - 1280px) / 2 + 24px) !important;
    padding-right:calc((100vw - 1280px) / 2 + 24px) !important;
  }

  .progress-steps{
    padding-left:calc((100vw - 1280px) / 2 + 24px) !important;
    padding-right:calc((100vw - 1280px) / 2 + 24px) !important;
  }
}

@media (min-width:1024px) and (max-width:1280px){
  .header{
    padding-left:24px !important;
    padding-right:24px !important;
  }

  .progress-steps{
    padding-left:24px !important;
    padding-right:24px !important;
  }
}

/* =============================
   DESKTOP WIDTH REBALANCE 1440
   Tambahan saja - tidak mengubah CSS lama
   ============================= */
@media (min-width:1024px){
  .brand-row,
  .stats,
  .container{
    max-width:1440px !important;
    margin-left:auto !important;
    margin-right:auto !important;
  }

  .hero-card,
  .cta{
    max-width:1440px !important;
    width:calc(100% - 48px) !important;
    margin-left:auto !important;
    margin-right:auto !important;
  }
}

@media (min-width:1441px){
  .header{
    padding-left:calc((100vw - 1440px) / 2 + 24px) !important;
    padding-right:calc((100vw - 1440px) / 2 + 24px) !important;
  }

  .progress-steps{
    padding-left:calc((100vw - 1440px) / 2 + 24px) !important;
    padding-right:calc((100vw - 1440px) / 2 + 24px) !important;
  }

  .bottom-nav{
    padding-left:calc((100vw - 1440px) / 2) !important;
    padding-right:calc((100vw - 1440px) / 2) !important;
  }
}

@media (min-width:1024px) and (max-width:1440px){
  .header{
    padding-left:24px !important;
    padding-right:24px !important;
  }

  .progress-steps{
    padding-left:24px !important;
    padding-right:24px !important;
  }

  .bottom-nav{
    padding-left:0 !important;
    padding-right:0 !important;
  }
}

/* =========================================================
   WORKERPRO SMOOTH ANIMATION PACK
   Tambahan saja - tidak mengubah CSS lama
   ========================================================= */

@keyframes wpFadeUp{
  from{
    opacity:0;
    transform:translateY(18px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}

@keyframes wpFadeDown{
  from{
    opacity:0;
    transform:translateY(-14px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}

@keyframes wpScaleIn{
  from{
    opacity:0;
    transform:scale(.96);
  }
  to{
    opacity:1;
    transform:scale(1);
  }
}

@keyframes wpFloatSoft{
  0%,100%{
    transform:translateY(0);
  }
  50%{
    transform:translateY(-5px);
  }
}

@keyframes wpShimmer{
  0%{
    transform:translateX(-120%) skewX(-18deg);
  }
  100%{
    transform:translateX(220%) skewX(-18deg);
  }
}

@keyframes wpProgressMove{
  0%{
    background-position:0 50%;
  }
  100%{
    background-position:120px 50%;
  }
}

/* animasi masuk halaman */
.top-blue{
  animation:wpFadeDown .45s ease both;
}

.hero-card,
.grad-panel,
.profile-hero,
.cta{
  animation:wpScaleIn .5s ease both;
}

.container > *,
.why-card,
.feature-card,
.module-card,
.job-card,
.benefit-card,
.question-card,
.progress-card,
.video-card,
.lesson-list,
.search-box,
.empty-search,
.certificate-modern,
.admin-profile-panel,
.admin-dashboard-card,
.admin-bpjs-card{
  animation:wpFadeUp .5s ease both;
}

/* delay ringan biar tidak muncul kaku */
.container > *:nth-child(1){animation-delay:.03s}
.container > *:nth-child(2){animation-delay:.07s}
.container > *:nth-child(3){animation-delay:.11s}
.container > *:nth-child(4){animation-delay:.15s}
.container > *:nth-child(5){animation-delay:.19s}

.why-list > *:nth-child(1),
.features > *:nth-child(1),
.stats > *:nth-child(1){
  animation-delay:.04s;
}

.why-list > *:nth-child(2),
.features > *:nth-child(2),
.stats > *:nth-child(2){
  animation-delay:.09s;
}

.why-list > *:nth-child(3),
.features > *:nth-child(3),
.stats > *:nth-child(3){
  animation-delay:.14s;
}

.why-list > *:nth-child(4),
.features > *:nth-child(4){
  animation-delay:.19s;
}

/* hover card desktop */
@media (hover:hover){
  .why-card,
  .feature-card,
  .module-card,
  .job-card,
  .benefit-card,
  .question-card,
  .progress-card,
  .video-card,
  .search-box,
  .admin-profile-card,
  .admin-dashboard-card,
  .claim-empty-card,
  .claim-success-card{
    transition:transform .24s ease, box-shadow .24s ease, border-color .24s ease, background .24s ease;
  }

  .why-card:hover,
  .feature-card:hover,
  .module-card:hover,
  .job-card:hover,
  .benefit-card:hover,
  .question-card:hover,
  .progress-card:hover,
  .video-card:hover,
  .search-box:hover,
  .admin-profile-card:hover,
  .admin-dashboard-card:hover,
  .claim-empty-card:hover,
  .claim-success-card:hover{
    transform:translateY(-4px);
    box-shadow:0 16px 42px rgba(15,23,42,.10);
    border-color:#bfdbfe;
  }

  .feature-icon,
  .why-icon,
  .module-icon,
  .admin-card-icon,
  .admin-dashboard-icon,
  .claim-icon,
  .brand-icon{
    transition:transform .24s ease, box-shadow .24s ease;
  }

  .feature-card:hover .feature-icon,
  .why-card:hover .why-icon,
  .module-card:hover .module-icon,
  .admin-profile-card:hover .admin-card-icon,
  .admin-dashboard-card:hover .admin-dashboard-icon,
  .claim-empty-card:hover .claim-icon,
  .claim-success-card:hover .claim-icon{
    transform:translateY(-3px) scale(1.04);
  }
}

/* tombol lebih hidup */
.full-btn,
.small-btn,
.white-action,
.claim-btn,
.logout-profile-btn,
.google-login-btn,
.search-lowongan-btn,
.profile-skill-chip,
.chip-btn,
.tab,
.chip,
.badge{
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease, border-color .18s ease, opacity .18s ease;
}

@media (hover:hover){
  .full-btn:hover,
  .small-btn:hover,
  .white-action:hover,
  .claim-btn:hover,
  .logout-profile-btn:hover,
  .google-login-btn:hover,
  .search-lowongan-btn:hover{
    transform:translateY(-2px);
    box-shadow:0 12px 28px rgba(20,92,255,.18);
  }

  .profile-skill-chip:hover,
  .chip-btn:hover,
  .tab:hover,
  .chip:hover,
  .badge:hover{
    transform:translateY(-1px);
  }
}

.full-btn:active,
.small-btn:active,
.white-action:active,
.claim-btn:active,
.logout-profile-btn:active,
.google-login-btn:active,
.search-lowongan-btn:active,
.profile-skill-chip:active,
.chip-btn:active,
.tab:active,
.chip:active{
  transform:scale(.97);
}

/* shimmer halus untuk panel utama */
.hero-card,
.grad-panel,
.profile-hero,
.cta,
.quiz-result-hero{
  position:relative;
  overflow:hidden;
}

.hero-card::after,
.grad-panel::after,
.profile-hero::after,
.cta::after,
.quiz-result-hero::after{
  content:"";
  position:absolute;
  top:-55%;
  left:-80%;
  width:38%;
  height:210%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.28),transparent);
  transform:skewX(-18deg);
  animation:wpShimmer 5.5s ease-in-out infinite;
  pointer-events:none;
}

/* progress bar terasa bergerak */
.progress-line span{
  background:linear-gradient(90deg,var(--green),#22c55e,var(--green)) !important;
  background-size:120px 100% !important;
  animation:wpProgressMove 2.8s linear infinite;
}

/* bottom nav smooth */
.bottom-nav .nav-item,
.bottom-nav a{
  transition:color .2s ease, transform .2s ease, background .2s ease;
}

.bottom-nav .nav-icon{
  transition:transform .2s ease;
}

.bottom-nav .nav-item.active .nav-icon,
.bottom-nav a.active .nav-icon{
  transform:translateY(-2px) scale(1.05);
}

@media (hover:hover){
  .bottom-nav .nav-item:hover,
  .bottom-nav a:hover{
    color:var(--blue);
  }

  .bottom-nav .nav-item:hover .nav-icon,
  .bottom-nav a:hover .nav-icon{
    transform:translateY(-2px);
  }
}

/* notifikasi popup lebih smooth */
.notif-popup{
  animation:wpScaleIn .2s ease both !important;
}

/* input focus lebih modern */
.input,
.auth-card input,
.photo-input,
textarea{
  transition:border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.input:focus,
.auth-card input:focus,
.photo-input:focus,
textarea:focus{
  outline:none;
  border-color:#93c5fd !important;
  box-shadow:0 0 0 4px rgba(37,99,235,.12);
}

/* icon kecil terasa hidup */
.bell,
.notif-bell{
  transition:transform .2s ease, background .2s ease;
}

@media (hover:hover){
  .bell:hover,
  .notif-bell:hover{
    transform:translateY(-2px) scale(1.03);
  }
}

/* respect user/device yang mengurangi animasi */
@media (prefers-reduced-motion:reduce){
  *,
  *::before,
  *::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    scroll-behavior:auto !important;
    transition-duration:.01ms !important;
  }
}

/* =========================================================
   LOGIN PAGE CARD POSITION FIX
   Tambahan saja - mendekatkan card login ke highlight
   ========================================================= */
@media (min-width:1100px){
  .auth-page.auth-landing-page{
    grid-template-columns:minmax(0,760px) 430px !important;
    justify-content:center !important;
    align-items:center !important;
    gap:48px !important;
    padding-left:36px !important;
    padding-right:36px !important;
  }

  .auth-page.auth-landing-page .auth-highlight{
    max-width:760px !important;
    justify-self:end !important;
  }

  .auth-page.auth-landing-page .auth-card{
    width:430px !important;
    max-width:430px !important;
    justify-self:start !important;
    transform:none !important;
  }
}

@media (min-width:901px) and (max-width:1099px){
  .auth-page.auth-landing-page{
    grid-template-columns:minmax(0,1fr) minmax(360px,430px) !important;
    justify-content:center !important;
    gap:24px !important;
  }

  .auth-page.auth-landing-page .auth-card{
    transform:none !important;
  }
}

/* =========================================================
   WORKERPRO LOGIN RESPONSIVE FIX - STYLE GAMBAR 2
   Style ini sengaja ada di login.blade.php agar tetap kebaca
   walaupun cache CSS hosting belum refresh.
   ========================================================= */
body:has(.wp-login-page){
    padding-bottom:0 !important;
    overflow-x:hidden !important;
    background:#f7f1ff !important;
}

.wp-login-page,
.wp-login-page *{
    box-sizing:border-box;
}

.wp-login-page{
    --wp-purple-950:#21064b;
    --wp-purple-900:#2d075f;
    --wp-purple-800:#3f1288;
    --wp-purple-700:#5b21b6;
    --wp-purple-600:#7c2ee8;
    --wp-purple-500:#8b35ff;
    --wp-purple-300:#c7a6ff;
    --wp-lavender:#f6efff;
    --wp-ink:#111827;
    --wp-muted:#6b7280;
    --wp-line:#e7dcff;
    --wp-white:#ffffff;
    width:100%;
    min-height:100vh;
    padding:clamp(20px,4vw,56px) 18px;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:22px;
    color:var(--wp-ink);
    background:
        radial-gradient(circle at 8% 16%, rgba(124,46,232,.16), transparent 28%),
        radial-gradient(circle at 92% 84%, rgba(139,53,255,.20), transparent 26%),
        linear-gradient(135deg,#fbf8ff 0%,#f1e7ff 100%);
    position:relative;
    overflow:hidden;
}

.wp-login-page::before{
    content:"";
    position:absolute;
    inset:0;
    background-image:radial-gradient(rgba(124,46,232,.13) 1px, transparent 1px);
    background-size:18px 18px;
    pointer-events:none;
    opacity:.55;
}

.wp-login-shell{
    position:relative;
    z-index:1;
    width:min(1180px,100%);
    min-height:min(760px,calc(100vh - 120px));
    display:grid;
    grid-template-columns:minmax(0,1.18fr) minmax(390px,.82fr);
    background:var(--wp-white);
    border:1px solid rgba(124,46,232,.10);
    border-radius:30px;
    overflow:hidden;
    box-shadow:0 28px 90px rgba(68,20,129,.16);
}

.wp-login-hero{
    min-width:0;
    min-height:680px;
    padding:34px clamp(28px,4vw,52px) 56px;
    color:#fff;
    position:relative;
    overflow:hidden;
    display:flex;
    flex-direction:column;
    justify-content:space-between;
    background:
        linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px),
        linear-gradient(180deg,rgba(255,255,255,.035) 1px,transparent 1px),
        radial-gradient(circle at 76% 34%,rgba(199,166,255,.20),transparent 28%),
        linear-gradient(135deg,var(--wp-purple-950) 0%,var(--wp-purple-800) 50%,var(--wp-purple-600) 100%);
    background-size:64px 64px,64px 64px,auto,auto;
}

.wp-login-hero::before{
    content:"";
    position:absolute;
    left:-8%;
    right:-8%;
    bottom:-95px;
    height:170px;
    background:#f7f1ff;
    border-radius:50% 50% 0 0 / 58% 58% 0 0;
    transform:rotate(-2deg);
    opacity:1;
}

.wp-login-hero::after{
    content:"";
    position:absolute;
    inset:auto -70px 82px auto;
    width:520px;
    height:520px;
    border:1px solid rgba(255,255,255,.08);
    border-radius:50%;
    box-shadow:0 0 0 80px rgba(255,255,255,.028), 0 0 0 170px rgba(255,255,255,.022);
    pointer-events:none;
}

.wp-hero-top,
.wp-hero-main,
.wp-hero-stats{
    position:relative;
    z-index:2;
}

.wp-hero-top{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:16px;
}

.wp-brand{
    display:flex;
    align-items:center;
    gap:12px;
}

.wp-brand-mark{
    width:46px;
    height:46px;
    border-radius:15px;
    background:linear-gradient(135deg,#a855f7,#6d28d9);
    display:grid;
    place-items:center;
    color:#fff;
    font-size:20px;
    font-weight:900;
    box-shadow:0 12px 28px rgba(0,0,0,.18);
}

.wp-brand-name{
    display:block;
    font-size:19px;
    font-weight:900;
    line-height:1.1;
}

.wp-brand-sub{
    display:block;
    margin-top:3px;
    font-size:12px;
    color:rgba(255,255,255,.76);
}

.wp-register-pill{
    min-width:92px;
    min-height:42px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-radius:999px;
    border:1px solid rgba(255,255,255,.28);
    background:rgba(255,255,255,.12);
    color:#fff;
    font-size:14px;
    font-weight:800;
    backdrop-filter:blur(10px);
    transition:.2s ease;
}

.wp-register-pill:hover{
    transform:translateY(-2px);
    background:rgba(255,255,255,.18);
}

.wp-hero-main{
    margin-top:56px;
}

.wp-badge{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:10px 18px;
    border-radius:999px;
    background:rgba(139,53,255,.66);
    border:1px solid rgba(255,255,255,.18);
    color:#fff;
    font-size:13px;
    font-weight:900;
    letter-spacing:.02em;
    box-shadow:0 14px 28px rgba(0,0,0,.10);
}

.wp-hero-title{
    margin:30px 0 18px;
    max-width:660px;
    font-size:clamp(42px,5.4vw,68px);
    line-height:.98;
    letter-spacing:-.055em;
    font-weight:950;
}

.wp-hero-title span{
    color:#d8c3ff;
}

.wp-hero-copy{
    max-width:620px;
    margin:0;
    font-size:16px;
    line-height:1.75;
    color:rgba(255,255,255,.88);
}

.wp-hero-stats{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:12px;
    margin-top:38px;
    padding:12px;
    border-radius:22px;
    border:1px solid rgba(255,255,255,.18);
    background:rgba(255,255,255,.10);
    backdrop-filter:blur(12px);
}

.wp-stat-card{
    min-width:0;
    display:grid;
    grid-template-columns:44px 1fr;
    align-items:center;
    gap:12px;
    padding:18px 15px;
    border-radius:16px;
    background:rgba(255,255,255,.10);
}

.wp-stat-icon{
    width:44px;
    height:44px;
    border-radius:50%;
    display:grid;
    place-items:center;
    background:linear-gradient(135deg,#a855f7,#7c2ee8);
    color:#fff;
    flex:0 0 auto;
}

.wp-stat-icon svg,
.wp-stat-icon [data-lucide]{
    width:21px !important;
    height:21px !important;
}

.wp-stat-label{
    display:block;
    font-size:11px;
    color:rgba(255,255,255,.74);
    font-weight:700;
}

.wp-stat-value{
    display:block;
    margin-top:5px;
    font-size:24px;
    line-height:1;
    font-weight:950;
    color:#fff;
}

.wp-stat-note{
    display:block;
    margin-top:6px;
    font-size:11px;
    line-height:1.25;
    color:rgba(255,255,255,.70);
}

.wp-login-card{
    min-width:0;
    padding:clamp(34px,4vw,62px) clamp(28px,4.2vw,58px);
    display:flex;
    flex-direction:column;
    justify-content:center;
    background:#fff;
}

.wp-secure-badge{
    width:max-content;
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:10px 14px;
    border-radius:999px;
    background:#f3e8ff;
    border:1px solid #e7d4ff;
    color:var(--wp-purple-700);
    font-size:13px;
    font-weight:900;
}

.wp-secure-badge svg,
.wp-secure-badge [data-lucide]{
    width:16px !important;
    height:16px !important;
}

.wp-login-card h1{
    margin:28px 0 12px;
    font-size:clamp(34px,4vw,44px);
    line-height:1.05;
    letter-spacing:-.04em;
    color:#111827;
    font-weight:950;
}

.wp-login-intro{
    max-width:390px;
    margin:0 0 30px;
    color:#6b7280;
    font-size:16px;
    line-height:1.65;
}

.wp-field{
    margin-bottom:18px;
}

.wp-field label{
    display:block;
    margin-bottom:9px;
    color:#111827;
    font-size:14px;
    font-weight:900;
}

.wp-input-wrap{
    position:relative;
    display:flex;
    align-items:center;
}

.wp-input-wrap > i,
.wp-input-wrap > svg{
    position:absolute;
    left:18px;
    width:20px !important;
    height:20px !important;
    color:#9ca3af;
    z-index:2;
}

.wp-input-wrap input{
    width:100%;
    height:58px;
    border:1.5px solid #ded0fb;
    border-radius:16px;
    padding:0 52px;
    background:#fff;
    color:#111827;
    font-size:15px;
    font-weight:700;
    outline:none;
    transition:border-color .18s ease, box-shadow .18s ease;
}

.wp-input-wrap input::placeholder{
    color:#9ca3af;
    font-weight:800;
}

.wp-input-wrap input:focus{
    border-color:#8b35ff;
    box-shadow:0 0 0 5px rgba(139,53,255,.12);
}

.wp-password-toggle{
    position:absolute;
    right:15px;
    width:34px;
    height:34px;
    border:0;
    border-radius:10px;
    background:transparent;
    color:#6b7280;
    display:grid;
    place-items:center;
    cursor:pointer;
    z-index:3;
}

.wp-password-toggle svg,
.wp-password-toggle [data-lucide]{
    width:20px !important;
    height:20px !important;
}

.wp-form-row{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
    margin:2px 0 22px;
    font-size:14px;
}

.wp-check{
    display:inline-flex;
    align-items:center;
    gap:9px;
    color:#6b7280;
    font-weight:800;
}

.wp-check input{
    width:18px;
    height:18px;
    accent-color:#8b35ff;
}

.wp-forgot{
    color:#7c2ee8;
    font-weight:900;
    white-space:nowrap;
}

.wp-submit{
    width:100%;
    height:60px;
    border:0;
    border-radius:16px;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    background:linear-gradient(90deg,#7c2ee8,#9b35ff);
    color:#fff;
    font-size:16px;
    font-weight:950;
    cursor:pointer;
    box-shadow:0 18px 42px rgba(124,46,232,.28);
    transition:.2s ease;
}

.wp-submit:hover{
    transform:translateY(-2px);
    box-shadow:0 22px 50px rgba(124,46,232,.34);
}

.wp-divider{
    display:flex;
    align-items:center;
    gap:16px;
    margin:30px 0 24px;
    color:#9ca3af;
    font-size:12px;
    font-weight:950;
    letter-spacing:.08em;
}

.wp-divider::before,
.wp-divider::after{
    content:"";
    height:1px;
    flex:1;
    background:#eadffc;
}

.wp-google{
    width:100%;
    height:58px;
    border-radius:16px;
    border:1.5px solid #ded0fb;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:12px;
    color:#111827;
    background:#fff;
    font-size:15px;
    font-weight:950;
    transition:.18s ease;
}

.wp-google:hover{
    transform:translateY(-2px);
    border-color:#c7a6ff;
    box-shadow:0 16px 32px rgba(124,46,232,.10);
}

.wp-google-mark{
    width:22px;
    height:22px;
    border-radius:50%;
    display:grid;
    place-items:center;
    color:#ea4335;
    background:#fff;
    border:1px solid #eef0f4;
    font-weight:950;
    line-height:1;
}

.wp-register-text{
    margin:26px 0 0;
    text-align:center;
    color:#7b8191;
    font-size:15px;
    font-weight:700;
}

.wp-register-text a{
    color:#7c2ee8;
    font-weight:950;
}

.wp-login-trust{
    position:relative;
    z-index:2;
    width:min(760px,100%);
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    align-items:center;
    justify-content:center;
    gap:28px;
    color:#6b6477;
    margin-top:-4px;
}

.wp-trust-item{
    min-width:0;
    display:grid;
    grid-template-columns:46px 1fr;
    align-items:center;
    gap:12px;
}

.wp-trust-icon{
    width:46px;
    height:46px;
    border-radius:50%;
    display:grid;
    place-items:center;
    color:#8b35ff;
    background:rgba(255,255,255,.74);
    border:1px solid rgba(124,46,232,.08);
    box-shadow:0 8px 22px rgba(124,46,232,.08);
}

.wp-trust-title{
    display:block;
    color:#5b5870;
    font-size:14px;
    font-weight:950;
}

.wp-trust-copy{
    display:block;
    margin-top:2px;
    color:#8a8499;
    font-size:12px;
}

@media(max-width:1100px){
    .wp-login-shell{
        grid-template-columns:minmax(0,1fr) minmax(360px,.86fr);
    }

    .wp-login-hero{
        padding-left:30px;
        padding-right:30px;
    }

    .wp-hero-title{
        font-size:52px;
    }

    .wp-stat-card{
        grid-template-columns:1fr;
        text-align:center;
        justify-items:center;
    }
}

@media(max-width:860px){
    body:has(.wp-login-page){
        min-width:0 !important;
    }

    .wp-login-page{
        justify-content:flex-start;
        padding:14px;
        gap:14px;
        overflow-x:hidden;
    }

    .wp-login-shell{
        width:min(100%,520px);
        min-height:0;
        display:flex;
        flex-direction:column;
        border-radius:26px;
        overflow:hidden;
    }

    .wp-login-hero{
        min-height:auto;
        padding:26px 22px 42px;
        border-radius:0;
    }

    .wp-login-hero::before{
        height:92px;
        bottom:-58px;
    }

    .wp-login-hero::after{
        width:280px;
        height:280px;
        right:-110px;
        bottom:44px;
    }

    .wp-hero-top{
        align-items:center;
    }

    .wp-brand-mark{
        width:42px;
        height:42px;
        border-radius:14px;
    }

    .wp-register-pill{
        min-width:78px;
        min-height:38px;
        font-size:13px;
    }

    .wp-hero-main{
        margin-top:38px;
    }

    .wp-badge{
        padding:9px 14px;
        font-size:12px;
    }

    .wp-hero-title{
        margin-top:24px;
        font-size:clamp(38px,12vw,54px);
        line-height:1.02;
        max-width:420px;
    }

    .wp-hero-copy{
        max-width:430px;
        font-size:15px;
        line-height:1.65;
    }

    .wp-hero-stats{
        grid-template-columns:1fr;
        margin-top:28px;
        padding:10px;
    }

    .wp-stat-card{
        grid-template-columns:44px 1fr;
        justify-items:stretch;
        text-align:left;
        padding:14px;
    }

    .wp-stat-value{
        font-size:22px;
    }

    .wp-login-card{
        padding:34px 22px 30px;
    }

    .wp-login-card h1{
        margin-top:22px;
        font-size:34px;
    }

    .wp-login-intro{
        font-size:14px;
        margin-bottom:24px;
    }

    .wp-form-row{
        align-items:flex-start;
        flex-direction:column;
        gap:10px;
    }

    .wp-forgot{
        white-space:normal;
    }

    .wp-login-trust{
        width:min(100%,520px);
        grid-template-columns:1fr;
        gap:10px;
        margin:0;
        padding:6px 8px 12px;
    }

    .wp-trust-item{
        grid-template-columns:40px 1fr;
        padding:10px 12px;
        border-radius:18px;
        background:rgba(255,255,255,.72);
    }

    .wp-trust-icon{
        width:40px;
        height:40px;
    }
}

@media(max-width:420px){
    .wp-login-page{
        padding:10px;
    }

    .wp-login-shell{
        border-radius:22px;
    }

    .wp-login-hero{
        padding:22px 16px 36px;
    }

    .wp-brand-name{
        font-size:17px;
    }

    .wp-brand-sub{
        font-size:11px;
    }

    .wp-hero-title{
        font-size:38px;
        letter-spacing:-.045em;
    }

    .wp-login-card{
        padding:30px 16px 26px;
    }

    .wp-input-wrap input{
        height:54px;
        border-radius:14px;
    }

    .wp-submit,
    .wp-google{
        height:56px;
        border-radius:14px;
    }
}


/* =========================================================
   WORKERPRO AUTH PAGES MODERN FIX
   ========================================================= */


body.workerpro-modern{
    padding-bottom:0 !important;
    overflow-x:hidden !important;
    background:#f7f1ff !important;
}
.wp-auth-modern-page,
.wp-auth-modern-page *{
    box-sizing:border-box;
}
.wp-auth-modern-page{
    --wp-purple-950:#21064b;
    --wp-purple-900:#2d075f;
    --wp-purple-800:#3f1288;
    --wp-purple-700:#5b21b6;
    --wp-purple-600:#7c2ee8;
    --wp-purple-500:#8b35ff;
    --wp-purple-300:#c7a6ff;
    --wp-lavender:#f6efff;
    --wp-ink:#111827;
    --wp-muted:#6b7280;
    --wp-line:#e7dcff;
    --wp-white:#ffffff;
    width:100%;
    min-height:100vh;
    padding:clamp(18px,4vw,54px) 18px;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    color:var(--wp-ink);
    background:
        radial-gradient(circle at 8% 16%, rgba(124,46,232,.16), transparent 28%),
        radial-gradient(circle at 92% 84%, rgba(139,53,255,.20), transparent 26%),
        linear-gradient(135deg,#fbf8ff 0%,#f1e7ff 100%);
    position:relative;
    overflow:hidden;
}
.wp-auth-modern-page::before{
    content:"";
    position:absolute;
    inset:0;
    background-image:radial-gradient(rgba(124,46,232,.13) 1px, transparent 1px);
    background-size:18px 18px;
    pointer-events:none;
    opacity:.55;
}
.wp-auth-modern-shell{
    position:relative;
    z-index:1;
    width:min(1180px,100%);
    display:grid;
    grid-template-columns:minmax(0,1.05fr) minmax(390px,.95fr);
    background:#fff;
    border:1px solid rgba(124,46,232,.10);
    border-radius:30px;
    overflow:hidden;
    box-shadow:0 28px 90px rgba(68,20,129,.16);
}
.wp-auth-hero{
    min-height:690px;
    padding:34px clamp(28px,4vw,52px) 56px;
    color:#fff;
    position:relative;
    overflow:hidden;
    display:flex;
    flex-direction:column;
    justify-content:space-between;
    background:
        linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px),
        linear-gradient(180deg,rgba(255,255,255,.035) 1px,transparent 1px),
        radial-gradient(circle at 76% 34%,rgba(199,166,255,.20),transparent 28%),
        linear-gradient(135deg,var(--wp-purple-950) 0%,var(--wp-purple-800) 50%,var(--wp-purple-600) 100%);
    background-size:64px 64px,64px 64px,auto,auto;
}
.wp-auth-hero::before{
    content:"";
    position:absolute;
    left:-8%;
    right:-8%;
    bottom:-95px;
    height:170px;
    background:#f7f1ff;
    border-radius:50% 50% 0 0 / 58% 58% 0 0;
    transform:rotate(-2deg);
}
.wp-auth-top,
.wp-auth-main,
.wp-auth-stats{
    position:relative;
    z-index:2;
}
.wp-auth-top{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:16px;
}
.wp-auth-brand{
    display:flex;
    align-items:center;
    gap:12px;
    user-select:none;
    pointer-events:none;
}
.wp-auth-brand-mark{
    width:46px;
    height:46px;
    border-radius:15px;
    background:linear-gradient(135deg,#a855f7,#6d28d9);
    display:grid;
    place-items:center;
    color:#fff;
    font-size:20px;
    font-weight:900;
    box-shadow:0 12px 28px rgba(0,0,0,.18);
}
.wp-auth-brand-name{
    display:block;
    font-size:19px;
    font-weight:900;
    line-height:1.1;
}
.wp-auth-brand-sub{
    display:block;
    margin-top:3px;
    font-size:12px;
    color:rgba(255,255,255,.76);
}
.wp-auth-pill-link{
    min-width:92px;
    min-height:42px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-radius:999px;
    border:1px solid rgba(255,255,255,.28);
    background:rgba(255,255,255,.12);
    color:#fff;
    font-size:14px;
    font-weight:800;
    backdrop-filter:blur(10px);
    transition:.2s ease;
}
.wp-auth-pill-link:hover{
    transform:translateY(-2px);
    background:rgba(255,255,255,.18);
}
.wp-auth-main{
    margin-top:56px;
}
.wp-auth-badge{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:10px 18px;
    border-radius:999px;
    background:rgba(139,53,255,.66);
    border:1px solid rgba(255,255,255,.18);
    color:#fff;
    font-size:13px;
    font-weight:900;
    letter-spacing:.02em;
    box-shadow:0 14px 28px rgba(0,0,0,.10);
}
.wp-auth-title{
    margin:30px 0 18px;
    max-width:640px;
    font-size:clamp(40px,5vw,64px);
    line-height:.99;
    letter-spacing:-.055em;
    font-weight:950;
}
.wp-auth-title span{
    color:#d8c3ff;
}
.wp-auth-copy{
    max-width:600px;
    margin:0;
    font-size:16px;
    line-height:1.75;
    color:rgba(255,255,255,.88);
}
.wp-auth-stats{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:12px;
    margin-top:38px;
    padding:12px;
    border-radius:22px;
    border:1px solid rgba(255,255,255,.18);
    background:rgba(255,255,255,.10);
    backdrop-filter:blur(12px);
}
.wp-auth-stat-card{
    min-width:0;
    display:grid;
    grid-template-columns:44px 1fr;
    align-items:center;
    gap:12px;
    padding:18px 15px;
    border-radius:16px;
    background:rgba(255,255,255,.10);
}
.wp-auth-stat-icon{
    width:44px;
    height:44px;
    border-radius:50%;
    display:grid;
    place-items:center;
    background:linear-gradient(135deg,#a855f7,#7c2ee8);
    color:#fff;
}
.wp-auth-stat-icon svg,
.wp-auth-stat-icon [data-lucide]{
    width:21px !important;
    height:21px !important;
}
.wp-auth-stat-label{
    display:block;
    font-size:11px;
    color:rgba(255,255,255,.74);
    font-weight:700;
}
.wp-auth-stat-value{
    display:block;
    margin-top:5px;
    font-size:24px;
    line-height:1;
    font-weight:950;
    color:#fff;
}
.wp-auth-stat-note{
    display:block;
    margin-top:6px;
    font-size:11px;
    line-height:1.25;
    color:rgba(255,255,255,.70);
}
.wp-auth-card{
    padding:clamp(34px,4vw,62px) clamp(28px,4.2vw,58px);
    display:flex;
    flex-direction:column;
    justify-content:center;
    background:#fff;
}
.wp-auth-secure{
    width:max-content;
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:10px 14px;
    border-radius:999px;
    background:#f3e8ff;
    border:1px solid #e7d4ff;
    color:var(--wp-purple-700);
    font-size:13px;
    font-weight:900;
}
.wp-auth-secure svg,
.wp-auth-secure [data-lucide]{
    width:16px !important;
    height:16px !important;
}
.wp-auth-card h1{
    margin:28px 0 12px;
    font-size:clamp(34px,4vw,44px);
    line-height:1.05;
    letter-spacing:-.04em;
    color:#111827;
    font-weight:950;
}
.wp-auth-intro{
    max-width:390px;
    margin:0 0 30px;
    color:#6b7280;
    font-size:16px;
    line-height:1.65;
}
.wp-auth-field{
    margin-bottom:18px;
}
.wp-auth-field label{
    display:block;
    margin-bottom:9px;
    color:#111827;
    font-size:14px;
    font-weight:900;
}
.wp-auth-input-wrap{
    position:relative;
    display:flex;
    align-items:center;
}
.wp-auth-input-wrap > i,
.wp-auth-input-wrap > svg{
    position:absolute;
    left:18px;
    width:20px !important;
    height:20px !important;
    color:#9ca3af;
    z-index:2;
}
.wp-auth-input-wrap input{
    width:100%;
    height:58px;
    border:1.5px solid #ded0fb;
    border-radius:16px;
    padding:0 52px;
    background:#fff;
    color:#111827;
    font-size:15px;
    font-weight:700;
    outline:none;
    transition:border-color .18s ease, box-shadow .18s ease;
}
.wp-auth-input-wrap input::placeholder{
    color:#9ca3af;
    font-weight:800;
}
.wp-auth-input-wrap input:focus{
    border-color:#8b35ff;
    box-shadow:0 0 0 5px rgba(139,53,255,.12);
}
.wp-auth-submit{
    width:100%;
    height:60px;
    border:0;
    border-radius:16px;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    background:linear-gradient(90deg,#7c2ee8,#9b35ff);
    color:#fff;
    font-size:16px;
    font-weight:950;
    cursor:pointer;
    box-shadow:0 18px 42px rgba(124,46,232,.28);
    transition:.2s ease;
}
.wp-auth-submit:hover{
    transform:translateY(-2px);
    box-shadow:0 22px 50px rgba(124,46,232,.34);
}
.wp-auth-bottom-text{
    margin:24px 0 0;
    text-align:center;
    color:#7b8191;
    font-size:15px;
    font-weight:700;
}
.wp-auth-bottom-text a{
    color:#7c2ee8;
    font-weight:950;
}
.wp-auth-help-card{
    margin-top:22px;
    display:grid;
    grid-template-columns:38px 1fr;
    gap:12px;
    align-items:start;
    padding:14px;
    border-radius:16px;
    background:#faf5ff;
    border:1px solid #eadffc;
    color:#6b7280;
    font-size:13px;
    line-height:1.45;
}
.wp-auth-help-card i,
.wp-auth-help-card svg{
    width:38px !important;
    height:38px !important;
    border-radius:12px;
    padding:9px;
    color:#7c2ee8;
    background:#f3e8ff;
}
@media(max-width:1100px){
    .wp-auth-modern-shell{
        grid-template-columns:minmax(0,1fr) minmax(360px,.86fr);
    }
    .wp-auth-hero{
        padding-left:30px;
        padding-right:30px;
    }
    .wp-auth-title{
        font-size:52px;
    }
    .wp-auth-stat-card{
        grid-template-columns:1fr;
        text-align:center;
        justify-items:center;
    }
}
@media(max-width:860px){
    .wp-auth-modern-page{
        justify-content:flex-start;
        padding:14px;
        overflow-x:hidden;
    }
    .wp-auth-modern-shell{
        width:min(100%,520px);
        display:flex;
        flex-direction:column;
        border-radius:26px;
        overflow:hidden;
    }
    .wp-auth-hero{
        min-height:auto;
        padding:26px 22px 42px;
    }
    .wp-auth-hero::before{
        height:92px;
        bottom:-58px;
    }
    .wp-auth-top{
        align-items:center;
    }
    .wp-auth-brand-mark{
        width:42px;
        height:42px;
        border-radius:14px;
    }
    .wp-auth-pill-link{
        min-width:78px;
        min-height:38px;
        font-size:13px;
    }
    .wp-auth-main{
        margin-top:38px;
    }
    .wp-auth-badge{
        padding:9px 14px;
        font-size:12px;
    }
    .wp-auth-title{
        margin-top:24px;
        font-size:clamp(36px,11vw,52px);
        line-height:1.02;
        max-width:420px;
    }
    .wp-auth-copy{
        max-width:430px;
        font-size:15px;
        line-height:1.65;
    }
    .wp-auth-stats{
        grid-template-columns:1fr;
        margin-top:28px;
        padding:10px;
    }
    .wp-auth-stat-card{
        grid-template-columns:44px 1fr;
        justify-items:stretch;
        text-align:left;
        padding:14px;
    }
    .wp-auth-stat-value{
        font-size:22px;
    }
    .wp-auth-card{
        padding:34px 22px 30px;
    }
    .wp-auth-card h1{
        margin-top:22px;
        font-size:34px;
    }
    .wp-auth-intro{
        font-size:14px;
        margin-bottom:24px;
    }
}
@media(max-width:420px){
    .wp-auth-modern-page{
        padding:10px;
    }
    .wp-auth-modern-shell{
        border-radius:22px;
    }
    .wp-auth-hero{
        padding:22px 16px 36px;
    }
    .wp-auth-brand-name{
        font-size:17px;
    }
    .wp-auth-brand-sub{
        font-size:11px;
    }
    .wp-auth-title{
        font-size:37px;
        letter-spacing:-.045em;
    }
    .wp-auth-card{
        padding:30px 16px 26px;
    }
    .wp-auth-input-wrap input{
        height:54px;
        border-radius:14px;
    }
    .wp-auth-submit{
        height:56px;
        border-radius:14px;
    }
}



/* =========================================================
   WORKERPRO BERANDA MODERN FIX - APPENDED
   ========================================================= */
.wp-home-page{
  min-height:100vh;
  padding-bottom:94px;
  background:
    radial-gradient(circle at 12% 0%, rgba(124,58,237,.14), transparent 28%),
    radial-gradient(circle at 90% 10%, rgba(37,99,235,.12), transparent 28%),
    linear-gradient(180deg,#f5f3ff 0%,#f8fafc 360px,#f6f7fb 100%);
  color:#0f172a;
  overflow-x:hidden;
}
.wp-home-hero{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 9% 24%, rgba(255,255,255,.22), transparent 18%),
    radial-gradient(circle at 86% 20%, rgba(255,255,255,.16), transparent 18%),
    linear-gradient(135deg,#1d4ed8 0%,#5b21b6 48%,#9333ea 100%);
  color:#fff;
  padding:28px 18px 48px;
  isolation:isolate;
}
.wp-home-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.07) 1px, transparent 1px);
  background-size:54px 54px;
  mask-image:linear-gradient(180deg,#000,transparent 90%);
  opacity:.45;
  pointer-events:none;
}
.wp-home-bg-orb{
  position:absolute;
  width:360px;
  height:360px;
  border-radius:999px;
  filter:blur(8px);
  pointer-events:none;
  opacity:.18;
  z-index:-1;
}
.wp-home-bg-orb-one{
  left:-120px;
  top:80px;
  background:#fff;
}
.wp-home-bg-orb-two{
  right:-110px;
  bottom:-130px;
  background:#fb7185;
}
.wp-home-shell,
.wp-home-container{
  width:min(1440px, calc(100vw - 48px));
  margin:0 auto;
  position:relative;
  z-index:1;
}
.wp-home-topbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:18px;
  margin-bottom:38px;
}
.wp-home-brand{
  display:flex;
  align-items:center;
  gap:14px;
}
.wp-home-brand-mark{
  width:52px;
  height:52px;
  border-radius:18px;
  display:grid;
  place-items:center;
  color:#fff;
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.22);
  box-shadow:0 18px 44px rgba(15,23,42,.18);
  backdrop-filter:blur(12px);
}
.wp-home-brand-mark svg,
.wp-home-brand-mark [data-lucide]{
  width:26px !important;
  height:26px !important;
  stroke:#fff !important;
}
.wp-home-brand h1{
  margin:0;
  font-size:24px;
  line-height:1;
  font-weight:900;
  letter-spacing:-.03em;
}
.wp-home-brand p{
  margin:6px 0 0;
  color:rgba(255,255,255,.78);
  font-size:13px;
  font-weight:650;
}
.wp-home-notif{
  position:relative !important;
  z-index:50 !important;
}
.wp-home-bell{
  width:48px;
  height:48px;
  border-radius:999px;
  display:grid !important;
  place-items:center;
  color:#fff;
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.20);
  cursor:pointer;
  backdrop-filter:blur(12px);
  box-shadow:0 14px 35px rgba(15,23,42,.16);
}
.wp-home-bell svg,
.wp-home-bell [data-lucide]{
  width:22px !important;
  height:22px !important;
  stroke:#fff !important;
}
.wp-home-bell .notif-dot{
  top:6px !important;
  right:6px !important;
  border-color:#5b21b6 !important;
}
.wp-home-hero-grid{
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(360px,470px);
  gap:28px;
  align-items:stretch;
}
.wp-home-copy{
  min-height:430px;
  padding:34px;
  border-radius:34px;
  background:linear-gradient(135deg,rgba(255,255,255,.18),rgba(255,255,255,.07));
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 26px 80px rgba(15,23,42,.20);
  backdrop-filter:blur(14px);
}
.wp-home-kicker{
  display:inline-flex;
  align-items:center;
  gap:9px;
  min-height:38px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.24);
  color:#fff;
  font-size:13px;
  font-weight:900;
  letter-spacing:.01em;
}
.wp-home-kicker svg,
.wp-home-kicker [data-lucide]{
  width:17px !important;
  height:17px !important;
  stroke:#fff !important;
}
.wp-home-copy h2{
  margin:28px 0 18px;
  max-width:850px;
  font-size:clamp(42px,5.2vw,76px);
  line-height:.98;
  letter-spacing:-.065em;
  font-weight:950;
}
.wp-home-copy p{
  max-width:780px;
  margin:0;
  color:rgba(255,255,255,.84);
  font-size:17px;
  line-height:1.7;
}
.wp-home-actions{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  margin-top:28px;
}
.wp-home-btn{
  min-height:54px;
  padding:0 22px;
  border-radius:16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:9px;
  font-size:15px;
  font-weight:900;
  transition:.22s ease;
}
.wp-home-btn-primary{
  background:#fff;
  color:#5b21b6;
  box-shadow:0 20px 45px rgba(15,23,42,.22);
}
.wp-home-btn-ghost{
  color:#fff;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.22);
}
.wp-home-btn svg,
.wp-home-btn [data-lucide]{
  width:19px !important;
  height:19px !important;
}
.wp-home-btn-primary svg,
.wp-home-btn-primary [data-lucide]{
  stroke:#5b21b6 !important;
}
.wp-home-stats{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:12px;
  margin-top:34px;
}
.wp-home-stat-card{
  min-height:112px;
  border-radius:22px;
  padding:18px;
  background:rgba(255,255,255,.13);
  border:1px solid rgba(255,255,255,.16);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18);
}
.wp-home-stat-card svg,
.wp-home-stat-card [data-lucide]{
  width:24px !important;
  height:24px !important;
  stroke:#fff !important;
  margin-bottom:13px;
}
.wp-home-stat-card b{
  display:block;
  font-size:26px;
  line-height:1;
  font-weight:950;
  letter-spacing:-.03em;
}
.wp-home-stat-card span{
  display:block;
  margin-top:6px;
  color:rgba(255,255,255,.76);
  font-size:13px;
  font-weight:650;
}
.wp-home-progress-card{
  border-radius:34px;
  background:rgba(255,255,255,.96);
  color:#101828;
  padding:30px;
  box-shadow:0 28px 90px rgba(15,23,42,.22);
  border:1px solid rgba(255,255,255,.50);
  align-self:stretch;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.wp-home-card-label{
  width:max-content;
  padding:9px 13px;
  border-radius:999px;
  background:#f3e8ff;
  color:#7c3aed;
  font-size:12px;
  font-weight:900;
  margin-bottom:20px;
}
.wp-home-progress-card h3{
  margin:0;
  font-size:34px;
  line-height:1.05;
  letter-spacing:-.05em;
  font-weight:950;
}
.wp-home-progress-card p{
  margin:12px 0 0;
  color:#64748b;
  line-height:1.65;
  font-size:14px;
}
.wp-home-progress-meter{
  display:flex;
  align-items:center;
  gap:16px;
  margin:26px 0 22px;
  padding:16px;
  border-radius:22px;
  background:linear-gradient(135deg,#faf5ff,#eff6ff);
  border:1px solid #e9d5ff;
}
.wp-home-progress-circle{
  width:74px;
  height:74px;
  border-radius:50%;
  display:grid;
  place-items:center;
  flex:0 0 74px;
  background:
    radial-gradient(circle at center,#fff 55%,transparent 57%),
    conic-gradient(#7c3aed 0 68%,#e9d5ff 68% 100%);
  color:#6d28d9;
  font-weight:950;
  box-shadow:0 10px 24px rgba(124,58,237,.18);
}
.wp-home-progress-meter b{
  display:block;
  color:#111827;
  font-size:16px;
  margin-bottom:4px;
}
.wp-home-progress-meter span{
  color:#64748b;
  font-size:13px;
}
.wp-home-task-list{
  display:grid;
  gap:10px;
}
.wp-home-task-list a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  min-height:54px;
  padding:0 14px;
  border-radius:16px;
  background:#fff;
  border:1px solid #e7eaf0;
  color:#334155;
  font-weight:800;
  transition:.2s ease;
}
.wp-home-task-list span{
  display:flex;
  align-items:center;
  gap:10px;
}
.wp-home-task-list svg,
.wp-home-task-list [data-lucide]{
  width:20px !important;
  height:20px !important;
  color:#7c3aed;
  stroke:#7c3aed;
}
.wp-home-container{
  padding:34px 0 38px;
}
.wp-home-section-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:18px;
  margin-bottom:18px;
}
.wp-home-section-head span,
.wp-home-panel-title span{
  display:inline-block;
  color:#7c3aed;
  font-size:13px;
  font-weight:950;
  letter-spacing:.08em;
  text-transform:uppercase;
  margin-bottom:8px;
}
.wp-home-section-head h2,
.wp-home-panel-title h2{
  margin:0;
  color:#0f172a;
  font-size:clamp(24px,3vw,38px);
  line-height:1.1;
  letter-spacing:-.04em;
  font-weight:950;
}
.wp-home-section-head a{
  flex:0 0 auto;
  min-height:44px;
  padding:0 16px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:#6d28d9;
  background:#f3e8ff;
  border:1px solid #e9d5ff;
  font-size:14px;
  font-weight:900;
}
.wp-home-feature-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
  margin-bottom:18px;
}
.wp-home-feature-card{
  position:relative;
  overflow:hidden;
  min-height:245px;
  padding:22px;
  border-radius:26px;
  background:#fff;
  border:1px solid #e6e9f2;
  box-shadow:0 16px 42px rgba(15,23,42,.07);
  transition:.22s ease;
}
.wp-home-feature-card::before{
  content:"";
  position:absolute;
  inset:auto -30% -45% -30%;
  height:120px;
  background:var(--feature-glow,#dbeafe);
  filter:blur(38px);
  opacity:.8;
  pointer-events:none;
}
.wp-home-feature-icon{
  width:58px;
  height:58px;
  border-radius:18px;
  display:grid;
  place-items:center;
  color:#fff;
  background:var(--feature-color,#2563eb);
  box-shadow:0 12px 28px var(--feature-shadow,rgba(37,99,235,.22));
  position:relative;
  z-index:1;
}
.wp-home-feature-icon svg,
.wp-home-feature-icon [data-lucide]{
  width:27px !important;
  height:27px !important;
  stroke:#fff !important;
}
.wp-home-feature-card h3{
  position:relative;
  z-index:1;
  margin:24px 0 8px;
  color:#111827;
  font-size:20px;
  letter-spacing:-.02em;
}
.wp-home-feature-card p{
  position:relative;
  z-index:1;
  margin:0;
  color:#64748b;
  line-height:1.55;
  font-size:14px;
}
.wp-home-feature-card > span{
  position:absolute;
  left:22px;
  bottom:20px;
  display:inline-flex;
  align-items:center;
  gap:7px;
  color:var(--feature-color,#2563eb);
  font-size:14px;
  font-weight:950;
}
.wp-home-feature-card > span svg,
.wp-home-feature-card > span [data-lucide]{
  width:16px !important;
  height:16px !important;
  stroke:currentColor !important;
}
.wp-card-blue{--feature-color:#2563eb;--feature-glow:#dbeafe;--feature-shadow:rgba(37,99,235,.25)}
.wp-card-green{--feature-color:#10b981;--feature-glow:#d1fae5;--feature-shadow:rgba(16,185,129,.25)}
.wp-card-purple{--feature-color:#8b5cf6;--feature-glow:#ede9fe;--feature-shadow:rgba(139,92,246,.25)}
.wp-card-orange{--feature-color:#f97316;--feature-glow:#ffedd5;--feature-shadow:rgba(249,115,22,.25)}
.wp-home-lower-grid{
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr);
  gap:16px;
  align-items:stretch;
}
.wp-home-panel,
.wp-home-cta-modern{
  border-radius:30px;
  border:1px solid #e6e9f2;
  background:rgba(255,255,255,.86);
  box-shadow:0 16px 42px rgba(15,23,42,.06);
}
.wp-home-panel{
  padding:24px;
}
.wp-home-benefit-list{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  margin-top:20px;
}
.wp-home-benefit-item{
  min-height:170px;
  padding:18px;
  border-radius:22px;
  background:#f8fafc;
  border:1px solid #e6e9f2;
}
.wp-home-benefit-item > div{
  width:46px;
  height:46px;
  border-radius:16px;
  display:grid;
  place-items:center;
  color:#7c3aed;
  background:#f3e8ff;
  margin-bottom:16px;
}
.wp-home-benefit-item svg,
.wp-home-benefit-item [data-lucide]{
  width:22px !important;
  height:22px !important;
  stroke:#7c3aed !important;
}
.wp-home-benefit-item h3{
  margin:0 0 8px;
  color:#111827;
  font-size:17px;
}
.wp-home-benefit-item p{
  margin:0;
  color:#64748b;
  line-height:1.55;
  font-size:13px;
}
.wp-home-cta-modern{
  position:relative;
  overflow:hidden;
  padding:28px;
  color:#fff;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,.20), transparent 34%),
    linear-gradient(135deg,#f97316,#ec4899 45%,#7c3aed);
  border:0;
  display:flex;
  flex-direction:column;
  justify-content:center;
  min-height:300px;
}
.wp-home-cta-modern::after{
  content:"";
  position:absolute;
  right:-68px;
  bottom:-68px;
  width:180px;
  height:180px;
  border-radius:999px;
  background:rgba(255,255,255,.18);
}
.wp-home-cta-icon{
  width:58px;
  height:58px;
  border-radius:20px;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.24);
  margin-bottom:20px;
}
.wp-home-cta-icon svg,
.wp-home-cta-icon [data-lucide]{
  width:28px !important;
  height:28px !important;
  stroke:#fff !important;
}
.wp-home-cta-modern h2{
  margin:0;
  font-size:32px;
  line-height:1.05;
  letter-spacing:-.04em;
}
.wp-home-cta-modern p{
  margin:12px 0 24px;
  color:rgba(255,255,255,.86);
  line-height:1.6;
}
.wp-home-cta-modern a{
  width:100%;
  min-height:54px;
  border-radius:16px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#fff;
  color:#7c3aed;
  font-weight:950;
  box-shadow:0 18px 42px rgba(15,23,42,.18);
}
@media(hover:hover){
  .wp-home-btn:hover,
  .wp-home-section-head a:hover,
  .wp-home-task-list a:hover,
  .wp-home-feature-card:hover,
  .wp-home-cta-modern a:hover{
    transform:translateY(-3px);
  }
  .wp-home-feature-card:hover{
    box-shadow:0 24px 60px rgba(15,23,42,.10);
    border-color:#ddd6fe;
  }
}
@media(max-width:1180px){
  .wp-home-hero-grid{
    grid-template-columns:1fr;
  }
  .wp-home-copy{
    min-height:auto;
  }
  .wp-home-progress-card{
    max-width:none;
  }
  .wp-home-feature-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .wp-home-lower-grid{
    grid-template-columns:1fr;
  }
}
@media(max-width:760px){
  .wp-home-page{
    padding-bottom:88px;
    background:linear-gradient(180deg,#f5f3ff 0%,#f8fafc 280px,#f6f7fb 100%);
  }
  .wp-home-hero{
    padding:18px 14px 30px;
    border-bottom-left-radius:28px;
    border-bottom-right-radius:28px;
  }
  .wp-home-shell,
  .wp-home-container{
    width:min(100%, calc(100vw - 24px));
  }
  .wp-home-topbar{
    margin-bottom:18px;
  }
  .wp-home-brand-mark{
    width:46px;
    height:46px;
    border-radius:16px;
  }
  .wp-home-brand h1{
    font-size:19px;
  }
  .wp-home-brand p{
    font-size:11px;
  }
  .wp-home-bell{
    width:44px;
    height:44px;
  }
  .wp-home-copy{
    padding:22px;
    border-radius:26px;
  }
  .wp-home-kicker{
    font-size:12px;
    min-height:34px;
    padding:0 12px;
  }
  .wp-home-copy h2{
    margin-top:22px;
    font-size:clamp(34px,11vw,48px);
    line-height:1.03;
  }
  .wp-home-copy p{
    font-size:14px;
    line-height:1.65;
  }
  .wp-home-actions{
    display:grid;
    grid-template-columns:1fr;
  }
  .wp-home-btn{
    width:100%;
  }
  .wp-home-stats{
    grid-template-columns:1fr;
    gap:10px;
  }
  .wp-home-stat-card{
    min-height:82px;
    display:grid;
    grid-template-columns:42px 1fr;
    align-items:center;
    column-gap:12px;
    padding:14px;
  }
  .wp-home-stat-card svg,
  .wp-home-stat-card [data-lucide]{
    margin:0;
  }
  .wp-home-stat-card span{
    margin-top:4px;
  }
  .wp-home-progress-card{
    border-radius:26px;
    padding:22px;
  }
  .wp-home-progress-card h3{
    font-size:28px;
  }
  .wp-home-progress-meter{
    align-items:flex-start;
  }
  .wp-home-progress-circle{
    width:64px;
    height:64px;
    flex-basis:64px;
  }
  .wp-home-container{
    padding-top:24px;
  }
  .wp-home-section-head{
    align-items:flex-start;
    flex-direction:column;
  }
  .wp-home-section-head a{
    width:100%;
  }
  .wp-home-feature-grid,
  .wp-home-benefit-list{
    grid-template-columns:1fr;
  }
  .wp-home-feature-card{
    min-height:210px;
    border-radius:24px;
  }
  .wp-home-panel,
  .wp-home-cta-modern{
    border-radius:26px;
    padding:20px;
  }
  .wp-home-benefit-item{
    min-height:auto;
    display:grid;
    grid-template-columns:48px 1fr;
    gap:14px;
    align-items:flex-start;
  }
  .wp-home-benefit-item > div{
    margin:0;
  }
  .wp-home-cta-modern{
    min-height:260px;
  }
  .wp-home-cta-modern h2{
    font-size:28px;
  }
  .wp-home-notif .notif-popup{
    position:fixed !important;
    top:76px !important;
    left:12px !important;
    right:12px !important;
    width:auto !important;
  }
}
@media(max-width:390px){
  .wp-home-copy,
  .wp-home-progress-card,
  .wp-home-panel,
  .wp-home-cta-modern{
    padding:18px;
  }
  .wp-home-copy h2{
    font-size:34px;
  }
  .wp-home-feature-card{
    padding:18px;
  }
}


/* WORKERPRO BERANDA BUTTON BUGFIX */
.wp-home-actions .wp-home-btn,
.wp-home-cta-modern a{
  position:relative !important;
  z-index:3 !important;
  overflow:visible !important;
  opacity:1 !important;
  visibility:visible !important;
  text-indent:0 !important;
  letter-spacing:normal !important;
  white-space:nowrap !important;
}
.wp-home-actions .wp-home-btn{
  min-width:180px !important;
  gap:10px !important;
  font-size:15px !important;
  line-height:1 !important;
}
.wp-home-actions .wp-home-btn-primary,
.wp-home-actions .wp-home-btn-primary .wp-home-btn-text{
  color:#6d28d9 !important;
}
.wp-home-actions .wp-home-btn-ghost,
.wp-home-actions .wp-home-btn-ghost .wp-home-btn-text{
  color:#ffffff !important;
}
.wp-home-btn-text,
.wp-home-cta-link-text{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  opacity:1 !important;
  visibility:visible !important;
  font-size:inherit !important;
  font-weight:950 !important;
  line-height:1 !important;
  color:inherit !important;
  width:auto !important;
  height:auto !important;
  max-width:none !important;
  overflow:visible !important;
}
.wp-home-cta-modern::after{
  z-index:0 !important;
  pointer-events:none !important;
}
.wp-home-cta-modern > *{
  position:relative !important;
  z-index:2 !important;
}
.wp-home-cta-modern a{
  color:#7c3aed !important;
  font-size:15px !important;
  font-weight:950 !important;
}
.wp-home-cta-modern a .wp-home-cta-link-text{
  color:#7c3aed !important;
}
@media(max-width:760px){
  .wp-home-actions .wp-home-btn{
    width:100% !important;
    min-width:0 !important;
  }
  .wp-home-actions .wp-home-btn .wp-home-btn-text{
    display:inline-flex !important;
  }
}


/* =========================================================
   PROFILE PAGE MODERN FALLBACK
   CSS utama profil juga tersedia inline di Blade agar aman dari cache.
   ========================================================= */
.wp-profile-page{background:#f6f7fb;}

/* =========================================================
   WORKERPRO BENEFITS MODERN SUPPORT
   Style utama juga ada inline di benefits/index.blade.php
   agar tetap tampil saat cache CSS hosting belum refresh.
   ========================================================= */
.wp-benefits-page{min-height:100vh;padding-bottom:98px;background:#f6f7fb;}
.wp-benefits-header{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.86);backdrop-filter:blur(18px);border-bottom:1px solid rgba(226,232,240,.86);}
.wp-benefits-header-inner,.wp-benefits-main{width:min(1440px,calc(100vw - 48px));margin-left:auto;margin-right:auto;}
.wp-benefits-header-inner{height:78px;display:flex;align-items:center;gap:16px;}
.wp-benefits-back{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:#fff;border:1px solid #e7eaf0;text-decoration:none;}
@media(max-width:760px){.wp-benefits-header-inner,.wp-benefits-main{width:min(100%,calc(100vw - 24px));}.wp-benefits-header-inner{height:72px;}}



/* BENEFITS HERO TEXT PRECISION FIX - teks kiri dibuat lebih tengah dan presisi */
.wp-benefits-hero{
  align-items:center !important;
  min-height:430px !important;
}
.wp-benefits-hero-copy{
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
  min-height:360px !important;
  padding:18px 8px 18px 0 !important;
}
.wp-benefits-hero-copy .wp-benefits-kicker{
  margin-bottom:4px !important;
}
.wp-benefits-hero-copy h2{
  margin-top:24px !important;
  margin-bottom:18px !important;
}
.wp-benefits-hero-copy p{
  max-width:820px !important;
}
.wp-benefits-hero-actions{
  margin-top:30px !important;
}
@media(min-width:1181px){
  .wp-benefits-hero{
    padding:34px 34px 34px 42px !important;
  }
  .wp-benefits-hero-copy{
    padding-left:0 !important;
    transform:translateY(8px) !important;
  }
}
@media(max-width:1180px){
  .wp-benefits-hero{
    min-height:auto !important;
  }
  .wp-benefits-hero-copy{
    min-height:0 !important;
    padding:8px 0 10px !important;
    transform:none !important;
  }
}
@media(max-width:760px){
  .wp-benefits-hero{
    padding:22px !important;
    align-items:start !important;
  }
  .wp-benefits-hero-copy h2{
    margin-top:20px !important;
    margin-bottom:14px !important;
  }
  .wp-benefits-hero-actions{
    margin-top:22px !important;
  }
}



/* =========================================================
   BENEFITS SLIDER ARROW BUTTON REMOVAL
   Hilangkan semua tombol panah slider ungu. Swipe/scroll dan dot tetap aktif.
   ========================================================= */
.wp-benefits-slider-arrows,
.wp-benefits-card-arrows,
.wp-benefits-slider-btn,
[data-benefit-prev],
[data-benefit-next]{
  display:none !important;
  visibility:hidden !important;
  opacity:0 !important;
  pointer-events:none !important;
}

.wp-benefits-slider-head{
  justify-content:flex-start !important;
}

.wp-benefits-section-head{
  align-items:flex-end !important;
}
/* =========================================================
   WORKERPRO JOBS MODERN UI
   Scoped untuk halaman Cari Pekerjaan, Lamaran Saya, dan Form Lamaran
   ========================================================= */
html,body{overflow-x:hidden!important;}
.wp-jobs-page,.wp-jobs-page *{box-sizing:border-box;}
.wp-jobs-page{min-height:100vh;padding-bottom:96px;background:radial-gradient(circle at 10% 0%,rgba(124,58,237,.13),transparent 30%),radial-gradient(circle at 92% 8%,rgba(37,99,235,.10),transparent 30%),linear-gradient(180deg,#f5f3ff 0%,#f8fafc 330px,#f6f7fb 100%);color:#0f172a;font-family:Inter,Arial,sans-serif;}
.wp-jobs-shell{width:min(1440px,calc(100vw - 48px));margin:0 auto;}
.wp-jobs-header{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.82);backdrop-filter:blur(16px);border-bottom:1px solid rgba(226,232,240,.88);}
.wp-jobs-header-inner{width:min(1440px,calc(100vw - 48px));height:76px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:18px;}
.wp-jobs-head-left{display:flex;align-items:center;gap:14px;min-width:0;}
.wp-jobs-back{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:#fff;border:1px solid #e6e9f2;color:#111827;font-size:28px;font-weight:800;box-shadow:0 10px 24px rgba(15,23,42,.06);transition:.2s ease;}
.wp-jobs-back:hover{transform:translateY(-1px);color:#7c3aed;border-color:#ddd6fe;}
.wp-jobs-header h1{margin:0;font-size:24px;line-height:1;font-weight:950;letter-spacing:-.035em;}
.wp-jobs-header p{margin:5px 0 0;color:#64748b;font-size:13px;font-weight:650;}
.wp-jobs-header-badge{display:inline-flex;align-items:center;gap:8px;min-height:38px;padding:0 14px;border-radius:999px;background:#f3e8ff;color:#7c3aed;border:1px solid #e9d5ff;font-size:13px;font-weight:900;white-space:nowrap;}
.wp-jobs-header-badge svg,.wp-jobs-header-badge [data-lucide]{width:17px!important;height:17px!important;stroke:#7c3aed!important;}
.wp-jobs-hero{position:relative;overflow:hidden;margin:28px 0 20px;padding:30px;border-radius:34px;color:#fff;background:linear-gradient(135deg,#2563eb 0%,#5b21b6 48%,#a21caf 100%);box-shadow:0 28px 80px rgba(79,70,229,.22);isolation:isolate;}
.wp-jobs-hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.07) 1px,transparent 1px);background-size:52px 52px;opacity:.55;pointer-events:none;}
.wp-jobs-hero::after{content:"";position:absolute;width:260px;height:260px;border-radius:999px;right:-90px;bottom:-110px;background:rgba(255,255,255,.18);pointer-events:none;}
.wp-jobs-hero-content{position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,410px);gap:24px;align-items:center;}
.wp-jobs-kicker{display:inline-flex;align-items:center;gap:8px;width:max-content;min-height:36px;padding:0 13px;border-radius:999px;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.22);font-size:13px;font-weight:900;}
.wp-jobs-kicker svg,.wp-jobs-kicker [data-lucide]{width:17px!important;height:17px!important;stroke:#fff!important;}
.wp-jobs-hero h2{margin:18px 0 12px;font-size:clamp(38px,5vw,68px);line-height:.98;letter-spacing:-.065em;font-weight:950;max-width:850px;}
.wp-jobs-hero p{margin:0;color:rgba(255,255,255,.86);font-size:16px;line-height:1.65;max-width:700px;}
.wp-jobs-hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px;}
.wp-jobs-btn{min-height:52px;padding:0 20px;border:0;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;gap:9px;font-weight:950;font-size:15px;cursor:pointer;text-decoration:none;transition:.2s ease;}
.wp-jobs-btn-primary{background:#fff;color:#6d28d9;box-shadow:0 18px 40px rgba(15,23,42,.18);}
.wp-jobs-btn-ghost{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.24);color:#fff;}
.wp-jobs-btn-blue{background:linear-gradient(90deg,#2563eb,#7c3aed);color:#fff;box-shadow:0 16px 36px rgba(37,99,235,.22);}
.wp-jobs-btn svg,.wp-jobs-btn [data-lucide]{width:18px!important;height:18px!important;}
.wp-jobs-btn-primary svg,.wp-jobs-btn-primary [data-lucide]{stroke:#6d28d9!important;}
.wp-jobs-hero-card{position:relative;z-index:2;border-radius:28px;padding:24px;background:rgba(255,255,255,.95);color:#0f172a;box-shadow:0 22px 55px rgba(15,23,42,.18);border:1px solid rgba(255,255,255,.55);}
.wp-jobs-hero-icon{width:56px;height:56px;border-radius:18px;display:grid;place-items:center;background:#f3e8ff;color:#7c3aed;margin-bottom:18px;}
.wp-jobs-hero-icon svg,.wp-jobs-hero-icon [data-lucide]{width:27px!important;height:27px!important;stroke:#7c3aed!important;}
.wp-jobs-hero-card h3{margin:0 0 8px;font-size:22px;letter-spacing:-.03em;font-weight:950;}
.wp-jobs-hero-card p{color:#64748b;font-size:14px;line-height:1.55;}
.wp-jobs-mini-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:18px;}
.wp-jobs-mini-stat{border-radius:18px;background:#f8fafc;border:1px solid #e6e9f2;padding:14px;}
.wp-jobs-mini-stat b{display:block;color:#111827;font-size:20px;font-weight:950;}
.wp-jobs-mini-stat span{display:block;margin-top:4px;color:#64748b;font-size:12px;font-weight:800;}
.wp-jobs-tabs{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:0 0 16px;}
.wp-jobs-tabs a{min-height:54px;border-radius:18px;display:flex;align-items:center;justify-content:center;gap:8px;background:#fff;border:1px solid #e6e9f2;color:#64748b;font-weight:900;text-decoration:none;box-shadow:0 12px 32px rgba(15,23,42,.05);transition:.2s ease;}
.wp-jobs-tabs a.active{background:linear-gradient(90deg,#2563eb,#7c3aed);color:#fff;border-color:transparent;box-shadow:0 18px 42px rgba(37,99,235,.20);}
.wp-jobs-tabs svg,.wp-jobs-tabs [data-lucide]{width:18px!important;height:18px!important;}
.wp-jobs-tabs a.active svg,.wp-jobs-tabs a.active [data-lucide]{stroke:#fff!important;}
.wp-jobs-panel{border-radius:28px;background:rgba(255,255,255,.92);border:1px solid #e6e9f2;box-shadow:0 18px 48px rgba(15,23,42,.07);padding:24px;margin-bottom:18px;}
.wp-jobs-panel-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:18px;}
.wp-jobs-panel-head h3{margin:0;color:#111827;font-size:22px;letter-spacing:-.03em;font-weight:950;}
.wp-jobs-panel-head p{margin:6px 0 0;color:#64748b;line-height:1.55;font-size:14px;}
.wp-jobs-skill-form{display:flex;gap:10px;margin-bottom:16px;}
.wp-jobs-input,.wp-jobs-textarea,.wp-jobs-file{width:100%;min-height:54px;border:1px solid #d8e0ea;border-radius:16px;background:#fff;padding:0 16px;color:#0f172a;font-size:14px;outline:none;transition:.18s ease;}
.wp-jobs-textarea{min-height:126px;padding:14px 16px;resize:vertical;line-height:1.55;}
.wp-jobs-input:focus,.wp-jobs-textarea:focus,.wp-jobs-file:focus{border-color:#a78bfa;box-shadow:0 0 0 4px rgba(124,58,237,.12);}
.wp-jobs-add-btn{width:54px;height:54px;border:0;border-radius:16px;display:grid;place-items:center;background:#2563eb;color:#fff;flex:0 0 54px;cursor:pointer;box-shadow:0 12px 28px rgba(37,99,235,.22);}
.wp-jobs-add-btn svg,.wp-jobs-add-btn [data-lucide]{width:22px!important;height:22px!important;stroke:#fff!important;}
.wp-jobs-chip-title{margin:10px 0 10px;color:#64748b;font-size:13px;font-weight:850;}
.wp-jobs-chip-wrap{display:flex;align-items:center;flex-wrap:wrap;gap:9px;}
.wp-jobs-chip-form{display:inline-flex;margin:0;padding:0;}
.wp-jobs-chip,.wp-jobs-chip-btn{min-height:36px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 13px;border:1px solid #dbe3ee;background:#fff;color:#334155;font-size:13px;font-weight:850;cursor:pointer;transition:.18s ease;}
.wp-jobs-chip-btn:hover,.wp-jobs-chip:hover{transform:translateY(-1px);border-color:#c4b5fd;background:#faf5ff;color:#6d28d9;}
.wp-jobs-chip-active{background:#f3e8ff!important;border-color:#e9d5ff!important;color:#6d28d9!important;}
.wp-jobs-search-submit{width:100%;margin-top:14px;}
.wp-jobs-results-head{display:flex;justify-content:space-between;align-items:flex-end;gap:14px;margin:24px 0 14px;}
.wp-jobs-results-head h3{margin:0;font-size:26px;letter-spacing:-.04em;font-weight:950;}
.wp-jobs-results-head p{margin:5px 0 0;color:#64748b;}
.wp-jobs-results-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;}
.wp-jobs-card{position:relative;overflow:hidden;border-radius:26px;padding:22px;background:#fff;border:1px solid #e6e9f2;box-shadow:0 16px 42px rgba(15,23,42,.07);transition:.22s ease;}
.wp-jobs-card::before{content:"";position:absolute;right:-50px;top:-50px;width:160px;height:160px;border-radius:999px;background:#f3e8ff;opacity:.9;pointer-events:none;}
.wp-jobs-card-top{position:relative;z-index:1;display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:16px;}
.wp-jobs-card-icon{width:52px;height:52px;border-radius:18px;background:linear-gradient(135deg,#2563eb,#7c3aed);display:grid;place-items:center;color:#fff;box-shadow:0 12px 28px rgba(37,99,235,.22);flex:0 0 52px;}
.wp-jobs-card-icon svg,.wp-jobs-card-icon [data-lucide]{width:24px!important;height:24px!important;stroke:#fff!important;}
.wp-jobs-card h3{position:relative;z-index:1;margin:0 0 8px;color:#111827;font-size:20px;line-height:1.2;letter-spacing:-.025em;font-weight:950;}
.wp-jobs-meta{position:relative;z-index:1;display:flex;flex-wrap:wrap;gap:8px 12px;margin:0 0 12px;color:#64748b;font-size:14px;}
.wp-jobs-meta span{display:inline-flex;align-items:center;gap:6px;}
.wp-jobs-meta svg,.wp-jobs-meta [data-lucide]{width:15px!important;height:15px!important;stroke:#64748b!important;}
.wp-jobs-salary{position:relative;z-index:1;margin:0 0 14px;color:#15803d;font-size:17px;font-weight:950;}
.wp-jobs-tag-wrap{position:relative;z-index:1;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;}
.wp-jobs-tag{display:inline-flex;align-items:center;min-height:30px;padding:0 10px;border-radius:999px;background:#f8fafc;border:1px solid #e6e9f2;color:#475569;font-size:12px;font-weight:850;}
.wp-jobs-card form{position:relative;z-index:1;margin-top:12px;}
.wp-jobs-empty{border-radius:30px;min-height:260px;display:grid;place-items:center;text-align:center;background:linear-gradient(135deg,#eff6ff,#faf5ff);border:1px solid #bfdbfe;box-shadow:0 16px 42px rgba(37,99,235,.08);padding:34px;margin-top:18px;}
.wp-jobs-empty-icon{width:72px;height:72px;border-radius:24px;display:grid;place-items:center;margin:0 auto 18px;background:#fff;color:#2563eb;box-shadow:0 12px 30px rgba(37,99,235,.13);}
.wp-jobs-empty-icon svg,.wp-jobs-empty-icon [data-lucide]{width:34px!important;height:34px!important;stroke:#2563eb!important;}
.wp-jobs-empty h3{margin:0 0 8px;font-size:24px;letter-spacing:-.03em;}
.wp-jobs-empty p{margin:0;color:#64748b;line-height:1.6;}
.wp-jobs-app-card{border-radius:24px;padding:20px;background:#fff;border:1px solid #e6e9f2;box-shadow:0 15px 38px rgba(15,23,42,.06);margin-bottom:14px;}
.wp-jobs-app-main{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;}
.wp-jobs-status{min-height:34px;border-radius:999px;padding:0 12px;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:950;white-space:nowrap;}
.wp-jobs-status-diproses{background:#fff7ed;color:#f97316;border:1px solid #fed7aa;}
.wp-jobs-status-diterima{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0;}
.wp-jobs-status-ditolak{background:#fef2f2;color:#dc2626;border:1px solid #fecaca;}
.wp-jobs-apply-grid{display:grid;grid-template-columns:minmax(320px,.72fr) minmax(0,1.28fr);gap:18px;align-items:start;}
.wp-jobs-summary-card{position:sticky;top:96px;border-radius:30px;padding:24px;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;box-shadow:0 24px 70px rgba(79,70,229,.22);overflow:hidden;}
.wp-jobs-summary-card::after{content:"";position:absolute;right:-55px;bottom:-70px;width:180px;height:180px;border-radius:999px;background:rgba(255,255,255,.18);}
.wp-jobs-summary-card > *{position:relative;z-index:1;}
.wp-jobs-summary-card h2{margin:0 0 10px;font-size:28px;line-height:1.08;letter-spacing:-.04em;}
.wp-jobs-summary-card p{margin:0 0 10px;color:rgba(255,255,255,.84);}
.wp-jobs-summary-card b{font-size:17px;}
.wp-jobs-form-card{border-radius:30px;background:#fff;border:1px solid #e6e9f2;box-shadow:0 18px 48px rgba(15,23,42,.07);padding:24px;}
.wp-jobs-form-title{display:flex;align-items:center;gap:12px;margin-bottom:20px;}
.wp-jobs-form-title div{width:50px;height:50px;border-radius:18px;display:grid;place-items:center;background:#f3e8ff;color:#7c3aed;}
.wp-jobs-form-title svg,.wp-jobs-form-title [data-lucide]{width:24px!important;height:24px!important;stroke:#7c3aed!important;}
.wp-jobs-form-title h3{margin:0;font-size:23px;font-weight:950;letter-spacing:-.03em;}
.wp-jobs-form-title p{margin:4px 0 0;color:#64748b;font-size:13px;}
.wp-jobs-field{margin-bottom:14px;}
.wp-jobs-field label{display:block;margin:0 0 7px;color:#0f172a;font-size:13px;font-weight:900;}
.wp-jobs-help{margin:8px 0 0;color:#64748b;font-size:12px;line-height:1.5;}
@media(hover:hover){.wp-jobs-btn:hover,.wp-jobs-tabs a:hover,.wp-jobs-card:hover,.wp-jobs-app-card:hover{transform:translateY(-3px)}.wp-jobs-card:hover,.wp-jobs-app-card:hover{box-shadow:0 24px 62px rgba(15,23,42,.10);border-color:#ddd6fe;}}
@media(max-width:1180px){.wp-jobs-hero-content,.wp-jobs-apply-grid{grid-template-columns:1fr}.wp-jobs-summary-card{position:relative;top:auto}.wp-jobs-results-grid{grid-template-columns:1fr}.wp-jobs-hero-card{max-width:none}.wp-jobs-feature-grid{grid-template-columns:1fr 1fr}}
@media(max-width:760px){.wp-jobs-page{padding-bottom:88px}.wp-jobs-shell,.wp-jobs-header-inner{width:min(100%,calc(100vw - 24px))}.wp-jobs-header-inner{height:70px}.wp-jobs-header h1{font-size:20px}.wp-jobs-header-badge{display:none}.wp-jobs-back{width:38px;height:38px;border-radius:13px}.wp-jobs-hero{margin:16px 0 14px;padding:22px;border-radius:28px}.wp-jobs-hero h2{font-size:clamp(34px,11vw,46px);line-height:1.03}.wp-jobs-hero p{font-size:14px}.wp-jobs-hero-actions{display:grid;grid-template-columns:1fr}.wp-jobs-btn{width:100%}.wp-jobs-mini-stats{grid-template-columns:1fr}.wp-jobs-tabs{grid-template-columns:1fr;gap:9px}.wp-jobs-panel{padding:18px;border-radius:24px}.wp-jobs-panel-head{flex-direction:column}.wp-jobs-skill-form{align-items:stretch}.wp-jobs-results-head{align-items:flex-start;flex-direction:column}.wp-jobs-app-main{flex-direction:column}.wp-jobs-status{align-self:flex-start}.wp-jobs-empty{min-height:220px;padding:24px}.wp-jobs-card{padding:18px;border-radius:22px}.wp-jobs-summary-card,.wp-jobs-form-card{padding:20px;border-radius:24px}}
@media(max-width:390px){.wp-jobs-hero,.wp-jobs-panel,.wp-jobs-form-card,.wp-jobs-summary-card{padding:18px}.wp-jobs-chip,.wp-jobs-chip-btn{font-size:12px;padding:0 10px}.wp-jobs-card h3{font-size:18px}}

/* =========================================================
   WORKERPRO GLOBAL ANIMATION PACK
   Tambahkan di paling bawah public/css/workerpro.css
   ========================================================= */
:root{
  --wp-ease: cubic-bezier(.2,.8,.2,1);
  --wp-fast: .18s;
  --wp-normal: .35s;
  --wp-slow: .65s;
}

html{
  scroll-behavior:smooth;
}

body{
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

@keyframes wpAnimFadeUp{
  from{opacity:0;transform:translate3d(0,22px,0)}
  to{opacity:1;transform:translate3d(0,0,0)}
}

@keyframes wpAnimFadeDown{
  from{opacity:0;transform:translate3d(0,-18px,0)}
  to{opacity:1;transform:translate3d(0,0,0)}
}

@keyframes wpAnimFadeLeft{
  from{opacity:0;transform:translate3d(28px,0,0)}
  to{opacity:1;transform:translate3d(0,0,0)}
}

@keyframes wpAnimScaleIn{
  from{opacity:0;transform:scale(.965)}
  to{opacity:1;transform:scale(1)}
}

@keyframes wpAnimSoftPulse{
  0%,100%{transform:scale(1);opacity:1}
  50%{transform:scale(1.035);opacity:.92}
}

@keyframes wpAnimFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-7px)}
}

@keyframes wpAnimShimmer{
  0%{transform:translateX(-130%) skewX(-18deg)}
  100%{transform:translateX(230%) skewX(-18deg)}
}

@keyframes wpAnimGradientMove{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}

@keyframes wpAnimPop{
  0%{opacity:0;transform:scale(.94)}
  70%{transform:scale(1.025)}
  100%{opacity:1;transform:scale(1)}
}

@keyframes wpPageOverlayIn{
  from{opacity:0;transform:scaleX(0)}
  to{opacity:1;transform:scaleX(1)}
}

/* Page entrance */
body.wp-anim-ready main,
body.wp-anim-ready .page,
body.wp-anim-ready .auth-page,
body.wp-anim-ready .wp-home-page,
body.wp-anim-ready .wp-profile-page,
body.wp-anim-ready .wp-edit-page,
body.wp-anim-ready .wp-benefits-page,
body.wp-anim-ready .wp-jobs-page,
body.wp-anim-ready .wp-course-page{
  animation:wpAnimFadeUp .55s var(--wp-ease) both;
}

.header,
.wp-home-header,
.wp-jobs-header,
.wp-benefits-header,
.wp-profile-header,
.wp-edit-header,
.auth-card,
.auth-highlight{
  animation:wpAnimFadeDown .5s var(--wp-ease) both;
}

/* Global stagger cards */
.card,
.why-card,
.feature-card,
.module-card,
.job-card,
.benefit-card,
.question-card,
.progress-card,
.video-card,
.search-box,
.empty-search,
.lesson-row,
.certificate-modern,
.admin-profile-panel,
.admin-dashboard-card,
.admin-bpjs-card,
.wp-home-copy,
.wp-home-progress-card,
.wp-home-feature-card,
.wp-home-panel,
.wp-home-cta-modern,
.wp-profile-hero,
.wp-profile-card,
.wp-edit-form-card,
.wp-benefits-hero,
.wp-benefits-card,
.wp-benefits-summary-card,
.wp-jobs-panel,
.wp-jobs-card,
.wp-jobs-app-card,
.wp-jobs-form-card,
.wp-course-card,
.wp-course-panel,
.wp-course-question,
.notif-item{
  animation:wpAnimFadeUp .55s var(--wp-ease) both;
  will-change:transform,opacity;
}

.container > *:nth-child(1),
.wp-home-feature-grid > *:nth-child(1),
.wp-benefits-grid > *:nth-child(1),
.wp-jobs-results-grid > *:nth-child(1),
.features > *:nth-child(1),
.why-list > *:nth-child(1){animation-delay:.03s}
.container > *:nth-child(2),
.wp-home-feature-grid > *:nth-child(2),
.wp-benefits-grid > *:nth-child(2),
.wp-jobs-results-grid > *:nth-child(2),
.features > *:nth-child(2),
.why-list > *:nth-child(2){animation-delay:.08s}
.container > *:nth-child(3),
.wp-home-feature-grid > *:nth-child(3),
.wp-benefits-grid > *:nth-child(3),
.wp-jobs-results-grid > *:nth-child(3),
.features > *:nth-child(3),
.why-list > *:nth-child(3){animation-delay:.13s}
.container > *:nth-child(4),
.wp-home-feature-grid > *:nth-child(4),
.wp-benefits-grid > *:nth-child(4),
.wp-jobs-results-grid > *:nth-child(4),
.features > *:nth-child(4),
.why-list > *:nth-child(4){animation-delay:.18s}

/* Reveal on scroll */
.wp-reveal{
  opacity:0;
  transform:translateY(22px);
  transition:opacity .55s var(--wp-ease), transform .55s var(--wp-ease);
}
.wp-reveal.wp-inview{
  opacity:1;
  transform:translateY(0);
}

/* Modern hover motion */
@media(hover:hover){
  .card,
  .why-card,
  .feature-card,
  .module-card,
  .job-card,
  .benefit-card,
  .question-card,
  .progress-card,
  .video-card,
  .search-box,
  .lesson-row,
  .admin-profile-card,
  .admin-dashboard-card,
  .claim-empty-card,
  .claim-success-card,
  .wp-home-feature-card,
  .wp-home-panel,
  .wp-home-cta-modern,
  .wp-profile-card,
  .wp-edit-form-card,
  .wp-benefits-card,
  .wp-benefits-summary-card,
  .wp-jobs-card,
  .wp-jobs-app-card,
  .wp-jobs-panel,
  .wp-course-card,
  .wp-course-panel,
  .wp-course-question{
    transition:transform .26s var(--wp-ease), box-shadow .26s var(--wp-ease), border-color .26s var(--wp-ease), background .26s var(--wp-ease), filter .26s var(--wp-ease);
  }

  .card:hover,
  .why-card:hover,
  .feature-card:hover,
  .module-card:hover,
  .job-card:hover,
  .benefit-card:hover,
  .question-card:hover,
  .progress-card:hover,
  .video-card:hover,
  .search-box:hover,
  .lesson-row:hover,
  .admin-profile-card:hover,
  .admin-dashboard-card:hover,
  .claim-empty-card:hover,
  .claim-success-card:hover,
  .wp-home-feature-card:hover,
  .wp-home-panel:hover,
  .wp-profile-card:hover,
  .wp-edit-form-card:hover,
  .wp-benefits-card:hover,
  .wp-benefits-summary-card:hover,
  .wp-jobs-card:hover,
  .wp-jobs-app-card:hover,
  .wp-jobs-panel:hover,
  .wp-course-card:hover,
  .wp-course-panel:hover,
  .wp-course-question:hover{
    transform:translateY(-5px);
    box-shadow:0 24px 60px rgba(15,23,42,.11) !important;
  }
}

/* Button micro-interactions */
button,
.full-btn,
.small-btn,
.white-action,
.claim-btn,
.logout-profile-btn,
.google-login-btn,
.search-lowongan-btn,
.profile-skill-chip,
.chip-btn,
.tab,
.chip,
.badge,
.wp-home-btn,
.wp-jobs-btn,
.wp-jobs-add-btn,
.wp-benefits-btn,
.wp-course-btn,
.wp-edit-submit,
.wp-profile-action,
.wp-home-cta-modern a{
  transition:transform .18s var(--wp-ease), box-shadow .18s var(--wp-ease), background .18s var(--wp-ease), color .18s var(--wp-ease), border-color .18s var(--wp-ease), opacity .18s var(--wp-ease), filter .18s var(--wp-ease) !important;
}

@media(hover:hover){
  button:hover,
  .full-btn:hover,
  .small-btn:hover,
  .white-action:hover,
  .claim-btn:hover,
  .logout-profile-btn:hover,
  .google-login-btn:hover,
  .search-lowongan-btn:hover,
  .wp-home-btn:hover,
  .wp-jobs-btn:hover,
  .wp-jobs-add-btn:hover,
  .wp-benefits-btn:hover,
  .wp-course-btn:hover,
  .wp-edit-submit:hover,
  .wp-profile-action:hover,
  .wp-home-cta-modern a:hover{
    transform:translateY(-2px) scale(1.01);
    filter:saturate(1.04);
  }
}

button:active,
.full-btn:active,
.small-btn:active,
.white-action:active,
.claim-btn:active,
.logout-profile-btn:active,
.google-login-btn:active,
.search-lowongan-btn:active,
.wp-home-btn:active,
.wp-jobs-btn:active,
.wp-jobs-add-btn:active,
.wp-benefits-btn:active,
.wp-course-btn:active,
.wp-edit-submit:active,
.wp-profile-action:active,
.wp-home-cta-modern a:active{
  transform:scale(.975) !important;
}

/* Hero/CTA live gradient and shimmer */
.top-blue,
.hero-card,
.grad-panel,
.profile-hero,
.cta,
.quiz-result-hero,
.wp-home-hero,
.wp-home-copy,
.wp-home-cta-modern,
.wp-profile-hero,
.wp-edit-hero,
.wp-benefits-hero,
.wp-jobs-hero,
.wp-jobs-summary-card,
.auth-highlight,
.auth-page{
  background-size:180% 180%;
  animation-duration:.55s, 10s;
  animation-timing-function:var(--wp-ease), ease;
  animation-fill-mode:both;
}

.hero-card,
.grad-panel,
.profile-hero,
.cta,
.quiz-result-hero,
.wp-home-copy,
.wp-home-cta-modern,
.wp-profile-hero,
.wp-edit-hero,
.wp-benefits-hero,
.wp-jobs-hero,
.wp-jobs-summary-card{
  position:relative;
  overflow:hidden;
}

.hero-card::after,
.grad-panel::after,
.profile-hero::after,
.cta::after,
.quiz-result-hero::after,
.wp-home-copy::after,
.wp-home-cta-modern::before,
.wp-profile-hero::after,
.wp-edit-hero::after,
.wp-benefits-hero::after,
.wp-jobs-hero::after,
.wp-jobs-summary-card::before{
  content:"";
  position:absolute;
  top:-60%;
  left:-85%;
  width:42%;
  height:230%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.26),transparent);
  transform:skewX(-18deg);
  animation:wpAnimShimmer 6.5s ease-in-out infinite;
  pointer-events:none;
  z-index:1;
}

.hero-card > *,
.grad-panel > *,
.profile-hero > *,
.cta > *,
.quiz-result-hero > *,
.wp-home-copy > *,
.wp-home-cta-modern > *,
.wp-profile-hero > *,
.wp-edit-hero > *,
.wp-benefits-hero > *,
.wp-jobs-hero > *,
.wp-jobs-summary-card > *{
  position:relative;
  z-index:2;
}

/* Icons feel alive */
.brand-icon,
.ico,
.why-icon,
.feature-icon,
.module-icon,
.admin-card-icon,
.admin-dashboard-icon,
.claim-icon,
.wp-home-brand-mark,
.wp-home-feature-icon,
.wp-jobs-card-icon,
.wp-jobs-hero-icon,
.wp-benefits-icon,
.wp-profile-avatar,
.auth-logo{
  transition:transform .24s var(--wp-ease), box-shadow .24s var(--wp-ease), filter .24s var(--wp-ease) !important;
}

@media(hover:hover){
  .feature-card:hover .feature-icon,
  .why-card:hover .why-icon,
  .module-card:hover .module-icon,
  .wp-home-feature-card:hover .wp-home-feature-icon,
  .wp-jobs-card:hover .wp-jobs-card-icon,
  .wp-benefits-card:hover .wp-benefits-icon,
  .admin-profile-card:hover .admin-card-icon,
  .admin-dashboard-card:hover .admin-dashboard-icon{
    transform:translateY(-4px) scale(1.06) rotate(-1deg);
  }
}

/* Progress bars */
.progress-line span,
.wp-progress-fill,
.wp-home-progress-circle{
  transition:all .55s var(--wp-ease) !important;
}

.progress-line span{
  background-size:120px 100% !important;
  animation:wpProgressMove 2.8s linear infinite;
}

/* Form focus */
input,
textarea,
select,
.input,
.auth-card input,
.photo-input,
.wp-jobs-input,
.wp-jobs-textarea,
.wp-edit-input,
.wp-edit-textarea{
  transition:border-color .18s var(--wp-ease), box-shadow .18s var(--wp-ease), transform .18s var(--wp-ease), background .18s var(--wp-ease) !important;
}

input:focus,
textarea:focus,
select:focus,
.input:focus,
.auth-card input:focus,
.photo-input:focus,
.wp-jobs-input:focus,
.wp-jobs-textarea:focus,
.wp-edit-input:focus,
.wp-edit-textarea:focus{
  outline:none !important;
  transform:translateY(-1px);
  box-shadow:0 0 0 4px rgba(124,58,237,.13) !important;
}

/* Bottom nav */
.bottom-nav{
  animation:wpAnimFadeUp .55s var(--wp-ease) both;
}
.bottom-nav .nav-item,
.bottom-nav a{
  transition:color .2s var(--wp-ease), transform .2s var(--wp-ease), background .2s var(--wp-ease) !important;
}
.bottom-nav .nav-icon{
  transition:transform .2s var(--wp-ease), filter .2s var(--wp-ease) !important;
}
.bottom-nav .nav-item.active .nav-icon,
.bottom-nav a.active .nav-icon{
  transform:translateY(-3px) scale(1.08) !important;
}
@media(hover:hover){
  .bottom-nav .nav-item:hover,
  .bottom-nav a:hover{
    color:#7c3aed !important;
    transform:translateY(-2px);
  }
  .bottom-nav .nav-item:hover .nav-icon,
  .bottom-nav a:hover .nav-icon{
    transform:translateY(-3px) scale(1.08) !important;
  }
}

/* Notification motion */
.notif-popup{
  transform-origin:top right;
  animation:wpAnimPop .22s var(--wp-ease) both !important;
}
.notif-dot{
  animation:wpAnimSoftPulse 1.6s ease-in-out infinite;
}
.bell,
.notif-bell,
.wp-home-bell{
  transition:transform .2s var(--wp-ease), background .2s var(--wp-ease), box-shadow .2s var(--wp-ease) !important;
}
@media(hover:hover){
  .bell:hover,
  .notif-bell:hover,
  .wp-home-bell:hover{
    transform:translateY(-2px) scale(1.04) !important;
  }
}

/* Page transition overlay */
.wp-page-transition{
  position:fixed;
  inset:0;
  z-index:2147483647;
  pointer-events:none;
  opacity:0;
  transform:scaleX(0);
  transform-origin:right center;
  background:linear-gradient(135deg,#2563eb,#7c3aed,#a855f7);
}
body.wp-page-leaving .wp-page-transition{
  opacity:1;
  transform-origin:left center;
  animation:wpPageOverlayIn .28s var(--wp-ease) both;
}
body.wp-page-leaving{
  cursor:progress;
}
body.wp-page-leaving main,
body.wp-page-leaving .page{
  transition:opacity .2s var(--wp-ease), transform .2s var(--wp-ease);
  opacity:.65;
  transform:scale(.992);
}

/* Loading states */
.wp-is-loading{
  position:relative;
  pointer-events:none;
  opacity:.78;
}
.wp-is-loading::after{
  content:"";
  width:18px;
  height:18px;
  border-radius:50%;
  border:2px solid rgba(255,255,255,.5);
  border-top-color:#fff;
  animation:wpSpin .7s linear infinite;
  margin-left:8px;
}
@keyframes wpSpin{to{transform:rotate(360deg)}}

/* Mobile: keep animations smooth, not heavy */
@media(max-width:760px){
  body.wp-anim-ready main,
  body.wp-anim-ready .page,
  body.wp-anim-ready .auth-page,
  body.wp-anim-ready .wp-home-page,
  body.wp-anim-ready .wp-profile-page,
  body.wp-anim-ready .wp-edit-page,
  body.wp-anim-ready .wp-benefits-page,
  body.wp-anim-ready .wp-jobs-page,
  body.wp-anim-ready .wp-course-page{
    animation-duration:.42s;
  }

  .card,
  .why-card,
  .feature-card,
  .module-card,
  .job-card,
  .benefit-card,
  .question-card,
  .progress-card,
  .video-card,
  .search-box,
  .lesson-row,
  .wp-home-feature-card,
  .wp-jobs-card,
  .wp-benefits-card{
    animation-duration:.42s;
  }
}

/* Respect reduced motion */
@media (prefers-reduced-motion:reduce){
  *,
  *::before,
  *::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    scroll-behavior:auto !important;
    transition-duration:.01ms !important;
  }
  .wp-reveal{opacity:1 !important;transform:none !important;}
  .wp-page-transition{display:none !important;}
}

/* =========================================================
   WORKERPRO FORCE ANIMATION V2
   Dipasang paling bawah agar tetap jalan walau style lama menimpa.
   ========================================================= */
:root{
  --wp-anim-fast:.22s;
  --wp-anim-med:.55s;
  --wp-anim-slow:1.05s;
  --wp-ease-smooth:cubic-bezier(.22,1,.36,1);
}

@keyframes wpV2PageIn{
  0%{opacity:0;transform:translateY(22px) scale(.985);filter:blur(8px)}
  60%{opacity:1;filter:blur(0)}
  100%{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}
}
@keyframes wpV2FadeUp{
  0%{opacity:0;transform:translateY(24px) scale(.985)}
  100%{opacity:1;transform:translateY(0) scale(1)}
}
@keyframes wpV2FadeDown{
  0%{opacity:0;transform:translateY(-18px)}
  100%{opacity:1;transform:translateY(0)}
}
@keyframes wpV2Pop{
  0%{opacity:0;transform:scale(.92)}
  70%{opacity:1;transform:scale(1.025)}
  100%{opacity:1;transform:scale(1)}
}
@keyframes wpV2Float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-7px)}
}
@keyframes wpV2Pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(124,58,237,.28)}
  50%{box-shadow:0 0 0 11px rgba(124,58,237,0)}
}
@keyframes wpV2Shimmer{
  0%{transform:translateX(-140%) skewX(-18deg)}
  100%{transform:translateX(240%) skewX(-18deg)}
}
@keyframes wpV2GradientMove{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}
@keyframes wpV2OverlayIn{
  0%{opacity:0;transform:scaleX(0)}
  100%{opacity:1;transform:scaleX(1)}
}
@keyframes wpV2Spin{to{transform:rotate(360deg)}}

html.wp-v2-anim,
html.wp-v2-anim body{
  scroll-behavior:smooth !important;
}

html.wp-v2-anim body:not(.wp-v2-ready){
  opacity:0;
}

html.wp-v2-anim body.wp-v2-ready{
  opacity:1 !important;
  transition:opacity .28s ease !important;
}

/* page enter: sengaja broad supaya semua halaman ikut bergerak */
html.wp-v2-anim body.wp-v2-ready main,
html.wp-v2-anim body.wp-v2-ready .page,
html.wp-v2-anim body.wp-v2-ready .auth-page,
html.wp-v2-anim body.wp-v2-ready .wp-home-page,
html.wp-v2-anim body.wp-v2-ready .wp-profile-page,
html.wp-v2-anim body.wp-v2-ready .wp-edit-page,
html.wp-v2-anim body.wp-v2-ready .wp-benefits-page,
html.wp-v2-anim body.wp-v2-ready .wp-jobs-page,
html.wp-v2-anim body.wp-v2-ready .wp-course-page{
  animation:wpV2PageIn .62s var(--wp-ease-smooth) both !important;
  will-change:transform,opacity,filter;
}

/* header/top area */
html.wp-v2-anim body.wp-v2-ready .header,
html.wp-v2-anim body.wp-v2-ready .top-blue,
html.wp-v2-anim body.wp-v2-ready .wp-home-topbar,
html.wp-v2-anim body.wp-v2-ready .wp-profile-header,
html.wp-v2-anim body.wp-v2-ready .wp-benefits-header,
html.wp-v2-anim body.wp-v2-ready .wp-jobs-header,
html.wp-v2-anim body.wp-v2-ready .progress-steps{
  animation:wpV2FadeDown .55s var(--wp-ease-smooth) both !important;
}

/* hero/card masuk bertahap */
html.wp-v2-anim body.wp-v2-ready .hero-card,
html.wp-v2-anim body.wp-v2-ready .grad-panel,
html.wp-v2-anim body.wp-v2-ready .profile-hero,
html.wp-v2-anim body.wp-v2-ready .cta,
html.wp-v2-anim body.wp-v2-ready .auth-card,
html.wp-v2-anim body.wp-v2-ready .auth-highlight,
html.wp-v2-anim body.wp-v2-ready .wp-home-copy,
html.wp-v2-anim body.wp-v2-ready .wp-home-progress-card,
html.wp-v2-anim body.wp-v2-ready .wp-profile-hero,
html.wp-v2-anim body.wp-v2-ready .wp-edit-hero,
html.wp-v2-anim body.wp-v2-ready .wp-benefits-hero,
html.wp-v2-anim body.wp-v2-ready .wp-jobs-hero,
html.wp-v2-anim body.wp-v2-ready .wp-course-hero{
  animation:wpV2Pop .68s var(--wp-ease-smooth) both !important;
}

html.wp-v2-anim body.wp-v2-ready .card,
html.wp-v2-anim body.wp-v2-ready .why-card,
html.wp-v2-anim body.wp-v2-ready .feature-card,
html.wp-v2-anim body.wp-v2-ready .module-card,
html.wp-v2-anim body.wp-v2-ready .job-card,
html.wp-v2-anim body.wp-v2-ready .benefit-card,
html.wp-v2-anim body.wp-v2-ready .question-card,
html.wp-v2-anim body.wp-v2-ready .progress-card,
html.wp-v2-anim body.wp-v2-ready .video-card,
html.wp-v2-anim body.wp-v2-ready .lesson-row,
html.wp-v2-anim body.wp-v2-ready .search-box,
html.wp-v2-anim body.wp-v2-ready .wp-home-feature-card,
html.wp-v2-anim body.wp-v2-ready .wp-home-panel,
html.wp-v2-anim body.wp-v2-ready .wp-home-cta-modern,
html.wp-v2-anim body.wp-v2-ready .wp-profile-card,
html.wp-v2-anim body.wp-v2-ready .wp-edit-form-card,
html.wp-v2-anim body.wp-v2-ready .wp-benefits-card,
html.wp-v2-anim body.wp-v2-ready .wp-benefits-summary-card,
html.wp-v2-anim body.wp-v2-ready .wp-jobs-card,
html.wp-v2-anim body.wp-v2-ready .wp-jobs-app-card,
html.wp-v2-anim body.wp-v2-ready .wp-course-card,
html.wp-v2-anim body.wp-v2-ready .wp-course-panel{
  animation:wpV2FadeUp .58s var(--wp-ease-smooth) both !important;
  animation-delay:var(--wp-stagger,0ms) !important;
}

/* JS reveal on scroll */
.wp-v2-reveal{
  opacity:0 !important;
  transform:translateY(24px) scale(.985) !important;
  transition:opacity .62s var(--wp-ease-smooth), transform .62s var(--wp-ease-smooth), filter .62s var(--wp-ease-smooth) !important;
  filter:blur(4px);
}
.wp-v2-reveal.wp-v2-inview{
  opacity:1 !important;
  transform:translateY(0) scale(1) !important;
  filter:blur(0);
}

/* shimmer bergerak untuk hero/CTA */
.wp-home-copy,
.wp-home-progress-card,
.wp-profile-hero,
.wp-edit-hero,
.wp-benefits-hero,
.wp-jobs-hero,
.wp-course-hero,
.hero-card,
.grad-panel,
.profile-hero,
.cta,
.wp-home-cta-modern,
.quiz-result-hero{
  position:relative !important;
  overflow:hidden !important;
}
.wp-home-copy::after,
.wp-home-progress-card::after,
.wp-profile-hero::after,
.wp-edit-hero::after,
.wp-benefits-hero::after,
.wp-jobs-hero::after,
.wp-course-hero::after,
.hero-card::after,
.grad-panel::after,
.profile-hero::after,
.cta::after,
.wp-home-cta-modern::before,
.quiz-result-hero::after{
  content:"" !important;
  position:absolute !important;
  top:-70% !important;
  left:-85% !important;
  width:42% !important;
  height:240% !important;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.30),transparent) !important;
  transform:skewX(-18deg) !important;
  animation:wpV2Shimmer 5.8s ease-in-out infinite !important;
  pointer-events:none !important;
  z-index:1;
}

/* orb/logo/icon floating */
.brand-icon,
.auth-logo,
.wp-home-brand-mark,
.wp-home-cta-icon,
.wp-home-feature-icon,
.feature-icon,
.why-icon,
.module-icon,
.admin-card-icon,
.admin-dashboard-icon,
.claim-icon,
.wp-benefits-icon,
.wp-jobs-icon{
  animation:wpV2Float 4.2s ease-in-out infinite !important;
}

/* tombol dan card interaksi */
.full-btn,
.small-btn,
.white-action,
.claim-btn,
.logout-profile-btn,
.google-login-btn,
.search-lowongan-btn,
.wp-home-btn,
.wp-home-cta-modern a,
.wp-jobs-btn,
.wp-course-btn,
.wp-edit-submit,
button,
input[type="submit"],
a[class*="btn"]{
  transition:transform .22s var(--wp-ease-smooth), box-shadow .22s var(--wp-ease-smooth), filter .22s var(--wp-ease-smooth), background .22s var(--wp-ease-smooth) !important;
}
@media(hover:hover){
  .full-btn:hover,
  .small-btn:hover,
  .white-action:hover,
  .claim-btn:hover,
  .logout-profile-btn:hover,
  .google-login-btn:hover,
  .search-lowongan-btn:hover,
  .wp-home-btn:hover,
  .wp-home-cta-modern a:hover,
  .wp-jobs-btn:hover,
  .wp-course-btn:hover,
  .wp-edit-submit:hover,
  button:hover,
  input[type="submit"]:hover,
  a[class*="btn"]:hover{
    transform:translateY(-3px) scale(1.015) !important;
    filter:saturate(1.08) !important;
    box-shadow:0 18px 40px rgba(88,28,135,.18) !important;
  }

  .card:hover,
  .why-card:hover,
  .feature-card:hover,
  .module-card:hover,
  .job-card:hover,
  .benefit-card:hover,
  .question-card:hover,
  .progress-card:hover,
  .video-card:hover,
  .lesson-row:hover,
  .search-box:hover,
  .wp-home-feature-card:hover,
  .wp-home-panel:hover,
  .wp-profile-card:hover,
  .wp-edit-form-card:hover,
  .wp-benefits-card:hover,
  .wp-benefits-summary-card:hover,
  .wp-jobs-card:hover,
  .wp-jobs-app-card:hover,
  .wp-course-card:hover,
  .wp-course-panel:hover{
    transform:translateY(-5px) !important;
    box-shadow:0 22px 54px rgba(15,23,42,.12) !important;
  }
}
.full-btn:active,
.small-btn:active,
.white-action:active,
.claim-btn:active,
.logout-profile-btn:active,
.google-login-btn:active,
.search-lowongan-btn:active,
.wp-home-btn:active,
.wp-jobs-btn:active,
.wp-course-btn:active,
.wp-edit-submit:active,
button:active,
a[class*="btn"]:active{
  transform:scale(.97) !important;
}

/* progress bar bergerak */
.progress-line span,
.wp-progress-fill{
  background-size:180px 100% !important;
  animation:wpV2GradientMove 2.4s linear infinite !important;
}

/* notif modern motion */
.notif-popup{
  transform-origin:top right !important;
  animation:wpV2Pop .24s var(--wp-ease-smooth) both !important;
}
.notif-item{
  animation:wpV2FadeUp .34s var(--wp-ease-smooth) both !important;
}
.notif-dot{
  animation:wpV2Pulse 1.8s ease-in-out infinite !important;
}

/* bottom nav lebih hidup */
.bottom-nav,
.bottom-nav a,
.bottom-nav .nav-item,
.bottom-nav .nav-icon{
  transition:transform .22s var(--wp-ease-smooth), color .22s ease, background .22s ease, filter .22s ease !important;
}
.bottom-nav a.active .nav-icon,
.bottom-nav .nav-item.active .nav-icon{
  transform:translateY(-3px) scale(1.08) !important;
}
@media(hover:hover){
  .bottom-nav a:hover,
  .bottom-nav .nav-item:hover{
    transform:translateY(-2px) !important;
    color:var(--purple,#7c3aed) !important;
  }
}

/* form focus */
input,
textarea,
select,
.input,
.photo-input{
  transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease, background .2s ease !important;
}
input:focus,
textarea:focus,
select:focus,
.input:focus,
.photo-input:focus{
  outline:none !important;
  border-color:#a855f7 !important;
  box-shadow:0 0 0 5px rgba(168,85,247,.14) !important;
  transform:translateY(-1px) !important;
}

/* overlay transisi halaman */
.wp-v2-page-transition{
  position:fixed;
  inset:0;
  z-index:2147483000;
  pointer-events:none;
  opacity:0;
  transform:scaleX(0);
  transform-origin:right center;
  background:linear-gradient(135deg,#2563eb,#7c3aed,#a855f7);
}
body.wp-v2-leaving .wp-v2-page-transition{
  opacity:1;
  transform-origin:left center;
  animation:wpV2OverlayIn .32s var(--wp-ease-smooth) both !important;
}
body.wp-v2-leaving main,
body.wp-v2-leaving .page{
  opacity:.58 !important;
  transform:scale(.99) !important;
  transition:opacity .2s ease, transform .2s ease !important;
}

.wp-v2-loading{
  pointer-events:none !important;
  opacity:.76 !important;
  position:relative !important;
}
.wp-v2-loading::after{
  content:"";
  width:18px;
  height:18px;
  border-radius:50%;
  border:2px solid rgba(255,255,255,.55);
  border-top-color:#fff;
  animation:wpV2Spin .75s linear infinite;
  margin-left:9px;
}

@media(max-width:760px){
  html.wp-v2-anim body.wp-v2-ready main,
  html.wp-v2-anim body.wp-v2-ready .page,
  html.wp-v2-anim body.wp-v2-ready .auth-page,
  html.wp-v2-anim body.wp-v2-ready .wp-home-page,
  html.wp-v2-anim body.wp-v2-ready .wp-profile-page,
  html.wp-v2-anim body.wp-v2-ready .wp-edit-page,
  html.wp-v2-anim body.wp-v2-ready .wp-benefits-page,
  html.wp-v2-anim body.wp-v2-ready .wp-jobs-page,
  html.wp-v2-anim body.wp-v2-ready .wp-course-page{
    animation-duration:.48s !important;
  }
}

@media (prefers-reduced-motion:reduce){
  html.wp-v2-anim body.wp-v2-ready main,
  html.wp-v2-anim body.wp-v2-ready .page,
  html.wp-v2-anim body.wp-v2-ready .auth-page,
  .wp-v2-reveal,
  .brand-icon,
  .auth-logo,
  .wp-home-brand-mark,
  .wp-home-cta-icon,
  .wp-home-feature-icon,
  .feature-icon,
  .why-icon,
  .module-icon,
  .admin-card-icon,
  .admin-dashboard-icon,
  .claim-icon{
    animation:none !important;
    opacity:1 !important;
    transform:none !important;
    filter:none !important;
  }
  .wp-v2-page-transition{display:none !important;}
}

/* =========================================================
   WORKERPRO FINAL PAGE TRANSITION
   Tambahan saja - transisi smooth antar halaman
   ========================================================= */

html.wp-final-transitions{
  scroll-behavior:smooth;
}

.wp-final-page-transition{
  position:fixed;
  inset:0;
  z-index:2147483640;
  pointer-events:none;
  opacity:0;
  visibility:hidden;
  overflow:hidden;
  background:
    radial-gradient(circle at 18% 20%, rgba(255,255,255,.26), transparent 28%),
    radial-gradient(circle at 82% 82%, rgba(255,255,255,.18), transparent 30%),
    linear-gradient(135deg,#145cff 0%,#6d28d9 48%,#9d25ff 100%);
  transform:scale(1.035);
  transition:
    opacity .34s cubic-bezier(.22,.8,.22,1),
    visibility .34s cubic-bezier(.22,.8,.22,1),
    transform .34s cubic-bezier(.22,.8,.22,1);
}

.wp-final-page-transition::before{
  content:"";
  position:absolute;
  inset:-35%;
  background:
    linear-gradient(90deg,transparent,rgba(255,255,255,.20),transparent),
    radial-gradient(circle,rgba(255,255,255,.16) 0 2px,transparent 2px);
  background-size:420px 100%,28px 28px;
  transform:translateX(-32%) rotate(-8deg);
  opacity:.72;
  animation:wpFinalTransitionSweep 1.25s ease-in-out infinite;
}

.wp-final-page-transition::after{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  width:58px;
  height:58px;
  margin-left:-29px;
  margin-top:-29px;
  border-radius:999px;
  border:4px solid rgba(255,255,255,.36);
  border-top-color:#fff;
  box-shadow:0 0 0 10px rgba(255,255,255,.08);
  animation:wpFinalTransitionSpin .82s linear infinite;
}

.wp-final-page-transition-label{
  position:absolute;
  left:50%;
  top:calc(50% + 55px);
  transform:translateX(-50%);
  color:#fff;
  font-size:14px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  text-shadow:0 8px 22px rgba(15,23,42,.28);
  white-space:nowrap;
}

.wp-final-page-transition.is-active,
body.wp-final-leaving .wp-final-page-transition{
  opacity:1;
  visibility:visible;
  transform:scale(1);
  pointer-events:auto;
}

body.wp-final-leaving{
  cursor:progress;
}

body.wp-final-leaving main,
body.wp-final-leaving .page,
body.wp-final-leaving .wp-home-page,
body.wp-final-leaving .wp-login-page,
body.wp-final-leaving .wp-auth-modern-page{
  opacity:.52 !important;
  filter:blur(1px);
  transition:
    opacity .22s ease,
    filter .22s ease !important;
}

html.wp-final-transitions body.wp-final-ready main,
html.wp-final-transitions body.wp-final-ready .page,
html.wp-final-transitions body.wp-final-ready .wp-home-page,
html.wp-final-transitions body.wp-final-ready .wp-login-page,
html.wp-final-transitions body.wp-final-ready .wp-auth-modern-page{
  animation:wpFinalPageEnter .42s cubic-bezier(.22,.8,.22,1) both;
}

@keyframes wpFinalPageEnter{
  from{
    opacity:0;
    filter:blur(4px);
  }
  to{
    opacity:1;
    filter:blur(0);
  }
}

@keyframes wpFinalTransitionSpin{
  to{
    transform:rotate(360deg);
  }
}

@keyframes wpFinalTransitionSweep{
  0%{
    transform:translateX(-34%) rotate(-8deg);
  }
  50%{
    transform:translateX(8%) rotate(-8deg);
  }
  100%{
    transform:translateX(34%) rotate(-8deg);
  }
}

@media(prefers-reduced-motion:reduce){
  .wp-final-page-transition{
    display:none !important;
  }

  html.wp-final-transitions body.wp-final-ready main,
  html.wp-final-transitions body.wp-final-ready .page,
  html.wp-final-transitions body.wp-final-ready .wp-home-page,
  html.wp-final-transitions body.wp-final-ready .wp-login-page,
  html.wp-final-transitions body.wp-final-ready .wp-auth-modern-page{
    animation:none !important;
    opacity:1 !important;
    filter:none !important;
  }
}

/* =========================================================
   WORKERPRO DESKTOP PAGE TRANSITION FIX - APPENDED FINAL
   Tambahan saja: membuat transisi page-to-page terlihat di laptop/desktop
   ========================================================= */

.wp-page-transition{
  display:block !important;
  position:fixed !important;
  inset:0 !important;
  z-index:2147483647 !important;
  pointer-events:none !important;
  opacity:0 !important;
  visibility:hidden !important;
  background:
    radial-gradient(circle at 20% 20%, rgba(157,37,255,.32), transparent 32%),
    radial-gradient(circle at 80% 80%, rgba(20,92,255,.26), transparent 32%),
    linear-gradient(135deg,#145cff,#9d25ff) !important;
  transform:scale(1.04) !important;
  transition:
    opacity .34s ease,
    visibility .34s ease,
    transform .34s ease !important;
  overflow:hidden !important;
}

.wp-page-transition.active,
body.wp-is-leaving .wp-page-transition{
  display:block !important;
  opacity:1 !important;
  visibility:visible !important;
  transform:scale(1) !important;
  pointer-events:auto !important;
}

.wp-page-transition::before{
  content:"" !important;
  position:absolute !important;
  left:50% !important;
  top:50% !important;
  width:54px !important;
  height:54px !important;
  margin-left:-27px !important;
  margin-top:-27px !important;
  border-radius:50% !important;
  border:4px solid rgba(255,255,255,.35) !important;
  border-top-color:#fff !important;
  animation:wpPageTransitionLoaderFinal .8s linear infinite !important;
}

.wp-page-transition::after{
  content:"WorkerPro" !important;
  position:absolute !important;
  left:50% !important;
  top:calc(50% + 52px) !important;
  transform:translateX(-50%) !important;
  color:#fff !important;
  font-weight:900 !important;
  letter-spacing:.04em !important;
  font-size:15px !important;
}

body.wp-is-leaving{
  cursor:wait !important;
}

body.wp-is-leaving main,
body.wp-is-leaving .page,
body.wp-is-leaving .wp-home-page,
body.wp-is-leaving .wp-login-page,
body.wp-is-leaving .wp-auth-modern-page{
  filter:blur(1px) !important;
}

@keyframes wpPageTransitionLoaderFinal{
  to{
    transform:rotate(360deg);
  }
}

/* Override aturan reduce-motion lama yang sebelumnya bisa mematikan animasi di laptop tertentu */
@media(prefers-reduced-motion:reduce){
  .wp-page-transition{
    display:block !important;
    transition:
      opacity .34s ease,
      visibility .34s ease,
      transform .34s ease !important;
  }

  .wp-page-transition::before{
    animation:wpPageTransitionLoaderFinal .8s linear infinite !important;
  }

  .wp-page-transition.active,
  body.wp-is-leaving .wp-page-transition{
    display:block !important;
    opacity:1 !important;
    visibility:visible !important;
    transform:scale(1) !important;
  }
}

/* =========================================================
   WORKERPRO PAGE ENTER ANIMATION FINAL
   Tambahan saja - animasi saat halaman baru dibuka
   ========================================================= */

.wp-enter-transition{
  position:fixed !important;
  inset:0 !important;
  z-index:99999999 !important;
  pointer-events:none !important;
  opacity:1 !important;
  visibility:visible !important;
  background:
    radial-gradient(circle at 18% 20%, rgba(255,255,255,.22), transparent 30%),
    radial-gradient(circle at 82% 80%, rgba(255,255,255,.18), transparent 32%),
    linear-gradient(135deg,#145cff,#7c2ee8,#9d25ff) !important;
  transform:scale(1) !important;
  transition:
    opacity .58s ease,
    visibility .58s ease,
    transform .58s ease !important;
}

.wp-enter-transition::before{
  content:"WorkerPro" !important;
  position:absolute !important;
  left:50% !important;
  top:50% !important;
  transform:translate(-50%,-50%) scale(.96) !important;
  color:#fff !important;
  font-size:clamp(30px,4vw,52px) !important;
  font-weight:950 !important;
  letter-spacing:-.04em !important;
  opacity:1 !important;
  animation:wpEnterBrandPop .58s cubic-bezier(.2,.8,.2,1) both !important;
}

.wp-enter-transition::after{
  content:"" !important;
  position:absolute !important;
  left:50% !important;
  top:calc(50% + 58px) !important;
  width:170px !important;
  height:5px !important;
  transform:translateX(-50%) !important;
  border-radius:999px !important;
  background:
    linear-gradient(90deg,rgba(255,255,255,.24),#fff,rgba(255,255,255,.24)) !important;
  background-size:90px 100% !important;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.16) !important;
  animation:wpEnterBarMove .8s linear infinite !important;
  overflow:hidden !important;
}

.wp-enter-transition.is-hidden{
  opacity:0 !important;
  visibility:hidden !important;
  transform:scale(1.035) !important;
}

/* isi halaman disiapkan dulu sebelum overlay menghilang */
body.wp-site-entering .page,
body.wp-site-entering main,
body.wp-site-entering .wp-home-page,
body.wp-site-entering .wp-login-page,
body.wp-site-entering .wp-auth-modern-page,
body.wp-site-entering .container,
body.wp-site-entering .top-blue,
body.wp-site-entering .header,
body.wp-site-entering .progress-steps{
  opacity:0 !important;
  transform:translateY(22px) scale(.985) !important;
}

/* isi halaman masuk halus setelah overlay */
body.wp-site-entered .page,
body.wp-site-entered main,
body.wp-site-entered .wp-home-page,
body.wp-site-entered .wp-login-page,
body.wp-site-entered .wp-auth-modern-page,
body.wp-site-entered .container,
body.wp-site-entered .top-blue,
body.wp-site-entered .header,
body.wp-site-entered .progress-steps{
  opacity:1 !important;
  transform:translateY(0) scale(1) !important;
  transition:
    opacity .66s ease,
    transform .66s cubic-bezier(.2,.8,.2,1) !important;
}

/* login/auth/beranda masuk lebih terasa */
body.wp-site-entered .wp-login-shell,
body.wp-site-entered .wp-auth-modern-shell{
  animation:wpEnterShell .72s cubic-bezier(.2,.8,.2,1) both !important;
}

body.wp-site-entered .wp-login-hero,
body.wp-site-entered .wp-auth-hero,
body.wp-site-entered .wp-home-hero{
  animation:wpEnterLeft .72s cubic-bezier(.2,.8,.2,1) both !important;
}

body.wp-site-entered .wp-login-card,
body.wp-site-entered .wp-auth-card,
body.wp-site-entered .wp-home-copy,
body.wp-site-entered .wp-home-progress-card{
  animation:wpEnterRight .72s cubic-bezier(.2,.8,.2,1) .08s both !important;
}

/* bottom nav jangan langsung kaku */
body.wp-site-entering .bottom-nav{
  opacity:0 !important;
  transform:translateY(18px) !important;
}

body.wp-site-entered .bottom-nav{
  opacity:1 !important;
  transform:translateY(0) !important;
  transition:
    opacity .45s ease .18s,
    transform .45s ease .18s !important;
}

/* kartu/section ikut fade-up setelah halaman masuk */
body.wp-site-entered .card,
body.wp-site-entered .why-card,
body.wp-site-entered .feature-card,
body.wp-site-entered .module-card,
body.wp-site-entered .job-card,
body.wp-site-entered .benefit-card,
body.wp-site-entered .question-card,
body.wp-site-entered .progress-card,
body.wp-site-entered .video-card,
body.wp-site-entered .search-box,
body.wp-site-entered .empty-search,
body.wp-site-entered .admin-profile-panel,
body.wp-site-entered .admin-dashboard-card,
body.wp-site-entered .admin-bpjs-card,
body.wp-site-entered .wp-home-feature-card,
body.wp-site-entered .wp-home-panel,
body.wp-site-entered .wp-home-cta-modern,
body.wp-site-entered .wp-profile-card,
body.wp-site-entered .wp-benefit-card,
body.wp-site-entered .wp-job-card,
body.wp-site-entered .wp-course-card{
  animation:wpEnterFadeUp .58s ease both !important;
}

@keyframes wpEnterBrandPop{
  from{
    opacity:0;
    transform:translate(-50%,-50%) scale(.88);
    filter:blur(8px);
  }
  to{
    opacity:1;
    transform:translate(-50%,-50%) scale(1);
    filter:blur(0);
  }
}

@keyframes wpEnterBarMove{
  from{
    background-position:-90px 0;
  }
  to{
    background-position:170px 0;
  }
}

@keyframes wpEnterShell{
  from{
    opacity:0;
    transform:translateY(30px) scale(.96);
  }
  to{
    opacity:1;
    transform:translateY(0) scale(1);
  }
}

@keyframes wpEnterLeft{
  from{
    opacity:0;
    transform:translateX(-34px);
  }
  to{
    opacity:1;
    transform:translateX(0);
  }
}

@keyframes wpEnterRight{
  from{
    opacity:0;
    transform:translateX(34px);
  }
  to{
    opacity:1;
    transform:translateX(0);
  }
}

@keyframes wpEnterFadeUp{
  from{
    opacity:0;
    transform:translateY(20px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}

/* override terakhir agar animasi enter tetap jalan meski ada rule reduced-motion lama */
@media (prefers-reduced-motion:reduce){
  .wp-enter-transition,
  .wp-enter-transition::before,
  .wp-enter-transition::after,
  body.wp-site-entered .wp-login-shell,
  body.wp-site-entered .wp-auth-modern-shell,
  body.wp-site-entered .wp-login-hero,
  body.wp-site-entered .wp-auth-hero,
  body.wp-site-entered .wp-home-hero,
  body.wp-site-entered .wp-login-card,
  body.wp-site-entered .wp-auth-card,
  body.wp-site-entered .wp-home-copy,
  body.wp-site-entered .wp-home-progress-card{
    animation-duration:.58s !important;
    transition-duration:.58s !important;
  }
}


/* =========================================================
   WORKERPRO SLOW PAGE ENTER FINAL OVERRIDE
   Tambahan saja - memperlambat animasi masuk setiap halaman
   ========================================================= */

.wp-slow-enter-transition{
  position:fixed !important;
  inset:0 !important;
  z-index:100000000 !important;
  pointer-events:none !important;
  opacity:1 !important;
  visibility:visible !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  overflow:hidden !important;
  background:
    radial-gradient(circle at 16% 18%, rgba(255,255,255,.24), transparent 28%),
    radial-gradient(circle at 84% 82%, rgba(255,255,255,.18), transparent 30%),
    radial-gradient(circle at 50% 50%, rgba(255,255,255,.10), transparent 34%),
    linear-gradient(135deg,#145cff 0%,#5b21b6 48%,#9d25ff 100%) !important;
  transform:scale(1) !important;
  transition:
    opacity 1.05s ease,
    visibility 1.05s ease,
    transform 1.05s cubic-bezier(.2,.8,.2,1) !important;
}

.wp-slow-enter-transition::before,
.wp-slow-enter-transition::after{
  content:"" !important;
  position:absolute !important;
  border-radius:999px !important;
  pointer-events:none !important;
}

.wp-slow-enter-transition::before{
  width:520px !important;
  height:520px !important;
  left:-140px !important;
  top:-160px !important;
  background:rgba(255,255,255,.13) !important;
  filter:blur(4px) !important;
  animation:wpSlowEnterOrbOne 2.4s ease-in-out infinite alternate !important;
}

.wp-slow-enter-transition::after{
  width:460px !important;
  height:460px !important;
  right:-150px !important;
  bottom:-170px !important;
  background:rgba(236,63,184,.18) !important;
  filter:blur(6px) !important;
  animation:wpSlowEnterOrbTwo 2.6s ease-in-out infinite alternate !important;
}

.wp-slow-enter-transition.is-hidden{
  opacity:0 !important;
  visibility:hidden !important;
  transform:scale(1.045) !important;
}

.wp-slow-enter-inner{
  position:relative !important;
  z-index:2 !important;
  width:min(520px, calc(100vw - 42px)) !important;
  min-height:230px !important;
  display:flex !important;
  flex-direction:column !important;
  align-items:center !important;
  justify-content:center !important;
  text-align:center !important;
  color:#fff !important;
}

.wp-slow-enter-mark{
  width:72px !important;
  height:72px !important;
  border-radius:24px !important;
  display:grid !important;
  place-items:center !important;
  margin:0 auto 22px !important;
  background:rgba(255,255,255,.16) !important;
  border:1px solid rgba(255,255,255,.28) !important;
  box-shadow:0 22px 60px rgba(15,23,42,.22) !important;
  backdrop-filter:blur(12px) !important;
  animation:wpSlowEnterMark 1.25s cubic-bezier(.2,.8,.2,1) both !important;
}

.wp-slow-enter-mark span{
  display:block !important;
  color:#fff !important;
  font-size:28px !important;
  line-height:1 !important;
  font-weight:950 !important;
  letter-spacing:-.04em !important;
}

.wp-slow-enter-brand{
  display:block !important;
  margin:0 !important;
  color:#fff !important;
  font-size:clamp(34px,4.8vw,58px) !important;
  line-height:1 !important;
  font-weight:950 !important;
  letter-spacing:-.055em !important;
  text-shadow:0 14px 42px rgba(15,23,42,.26) !important;
  animation:wpSlowEnterText 1.18s cubic-bezier(.2,.8,.2,1) .12s both !important;
}

.wp-slow-enter-subtitle{
  display:block !important;
  margin:14px auto 0 !important;
  max-width:380px !important;
  color:rgba(255,255,255,.82) !important;
  font-size:14px !important;
  font-weight:750 !important;
  line-height:1.55 !important;
  animation:wpSlowEnterText 1.18s cubic-bezier(.2,.8,.2,1) .26s both !important;
}

.wp-slow-enter-loader{
  position:relative !important;
  width:190px !important;
  height:6px !important;
  margin:30px auto 0 !important;
  border-radius:999px !important;
  overflow:hidden !important;
  background:rgba(255,255,255,.22) !important;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.14) !important;
  animation:wpSlowEnterText 1.18s cubic-bezier(.2,.8,.2,1) .38s both !important;
}

.wp-slow-enter-loader span{
  position:absolute !important;
  inset:0 auto 0 0 !important;
  width:58% !important;
  border-radius:999px !important;
  background:linear-gradient(90deg,rgba(255,255,255,.20),#fff,rgba(255,255,255,.20)) !important;
  animation:wpSlowEnterLoader 1.35s ease-in-out infinite !important;
}

/* Konten halaman ditahan sebentar agar animasi masuk terasa lebih lambat */
body.wp-slow-site-entering .page,
body.wp-slow-site-entering main,
body.wp-slow-site-entering .wp-home-page,
body.wp-slow-site-entering .wp-login-page,
body.wp-slow-site-entering .wp-auth-modern-page,
body.wp-slow-site-entering .auth-page,
body.wp-slow-site-entering .container,
body.wp-slow-site-entering .top-blue,
body.wp-slow-site-entering .header,
body.wp-slow-site-entering .progress-steps{
  opacity:0 !important;
  transform:translateY(34px) scale(.975) !important;
}

body.wp-slow-site-entered .page,
body.wp-slow-site-entered main,
body.wp-slow-site-entered .wp-home-page,
body.wp-slow-site-entered .wp-login-page,
body.wp-slow-site-entered .wp-auth-modern-page,
body.wp-slow-site-entered .auth-page,
body.wp-slow-site-entered .container,
body.wp-slow-site-entered .top-blue,
body.wp-slow-site-entered .header,
body.wp-slow-site-entered .progress-steps{
  opacity:1 !important;
  transform:translateY(0) scale(1) !important;
  transition:
    opacity 1.15s ease,
    transform 1.15s cubic-bezier(.2,.8,.2,1) !important;
}

/* Animasi masuk khusus halaman login/auth/beranda */
body.wp-slow-site-entered .wp-login-shell,
body.wp-slow-site-entered .wp-auth-modern-shell{
  animation:wpSlowEnterShell 1.25s cubic-bezier(.2,.8,.2,1) both !important;
}

body.wp-slow-site-entered .wp-login-hero,
body.wp-slow-site-entered .wp-auth-hero,
body.wp-slow-site-entered .wp-home-hero{
  animation:wpSlowEnterLeft 1.2s cubic-bezier(.2,.8,.2,1) both !important;
}

body.wp-slow-site-entered .wp-login-card,
body.wp-slow-site-entered .wp-auth-card,
body.wp-slow-site-entered .wp-home-copy,
body.wp-slow-site-entered .wp-home-progress-card{
  animation:wpSlowEnterRight 1.2s cubic-bezier(.2,.8,.2,1) .14s both !important;
}

body.wp-slow-site-entering .bottom-nav{
  opacity:0 !important;
  transform:translateY(24px) !important;
}

body.wp-slow-site-entered .bottom-nav{
  opacity:1 !important;
  transform:translateY(0) !important;
  transition:
    opacity .9s ease .28s,
    transform .9s cubic-bezier(.2,.8,.2,1) .28s !important;
}

/* Override kalau ada prefers-reduced-motion dari device/browser */
@media (prefers-reduced-motion:reduce){
  .wp-slow-enter-transition,
  .wp-slow-enter-transition::before,
  .wp-slow-enter-transition::after,
  .wp-slow-enter-mark,
  .wp-slow-enter-brand,
  .wp-slow-enter-subtitle,
  .wp-slow-enter-loader,
  .wp-slow-enter-loader span{
    animation-duration:1.25s !important;
    animation-iteration-count:1 !important;
    transition-duration:1.05s !important;
  }

  body.wp-slow-site-entered .page,
  body.wp-slow-site-entered main,
  body.wp-slow-site-entered .wp-home-page,
  body.wp-slow-site-entered .wp-login-page,
  body.wp-slow-site-entered .wp-auth-modern-page,
  body.wp-slow-site-entered .auth-page,
  body.wp-slow-site-entered .container,
  body.wp-slow-site-entered .top-blue,
  body.wp-slow-site-entered .header,
  body.wp-slow-site-entered .progress-steps{
    transition-duration:1.15s !important;
  }
}

@keyframes wpSlowEnterMark{
  from{
    opacity:0;
    transform:translateY(18px) scale(.82) rotate(-8deg);
    filter:blur(10px);
  }
  to{
    opacity:1;
    transform:translateY(0) scale(1) rotate(0);
    filter:blur(0);
  }
}

@keyframes wpSlowEnterText{
  from{
    opacity:0;
    transform:translateY(22px);
    filter:blur(8px);
  }
  to{
    opacity:1;
    transform:translateY(0);
    filter:blur(0);
  }
}

@keyframes wpSlowEnterLoader{
  0%{
    transform:translateX(-110%);
  }
  55%{
    transform:translateX(78%);
  }
  100%{
    transform:translateX(210%);
  }
}

@keyframes wpSlowEnterShell{
  from{
    opacity:0;
    transform:translateY(44px) scale(.955);
  }
  to{
    opacity:1;
    transform:translateY(0) scale(1);
  }
}

@keyframes wpSlowEnterLeft{
  from{
    opacity:0;
    transform:translateX(-52px);
  }
  to{
    opacity:1;
    transform:translateX(0);
  }
}

@keyframes wpSlowEnterRight{
  from{
    opacity:0;
    transform:translateX(52px);
  }
  to{
    opacity:1;
    transform:translateX(0);
  }
}

@keyframes wpSlowEnterOrbOne{
  from{
    transform:translate(0,0) scale(1);
  }
  to{
    transform:translate(34px,26px) scale(1.08);
  }
}

@keyframes wpSlowEnterOrbTwo{
  from{
    transform:translate(0,0) scale(1);
  }
  to{
    transform:translate(-32px,-24px) scale(1.1);
  }
}


/* =========================================================
   FIX ANIMASI DESKTOP + MOBILE
   Tambahan ini sengaja ditaruh paling bawah.
   Kode lama di atas tidak dihapus dan tidak diubah.
   ========================================================= */

@keyframes wpDesktopMobileFadeUpFix{
  from{
    opacity:0;
    transform:translateY(18px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}

@keyframes wpDesktopMobileFadeDownFix{
  from{
    opacity:0;
    transform:translateY(-14px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}

@keyframes wpDesktopMobileScaleFix{
  from{
    opacity:0;
    transform:scale(.96);
  }
  to{
    opacity:1;
    transform:scale(1);
  }
}

.top-blue{
  animation:wpDesktopMobileFadeDownFix .45s ease both !important;
}

.hero-card,
.grad-panel,
.profile-hero,
.auth-card,
.certificate-modern{
  animation:wpDesktopMobileFadeUpFix .6s ease both !important;
}

.why-card,
.feature-card,
.module-card,
.video-card,
.lesson-row,
.job-card,
.benefit-card,
.progress-card,
.question-card,
.admin-profile-card,
.admin-dashboard-card,
.quiz-review-card{
  animation:wpDesktopMobileFadeUpFix .55s ease both !important;
}

.cta,
.full-btn,
.white-action,
.claim-btn,
.logout-profile-btn,
.google-login-btn{
  animation:wpDesktopMobileScaleFix .45s ease both !important;
}

/* Navbar sengaja tetap tidak dianimasikan supaya fixed bottom-nav tidak loncat */
.bottom-nav{
  animation:none !important;
}

@media(max-width:720px){
  .top-blue{
    animation:wpDesktopMobileFadeDownFix .45s ease both !important;
  }

  .hero-card,
  .grad-panel,
  .profile-hero,
  .auth-card,
  .certificate-modern{
    animation:wpDesktopMobileFadeUpFix .6s ease both !important;
  }

  .why-card,
  .feature-card,
  .module-card,
  .video-card,
  .lesson-row,
  .job-card,
  .benefit-card,
  .progress-card,
  .question-card,
  .admin-profile-card,
  .admin-dashboard-card,
  .quiz-review-card{
    animation:wpDesktopMobileFadeUpFix .55s ease both !important;
  }

  .cta,
  .full-btn,
  .white-action,
  .claim-btn,
  .logout-profile-btn,
  .google-login-btn{
    animation:wpDesktopMobileScaleFix .45s ease both !important;
  }
}
/* =========================================================
   WORKERPRO GLOBAL ANIMATION FIX FINAL
   Ditambahkan paling bawah. CSS lama tetap utuh.
   Fix ini tanpa prefix body.wp-page supaya tetap kena semua halaman.
   ========================================================= */

@keyframes wpFixFadeUp{
  from{opacity:0; transform:translateY(22px);}
  to{opacity:1; transform:translateY(0);}
}

@keyframes wpFixFadeDown{
  from{opacity:0; transform:translateY(-16px);}
  to{opacity:1; transform:translateY(0);}
}

@keyframes wpFixScaleIn{
  from{opacity:0; transform:scale(.965);}
  to{opacity:1; transform:scale(1);}
}

.top-blue,
.header,
.progress-steps,
.section-title{
  animation:wpFixFadeDown .6s cubic-bezier(.2,.8,.2,1) both !important;
}

.container,
.hero-card,
.grad-panel,
.profile-hero,
.auth-card,
.certificate-modern,
.stats,
.stat,
.why-card,
.feature-card,
.module-card,
.video-card,
.lesson-content,
.lesson-row,
.job-card,
.benefit-card,
.progress-card,
.question-card,
.quiz-review-card,
.admin-profile-card,
.admin-dashboard-card,
.card,
.panel,
.box{
  animation:wpFixFadeUp .68s cubic-bezier(.2,.8,.2,1) both !important;
}

.cta,
.full-btn,
.white-action,
.claim-btn,
.logout-profile-btn,
.google-login-btn,
button,
.btn{
  animation:wpFixScaleIn .45s cubic-bezier(.2,.8,.2,1) both !important;
}

/* bottom nav jangan dianimasikan karena position fixed bisa loncat */
.bottom-nav{
  animation:none !important;
  opacity:1 !important;
  transform:none !important;
}

@media(max-width:720px){
  .top-blue,
  .header,
  .progress-steps,
  .section-title,
  .container,
  .hero-card,
  .grad-panel,
  .profile-hero,
  .auth-card,
  .certificate-modern,
  .stats,
  .stat,
  .why-card,
  .feature-card,
  .module-card,
  .video-card,
  .lesson-content,
  .lesson-row,
  .job-card,
  .benefit-card,
  .progress-card,
  .question-card,
  .quiz-review-card,
  .admin-profile-card,
  .admin-dashboard-card,
  .card,
  .panel,
  .box{
    animation:wpFixFadeUp .62s cubic-bezier(.2,.8,.2,1) both !important;
  }
}

@keyframes wpFadeUpSlow {
  from {opacity:0; transform:translateY(50px);}
  to {opacity:1; transform:translateY(0);}
}

.top-blue, .hero-card, .grad-panel, .profile-hero, .auth-card, .certificate-modern,
.feature-card, .module-card, .job-card, .progress-card, .question-card, .quiz-review-card,
.card, .panel, .box, .cta, .full-btn, .white-action, .claim-btn, .logout-profile-btn,
.google-login-btn, button, .btn {
  animation-name: wpFadeUpSlow;
  animation-duration: 2s;
  animation-timing-function: cubic-bezier(.2,.8,.2,1);
  animation-fill-mode: both;
}

.floating {
  animation-name: wpFadeUpSlow;
  animation-duration: 2.5s;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite;
}

@media(max-width:720px){
  .top-blue, .hero-card, .grad-panel, .profile-hero, .auth-card, .certificate-modern,
  .feature-card, .module-card, .job-card, .progress-card, .question-card, .quiz-review-card,
  .card, .panel, .box, .cta, .full-btn, .white-action, .claim-btn, .logout-profile-btn,
  .google-login-btn, button, .btn {
    animation-name: wpFadeUpSlow;
    animation-duration: 2s;
    animation-timing-function: cubic-bezier(.2,.8,.2,1);
    animation-fill-mode: both;
  }

  .floating {
    animation-name: wpFadeUpSlow;
    animation-duration: 2.5s;
    animation-timing-function: ease-in-out;
    animation-iteration-count: infinite;
  }
}

/* =========================================================
   WORKERPRO MAGIC ANIMATION V10 - FORCE SMOOTH
   Loader awal, transisi antar page, card reveal satu-satu,
   hover premium. Sengaja ditaruh paling bawah agar override
   animasi lama dan tidak kalah cache/style sebelumnya.
   ========================================================= */
:root{
  --wp-magic-blue:#2563eb;
  --wp-magic-violet:#7c3aed;
  --wp-magic-cyan:#06b6d4;
  --wp-magic-ink:#0f172a;
  --wp-magic-ease:cubic-bezier(.22,1,.36,1);
  --wp-magic-ease-out:cubic-bezier(.16,1,.3,1);
}

/* matikan loader lama yang pernah bug */
.wp-slow-enter-transition,
.wp-enter-transition,
.wp-page-transition,
.wp-final-page-transition,
.wp-v2-page-transition,
.wp-projectuas-transition,
.wp-premium-loader,
.wp-loader-overlay{
  display:none!important;
  opacity:0!important;
  visibility:hidden!important;
  pointer-events:none!important;
}

body.wp-slow-site-entering,
body.wp-site-entering,
body.wp-is-loading,
body.wp-v2-loading,
body.wp-final-leaving,
body.wp-page-leaving{
  overflow:auto!important;
}

html{scroll-behavior:smooth;}
body.wp-magic-page{
  animation:wpMagicBodyIn .48s var(--wp-magic-ease-out) both!important;
}
body.wp-magic-page::before,
body.wp-magic-page::after{
  content:"";
  position:fixed;
  z-index:-1;
  width:340px;
  height:340px;
  border-radius:999px;
  pointer-events:none;
  filter:blur(34px);
  opacity:.22;
  animation:wpMagicAura 10s ease-in-out infinite alternate!important;
}
body.wp-magic-page::before{
  top:10vh;
  left:-160px;
  background:radial-gradient(circle,rgba(37,99,235,.42),rgba(124,58,237,.14) 55%,transparent 72%);
}
body.wp-magic-page::after{
  right:-145px;
  bottom:2vh;
  background:radial-gradient(circle,rgba(6,182,212,.33),rgba(124,58,237,.13) 55%,transparent 72%);
  animation-delay:-4s!important;
}
@keyframes wpMagicAura{to{transform:translate3d(28px,-28px,0) scale(1.12)}}
@keyframes wpMagicBodyIn{from{opacity:.35;filter:blur(8px)}to{opacity:1;filter:blur(0)}}

/* loader awal website */
html.wp-magic-show-loader .wp-magic-loader{display:flex!important;}
html.wp-magic-skip-loader .wp-magic-loader{display:none!important;}
.wp-magic-loader{
  position:fixed!important;
  inset:0!important;
  z-index:2147483000!important;
  display:none;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  background:
    radial-gradient(circle at 18% 18%,rgba(37,99,235,.22),transparent 32%),
    radial-gradient(circle at 82% 76%,rgba(124,58,237,.18),transparent 34%),
    linear-gradient(135deg,#f8fbff,#ffffff 48%,#f4f0ff)!important;
  animation:wpMagicLoaderExit .55s ease 1.25s forwards!important;
}
.wp-magic-loader::before{
  content:"";
  position:absolute;
  inset:-35%;
  background:conic-gradient(from 180deg,rgba(37,99,235,.12),rgba(124,58,237,.2),rgba(14,165,233,.14),rgba(37,99,235,.12));
  filter:blur(46px);
  animation:wpMagicSpin 4s linear infinite!important;
}
.wp-magic-loader-card{
  position:relative;
  width:min(86vw,330px);
  padding:30px 26px 25px;
  border-radius:30px;
  text-align:center;
  background:rgba(255,255,255,.74);
  border:1px solid rgba(255,255,255,.9);
  box-shadow:0 28px 85px rgba(37,99,235,.18),inset 0 1px 0 rgba(255,255,255,.9);
  color:var(--wp-magic-ink);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  animation:wpMagicCardIn .7s var(--wp-magic-ease-out) both!important;
}
.wp-magic-logo{
  width:64px;
  height:64px;
  margin:0 auto 13px;
  border-radius:22px;
  display:grid;
  place-items:center;
  color:#fff;
  font-size:30px;
  font-weight:900;
  letter-spacing:-1px;
  background:linear-gradient(135deg,var(--wp-magic-blue),var(--wp-magic-violet));
  box-shadow:0 18px 38px rgba(79,70,229,.34);
  animation:wpMagicPulse 1.55s ease-in-out infinite!important;
}
.wp-magic-brand{font-size:23px;font-weight:900;letter-spacing:-.8px;line-height:1.1;margin-bottom:8px;color:#0f172a;}
.wp-magic-caption{font-size:13px;font-weight:700;line-height:1.35;color:#64748b;margin-bottom:18px;}
.wp-magic-bar{height:5px;width:150px;margin:0 auto;border-radius:999px;background:rgba(37,99,235,.12);overflow:hidden;}
.wp-magic-bar span{display:block;height:100%;width:44%;border-radius:inherit;background:linear-gradient(90deg,var(--wp-magic-blue),var(--wp-magic-violet),var(--wp-magic-cyan));animation:wpMagicBar 1s var(--wp-magic-ease-out) infinite!important;}
@keyframes wpMagicSpin{to{transform:rotate(360deg)}}
@keyframes wpMagicCardIn{from{opacity:0;transform:translateY(24px) scale(.94);filter:blur(14px)}to{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}}
@keyframes wpMagicPulse{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-3px) scale(1.045)}}
@keyframes wpMagicBar{0%{transform:translateX(-120%);width:32%}55%{width:66%}100%{transform:translateX(260%);width:34%}}
@keyframes wpMagicLoaderExit{to{opacity:0;visibility:hidden;pointer-events:none;filter:blur(10px)}}

/* card muncul pelan-pelan satu-satu */
body.wp-magic-page .wp-magic-reveal{
  opacity:0!important;
  transform:translate3d(0,30px,0) scale(.985)!important;
  filter:blur(12px)!important;
  transition:
    opacity .82s var(--wp-magic-ease-out),
    transform .82s var(--wp-magic-ease-out),
    filter .82s var(--wp-magic-ease-out)!important;
  transition-delay:var(--wp-magic-delay,0ms)!important;
  will-change:opacity,transform,filter;
}
body.wp-magic-page .wp-magic-reveal.wp-magic-visible{
  opacity:1!important;
  transform:translate3d(0,0,0) scale(1)!important;
  filter:blur(0)!important;
}

/* transisi keluar antar page: bukan loader besar */
.wp-route-bar{
  position:fixed;
  top:0;
  left:0;
  z-index:2147482500;
  width:100%;
  height:3px;
  pointer-events:none;
  opacity:0;
  transform:scaleX(.12);
  transform-origin:left;
  background:linear-gradient(90deg,var(--wp-magic-blue),var(--wp-magic-violet),var(--wp-magic-cyan));
  box-shadow:0 0 22px rgba(37,99,235,.28);
}
body.wp-magic-leaving .wp-route-bar{
  opacity:1!important;
  animation:wpMagicRouteBar .42s var(--wp-magic-ease-out) both!important;
}
@keyframes wpMagicRouteBar{to{transform:scaleX(1)}}
body.wp-magic-leaving main,
body.wp-magic-leaving .auth-page,
body.wp-magic-leaving .container,
body.wp-magic-leaving .wp-home-shell,
body.wp-magic-leaving .wp-jobs-shell,
body.wp-magic-leaving .wp-course-page,
body.wp-magic-leaving .wp-benefits-page,
body.wp-magic-leaving .wp-profile-page{
  opacity:0!important;
  transform:translate3d(0,-14px,0) scale(.992)!important;
  filter:blur(10px)!important;
  transition:opacity .22s ease,transform .22s ease,filter .22s ease!important;
}
body.wp-magic-leaving .bottom-nav{
  opacity:.68!important;
  transform:translateY(9px)!important;
  transition:opacity .22s ease,transform .22s ease!important;
}

/* hover premium */
body.wp-magic-page :where(
  .auth-card,.wp-login-card,.wp-register-card,.wp-login-hero,.top-blue,.hero-card,.grad-panel,.profile-hero,
  .certificate-modern,.stat,.why-card,.feature-card,.module-card,.video-card,.lesson-card,.lesson-content,.lesson-row,
  .job-card,.benefit-card,.progress-card,.question-card,.quiz-review-card,.admin-profile-card,.admin-dashboard-card,
  .card,.panel,.box,.form-card,.claim-empty-card,.claim-success-card,.search-box,
  .wp-home-panel,.wp-home-feature-card,.wp-home-stat-card,.wp-home-progress-card,.wp-home-cta-modern,
  .wp-course-card,.wp-course-panel,.wp-course-question,.wp-jobs-card,.wp-jobs-summary-card,.wp-jobs-app-card,.wp-jobs-form-card,
  .wp-benefits-card,.wp-benefits-summary-card,.wp-profile-card,.wp-profile-action
){
  position:relative;
  isolation:isolate;
  transform-style:preserve-3d;
  transition:transform .34s var(--wp-magic-ease),box-shadow .34s var(--wp-magic-ease),border-color .34s var(--wp-magic-ease),filter .34s var(--wp-magic-ease),background .34s var(--wp-magic-ease)!important;
}
body.wp-magic-page :where(
  .auth-card,.wp-login-card,.wp-register-card,.wp-login-hero,.top-blue,.hero-card,.grad-panel,.profile-hero,
  .certificate-modern,.stat,.why-card,.feature-card,.module-card,.video-card,.lesson-card,.lesson-content,.lesson-row,
  .job-card,.benefit-card,.progress-card,.question-card,.quiz-review-card,.admin-profile-card,.admin-dashboard-card,
  .card,.panel,.box,.form-card,.claim-empty-card,.claim-success-card,.search-box,
  .wp-home-panel,.wp-home-feature-card,.wp-home-stat-card,.wp-home-progress-card,.wp-home-cta-modern,
  .wp-course-card,.wp-course-panel,.wp-course-question,.wp-jobs-card,.wp-jobs-summary-card,.wp-jobs-app-card,.wp-jobs-form-card,
  .wp-benefits-card,.wp-benefits-summary-card,.wp-profile-card,.wp-profile-action
)::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  border-radius:inherit;
  pointer-events:none;
  opacity:0;
  background:radial-gradient(circle at var(--wp-mx,50%) var(--wp-my,50%),rgba(37,99,235,.16),transparent 36%);
  transition:opacity .34s ease!important;
}
@media (hover:hover){
  body.wp-magic-page :where(
    .auth-card,.wp-login-card,.wp-register-card,.wp-login-hero,.top-blue,.hero-card,.grad-panel,.profile-hero,
    .certificate-modern,.stat,.why-card,.feature-card,.module-card,.video-card,.lesson-card,.lesson-content,.lesson-row,
    .job-card,.benefit-card,.progress-card,.question-card,.quiz-review-card,.admin-profile-card,.admin-dashboard-card,
    .card,.panel,.box,.form-card,.claim-empty-card,.claim-success-card,.search-box,
    .wp-home-panel,.wp-home-feature-card,.wp-home-stat-card,.wp-home-progress-card,.wp-home-cta-modern,
    .wp-course-card,.wp-course-panel,.wp-course-question,.wp-jobs-card,.wp-jobs-summary-card,.wp-jobs-app-card,.wp-jobs-form-card,
    .wp-benefits-card,.wp-benefits-summary-card,.wp-profile-card,.wp-profile-action
  ):hover{
    transform:translateY(-6px) scale(1.008)!important;
    box-shadow:0 24px 60px rgba(15,23,42,.12),0 12px 28px rgba(37,99,235,.08)!important;
    filter:saturate(1.04)!important;
  }
  body.wp-magic-page :where(
    .auth-card,.wp-login-card,.wp-register-card,.wp-login-hero,.top-blue,.hero-card,.grad-panel,.profile-hero,
    .certificate-modern,.stat,.why-card,.feature-card,.module-card,.video-card,.lesson-card,.lesson-content,.lesson-row,
    .job-card,.benefit-card,.progress-card,.question-card,.quiz-review-card,.admin-profile-card,.admin-dashboard-card,
    .card,.panel,.box,.form-card,.claim-empty-card,.claim-success-card,.search-box,
    .wp-home-panel,.wp-home-feature-card,.wp-home-stat-card,.wp-home-progress-card,.wp-home-cta-modern,
    .wp-course-card,.wp-course-panel,.wp-course-question,.wp-jobs-card,.wp-jobs-summary-card,.wp-jobs-app-card,.wp-jobs-form-card,
    .wp-benefits-card,.wp-benefits-summary-card,.wp-profile-card,.wp-profile-action
  ):hover::after{opacity:1!important;}
}

/* button/nav hidup + ripple */
body.wp-magic-page :where(button,.btn,.cta,.full-btn,.small-btn,.white-action,.claim-btn,.logout-profile-btn,.google-login-btn,.wp-submit,.wp-google,.search-lowongan-btn,.nav-item,a[class*="btn"]){
  position:relative;
  overflow:hidden;
  transform:translateZ(0);
  transition:transform .22s var(--wp-magic-ease),box-shadow .22s var(--wp-magic-ease),filter .22s ease,background .22s ease!important;
}
@media (hover:hover){
  body.wp-magic-page :where(button,.btn,.cta,.full-btn,.small-btn,.white-action,.claim-btn,.logout-profile-btn,.google-login-btn,.wp-submit,.wp-google,.search-lowongan-btn,a[class*="btn"]):hover{
    transform:translateY(-2px) scale(1.012)!important;
    filter:saturate(1.06)!important;
  }
  body.wp-magic-page .bottom-nav .nav-item:hover{transform:translateY(-4px)!important;}
}
body.wp-magic-page :where(button,.btn,.cta,.full-btn,.small-btn,.white-action,.claim-btn,.logout-profile-btn,.google-login-btn,.wp-submit,.wp-google,.search-lowongan-btn,.nav-item,a[class*="btn"]):active{transform:scale(.985)!important;}
.wp-magic-ripple-parent{position:relative!important;overflow:hidden!important;}
.wp-magic-ink{position:absolute;z-index:4;border-radius:999px;pointer-events:none;background:rgba(255,255,255,.48);transform:scale(0);animation:wpMagicInk .62s ease-out forwards!important;mix-blend-mode:screen;}
@keyframes wpMagicInk{to{transform:scale(1);opacity:0}}

/* input glow */
body.wp-magic-page :where(input,select,textarea){transition:border-color .25s ease,box-shadow .25s ease,transform .25s ease,background .25s ease!important;}
body.wp-magic-page :where(input,select,textarea):focus{outline:none!important;border-color:rgba(99,102,241,.72)!important;box-shadow:0 0 0 4px rgba(99,102,241,.12),0 12px 28px rgba(99,102,241,.08)!important;transform:translateY(-1px)!important;}

/* bottom nav muncul smooth */
body.wp-magic-page .bottom-nav{animation:wpMagicBottomNav .62s var(--wp-magic-ease-out) both!important;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);}
@keyframes wpMagicBottomNav{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
body.wp-magic-page .bottom-nav .nav-item.active .nav-icon,
body.wp-magic-page .bottom-nav .nav-item.active svg,
body.wp-magic-page .bottom-nav .nav-item.active i{animation:wpMagicNavPulse 1.9s ease-in-out infinite!important;}
@keyframes wpMagicNavPulse{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-2px) scale(1.08)}}

/* paksa tetap animasi walau Windows/browser reduced motion aktif */
.wp-magic-loader,
.wp-magic-loader *,
body.wp-magic-page,
body.wp-magic-page::before,
body.wp-magic-page::after,
body.wp-magic-page .wp-magic-reveal,
body.wp-magic-page .bottom-nav,
body.wp-magic-page .bottom-nav *{
  animation-play-state:running!important;
}
@media (max-width:720px){
  .wp-magic-loader-card{width:min(86vw,300px);padding:26px 22px 23px;border-radius:28px;}
  .wp-magic-logo{width:56px;height:56px;border-radius:19px;font-size:26px;}
  body.wp-magic-page .wp-magic-reveal{transform:translate3d(0,24px,0) scale(.99)!important;filter:blur(9px)!important;transition-duration:.68s!important;}
}

/* =========================================================
   WorkerPro Alive Card Reveal v11
   - Tidak ada loading screen / fullscreen loader
   - Semua page pakai card reveal pelan-pelan
   - Hover, ripple, dan transisi page tetap smooth
   ========================================================= */
:root{
  --wp-alive-blue:#2563eb;
  --wp-alive-violet:#7c3aed;
  --wp-alive-cyan:#06b6d4;
  --wp-alive-ease:cubic-bezier(.22,.9,.24,1);
  --wp-alive-ease-out:cubic-bezier(.16,1,.3,1);
}

html{
  scroll-behavior:smooth;
}

/* Matikan total semua loader lama yang pernah dibuat */
#wpMagicLoader,
.wp-magic-loader,
.wp-premium-loader,
.wp-loader-overlay,
.wp-page-transition,
.wp-final-page-transition,
.wp-v2-page-transition,
.wp-projectuas-transition,
.wp-enter-transition,
.wp-slow-enter-transition{
  display:none!important;
  opacity:0!important;
  visibility:hidden!important;
  pointer-events:none!important;
  animation:none!important;
}

body.wp-alive-page{
  overflow-x:hidden;
  animation:wpAlivePageIn .42s var(--wp-alive-ease-out) both!important;
}

@keyframes wpAlivePageIn{
  from{opacity:.88;transform:translateY(10px);filter:blur(8px)}
  to{opacity:1;transform:translateY(0);filter:blur(0)}
}

/* Garis transisi kecil di atas saat pindah halaman, bukan loading screen */
body.wp-alive-page::before{
  content:"";
  position:fixed;
  top:0;
  left:0;
  z-index:2147482500;
  width:100%;
  height:3px;
  pointer-events:none;
  opacity:0;
  transform:scaleX(.08);
  transform-origin:left;
  background:linear-gradient(90deg,var(--wp-alive-blue),var(--wp-alive-violet),var(--wp-alive-cyan));
  box-shadow:0 0 24px rgba(37,99,235,.32);
}
body.wp-alive-page.wp-alive-leaving::before{
  opacity:1;
  animation:wpAliveRouteBar .28s var(--wp-alive-ease-out) both!important;
}
@keyframes wpAliveRouteBar{to{transform:scaleX(1)}}

/* Fallback CSS: kalau JS terlambat, elemen tetap ada animasi masuk */
body.wp-alive-page :where(
  .auth-card,.wp-login-card,.wp-register-card,.wp-login-hero,.wp-secure-badge,.wp-badge,
  .top-blue,.hero-card,.grad-panel,.profile-hero,.certificate-modern,
  .stat,.why-card,.feature-card,.module-card,.video-card,.lesson-card,.lesson-content,.lesson-row,
  .job-card,.benefit-card,.progress-card,.question-card,.quiz-review-card,
  .admin-profile-card,.admin-dashboard-card,.admin-bpjs-card,
  .card,.panel,.box,.form-card,.claim-empty-card,.claim-success-card,.search-box,.empty-search,
  .wp-home-hero,.wp-home-panel,.wp-home-feature-card,.wp-home-stat-card,.wp-home-progress-card,.wp-home-cta-modern,
  .wp-course-hero,.wp-course-panel,.wp-course-card,.wp-course-question,
  .wp-jobs-hero,.wp-jobs-panel,.wp-jobs-card,.wp-jobs-summary-card,.wp-jobs-app-card,.wp-jobs-form-card,
  .wp-benefits-hero,.wp-benefits-card,.wp-benefits-summary-card,
  .wp-profile-hero,.wp-profile-card,.wp-profile-action,
  main > section,main > div,.container > *
){
  animation:wpAliveAutoCard .74s var(--wp-alive-ease-out) both;
  animation-delay:.04s;
  will-change:opacity,transform,filter;
}

body.wp-alive-page :where(.stats,.why-list,.features,.lesson-list) > *:nth-child(1){animation-delay:.06s!important}
body.wp-alive-page :where(.stats,.why-list,.features,.lesson-list) > *:nth-child(2){animation-delay:.13s!important}
body.wp-alive-page :where(.stats,.why-list,.features,.lesson-list) > *:nth-child(3){animation-delay:.20s!important}
body.wp-alive-page :where(.stats,.why-list,.features,.lesson-list) > *:nth-child(4){animation-delay:.27s!important}
body.wp-alive-page :where(.stats,.why-list,.features,.lesson-list) > *:nth-child(5){animation-delay:.34s!important}

@keyframes wpAliveAutoCard{
  from{opacity:0;transform:translate3d(0,28px,0) scale(.982);filter:blur(12px)}
  to{opacity:1;transform:translate3d(0,0,0) scale(1);filter:blur(0)}
}

/* JS reveal: card muncul pelan-pelan satu-satu di semua page */
body.wp-alive-page .wp-alive-reveal{
  opacity:0!important;
  transform:translate3d(0,32px,0) scale(.982)!important;
  filter:blur(12px)!important;
  animation:none!important;
  transition:
    opacity .86s var(--wp-alive-ease-out),
    transform .86s var(--wp-alive-ease-out),
    filter .86s var(--wp-alive-ease-out)!important;
  transition-delay:var(--wp-alive-delay,0ms)!important;
  will-change:opacity,transform,filter;
}
body.wp-alive-page .wp-alive-reveal.wp-alive-visible{
  opacity:1!important;
  transform:translate3d(0,0,0) scale(1)!important;
  filter:blur(0)!important;
}

/* Transisi keluar antar halaman: konten mengecil halus */
body.wp-alive-page.wp-alive-leaving :where(
  main,.auth-page,.container,.wp-home-shell,.wp-jobs-shell,.wp-course-page,.wp-benefits-page,.wp-profile-page,
  .dashboard-page,.content,.page-wrapper
){
  opacity:0!important;
  transform:translate3d(0,-12px,0) scale(.992)!important;
  filter:blur(9px)!important;
  transition:opacity .22s ease,transform .22s ease,filter .22s ease!important;
}
body.wp-alive-page.wp-alive-leaving .bottom-nav{
  opacity:.62!important;
  transform:translateY(9px)!important;
  transition:opacity .22s ease,transform .22s ease!important;
}

/* Hover card premium tapi tetap smooth */
body.wp-alive-page :where(
  .auth-card,.wp-login-card,.wp-register-card,.wp-login-hero,.top-blue,.hero-card,.grad-panel,.profile-hero,
  .certificate-modern,.stat,.why-card,.feature-card,.module-card,.video-card,.lesson-card,.lesson-content,.lesson-row,
  .job-card,.benefit-card,.progress-card,.question-card,.quiz-review-card,.admin-profile-card,.admin-dashboard-card,
  .card,.panel,.box,.form-card,.claim-empty-card,.claim-success-card,.search-box,
  .wp-home-panel,.wp-home-feature-card,.wp-home-stat-card,.wp-home-progress-card,.wp-home-cta-modern,
  .wp-course-card,.wp-course-panel,.wp-course-question,.wp-jobs-card,.wp-jobs-summary-card,.wp-jobs-app-card,.wp-jobs-form-card,
  .wp-benefits-card,.wp-benefits-summary-card,.wp-profile-card,.wp-profile-action
){
  position:relative;
  isolation:isolate;
  transform-style:preserve-3d;
  transition:transform .34s var(--wp-alive-ease),box-shadow .34s var(--wp-alive-ease),border-color .34s var(--wp-alive-ease),filter .34s var(--wp-alive-ease),background .34s var(--wp-alive-ease)!important;
}
body.wp-alive-page :where(
  .auth-card,.wp-login-card,.wp-register-card,.wp-login-hero,.top-blue,.hero-card,.grad-panel,.profile-hero,
  .certificate-modern,.stat,.why-card,.feature-card,.module-card,.video-card,.lesson-card,.lesson-content,.lesson-row,
  .job-card,.benefit-card,.progress-card,.question-card,.quiz-review-card,.admin-profile-card,.admin-dashboard-card,
  .card,.panel,.box,.form-card,.claim-empty-card,.claim-success-card,.search-box,
  .wp-home-panel,.wp-home-feature-card,.wp-home-stat-card,.wp-home-progress-card,.wp-home-cta-modern,
  .wp-course-card,.wp-course-panel,.wp-course-question,.wp-jobs-card,.wp-jobs-summary-card,.wp-jobs-app-card,.wp-jobs-form-card,
  .wp-benefits-card,.wp-benefits-summary-card,.wp-profile-card,.wp-profile-action
)::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  border-radius:inherit;
  pointer-events:none;
  opacity:0;
  background:radial-gradient(circle at var(--wp-mx,50%) var(--wp-my,50%),rgba(37,99,235,.15),transparent 38%);
  transition:opacity .34s ease!important;
}
@media (hover:hover){
  body.wp-alive-page :where(
    .auth-card,.wp-login-card,.wp-register-card,.wp-login-hero,.top-blue,.hero-card,.grad-panel,.profile-hero,
    .certificate-modern,.stat,.why-card,.feature-card,.module-card,.video-card,.lesson-card,.lesson-content,.lesson-row,
    .job-card,.benefit-card,.progress-card,.question-card,.quiz-review-card,.admin-profile-card,.admin-dashboard-card,
    .card,.panel,.box,.form-card,.claim-empty-card,.claim-success-card,.search-box,
    .wp-home-panel,.wp-home-feature-card,.wp-home-stat-card,.wp-home-progress-card,.wp-home-cta-modern,
    .wp-course-card,.wp-course-panel,.wp-course-question,.wp-jobs-card,.wp-jobs-summary-card,.wp-jobs-app-card,.wp-jobs-form-card,
    .wp-benefits-card,.wp-benefits-summary-card,.wp-profile-card,.wp-profile-action
  ):hover{
    transform:translateY(-6px) scale(1.008)!important;
    box-shadow:0 24px 60px rgba(15,23,42,.12),0 12px 28px rgba(37,99,235,.08)!important;
    filter:saturate(1.04)!important;
  }
  body.wp-alive-page :where(
    .auth-card,.wp-login-card,.wp-register-card,.wp-login-hero,.top-blue,.hero-card,.grad-panel,.profile-hero,
    .certificate-modern,.stat,.why-card,.feature-card,.module-card,.video-card,.lesson-card,.lesson-content,.lesson-row,
    .job-card,.benefit-card,.progress-card,.question-card,.quiz-review-card,.admin-profile-card,.admin-dashboard-card,
    .card,.panel,.box,.form-card,.claim-empty-card,.claim-success-card,.search-box,
    .wp-home-panel,.wp-home-feature-card,.wp-home-stat-card,.wp-home-progress-card,.wp-home-cta-modern,
    .wp-course-card,.wp-course-panel,.wp-course-question,.wp-jobs-card,.wp-jobs-summary-card,.wp-jobs-app-card,.wp-jobs-form-card,
    .wp-benefits-card,.wp-benefits-summary-card,.wp-profile-card,.wp-profile-action
  ):hover::after{opacity:1!important;}
}

/* Button/nav hidup + ripple */
body.wp-alive-page :where(button,.btn,.cta,.full-btn,.small-btn,.white-action,.claim-btn,.logout-profile-btn,.google-login-btn,.wp-submit,.wp-google,.search-lowongan-btn,.nav-item,a[class*="btn"]){
  position:relative;
  overflow:hidden;
  transform:translateZ(0);
  transition:transform .22s var(--wp-alive-ease),box-shadow .22s var(--wp-alive-ease),filter .22s ease,background .22s ease!important;
}
@media (hover:hover){
  body.wp-alive-page :where(button,.btn,.cta,.full-btn,.small-btn,.white-action,.claim-btn,.logout-profile-btn,.google-login-btn,.wp-submit,.wp-google,.search-lowongan-btn,a[class*="btn"]):hover{
    transform:translateY(-2px) scale(1.012)!important;
    filter:saturate(1.06)!important;
  }
  body.wp-alive-page .bottom-nav .nav-item:hover{transform:translateY(-4px)!important;}
}
body.wp-alive-page :where(button,.btn,.cta,.full-btn,.small-btn,.white-action,.claim-btn,.logout-profile-btn,.google-login-btn,.wp-submit,.wp-google,.search-lowongan-btn,.nav-item,a[class*="btn"]):active{transform:scale(.985)!important;}
.wp-alive-ripple-parent{position:relative!important;overflow:hidden!important;}
.wp-alive-ink{
  position:absolute;
  z-index:4;
  border-radius:999px;
  pointer-events:none;
  background:rgba(255,255,255,.48);
  transform:scale(0);
  animation:wpAliveInk .68s ease-out forwards!important;
  mix-blend-mode:screen;
}
@keyframes wpAliveInk{to{transform:scale(1);opacity:0}}

/* Input glow */
body.wp-alive-page :where(input,select,textarea){
  transition:border-color .25s ease,box-shadow .25s ease,transform .25s ease,background .25s ease!important;
}
body.wp-alive-page :where(input,select,textarea):focus{
  outline:none!important;
  border-color:rgba(99,102,241,.72)!important;
  box-shadow:0 0 0 4px rgba(99,102,241,.12),0 12px 28px rgba(99,102,241,.08)!important;
  transform:translateY(-1px)!important;
}

/* Bottom nav masuk smooth */
body.wp-alive-page .bottom-nav{
  animation:wpAliveBottomNav .62s var(--wp-alive-ease-out) both!important;
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
}
@keyframes wpAliveBottomNav{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
body.wp-alive-page .bottom-nav .nav-item.active .nav-icon,
body.wp-alive-page .bottom-nav .nav-item.active svg,
body.wp-alive-page .bottom-nav .nav-item.active i{
  animation:wpAliveNavPulse 1.9s ease-in-out infinite!important;
}
@keyframes wpAliveNavPulse{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-2px) scale(1.08)}}

@media (max-width:720px){
  body.wp-alive-page .wp-alive-reveal{
    transform:translate3d(0,24px,0) scale(.99)!important;
    filter:blur(9px)!important;
    transition-duration:.72s!important;
  }
}


/* =========================================================
   WORKERPRO NAVBAR FIXED VIEWPORT v12
   - Navbar benar-benar nempel di bawah layar, bukan bawah page
   - Animasi card reveal tetap jalan
   - Loading screen tetap tidak ada
   ========================================================= */

/* Penting: body jangan dianimasikan pakai transform, karena bisa bikin fixed nav ikut page */
html,
body{
  transform:none !important;
  filter:none !important;
}

body.wp-alive-page{
  animation:none !important;
  transform:none !important;
  filter:none !important;
  opacity:1 !important;
  overflow-x:hidden !important;
  padding-bottom:96px !important;
}

/* Kalau bottom-nav berada di dalam wrapper yang punya transform/animation, matikan transform wrapper-nya saja */
.page:has(.bottom-nav),
.container:has(.bottom-nav),
main:has(.bottom-nav),
.content:has(.bottom-nav),
.page-wrapper:has(.bottom-nav),
.dashboard-page:has(.bottom-nav),
.wp-home-shell:has(.bottom-nav),
.wp-course-page:has(.bottom-nav),
.wp-jobs-shell:has(.bottom-nav),
.wp-benefits-page:has(.bottom-nav),
.wp-profile-page:has(.bottom-nav){
  transform:none !important;
  animation:none !important;
  filter:none !important;
}

/* Navbar wajib fixed ke viewport */
.bottom-nav,
body.wp-alive-page .bottom-nav,
body.wp-magic-page .bottom-nav,
body.wp-site-entered .bottom-nav,
body.wp-slow-site-entered .bottom-nav{
  position:fixed !important;
  left:0 !important;
  right:0 !important;
  bottom:0 !important;
  top:auto !important;
  width:100vw !important;
  height:76px !important;

  display:grid !important;
  grid-template-columns:repeat(5,1fr) !important;
  align-items:center !important;

  background:rgba(255,255,255,.97) !important;
  border-top:1px solid #e5e7eb !important;
  box-shadow:0 -12px 30px rgba(15,23,42,.08) !important;
  backdrop-filter:blur(18px) !important;
  -webkit-backdrop-filter:blur(18px) !important;

  z-index:2147482000 !important;
  opacity:1 !important;
  visibility:visible !important;
  transform:none !important;
  translate:none !important;
  animation:none !important;
  filter:none !important;
  margin:0 !important;
  border-radius:0 !important;
}

/* Kalau JS animasi sempat memberi class reveal ke navbar, paksa tetap normal */
.bottom-nav.wp-alive-reveal,
body.wp-alive-page .bottom-nav.wp-alive-reveal,
body.wp-alive-page .bottom-nav.wp-alive-visible,
body.wp-alive-page.wp-alive-leaving .bottom-nav{
  opacity:1 !important;
  visibility:visible !important;
  transform:none !important;
  translate:none !important;
  filter:none !important;
  animation:none !important;
  transition:none !important;
}

/* Item nav tetap rapi dan hover tetap premium */
.bottom-nav .nav-item,
.bottom-nav a{
  height:76px !important;
  min-width:0 !important;
  display:flex !important;
  flex-direction:column !important;
  align-items:center !important;
  justify-content:center !important;
  gap:5px !important;
  color:#64748b !important;
  font-size:12px !important;
  font-weight:600 !important;
  text-decoration:none !important;
  transition:color .22s ease, background .22s ease, transform .22s ease !important;
}

.bottom-nav .nav-item.active,
.bottom-nav a.active{
  color:var(--blue,#145cff) !important;
}

.bottom-nav .nav-icon{
  width:24px !important;
  height:24px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  color:inherit !important;
  transition:transform .22s ease !important;
}

.bottom-nav .nav-icon svg,
.bottom-nav .nav-icon [data-lucide],
.bottom-nav .nav-icon i{
  width:23px !important;
  height:23px !important;
  color:currentColor !important;
  stroke:currentColor !important;
}

@media(hover:hover){
  .bottom-nav .nav-item:hover,
  .bottom-nav a:hover{
    color:#2563eb !important;
    background:rgba(37,99,235,.07) !important;
    transform:translateY(-3px) !important;
  }
}

/* Jarak bawah supaya konten tidak ketutup navbar */
.container{
  padding-bottom:110px !important;
}

@media(max-width:720px){
  body.wp-alive-page,
  body{
    padding-bottom:86px !important;
  }

  .bottom-nav,
  body.wp-alive-page .bottom-nav{
    height:72px !important;
    width:100vw !important;
  }

  .bottom-nav .nav-item,
  .bottom-nav a{
    height:72px !important;
    font-size:11px !important;
  }

  .container{
    padding-bottom:96px !important;
  }
}

/* Marker cache: wp-navbar-fixed-v12-20260524 */

/* Marker cache: wp-mobile-keyboard-fix-v20-20260524 */

/* =========================================================
   wp-mobile-smooth-reveal-v21-20260524
   FIX GLITCH MOBILE:
   - Body tidak pakai blur/transform saat pertama buka
   - Mobile reveal hanya opacity + translateY kecil
   - Matikan blur/filter berat di HP supaya card masuk smooth
   - Animasi desktop tetap aman
   ========================================================= */

body.wp-alive-page {
  animation: none !important;
  opacity: 1 !important;
  transform: none !important;
  filter: none !important;
}

@media (max-width: 768px) {
  html,
  body {
    transform: none !important;
    filter: none !important;
  }

  body.wp-alive-page {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    overflow-x: hidden !important;
  }

  /* Critical prep: cegah flicker sebelum JS siap */
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .top-blue,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .hero-card,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .grad-panel,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .profile-hero,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .certificate-modern,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .stat,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .why-card,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .feature-card,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .module-card,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .video-card,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .lesson-card,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .lesson-row,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .job-card,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .benefit-card,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .progress-card,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .question-card,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .card,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .panel,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .box,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .search-box,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .cta,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .wp-login-card,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .wp-login-hero,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .auth-card {
    opacity: 0 !important;
    transform: translate3d(0, 14px, 0) !important;
    filter: none !important;
  }

  /* Matikan fallback animasi berat lama di mobile */
  body.wp-alive-page .top-blue,
  body.wp-alive-page .hero-card,
  body.wp-alive-page .grad-panel,
  body.wp-alive-page .profile-hero,
  body.wp-alive-page .certificate-modern,
  body.wp-alive-page .stat,
  body.wp-alive-page .why-card,
  body.wp-alive-page .feature-card,
  body.wp-alive-page .module-card,
  body.wp-alive-page .video-card,
  body.wp-alive-page .lesson-card,
  body.wp-alive-page .lesson-content,
  body.wp-alive-page .lesson-row,
  body.wp-alive-page .job-card,
  body.wp-alive-page .benefit-card,
  body.wp-alive-page .progress-card,
  body.wp-alive-page .question-card,
  body.wp-alive-page .quiz-review-card,
  body.wp-alive-page .admin-profile-card,
  body.wp-alive-page .admin-dashboard-card,
  body.wp-alive-page .card,
  body.wp-alive-page .panel,
  body.wp-alive-page .box,
  body.wp-alive-page .form-card,
  body.wp-alive-page .claim-empty-card,
  body.wp-alive-page .claim-success-card,
  body.wp-alive-page .search-box,
  body.wp-alive-page .empty-search,
  body.wp-alive-page .cta,
  body.wp-alive-page .wp-login-card,
  body.wp-alive-page .wp-register-card,
  body.wp-alive-page .wp-login-hero,
  body.wp-alive-page .auth-card {
    animation: none !important;
    filter: none !important;
    backface-visibility: hidden !important;
    -webkit-backface-visibility: hidden !important;
  }

  /* Reveal mobile yang ringan: tanpa blur supaya tidak patah/glitch */
  body.wp-alive-page .wp-alive-reveal {
    opacity: 0 !important;
    transform: translate3d(0, 14px, 0) !important;
    filter: none !important;
    animation: none !important;
    transition-property: opacity, transform !important;
    transition-duration: 0.52s, 0.52s !important;
    transition-timing-function: cubic-bezier(0.22, 1, 0.36, 1), cubic-bezier(0.22, 1, 0.36, 1) !important;
    transition-delay: var(--wp-alive-delay, 0ms), var(--wp-alive-delay, 0ms) !important;
    will-change: opacity, transform !important;
  }

  body.wp-alive-page .wp-alive-reveal.wp-alive-visible {
    opacity: 1 !important;
    transform: translate3d(0, 0, 0) !important;
    filter: none !important;
  }

  /* Transisi keluar lebih ringan di HP */
  body.wp-alive-page.wp-alive-leaving main,
  body.wp-alive-page.wp-alive-leaving .auth-page,
  body.wp-alive-page.wp-alive-leaving .container,
  body.wp-alive-page.wp-alive-leaving .page {
    opacity: 0.92 !important;
    transform: translate3d(0, -6px, 0) !important;
    filter: none !important;
    transition: opacity 0.18s ease, transform 0.18s ease !important;
  }

  /* Ripple dan nav pulse dimatikan di HP agar scroll/render lebih halus */
  .wp-alive-ink {
    display: none !important;
  }

  body.wp-alive-page .bottom-nav,
  body.wp-alive-page .bottom-nav .nav-item.active .nav-icon,
  body.wp-alive-page .bottom-nav .nav-item.active svg,
  body.wp-alive-page .bottom-nav .nav-item.active i {
    animation: none !important;
    filter: none !important;
  }
}

/* marker untuk cek di Ctrl+U: wp-mobile-smooth-reveal-v21-20260524 */


/* =========================================================
   wp-mobile-no-white-blink-v22-20260524
   FIX KEDIP PUTIH MOBILE:
   - Jangan hide section besar seperti .top-blue / .wp-login-hero
   - Background halaman disiapkan dari awal
   - Animasi card tetap smooth satu-satu
   - Filter/blur berat tetap dimatikan di mobile
   ========================================================= */

html,
body {
  background: #f6f7f9 !important;
}

body.wp-auth-page,
body:has(.wp-login-page),
body:has(.wp-auth-modern-page) {
  background: #f7f1ff !important;
}

@media (max-width: 768px) {
  html,
  body {
    background-color: #f6f7f9 !important;
    transform: none !important;
    filter: none !important;
    overflow-x: hidden !important;
  }

  body.wp-auth-page,
  body:has(.wp-login-page),
  body:has(.wp-auth-modern-page) {
    background: #f7f1ff !important;
  }

  /* INI KUNCI: section besar jangan pernah dibuat opacity 0 */
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .top-blue,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .wp-login-page,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .wp-login-shell,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .wp-login-hero,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .auth-page,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page main,
  html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .page {
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
    filter: none !important;
  }

  body.wp-alive-page .top-blue.wp-alive-reveal,
  body.wp-alive-page .wp-login-page.wp-alive-reveal,
  body.wp-alive-page .wp-login-shell.wp-alive-reveal,
  body.wp-alive-page .wp-login-hero.wp-alive-reveal,
  body.wp-alive-page .auth-page.wp-alive-reveal,
  body.wp-alive-page main.wp-alive-reveal,
  body.wp-alive-page .page.wp-alive-reveal {
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
    filter: none !important;
    transition: none !important;
    animation: none !important;
  }

  /* Card reveal dibuat lebih ringan supaya tidak flicker */
  body.wp-alive-page .wp-alive-reveal {
    opacity: 0 !important;
    visibility: visible !important;
    transform: translate3d(0, 10px, 0) !important;
    filter: none !important;
    animation: none !important;
    transition-property: opacity, transform !important;
    transition-duration: 0.46s, 0.46s !important;
    transition-timing-function: cubic-bezier(0.22, 1, 0.36, 1), cubic-bezier(0.22, 1, 0.36, 1) !important;
    transition-delay: var(--wp-alive-delay, 0ms), var(--wp-alive-delay, 0ms) !important;
    will-change: opacity, transform !important;
  }

  body.wp-alive-page .wp-alive-reveal.wp-alive-visible {
    opacity: 1 !important;
    transform: translate3d(0, 0, 0) !important;
    filter: none !important;
  }

  /* Kalau browser restore halaman dari back/forward cache, jangan kedip */
  html.wp-mobile-anim-ready body.wp-alive-page .wp-alive-reveal.wp-alive-visible {
    opacity: 1 !important;
  }

  /* Transisi keluar jangan putih/blank */
  body.wp-alive-page.wp-alive-leaving main,
  body.wp-alive-page.wp-alive-leaving .auth-page,
  body.wp-alive-page.wp-alive-leaving .container,
  body.wp-alive-page.wp-alive-leaving .page {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    transition: none !important;
  }
}

/* marker untuk cek di Ctrl+U: wp-mobile-no-white-blink-v22-20260524 */

/* =========================================================
   wp-anti-white-flash-v23-20260524
   Auth anti white flash handled in resources/views/layouts/auth.blade.php
   ========================================================= */

/* marker: wp-remove-comment-text-v24-20260524 */


/* =========================================================
   wp-restore-login-v26-20260525
   FIX LOGIN DESKTOP:
   - Desktop login dikembalikan ke background dotted/lavender, bukan biru full
   - Anti white flash hanya untuk mobile
   - V25 mobile stagger yang bikin login jelek dinetralisir di auth page
   ========================================================= */

/* Desktop login jangan pakai background biru anti-white-flash */
@media (min-width: 769px) {
  body:has(.wp-login-page),
  body:has(.wp-auth-modern-page),
  .wp-login-page,
  .wp-auth-modern-page {
    background:
      radial-gradient(circle at 1px 1px, rgba(124, 58, 237, 0.16) 1px, transparent 0) 0 0 / 22px 22px,
      #f7f1ff !important;
    background-color: #f7f1ff !important;
  }

  .auth-page {
    background:
      radial-gradient(circle at 1px 1px, rgba(124, 58, 237, 0.16) 1px, transparent 0) 0 0 / 22px 22px,
      #f7f1ff !important;
    background-color: #f7f1ff !important;
  }
}

/* Pastikan auth desktop tidak kena stagger mobile v25 */
@media (min-width: 769px) {
  .wp-login-page .wp-mobile-stagger-item,
  .wp-auth-modern-page .wp-mobile-stagger-item,
  .auth-page .wp-mobile-stagger-item {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    transition: none !important;
  }
}

/* Mobile: background langsung muncul supaya tidak ada kedip putih */
@media (max-width: 768px) {
  body:has(.wp-login-page),
  body:has(.wp-auth-modern-page),
  .wp-login-page,
  .wp-auth-modern-page,
  .auth-page {
    background: #f7f1ff !important;
    background-color: #f7f1ff !important;
  }

  /* jangan sembunyikan container login besar */
  .wp-login-page,
  .wp-login-shell,
  .wp-login-hero,
  .wp-login-card,
  .wp-auth-modern-page,
  .wp-auth-card,
  .auth-page,
  .auth-card {
    visibility: visible !important;
  }
}

/* marker: wp-restore-login-v26-20260525 */


/* =========================================================
   wp-auth-desktop-transition-v27-20260525
   FIX TRANSISI DESKTOP AUTH:
   - Klik "Lupa password" dan "Buat akun gratis" sekarang masuk dengan animasi desktop
   - Register dan forgot page punya elemen muncul satu-satu
   - Form/input tidak dianimasikan langsung supaya tidak berantakan
   - Mobile tetap seperti sebelumnya
   ========================================================= */

@keyframes wpAuthDesktopPageInV27 {
  from {
    opacity: 0;
    transform: translate3d(0, 16px, 0) scale(0.992);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
  }
}

@keyframes wpAuthDesktopLeftInV27 {
  from {
    opacity: 0;
    transform: translate3d(-26px, 0, 0) scale(0.99);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
  }
}

@keyframes wpAuthDesktopRightInV27 {
  from {
    opacity: 0;
    transform: translate3d(26px, 0, 0) scale(0.99);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
  }
}

@keyframes wpAuthDesktopItemInV27 {
  from {
    opacity: 0;
    transform: translate3d(0, 18px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@media (min-width: 769px) {
  .wp-auth-modern-page {
    animation: wpAuthDesktopPageInV27 0.58s cubic-bezier(0.22, 1, 0.36, 1) both !important;
  }

  .wp-auth-modern-page .wp-auth-hero {
    animation: wpAuthDesktopLeftInV27 0.72s cubic-bezier(0.22, 1, 0.36, 1) both !important;
  }

  .wp-auth-modern-page .wp-auth-card {
    animation: wpAuthDesktopRightInV27 0.72s cubic-bezier(0.22, 1, 0.36, 1) both !important;
  }

  .wp-auth-modern-page .wp-auth-brand,
  .wp-auth-modern-page .wp-auth-pill-link,
  .wp-auth-modern-page .wp-auth-badge,
  .wp-auth-modern-page .wp-auth-title,
  .wp-auth-modern-page .wp-auth-copy,
  .wp-auth-modern-page .wp-auth-stat-card,
  .wp-auth-modern-page .wp-auth-secure,
  .wp-auth-modern-page .wp-auth-card h1,
  .wp-auth-modern-page .wp-auth-intro,
  .wp-auth-modern-page .wp-auth-field,
  .wp-auth-modern-page .wp-auth-submit,
  .wp-auth-modern-page .wp-auth-help-card,
  .wp-auth-modern-page .wp-auth-bottom-text {
    opacity: 0;
    animation: wpAuthDesktopItemInV27 0.62s cubic-bezier(0.22, 1, 0.36, 1) both !important;
    animation-delay: var(--wp-auth-delay, 0ms) !important;
  }

  .wp-auth-modern-page .wp-auth-brand { --wp-auth-delay: 70ms; }
  .wp-auth-modern-page .wp-auth-pill-link { --wp-auth-delay: 110ms; }
  .wp-auth-modern-page .wp-auth-badge { --wp-auth-delay: 170ms; }
  .wp-auth-modern-page .wp-auth-title { --wp-auth-delay: 230ms; }
  .wp-auth-modern-page .wp-auth-copy { --wp-auth-delay: 300ms; }
  .wp-auth-modern-page .wp-auth-stat-card:nth-child(1) { --wp-auth-delay: 410ms; }
  .wp-auth-modern-page .wp-auth-stat-card:nth-child(2) { --wp-auth-delay: 470ms; }
  .wp-auth-modern-page .wp-auth-stat-card:nth-child(3) { --wp-auth-delay: 530ms; }

  .wp-auth-modern-page .wp-auth-secure { --wp-auth-delay: 160ms; }
  .wp-auth-modern-page .wp-auth-card h1 { --wp-auth-delay: 230ms; }
  .wp-auth-modern-page .wp-auth-intro { --wp-auth-delay: 300ms; }
  .wp-auth-modern-page .wp-auth-field:nth-of-type(1) { --wp-auth-delay: 380ms; }
  .wp-auth-modern-page .wp-auth-field:nth-of-type(2) { --wp-auth-delay: 450ms; }
  .wp-auth-modern-page .wp-auth-field:nth-of-type(3) { --wp-auth-delay: 520ms; }
  .wp-auth-modern-page .wp-auth-field:nth-of-type(4) { --wp-auth-delay: 590ms; }
  .wp-auth-modern-page .wp-auth-submit { --wp-auth-delay: 680ms; }
  .wp-auth-modern-page .wp-auth-help-card { --wp-auth-delay: 760ms; }
  .wp-auth-modern-page .wp-auth-bottom-text { --wp-auth-delay: 820ms; }

  /* Jangan animasikan input langsung supaya form tetap rapi */
  .wp-auth-modern-page input,
  .wp-auth-modern-page label,
  .wp-auth-modern-page svg,
  .wp-auth-modern-page i {
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
    filter: none !important;
  }

  body.wp-auth-leaving .wp-login-shell,
  body.wp-auth-leaving .wp-auth-modern-shell {
    opacity: 0.72 !important;
    transform: scale(0.988) !important;
    transition: opacity 0.18s ease, transform 0.18s ease !important;
  }
}

/* marker: wp-auth-desktop-transition-v27-20260525 */


/* =========================================================
   wp-v40-notif-real-fix-20260525
   REAL FIX NOTIFICATION DOT
   Masalah sebelumnya: JS tidak menangkap <summary class="wp-home-bell notif-bell">.
   Sekarang notif-dot hilang saat <details> dibuka dan statusnya disimpan.
   ========================================================= */

/* Dot langsung hilang ketika popup notification sedang dibuka */
.notif-wrap[open] > .notif-bell .notif-dot,
.notif-wrap[open] > summary .notif-dot,
.wp-home-notif[open] > .wp-home-bell .notif-dot {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
  transform: scale(0) !important;
  pointer-events: none !important;
}

/* Dot hilang permanen setelah sudah dibaca */
.notif-wrap.notif-read > .notif-bell .notif-dot,
.notif-wrap.notif-read > summary .notif-dot,
.notif-wrap.notif-read .notif-dot,
.wp-home-notif.notif-read > .wp-home-bell .notif-dot,
body.wp-notifications-read .notif-dot,
body.wp-notifications-read .wp-home-bell .notif-dot,
body.wp-notifications-read .notif-bell .notif-dot,
body.wp-notifications-read .notification-dot,
body.wp-notifications-read .notif-badge,
body.wp-notifications-read .notification-badge,
body.wp-notifications-read .bell-dot,
body.wp-notifications-read .red-dot,
body.wp-notifications-read .indicator-dot,
body.wp-notifications-read .wp-notification-red-dot {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
  transform: scale(0) !important;
  pointer-events: none !important;
}

/* Jika dot dibuat pseudo element oleh CSS, matikan juga */
.notif-wrap[open] > .notif-bell::after,
.notif-wrap[open] > summary::after,
.notif-wrap.notif-read > .notif-bell::after,
.notif-wrap.notif-read > summary::after,
body.wp-notifications-read .notif-bell::after,
body.wp-notifications-read .wp-home-bell::after,
body.wp-notifications-read [class*="notif"]::after,
body.wp-notifications-read [class*="bell"]::after {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
  transform: scale(0) !important;
  pointer-events: none !important;
}

/* marker: wp-v40-notif-real-fix-20260525 */


/* =========================================================
   wp-v41-assessment-button-fix-20260525
   FIX ASSESSMENT SUBMIT BUTTON
   Tombol Dapatkan Rekomendasi aktif setelah semua pertanyaan dijawab.
   ========================================================= */

form[data-enable-on-change] button[data-target-button]:not(:disabled),
form[data-enable-on-change] .wp-course-btn:not(:disabled) {
  background: linear-gradient(90deg, #2563eb, #9333ea) !important;
  box-shadow: 0 18px 42px rgba(88, 28, 135, .18) !important;
  cursor: pointer !important;
  opacity: 1 !important;
}

form[data-enable-on-change] button[data-target-button]:disabled,
form[data-enable-on-change] .wp-course-btn:disabled {
  background: #cbd5e1 !important;
  box-shadow: none !important;
  cursor: not-allowed !important;
  opacity: .95 !important;
}

/* marker: wp-v41-assessment-button-fix-20260525 */


/* =========================================================
   wp-v42-eye-outside-real-fix-20260525
   REAL FIX: IKON MATA DI LUAR KOTAK INPUT PASSWORD
   - Field password dibuat 2 kolom: input + tombol mata.
   - Tombol mata tidak absolute lagi dan tidak nabrak border.
   - Icon kiri password/email tetap di dalam input.
   ========================================================= */

/* Wrapper field password/login */
.wp-field .wp-input-wrap,
.auth-card .wp-input-wrap,
.wp-login-card .wp-input-wrap,
.wp-auth-card .wp-input-wrap,
.wp-field .password-wrap,
.auth-card .password-wrap,
.wp-login-card .password-wrap,
.wp-auth-card .password-wrap,
.wp-field .input-wrap,
.auth-card .input-wrap,
.wp-login-card .input-wrap,
.wp-auth-card .input-wrap {
  position: relative !important;
  overflow: visible !important;
}

/* Kalau ada tombol mata di dalam wrapper, wrapper jadi grid: input | eye */
.wp-field .wp-input-wrap:has(.wp-password-toggle),
.wp-field .wp-input-wrap:has(.password-toggle),
.wp-field .wp-input-wrap:has(.toggle-password),
.wp-field .wp-input-wrap:has(button[type="button"]),
.auth-card .wp-input-wrap:has(.wp-password-toggle),
.auth-card .wp-input-wrap:has(.password-toggle),
.auth-card .wp-input-wrap:has(.toggle-password),
.auth-card .wp-input-wrap:has(button[type="button"]),
.wp-login-card .wp-input-wrap:has(.wp-password-toggle),
.wp-login-card .wp-input-wrap:has(.password-toggle),
.wp-login-card .wp-input-wrap:has(.toggle-password),
.wp-login-card .wp-input-wrap:has(button[type="button"]),
.wp-auth-card .wp-input-wrap:has(.wp-password-toggle),
.wp-auth-card .wp-input-wrap:has(.password-toggle),
.wp-auth-card .wp-input-wrap:has(.toggle-password),
.wp-auth-card .wp-input-wrap:has(button[type="button"]) {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 44px !important;
  align-items: center !important;
  column-gap: 10px !important;
}

/* Input password hanya mengisi kolom kiri */
.wp-field .wp-input-wrap:has(.wp-password-toggle) input,
.wp-field .wp-input-wrap:has(.password-toggle) input,
.wp-field .wp-input-wrap:has(.toggle-password) input,
.wp-field .wp-input-wrap:has(button[type="button"]) input,
.auth-card .wp-input-wrap:has(.wp-password-toggle) input,
.auth-card .wp-input-wrap:has(.password-toggle) input,
.auth-card .wp-input-wrap:has(.toggle-password) input,
.auth-card .wp-input-wrap:has(button[type="button"]) input,
.wp-login-card .wp-input-wrap:has(.wp-password-toggle) input,
.wp-login-card .wp-input-wrap:has(.password-toggle) input,
.wp-login-card .wp-input-wrap:has(.toggle-password) input,
.wp-login-card .wp-input-wrap:has(button[type="button"]) input,
.wp-auth-card .wp-input-wrap:has(.wp-password-toggle) input,
.wp-auth-card .wp-input-wrap:has(.password-toggle) input,
.wp-auth-card .wp-input-wrap:has(.toggle-password) input,
.wp-auth-card .wp-input-wrap:has(button[type="button"]) input {
  grid-column: 1 !important;
  width: 100% !important;
  min-width: 0 !important;
  padding-right: 18px !important;
}

/* Icon kiri dalam input tetap absolute di dalam kolom input */
.wp-field .wp-input-wrap > i:first-child,
.wp-field .wp-input-wrap > svg:first-child,
.auth-card .wp-input-wrap > i:first-child,
.auth-card .wp-input-wrap > svg:first-child,
.wp-login-card .wp-input-wrap > i:first-child,
.wp-login-card .wp-input-wrap > svg:first-child,
.wp-auth-card .wp-input-wrap > i:first-child,
.wp-auth-card .wp-input-wrap > svg:first-child {
  position: absolute !important;
  left: 18px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  z-index: 4 !important;
  pointer-events: none !important;
}

/* Tombol mata dipaksa menjadi tombol terpisah di luar kotak input */
.wp-password-toggle,
.password-toggle,
.toggle-password,
.show-password,
.eye-toggle,
button[type="button"].wp-password-toggle,
button[type="button"].password-toggle,
button[type="button"].toggle-password,
.wp-input-wrap button[type="button"] {
  position: static !important;
  inset: auto !important;
  top: auto !important;
  right: auto !important;
  bottom: auto !important;
  left: auto !important;
  transform: none !important;

  grid-column: 2 !important;
  justify-self: end !important;
  align-self: center !important;

  width: 44px !important;
  height: 44px !important;
  min-width: 44px !important;
  min-height: 44px !important;
  max-width: 44px !important;
  max-height: 44px !important;

  display: grid !important;
  place-items: center !important;

  padding: 0 !important;
  margin: 0 !important;
  border: 1.5px solid rgba(148, 163, 184, 0.30) !important;
  border-radius: 14px !important;
  outline: 0 !important;
  background: #ffffff !important;
  color: #64748b !important;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.07) !important;
  cursor: pointer !important;
  z-index: 5 !important;
}

.wp-password-toggle:hover,
.password-toggle:hover,
.toggle-password:hover,
.show-password:hover,
.eye-toggle:hover,
.wp-input-wrap button[type="button"]:hover {
  background: rgba(124, 58, 237, 0.08) !important;
  border-color: rgba(124, 58, 237, 0.38) !important;
  color: #6d28d9 !important;
  transform: translateY(-1px) !important;
}

/* Icon mata di dalam tombol */
.wp-password-toggle svg,
.wp-password-toggle i,
.password-toggle svg,
.password-toggle i,
.toggle-password svg,
.toggle-password i,
.show-password svg,
.show-password i,
.eye-toggle svg,
.eye-toggle i,
.wp-input-wrap button[type="button"] svg,
.wp-input-wrap button[type="button"] i {
  position: static !important;
  inset: auto !important;
  transform: none !important;
  width: 20px !important;
  height: 20px !important;
  min-width: 20px !important;
  min-height: 20px !important;
  margin: 0 !important;
  display: block !important;
  color: currentColor !important;
  stroke-width: 2.2 !important;
  pointer-events: none !important;
}

/* Fallback jika browser tidak support :has(), class ini ditambahkan JS */
.wp-input-wrap.wp-eye-outside {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 44px !important;
  align-items: center !important;
  column-gap: 10px !important;
}

.wp-input-wrap.wp-eye-outside input {
  grid-column: 1 !important;
  width: 100% !important;
  min-width: 0 !important;
  padding-right: 18px !important;
}

.wp-input-wrap.wp-eye-outside .wp-password-toggle,
.wp-input-wrap.wp-eye-outside .password-toggle,
.wp-input-wrap.wp-eye-outside .toggle-password,
.wp-input-wrap.wp-eye-outside button[type="button"] {
  grid-column: 2 !important;
}

@media (max-width: 768px) {
  .wp-field .wp-input-wrap:has(.wp-password-toggle),
  .wp-field .wp-input-wrap:has(.password-toggle),
  .wp-field .wp-input-wrap:has(.toggle-password),
  .wp-field .wp-input-wrap:has(button[type="button"]),
  .auth-card .wp-input-wrap:has(.wp-password-toggle),
  .auth-card .wp-input-wrap:has(.password-toggle),
  .auth-card .wp-input-wrap:has(.toggle-password),
  .auth-card .wp-input-wrap:has(button[type="button"]),
  .wp-login-card .wp-input-wrap:has(.wp-password-toggle),
  .wp-login-card .wp-input-wrap:has(.password-toggle),
  .wp-login-card .wp-input-wrap:has(.toggle-password),
  .wp-login-card .wp-input-wrap:has(button[type="button"]),
  .wp-auth-card .wp-input-wrap:has(.wp-password-toggle),
  .wp-auth-card .wp-input-wrap:has(.password-toggle),
  .wp-auth-card .wp-input-wrap:has(.toggle-password),
  .wp-auth-card .wp-input-wrap:has(button[type="button"]),
  .wp-input-wrap.wp-eye-outside {
    grid-template-columns: minmax(0, 1fr) 40px !important;
    column-gap: 8px !important;
  }

  .wp-password-toggle,
  .password-toggle,
  .toggle-password,
  .show-password,
  .eye-toggle,
  .wp-input-wrap button[type="button"] {
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    min-height: 40px !important;
    max-width: 40px !important;
    max-height: 40px !important;
    border-radius: 12px !important;
  }

  .wp-password-toggle svg,
  .wp-password-toggle i,
  .password-toggle svg,
  .password-toggle i,
  .toggle-password svg,
  .toggle-password i,
  .wp-input-wrap button[type="button"] svg,
  .wp-input-wrap button[type="button"] i {
    width: 18px !important;
    height: 18px !important;
    min-width: 18px !important;
    min-height: 18px !important;
  }
}

/* marker: wp-v42-eye-outside-real-fix-20260525 */


/* =========================================================
   wp-v43-slider-mobile-only-fix-20260525
   FIX: SLIDER/DOTS HANYA UNTUK MOBILE
========================================================= */

@media (min-width: 769px) {
  .benefits-dots,
  .benefit-dots,
  .bpjs-dots,
  .bpjs-slider-dots,
  .protection-dots,
  .protection-slider-dots,
  .jaminan-dots,
  .claim-dots,
  .slider-dots,
  .carousel-dots,
  .swiper-pagination,
  .splide__pagination,
  .glide__bullets,
  .owl-dots,
  .slick-dots,
  .wp-benefits-dots,
  .wp-protection-dots,
  .mobile-slider-dots,
  .mobile-only-dots,
  .scroll-dots,
  .slide-indicators,
  .slider-indicators,
  .carousel-indicators,
  [class*="slider-dots"],
  [class*="carousel-dots"],
  [class*="slide-indicator"],
  [class*="slider-indicator"] {
    display: none !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }

  .benefits-track,
  .benefit-track,
  .bpjs-track,
  .bpjs-slider,
  .protection-track,
  .protection-slider,
  .jaminan-track,
  .claim-track,
  .cards-slider,
  .card-slider,
  .slider-track,
  .carousel-track,
  .wp-benefits-track,
  .wp-protection-track,
  .mobile-slider,
  .mobile-carousel {
    overflow: visible !important;
    scroll-snap-type: none !important;
    scroll-behavior: auto !important;
  }

  .benefits-track,
  .bpjs-track,
  .protection-track,
  .jaminan-track,
  .wp-benefits-track,
  .wp-protection-track {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 22px !important;
  }

  .benefits-track > *,
  .benefit-track > *,
  .bpjs-track > *,
  .bpjs-slider > *,
  .protection-track > *,
  .protection-slider > *,
  .jaminan-track > *,
  .claim-track > *,
  .cards-slider > *,
  .card-slider > *,
  .slider-track > *,
  .carousel-track > *,
  .wp-benefits-track > *,
  .wp-protection-track > *,
  .mobile-slider > *,
  .mobile-carousel > * {
    scroll-snap-align: none !important;
  }
}

@media (max-width: 768px) {
  .benefits-dots,
  .benefit-dots,
  .bpjs-dots,
  .bpjs-slider-dots,
  .protection-dots,
  .protection-slider-dots,
  .jaminan-dots,
  .claim-dots,
  .slider-dots,
  .carousel-dots,
  .swiper-pagination,
  .splide__pagination,
  .glide__bullets,
  .owl-dots,
  .slick-dots,
  .wp-benefits-dots,
  .wp-protection-dots,
  .mobile-slider-dots,
  .mobile-only-dots,
  .scroll-dots,
  .slide-indicators,
  .slider-indicators,
  .carousel-indicators {
    display: flex !important;
    visibility: visible !important;
  }
}

/* marker: wp-v43-slider-mobile-only-fix-20260525 */


/* =========================================================
   wp-v45-toast-visible-fix-20260527
   FIX POPUP SUCCESS: muncul dulu, lalu hilang otomatis.
   ========================================================= */

.flash.success,
.alert-success,
.wp-flash-success,
.toast-success,
.success-toast,
.profile-success-toast,
.flash:not(.error):not(.danger),
.wp-flash:not(.error):not(.danger) {
  position: fixed !important;
  top: 18px !important;
  left: 50% !important;
  right: auto !important;
  bottom: auto !important;
  z-index: 99999 !important;

  width: max-content !important;
  max-width: calc(100vw - 32px) !important;
  min-height: 44px !important;

  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;

  padding: 12px 18px 12px 20px !important;
  border-radius: 14px !important;
  border: 1px solid rgba(226, 232, 240, .9) !important;
  border-left: 5px solid #22c55e !important;

  background: rgba(255, 255, 255, .97) !important;
  color: #0f172a !important;
  font-weight: 700 !important;
  box-shadow: 0 18px 44px rgba(15, 23, 42, .16) !important;
  backdrop-filter: blur(18px) !important;
  -webkit-backdrop-filter: blur(18px) !important;

  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: none !important;
  transform: translateX(-50%) translateY(0) scale(1) !important;

  animation: wpToastEnterV45 .32s cubic-bezier(.22, 1, .36, 1) both !important;
}

.flash.error,
.alert-danger,
.alert-error,
.wp-flash-error {
  position: fixed !important;
  top: 18px !important;
  left: 50% !important;
  right: auto !important;
  bottom: auto !important;
  z-index: 99999 !important;

  max-width: calc(100vw - 32px) !important;
  padding: 12px 18px !important;
  border-radius: 14px !important;
  border: 1px solid rgba(254, 202, 202, .9) !important;
  border-left: 5px solid #ef4444 !important;

  background: rgba(255, 255, 255, .97) !important;
  color: #991b1b !important;
  font-weight: 700 !important;
  box-shadow: 0 18px 44px rgba(15, 23, 42, .16) !important;

  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: none !important;
  transform: translateX(-50%) translateY(0) scale(1) !important;

  animation: wpToastEnterV45 .32s cubic-bezier(.22, 1, .36, 1) both !important;
}

.flash.wp-toast-hide-v45,
.alert.wp-toast-hide-v45,
.toast.wp-toast-hide-v45,
.wp-flash.wp-toast-hide-v45,
[class*="flash"].wp-toast-hide-v45,
[class*="toast"].wp-toast-hide-v45 {
  opacity: 0 !important;
  visibility: hidden !important;
  transform: translateX(-50%) translateY(-14px) scale(.96) !important;
  transition: opacity .28s ease, visibility .28s ease, transform .28s ease !important;
}

@keyframes wpToastEnterV45 {
  from {
    opacity: 0;
    transform: translateX(-50%) translateY(-12px) scale(.96);
  }
  to {
    opacity: 1;
    transform: translateX(-50%) translateY(0) scale(1);
  }
}

@media (max-width: 768px) {
  .flash.success,
  .alert-success,
  .wp-flash-success,
  .toast-success,
  .success-toast,
  .profile-success-toast,
  .flash:not(.error):not(.danger),
  .wp-flash:not(.error):not(.danger),
  .flash.error,
  .alert-danger,
  .alert-error,
  .wp-flash-error {
    top: 12px !important;
    width: calc(100vw - 28px) !important;
    max-width: calc(100vw - 28px) !important;
    text-align: center !important;
    font-size: 14px !important;
    padding: 12px 14px !important;
  }
}

/* marker: wp-v45-toast-visible-fix-20260527 */

/* =========================================================
   wp-v50-navbar-active-shadow-fix-20260528
   FIX KHUSUS: ACTIVE NAVBAR SHADOW/BACKGROUND OFFSIDE
   Hanya membenahi highlight biru di bottom navbar.
   Tidak mengubah UI/section lain.
   ========================================================= */

.bottom-nav {
  overflow: hidden !important;
}

.bottom-nav .nav-item,
.bottom-nav a {
  position: relative !important;
  isolation: isolate !important;
  overflow: visible !important;
  background: transparent !important;
  box-shadow: none !important;
}

.bottom-nav .nav-item.active,
.bottom-nav a.active,
.bottom-nav .nav-item[aria-current="page"],
.bottom-nav a[aria-current="page"] {
  background: transparent !important;
  box-shadow: none !important;
}

.bottom-nav .nav-item.active::before,
.bottom-nav a.active::before,
.bottom-nav .nav-item[aria-current="page"]::before,
.bottom-nav a[aria-current="page"]::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 8px;
  width: 58px;
  height: 44px;
  transform: translateX(-50%);
  border-radius: 18px;
  background: rgba(37, 99, 235, 0.08);
  z-index: -1;
  pointer-events: none;
}

.bottom-nav .nav-item.active .nav-icon,
.bottom-nav a.active .nav-icon,
.bottom-nav .nav-item[aria-current="page"] .nav-icon,
.bottom-nav a[aria-current="page"] .nav-icon {
  background: transparent !important;
  box-shadow: none !important;
  color: #2563eb !important;
}

.bottom-nav .nav-item.active span,
.bottom-nav a.active span,
.bottom-nav .nav-item[aria-current="page"] span,
.bottom-nav a[aria-current="page"] span {
  color: #2563eb !important;
  font-weight: 700 !important;
}

@media (max-width: 720px) {
  .bottom-nav .nav-item.active::before,
  .bottom-nav a.active::before,
  .bottom-nav .nav-item[aria-current="page"]::before,
  .bottom-nav a[aria-current="page"]::before {
    top: 8px;
    width: 52px;
    height: 42px;
    border-radius: 17px;
  }
}

/* marker: wp-v50-navbar-active-shadow-fix-20260528 */

/* =========================================================
   wp-v52-mobile-feature-card-spacing-20260529
   FIX KHUSUS MOBILE: jarak teks fitur utama
   Tidak mengubah layout desktop.
   ========================================================= */
@media (max-width: 720px) {
  .feature-card {
    min-height: 166px !important;
    padding: 18px 18px 20px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
  }

  .feature-card h3 {
    margin: 0 0 8px !important;
    line-height: 1.25 !important;
  }

  .feature-card p {
    margin: 0 0 14px !important;
    line-height: 1.55 !important;
    font-size: 13px !important;
  }

  .feature-card a,
  .feature-card .feature-link {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    margin-top: auto !important;
    line-height: 1.25 !important;
    font-weight: 800 !important;
  }
}

/* marker: wp-v52-mobile-feature-card-spacing-20260529 */

/* =========================================================
   wp-v53-ai-navbar-css-20260529
   NAVBAR AI MENU - 6 ITEM
   Khusus menyesuaikan bottom navbar setelah menu AI ditambahkan.
   ========================================================= */

.bottom-nav {
  grid-template-columns: repeat(6, 1fr) !important;
}

.bottom-nav .nav-item,
.bottom-nav a {
  font-size: 11px !important;
  gap: 4px !important;
  min-width: 0 !important;
}

.bottom-nav .nav-item span:last-child,
.bottom-nav a span:last-child {
  max-width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.bottom-nav .nav-icon {
  width: 22px !important;
  height: 22px !important;
}

.bottom-nav .nav-icon svg,
.bottom-nav .nav-icon [data-lucide] {
  width: 22px !important;
  height: 22px !important;
  stroke-width: 2.2 !important;
}

@media (max-width: 720px) {
  .bottom-nav {
    height: 76px !important;
    grid-template-columns: repeat(6, 1fr) !important;
  }

  .bottom-nav .nav-item,
  .bottom-nav a {
    height: 76px !important;
    font-size: 10.5px !important;
    gap: 4px !important;
    padding: 0 2px !important;
  }

  .bottom-nav .nav-icon {
    width: 21px !important;
    height: 21px !important;
  }

  .bottom-nav .nav-icon svg,
  .bottom-nav .nav-icon [data-lucide] {
    width: 21px !important;
    height: 21px !important;
  }
}

@media (max-width: 390px) {
  .bottom-nav .nav-item,
  .bottom-nav a {
    font-size: 10px !important;
  }

  .bottom-nav .nav-icon {
    width: 20px !important;
    height: 20px !important;
  }

  .bottom-nav .nav-icon svg,
  .bottom-nav .nav-icon [data-lucide] {
    width: 20px !important;
    height: 20px !important;
  }
}

/* marker: wp-v53-ai-navbar-css-20260529 */

/* =========================================================
   wp-v54-ai-chat-blank-page-fix-20260529
   FIX AI CHAT BLANK PAGE + NAVBAR 6 MENU
   Tambahan aman: tidak menghapus CSS lama, hanya override.
   ========================================================= */

/* Navbar sekarang ada 6 item: Beranda, Pelatihan, Kerja, Jaminan, AI, Profil */
.bottom-nav {
  display: grid !important;
  grid-template-columns: repeat(6, 1fr) !important;
  height: 76px !important;
  z-index: 99999 !important;
}

.bottom-nav .nav-item,
.bottom-nav a {
  min-width: 0 !important;
  height: 76px !important;
  font-size: 11px !important;
  gap: 4px !important;
  padding: 0 2px !important;
}

.bottom-nav .nav-item span:last-child,
.bottom-nav a span:last-child {
  max-width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.bottom-nav .nav-icon,
.bottom-nav .nav-icon svg,
.bottom-nav .nav-icon [data-lucide] {
  width: 22px !important;
  height: 22px !important;
}

/* Paksa halaman AI tampil, karena animasi lama bisa bikin blank sampai inspect dibuka */
body:has(.ai-chat-page) {
  background: #f6f7f9 !important;
  padding-bottom: 86px !important;
  overflow-x: hidden !important;
}

body:has(.ai-chat-page) .container {
  display: block !important;
  width: 100% !important;
  min-height: calc(100vh - 86px) !important;
  padding: 24px 18px 110px !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  filter: none !important;
}

.ai-chat-page,
.ai-chat-page *,
.ai-chat-head,
.ai-chat-box,
.ai-chat-form {
  opacity: 1 !important;
  visibility: visible !important;
  filter: none !important;
}

.ai-chat-page {
  display: block !important;
  transform: none !important;
  animation: none !important;
  position: relative !important;
  z-index: 5 !important;
}

.ai-chat-page .ai-chat-head {
  display: flex !important;
}

.ai-chat-page .ai-chat-box {
  display: flex !important;
}

.ai-chat-page .ai-chat-form {
  display: flex !important;
}

/* Override class animasi mobile lama yang kadang bikin konten tidak muncul */
html.wp-mobile-anim-prep body.wp-alive-page .ai-chat-page,
html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .ai-chat-page,
html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .ai-chat-head,
html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .ai-chat-box,
html.wp-mobile-anim-prep:not(.wp-mobile-anim-ready) body.wp-alive-page .ai-chat-form {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  filter: none !important;
  animation: none !important;
}

@media (max-width: 720px) {
  .bottom-nav {
    grid-template-columns: repeat(6, 1fr) !important;
  }

  .bottom-nav .nav-item,
  .bottom-nav a {
    font-size: 10.5px !important;
  }

  .bottom-nav .nav-icon,
  .bottom-nav .nav-icon svg,
  .bottom-nav .nav-icon [data-lucide] {
    width: 21px !important;
    height: 21px !important;
  }

  body:has(.ai-chat-page) .container {
    padding: 12px 10px 104px !important;
  }

  .ai-chat-page {
    margin: 10px auto 0 !important;
    max-width: 100% !important;
  }
}

@media (max-width: 390px) {
  .bottom-nav .nav-item,
  .bottom-nav a {
    font-size: 10px !important;
  }

  .bottom-nav .nav-icon,
  .bottom-nav .nav-icon svg,
  .bottom-nav .nav-icon [data-lucide] {
    width: 20px !important;
    height: 20px !important;
  }
}

/* marker: wp-v54-ai-chat-blank-page-fix-20260529 */

/* =========================================================
   wp-v56-navbar-profile-ai-order-fix-20260529
   FIX NAVBAR 6 MENU + URUTAN PROFIL SEBELUM AI
   Urutan akhir: Beranda, Pelatihan, Kerja, Jaminan, Profil, AI
   ========================================================= */

body {
  padding-bottom: 76px !important;
}

.bottom-nav {
  position: fixed !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100% !important;
  height: 76px !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  background: #ffffff !important;
  border-top: 1px solid #e5e7eb !important;
  display: grid !important;
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  align-items: center !important;
  overflow: visible !important;
  z-index: 99999 !important;
  transform: none !important;
  animation: none !important;
}

/* Paksa urutan navbar walaupun urutan di Blade belum rapi */
.bottom-nav .nav-item:nth-child(1),
.bottom-nav a:nth-child(1) {
  order: 1 !important;
}

.bottom-nav .nav-item:nth-child(2),
.bottom-nav a:nth-child(2) {
  order: 2 !important;
}

.bottom-nav .nav-item:nth-child(3),
.bottom-nav a:nth-child(3) {
  order: 3 !important;
}

.bottom-nav .nav-item:nth-child(4),
.bottom-nav a:nth-child(4) {
  order: 4 !important;
}

.bottom-nav a[href*="profil"],
.bottom-nav a[href*="/profil"] {
  order: 5 !important;
}

.bottom-nav a[href*="ai-chat"],
.bottom-nav a[href*="/ai-chat"] {
  order: 6 !important;
}

.bottom-nav .nav-item,
.bottom-nav a {
  min-width: 0 !important;
  width: 100% !important;
  height: 76px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 4px !important;
  padding: 0 2px !important;
  color: #64748b !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  line-height: 1.15 !important;
  text-align: center !important;
  text-decoration: none !important;
  white-space: nowrap !important;
}

.bottom-nav .nav-item.active,
.bottom-nav a.active {
  color: var(--blue) !important;
}

.bottom-nav .nav-item > span:last-child,
.bottom-nav a > span:last-child {
  display: block !important;
  max-width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.bottom-nav .nav-icon {
  width: 23px !important;
  height: 23px !important;
  min-width: 23px !important;
  min-height: 23px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 auto !important;
  font-size: 0 !important;
  line-height: 1 !important;
}

.bottom-nav .nav-icon svg,
.bottom-nav .nav-icon [data-lucide] {
  width: 22px !important;
  height: 22px !important;
  min-width: 22px !important;
  min-height: 22px !important;
  display: block !important;
  color: currentColor !important;
  stroke: currentColor !important;
  stroke-width: 2.2 !important;
}

@media (max-width: 720px) {
  .bottom-nav {
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
    height: 76px !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .bottom-nav .nav-item,
  .bottom-nav a {
    height: 76px !important;
    font-size: 10.5px !important;
    gap: 4px !important;
    padding: 0 1px !important;
  }

  .bottom-nav .nav-icon {
    width: 21px !important;
    height: 21px !important;
    min-width: 21px !important;
    min-height: 21px !important;
  }

  .bottom-nav .nav-icon svg,
  .bottom-nav .nav-icon [data-lucide] {
    width: 21px !important;
    height: 21px !important;
    min-width: 21px !important;
    min-height: 21px !important;
  }
}

@media (max-width: 390px) {
  .bottom-nav .nav-item,
  .bottom-nav a {
    font-size: 10px !important;
  }

  .bottom-nav .nav-icon,
  .bottom-nav .nav-icon svg,
  .bottom-nav .nav-icon [data-lucide] {
    width: 20px !important;
    height: 20px !important;
    min-width: 20px !important;
    min-height: 20px !important;
  }
}

/* marker: wp-v56-navbar-profile-ai-order-fix-20260529 */

/* =========================================================
   wp-v58-final-six-navbar-ai-visible-20260529
   FINAL FIX NAVBAR 6 MENU
   Urutan: Beranda - Pelatihan - Kerja - Jaminan - Profil - AI
   Fix utama:
   - override semua repeat(5,1fr)
   - cegah item AI kepotong/keluar layar
   - reset padding desktop yang bisa bikin menu terakhir hilang
   ========================================================= */

body {
  padding-bottom: 76px !important;
  overflow-x: hidden !important;
}

.bottom-nav {
  position: fixed !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100vw !important;
  max-width: 100vw !important;
  height: 76px !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin: 0 !important;
  background: #ffffff !important;
  border-top: 1px solid #e5e7eb !important;
  display: grid !important;
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  grid-auto-flow: column !important;
  grid-auto-columns: minmax(0, 1fr) !important;
  align-items: center !important;
  justify-items: stretch !important;
  overflow: visible !important;
  z-index: 999999 !important;
  transform: none !important;
  animation: none !important;
  box-sizing: border-box !important;
}

.bottom-nav .nav-item,
.bottom-nav a {
  position: relative !important;
  min-width: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
  height: 76px !important;
  min-height: 76px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 4px !important;
  padding: 0 1px !important;
  margin: 0 !important;
  color: #64748b !important;
  font-size: 10.8px !important;
  font-weight: 600 !important;
  line-height: 1.15 !important;
  text-align: center !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  overflow: visible !important;
  box-sizing: border-box !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

/* Jangan biarkan CSS lama menyembunyikan item terakhir */
.bottom-nav .nav-item:nth-child(6),
.bottom-nav a:nth-child(6),
.bottom-nav a[href*="ai-chat"],
.bottom-nav a[href*="/ai-chat"] {
  display: flex !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  order: 6 !important;
}

/* Profil tetap sebelum AI */
.bottom-nav a[href*="profil"],
.bottom-nav a[href*="/profil"] {
  order: 5 !important;
}

.bottom-nav .nav-item:nth-child(1),
.bottom-nav a:nth-child(1) {
  order: 1 !important;
}

.bottom-nav .nav-item:nth-child(2),
.bottom-nav a:nth-child(2) {
  order: 2 !important;
}

.bottom-nav .nav-item:nth-child(3),
.bottom-nav a:nth-child(3) {
  order: 3 !important;
}

.bottom-nav .nav-item:nth-child(4),
.bottom-nav a:nth-child(4) {
  order: 4 !important;
}

.bottom-nav .nav-item.active,
.bottom-nav a.active {
  color: var(--blue) !important;
}

.bottom-nav .nav-item > span:last-child,
.bottom-nav a > span:last-child {
  display: block !important;
  max-width: 100% !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  line-height: 1.15 !important;
}

.bottom-nav .nav-icon {
  width: 22px !important;
  height: 22px !important;
  min-width: 22px !important;
  min-height: 22px !important;
  max-width: 22px !important;
  max-height: 22px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 22px !important;
  font-size: 0 !important;
  line-height: 1 !important;
  color: currentColor !important;
}

.bottom-nav .nav-icon svg,
.bottom-nav .nav-icon [data-lucide] {
  width: 21px !important;
  height: 21px !important;
  min-width: 21px !important;
  min-height: 21px !important;
  display: block !important;
  color: currentColor !important;
  stroke: currentColor !important;
  stroke-width: 2.2 !important;
}

/* Desktop override: jangan pakai padding center dari CSS lama */
@media (min-width: 1024px) {
  .bottom-nav {
    left: 0 !important;
    right: 0 !important;
    width: 100vw !important;
    max-width: 100vw !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  }
}

@media (min-width: 1441px) {
  .bottom-nav {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}

@media (max-width: 720px) {
  .bottom-nav {
    width: 100vw !important;
    max-width: 100vw !important;
    height: 76px !important;
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .bottom-nav .nav-item,
  .bottom-nav a {
    height: 76px !important;
    min-height: 76px !important;
    font-size: 10px !important;
    gap: 4px !important;
    padding: 0 !important;
  }

  .bottom-nav .nav-icon {
    width: 20px !important;
    height: 20px !important;
    min-width: 20px !important;
    min-height: 20px !important;
    flex-basis: 20px !important;
  }

  .bottom-nav .nav-icon svg,
  .bottom-nav .nav-icon [data-lucide] {
    width: 20px !important;
    height: 20px !important;
    min-width: 20px !important;
    min-height: 20px !important;
  }
}

@media (max-width: 360px) {
  .bottom-nav .nav-item,
  .bottom-nav a {
    font-size: 9.5px !important;
  }
}

/* marker: wp-v58-final-six-navbar-ai-visible-20260529 */

/* =========================================================
   NAVBAR ACTIVE SHADOW MINIMAL FIX
   Shadow biru tetap muncul, tapi tidak mengubah layout navbar
   dan tidak melewati garis atas navbar.
   ========================================================= */

/* Pastikan navbar tetap 6 menu tanpa mengubah posisi item */
.bottom-nav{
  grid-template-columns:repeat(6, minmax(0, 1fr)) !important;
  overflow:hidden !important;
  border-top:1px solid #e5e7eb !important;
}

/* Item navbar tetap bersih, tidak ada background lebar */
.bottom-nav .nav-item,
.bottom-nav a{
  background:transparent !important;
  box-shadow:none !important;
  overflow:visible !important;
}

/* Area icon tetap ukuran normal dari CSS lama */
.bottom-nav .nav-icon{
  position:relative !important;
  z-index:1 !important;
  overflow:visible !important;
  background:transparent !important;
  box-shadow:none !important;
  transform:none !important;
}

/* Icon berada di atas shadow */
.bottom-nav .nav-icon svg,
.bottom-nav .nav-icon [data-lucide],
.bottom-nav .nav-icon .icon{
  position:relative !important;
  z-index:2 !important;
}

/* Shadow biru untuk menu aktif */
.bottom-nav .nav-item.active .nav-icon::before,
.bottom-nav a.active .nav-icon::before,
.bottom-nav .nav-item[aria-current="page"] .nav-icon::before,
.bottom-nav a[aria-current="page"] .nav-icon::before{
  content:"" !important;
  position:absolute !important;
  left:50% !important;
  top:50% !important;
  width:52px !important;
  height:40px !important;
  transform:translate(-50%, -50%) !important;
  border-radius:18px !important;
  background:rgba(37,99,235,.12) !important;
  box-shadow:0 8px 18px rgba(37,99,235,.18) !important;
  z-index:1 !important;
  pointer-events:none !important;
}

/* Shadow biru saat hover / mau diklik */
.bottom-nav .nav-item:hover .nav-icon::before,
.bottom-nav a:hover .nav-icon::before{
  content:"" !important;
  position:absolute !important;
  left:50% !important;
  top:50% !important;
  width:52px !important;
  height:40px !important;
  transform:translate(-50%, -50%) !important;
  border-radius:18px !important;
  background:rgba(37,99,235,.10) !important;
  box-shadow:0 8px 18px rgba(37,99,235,.16) !important;
  z-index:1 !important;
  pointer-events:none !important;
}

/* Warna aktif tetap biru, icon tidak ikut geser */
.bottom-nav .nav-item.active,
.bottom-nav a.active,
.bottom-nav .nav-item[aria-current="page"],
.bottom-nav a[aria-current="page"]{
  color:#2563eb !important;
  background:transparent !important;
  box-shadow:none !important;
}

.bottom-nav .nav-item.active .nav-icon,
.bottom-nav a.active .nav-icon,
.bottom-nav .nav-item:hover .nav-icon,
.bottom-nav a:hover .nav-icon{
  transform:none !important;
  background:transparent !important;
  box-shadow:none !important;
}

/* Matikan animasi lama yang bikin shadow/icon geser */
body.wp-alive-page .bottom-nav .nav-item.active .nav-icon,
body.wp-alive-page .bottom-nav a.active .nav-icon,
body.wp-magic-page .bottom-nav .nav-item.active .nav-icon,
body.wp-magic-page .bottom-nav a.active .nav-icon{
  animation:none !important;
  transform:none !important;
}

@media(max-width:390px){
  .bottom-nav .nav-item.active .nav-icon::before,
  .bottom-nav a.active .nav-icon::before,
  .bottom-nav .nav-item:hover .nav-icon::before,
  .bottom-nav a:hover .nav-icon::before{
    width:48px !important;
    height:38px !important;
  }
}

/* marker: navbar-shadow-minimal-safe-20260531 */

/* =========================================================
   FINAL NAVBAR SHADOW ACTIVE ONLY
   Shadow biru hanya muncul di menu halaman aktif.
   Hover/click menu lain tidak menampilkan shadow.
   ========================================================= */

/* Non-active menu: jangan tampilkan shadow saat hover */
.bottom-nav a:not(.active):not([aria-current="page"]):hover .nav-icon::before,
.bottom-nav .nav-item:not(.active):not([aria-current="page"]):hover .nav-icon::before,
.bottom-nav a:not(.active):not([aria-current="page"]):active .nav-icon::before,
.bottom-nav .nav-item:not(.active):not([aria-current="page"]):active .nav-icon::before{
  display:none !important;
  opacity:0 !important;
  background:transparent !important;
  box-shadow:none !important;
}

/* Active/current page: shadow tetap muncul */
.bottom-nav a.active .nav-icon::before,
.bottom-nav .nav-item.active .nav-icon::before,
.bottom-nav a[aria-current="page"] .nav-icon::before,
.bottom-nav .nav-item[aria-current="page"] .nav-icon::before,
.bottom-nav a.active:hover .nav-icon::before,
.bottom-nav .nav-item.active:hover .nav-icon::before,
.bottom-nav a[aria-current="page"]:hover .nav-icon::before,
.bottom-nav .nav-item[aria-current="page"]:hover .nav-icon::before{
  content:"" !important;
  display:block !important;
  position:absolute !important;
  left:50% !important;
  top:50% !important;
  width:52px !important;
  height:40px !important;
  transform:translate(-50%, -50%) !important;
  border-radius:18px !important;
  background:rgba(37,99,235,.12) !important;
  box-shadow:0 8px 18px rgba(37,99,235,.18) !important;
  opacity:1 !important;
  z-index:1 !important;
  pointer-events:none !important;
}

/* Pastikan icon dan teks tetap di atas shadow */
.bottom-nav .nav-icon svg,
.bottom-nav .nav-icon [data-lucide],
.bottom-nav .nav-icon .icon,
.bottom-nav a span,
.bottom-nav .nav-item span{
  position:relative !important;
  z-index:2 !important;
}

/* marker: navbar-active-only-shadow-20260531 */

/* =========================================================
   FINAL FIX NAVBAR NO JUMP - ACTIVE SHADOW ONLY
   Fix:
   - shadow biru hanya untuk menu aktif/current page
   - hover/click menu lain tidak memunculkan shadow
   - icon tidak loncat/naik saat diklik
   Tempel paling bawah agar override CSS lama.
   ========================================================= */

/* Matikan semua animasi/transform navbar yang bikin icon loncat */
.bottom-nav,
.bottom-nav .nav-item,
.bottom-nav a,
.bottom-nav .nav-icon,
.bottom-nav .nav-icon svg,
.bottom-nav .nav-icon [data-lucide],
.bottom-nav .nav-icon .icon,
.bottom-nav .nav-item i,
.bottom-nav a i,
.bottom-nav .nav-item span,
.bottom-nav a span{
  animation:none !important;
  transform:none !important;
}

/* Matikan transform saat hover/focus/active/click */
.bottom-nav .nav-item:hover,
.bottom-nav .nav-item:focus,
.bottom-nav .nav-item:active,
.bottom-nav a:hover,
.bottom-nav a:focus,
.bottom-nav a:active,
.bottom-nav .nav-item:hover .nav-icon,
.bottom-nav .nav-item:focus .nav-icon,
.bottom-nav .nav-item:active .nav-icon,
.bottom-nav a:hover .nav-icon,
.bottom-nav a:focus .nav-icon,
.bottom-nav a:active .nav-icon,
.bottom-nav .nav-item.active .nav-icon,
.bottom-nav a.active .nav-icon,
.bottom-nav .nav-item[aria-current="page"] .nav-icon,
.bottom-nav a[aria-current="page"] .nav-icon{
  animation:none !important;
  transform:none !important;
  translate:none !important;
  scale:1 !important;
}

/* Override animasi wp-alive/wp-magic yang sebelumnya membuat icon pulse/naik */
body.wp-alive-page .bottom-nav .nav-item.active .nav-icon,
body.wp-alive-page .bottom-nav .nav-item.active svg,
body.wp-alive-page .bottom-nav .nav-item.active i,
body.wp-alive-page .bottom-nav a.active .nav-icon,
body.wp-alive-page .bottom-nav a.active svg,
body.wp-alive-page .bottom-nav a.active i,
body.wp-magic-page .bottom-nav .nav-item.active .nav-icon,
body.wp-magic-page .bottom-nav .nav-item.active svg,
body.wp-magic-page .bottom-nav .nav-item.active i,
body.wp-magic-page .bottom-nav a.active .nav-icon,
body.wp-magic-page .bottom-nav a.active svg,
body.wp-magic-page .bottom-nav a.active i{
  animation:none !important;
  transform:none !important;
  translate:none !important;
  scale:1 !important;
}

/* Pastikan nav tetap 6 kolom dan tidak berubah layout */
.bottom-nav{
  grid-template-columns:repeat(6, minmax(0, 1fr)) !important;
  align-items:center !important;
  overflow:hidden !important;
}

.bottom-nav .nav-item,
.bottom-nav a{
  height:76px !important;
  min-height:76px !important;
  align-items:center !important;
  justify-content:center !important;
  background:transparent !important;
  box-shadow:none !important;
  overflow:visible !important;
}

/* Base icon: normal, tidak punya background/shadow sendiri */
.bottom-nav .nav-icon{
  position:relative !important;
  z-index:1 !important;
  overflow:visible !important;
  background:transparent !important;
  box-shadow:none !important;
}

/* Sembunyikan shadow untuk menu yang tidak aktif, termasuk saat hover/click */
.bottom-nav a:not(.active):not([aria-current="page"]) .nav-icon::before,
.bottom-nav .nav-item:not(.active):not([aria-current="page"]) .nav-icon::before,
.bottom-nav a:not(.active):not([aria-current="page"]):hover .nav-icon::before,
.bottom-nav .nav-item:not(.active):not([aria-current="page"]):hover .nav-icon::before,
.bottom-nav a:not(.active):not([aria-current="page"]):active .nav-icon::before,
.bottom-nav .nav-item:not(.active):not([aria-current="page"]):active .nav-icon::before{
  content:"" !important;
  display:none !important;
  opacity:0 !important;
  background:transparent !important;
  box-shadow:none !important;
}

/* Shadow biru hanya untuk halaman aktif */
.bottom-nav a.active .nav-icon::before,
.bottom-nav .nav-item.active .nav-icon::before,
.bottom-nav a[aria-current="page"] .nav-icon::before,
.bottom-nav .nav-item[aria-current="page"] .nav-icon::before{
  content:"" !important;
  display:block !important;
  position:absolute !important;
  left:50% !important;
  top:50% !important;
  width:52px !important;
  height:40px !important;
  transform:translate(-50%, -50%) !important;
  border-radius:18px !important;
  background:rgba(37,99,235,.12) !important;
  box-shadow:0 8px 18px rgba(37,99,235,.18) !important;
  opacity:1 !important;
  z-index:0 !important;
  pointer-events:none !important;
}

/* Icon, svg, dan teks selalu di atas shadow */
.bottom-nav .nav-icon svg,
.bottom-nav .nav-icon [data-lucide],
.bottom-nav .nav-icon .icon,
.bottom-nav .nav-item span,
.bottom-nav a span{
  position:relative !important;
  z-index:2 !important;
}

/* Warna menu aktif */
.bottom-nav .nav-item.active,
.bottom-nav a.active,
.bottom-nav .nav-item[aria-current="page"],
.bottom-nav a[aria-current="page"]{
  color:#2563eb !important;
}

/* Ukuran shadow mobile sedikit lebih kecil */
@media(max-width:390px){
  .bottom-nav a.active .nav-icon::before,
  .bottom-nav .nav-item.active .nav-icon::before,
  .bottom-nav a[aria-current="page"] .nav-icon::before,
  .bottom-nav .nav-item[aria-current="page"] .nav-icon::before{
    width:48px !important;
    height:38px !important;
  }
}

/* marker: navbar-no-jump-active-shadow-only-20260531 */



/* =========================================================
   JOB SKILL DELETE CHIP - NO RELOAD
   Tambahan untuk Cari Pekerjaan: skill aktif bisa dihapus seperti Profil
   ========================================================= */
.wp-jobs-remove-form{
  display:inline-flex !important;
  margin:0 !important;
  padding:0 !important;
}

.wp-jobs-chip-remove{
  appearance:none !important;
  border:none !important;
  cursor:pointer !important;
  gap:8px !important;
  padding:0 10px 0 14px !important;
}

.wp-jobs-chip-remove::before{
  content:"";
  width:7px;
  height:7px;
  border-radius:999px;
  background:#7c3aed;
  flex:0 0 auto;
}

.wp-jobs-chip-x{
  width:18px;
  height:18px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(124,58,237,.14);
  color:#6d28d9;
  font-size:14px;
  line-height:1;
  font-weight:950;
  transition:.18s ease;
}

.wp-jobs-chip-remove:hover{
  background:#ede9fe !important;
  border-color:#c4b5fd !important;
  color:#5b21b6 !important;
  transform:translateY(-1px);
}

.wp-jobs-chip-remove:hover .wp-jobs-chip-x{
  background:#7c3aed;
  color:#fff;
}

.wp-jobs-chip-remove:active{
  transform:scale(.97);
}

.wp-jobs-chip-remove:disabled,
.wp-jobs-chip-btn:disabled,
.wp-jobs-add-btn:disabled{
  opacity:.65;
  cursor:wait !important;
  transform:none !important;
}

#wp-job-skill-toast{
  max-width:calc(100vw - 32px);
  text-align:center;
}


/* =========================================================
   PROFILE PROGRESS BUGFIX - PERSEN TIDAK 0% LAGI
   Bar dan angka mengikuti data-profile-percent dari Blade.
   ========================================================= */
.wp-profile-ready-dynamic{
  --profile-ready: attr(data-profile-percent percentage);
}

.wp-profile-ready-dynamic .wp-profile-ready-percent{
  display:inline-block !important;
  min-width:54px !important;
  white-space:nowrap !important;
}

.wp-profile-ready-dynamic .wp-profile-ready-line{
  position:relative !important;
  overflow:hidden !important;
}

.wp-profile-ready-dynamic .wp-profile-ready-bar,
.wp-profile-ready-dynamic .wp-profile-ready-line > span{
  display:block !important;
  height:100% !important;
  width:var(--profile-ready, 0%) !important;
  max-width:100% !important;
  min-width:0 !important;
  border-radius:999px !important;
  transition:width .7s cubic-bezier(.22,1,.36,1) !important;
}

.wp-profile-ready-meta{
  display:flex;
  flex-wrap:wrap;
  gap:6px 10px;
  line-height:1.25;
}
