/* =========================================
   PsikoM – Demo Styles (style.css)
   ========================================= */

/* ---------- Tokens (selaras brand) ---------- */
:root{
  --primary:#2563EB;   /* biru */
  --secondary:#06B6D4; /* cyan */
  --accent:#F59E0B;    /* amber (CTA) */
  --text:#111827;
  --muted:#6B7280;
  --bg:#FFFFFF;
  --soft:#F9FAFB;
  --soft2:#F3F4F6;
  --line:#E5E7EB;

  --radius:18px;
  --shadow:0 8px 24px rgba(0,0,0,.08);
  --shadow-lg:0 16px 40px rgba(0,0,0,.14);
  --ring:0 0 0 4px rgba(37,99,235,.25);
}

/* ---------- Reset ringkas & asas ---------- */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:"Poppins",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  font-weight:400;
  color:var(--text);
  background:linear-gradient(180deg,#ffffff 0%,#f7fbff 100%);
  line-height:1.6;
}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}
:focus-visible{outline:2px solid transparent;box-shadow:var(--ring)}

/* ---------- Layout ---------- */
.container{max-width:960px;margin-inline:auto;padding:20px}
.demo-wrap{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-lg);padding:22px;margin:20px auto;
}

/* ---------- Branding kecil ---------- */
.brand-line{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:8px}
.brand-psiko{color:var(--primary);font-weight:600}
.brand-m{color:var(--secondary);font-weight:600}
.badge-demo{
  display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;
  background:linear-gradient(180deg,#fff 0%,#fdfdfd 100%);border:1px solid var(--line);
  color:#1f2937;font-weight:600;font-size:12px;
}

/* ---------- Tajuk ---------- */
.title{margin:6px 0 2px 0;text-align:center;font-size:26px;font-weight:600}
.subtitle{margin:0 0 10px;text-align:center;color:var(--muted)}

/* ---------- Status: Progress + Timer ---------- */
.status-bar{display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px;margin:16px 0 14px}
.progress{width:100%;height:10px;background:var(--soft2);border:1px solid var(--line);border-radius:999px;overflow:hidden}
.progress>span{display:block;height:100%;background:linear-gradient(90deg,var(--primary),var(--secondary));width:0%}
.timer{
  display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;
  background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);font-weight:600;
}

/* ---------- Kad Soalan ---------- */
.card{
  background:var(--soft);border:1px solid var(--line);border-radius:14px;
  padding:16px 14px;margin:10px 0 14px;
}
.q-index{font-size:12px;color:var(--muted);margin:0 0 6px}
.q-text{margin:0 0 12px;font-weight:600}

/* ---------- Likert Scale (VERTICAL) ---------- */
.likert{
  display:flex;
  flex-direction:column;   /* menegak */
  gap:10px;
}
.opt{
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 14px;
  border-radius:12px;
  background:#fff;
  border:1px solid var(--line);
  cursor:pointer;
  user-select:none;
  transition:.15s box-shadow,.15s transform,.15s background;
}
.opt:hover{box-shadow:var(--shadow)}
.opt input{
  appearance:none;
  width:20px;
  height:20px;
  border-radius:999px;
  border:2px solid var(--primary);
  outline:none;
  position:relative;
}
.opt input:checked{background:var(--primary)}
.opt small{
  color:#111827;
  font-size:14px;
  line-height:1.2;
}
.opt input:checked + small{font-weight:600}

/* ---------- Tip ---------- */
.tip{
  margin:8px 0 0;padding:10px 12px;background:#fff;border-left:4px solid var(--primary);
  border-radius:10px;font-size:14px;color:#293041;
}
.tip strong{font-weight:600}

/* ---------- Butang & Baris Butang ---------- */
.btn-row{display:flex;gap:10px;justify-content:space-between;margin-top:12px;flex-wrap:wrap}
.btn-right{display:flex;gap:10px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 18px;border-radius:12px;border:1px solid transparent;font-weight:600;
  background:#fff;color:#111827;cursor:pointer;box-shadow:0 4px 14px rgba(0,0,0,.06);
  transition:.2s box-shadow,.2s transform,.2s background-color,.2s border-color;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--accent);color:#111827}
.btn-outline{border-color:var(--line);background:#fff}
.btn[disabled]{opacity:.55;cursor:not-allowed}

/* ---------- Laporan ---------- */
.report{display:none;margin-top:18px}
.report.is-open{display:block}
.report-head{text-align:center;margin-bottom:10px}
.report-title{margin:0;font-size:24px;font-weight:600}
.report-sub{margin:6px 0 0;color:var(--muted)}
.report-grid{display:grid;gap:14px;grid-template-columns:1fr}
.report-card{
  background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);
  padding:16px 14px;position:relative;
}

/* ---------- 4 domain dikunci (kabur + nota) ---------- */
.report-card.locked{
  filter:blur(2px) grayscale(.1);
  opacity:.75;
  background:linear-gradient(180deg,#ffffff 0%,#fdfdfd 100%);
}
.report-card.locked::after{
  content:"🔒 Demo: domain ini dikunci. Dapatkan Analisa Penuh untuk buka.";
  position:absolute;left:12px;right:12px;bottom:12px;
  background:rgba(255,255,255,.92);border:1px solid var(--line);border-radius:10px;
  padding:8px 10px;color:#374151;font-size:13px;
}

/* ---------- CTA & Penafian ---------- */
.cta-buy{margin-top:14px;display:flex;justify-content:center}
.disclaimer{
  margin-top:16px;padding:12px 14px;border:1px solid var(--line);
  border-radius:12px;background:var(--soft);color:#374151;font-size:14px;
}

/* ---------- Responsif ---------- */
@media (max-width:560px){
  .btn-row{flex-direction:column}
  .btn-right{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:10px}
}
