: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;
}
