/* ============================================================
   PENDAFTARAN 6R — Single Page CSS
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --primary: #6366f1;
  --primary-dark: #4f46e5;
  --primary-light: #818cf8;
  --secondary: #8b5cf6;
  --accent: #06b6d4;
  --success: #10b981;
  --danger: #ef4444;

  --bg: #0f0f1a;
  --bg-card: rgba(255,255,255,0.04);
  --bg-input: rgba(255,255,255,0.06);
  --bg-input-focus: rgba(99,102,241,0.09);

  --text-1: #f1f5f9;
  --text-2: #94a3b8;
  --text-3: #64748b;

  --border: rgba(255,255,255,0.08);
  --border-focus: rgba(99,102,241,0.55);

  --r: 14px;
  --r-sm: 10px;
  --r-lg: 22px;
  --t: 0.22s cubic-bezier(.4,0,.2,1);
}

html { scroll-behavior: smooth; }

body {
  font-family: 'Plus Jakarta Sans', sans-serif;
  background: var(--bg);
  color: var(--text-1);
  min-height: 100vh;
  overflow-x: hidden;
}

/* ── Blobs ── */
.bg-blob { position: fixed; border-radius: 50%; filter: blur(90px); opacity: .11; pointer-events: none; z-index: 0; }
.blob-1 { width:580px; height:580px; background:radial-gradient(circle,#6366f1,#8b5cf6); top:-180px; left:-180px; animation: bf 13s ease-in-out infinite; }
.blob-2 { width:480px; height:480px; background:radial-gradient(circle,#06b6d4,#6366f1); bottom:-100px; right:-140px; animation: bf 16s ease-in-out infinite reverse; }
.blob-3 { width:280px; height:280px; background:radial-gradient(circle,#8b5cf6,#ec4899); top:55%; left:52%; transform:translate(-50%,-50%); animation: bf 19s ease-in-out infinite; }
@keyframes bf { 0%,100%{transform:translate(0,0) scale(1)} 33%{transform:translate(28px,-28px) scale(1.05)} 66%{transform:translate(-18px,18px) scale(.96)} }

/* ── Header ── */
.app-header { position:sticky; top:0; z-index:100; backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px); background:rgba(15,15,26,.82); border-bottom:1px solid var(--border); }
.header-inner { max-width:960px; margin:0 auto; padding:14px 24px; display:flex; align-items:center; justify-content:space-between; }
.header-logo { display:flex; align-items:center; gap:14px; }
.logo-icon svg { width:40px; height:40px; filter:drop-shadow(0 4px 10px rgba(99,102,241,.4)); }
.logo-text { display:flex; flex-direction:column; }
.logo-title { font-size:.96rem; font-weight:700; }
.logo-sub { font-size:.7rem; color:var(--primary-light); font-weight:500; letter-spacing:.04em; }
.header-badge { display:flex; align-items:center; gap:7px; background:rgba(16,185,129,.1); border:1px solid rgba(16,185,129,.25); color:#34d399; font-size:.76rem; font-weight:600; padding:5px 13px; border-radius:999px; }
.badge-dot { width:7px; height:7px; border-radius:50%; background:#34d399; animation:pulse 2s infinite; }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.55;transform:scale(.8)} }

/* ── Main ── */
.main-content { max-width:960px; margin:0 auto; padding:44px 24px 80px; position:relative; z-index:1; }

/* ── Hero ── */
.hero-section { text-align:center; margin-bottom:40px; }
.hero-tag { display:inline-flex; align-items:center; gap:8px; background:rgba(99,102,241,.12); border:1px solid rgba(99,102,241,.24); color:var(--primary-light); font-size:.8rem; font-weight:600; padding:7px 16px; border-radius:999px; margin-bottom:18px; letter-spacing:.04em; }
.hero-title { font-family:'Poppins',sans-serif; font-size:clamp(1.7rem,4vw,2.6rem); font-weight:800; line-height:1.22; margin-bottom:14px; }
.gradient-text { background:linear-gradient(135deg,var(--primary-light),var(--secondary),var(--accent)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.hero-desc { color:var(--text-2); font-size:.92rem; max-width:500px; margin:0 auto; line-height:1.7; }
.req-star { color:#f87171; font-weight:700; }

/* ── Card ── */
.card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--r-lg); padding:32px; margin-bottom:20px; backdrop-filter:blur(10px); transition:var(--t); }
.card:hover { border-color:rgba(255,255,255,0.12); }
.submit-card { border-color:rgba(99,102,241,.18); background:rgba(99,102,241,.04); }

.card-head { display:flex; align-items:center; gap:16px; margin-bottom:28px; padding-bottom:22px; border-bottom:1px solid var(--border); }
.card-icon { font-size:2rem; width:56px; height:56px; background:linear-gradient(135deg,rgba(99,102,241,.18),rgba(139,92,246,.18)); border:1px solid rgba(99,102,241,.18); border-radius:var(--r); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.card-title { font-family:'Poppins',sans-serif; font-size:1.12rem; font-weight:700; margin-bottom:3px; }
.card-desc { font-size:.82rem; color:var(--text-2); }

/* ── Grid ── */
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.fg { display:flex; flex-direction:column; gap:7px; }
.fg.full { grid-column:1/-1; }

/* ── Labels ── */
.flabel { font-size:.82rem; font-weight:600; color:var(--text-2); letter-spacing:.02em; }

/* ── Controls ── */
.fctl { width:100%; background:var(--bg-input); border:1.5px solid var(--border); border-radius:var(--r-sm); padding:12px 15px; font-family:'Plus Jakarta Sans',sans-serif; font-size:.9rem; font-weight:500; color:var(--text-1); outline:none; transition:var(--t); -webkit-appearance:none; }
.fctl::placeholder { color:var(--text-3); font-weight:400; }
.fctl:focus { border-color:var(--primary); background:var(--bg-input-focus); box-shadow:0 0 0 4px rgba(99,102,241,.1); }
.fctl.error { border-color:var(--danger); box-shadow:0 0 0 3px rgba(239,68,68,.1); }
textarea.fctl { resize:vertical; min-height:100px; }

/* ── Select ── */
.sel-wrap { position:relative; }
.sel-wrap select { cursor:pointer; }
.sel-arr { position:absolute; right:13px; top:50%; transform:translateY(-50%); color:var(--text-3); pointer-events:none; font-size:1rem; }

/* ── Hints & Errors ── */
.fhint { font-size:.73rem; color:var(--text-3); }
.ferr { font-size:.75rem; color:#f87171; font-weight:500; min-height:14px; display:block; }

/* ── Radio Cards ── */
.radio-group { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.radio-card { cursor:pointer; }
.radio-card input { display:none; }
.rc-inner { background:var(--bg-input); border:1.5px solid var(--border); border-radius:var(--r); padding:18px 14px; display:flex; flex-direction:column; align-items:center; gap:8px; transition:var(--t); }
.rc-icon { font-size:1.8rem; }
.rc-lbl { font-size:.85rem; font-weight:700; color:var(--text-1); }
.radio-card input:checked + .rc-inner { border-color:var(--primary); background:rgba(99,102,241,.12); box-shadow:0 0 0 4px rgba(99,102,241,.1); }
.radio-card:hover .rc-inner { border-color:var(--primary-light); background:rgba(255,255,255,.06); }

/* ── Gender ── */
.gender-group { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.gender-card { cursor:pointer; }
.gender-card input { display:none; }
.g-inner { background:var(--bg-input); border:1.5px solid var(--border); border-radius:var(--r-sm); padding:12px; display:flex; align-items:center; justify-content:center; gap:8px; font-size:.88rem; font-weight:600; color:var(--text-2); transition:var(--t); }
.g-inner span { font-size:1.2rem; }
.gender-card input:checked + .g-inner { border-color:var(--primary); background:rgba(99,102,241,.12); color:var(--primary-light); }
.gender-card:hover .g-inner { border-color:var(--primary-light); }

/* ── Checkbox ── */
.check-label { display:flex; align-items:flex-start; gap:13px; cursor:pointer; margin-bottom:10px; }
.check-label input { display:none; }
.chk-box { width:22px; height:22px; border-radius:6px; border:2px solid var(--border); background:var(--bg-input); display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:var(--t); margin-top:1px; }
.chk-box svg { width:12px; opacity:0; transition:var(--t); }
.check-label input:checked ~ .chk-box { background:var(--primary); border-color:var(--primary); }
.check-label input:checked ~ .chk-box svg { opacity:1; }
.check-label span:last-child { font-size:.84rem; color:var(--text-2); line-height:1.65; }

/* ── Submit Row ── */
.submit-row { display:flex; justify-content:flex-end; gap:12px; margin-top:20px; }

/* ── Buttons ── */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; font-family:'Plus Jakarta Sans',sans-serif; font-size:.9rem; font-weight:700; padding:13px 28px; border-radius:var(--r-sm); border:none; cursor:pointer; transition:var(--t); letter-spacing:.02em; }
.btn-reset { background:var(--bg-card); color:var(--text-2); border:1.5px solid var(--border); }
.btn-reset:hover { background:rgba(255,255,255,.07); color:var(--text-1); }
.btn-submit { background:linear-gradient(135deg,var(--primary),var(--secondary)); color:#fff; box-shadow:0 4px 22px rgba(99,102,241,.4); padding:14px 36px; font-size:.96rem; }
.btn-submit:hover { transform:translateY(-2px); box-shadow:0 8px 30px rgba(99,102,241,.5); }
.btn-submit:active { transform:translateY(0); }
.btn-icon { width:22px; height:22px; border-radius:50%; background:rgba(255,255,255,.2); display:flex; align-items:center; justify-content:center; font-size:.78rem; }
.btn-print { background:rgba(6,182,212,.1); border:1.5px solid rgba(6,182,212,.28); color:var(--accent); flex:1; }
.btn-print:hover { background:rgba(6,182,212,.18); }
.btn-new { background:linear-gradient(135deg,var(--primary),var(--secondary)); color:#fff; flex:1; box-shadow:0 4px 18px rgba(99,102,241,.35); }
.btn-new:hover { transform:translateY(-2px); }

/* ── Modal ── */
.modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.72); backdrop-filter:blur(14px); z-index:200; display:flex; align-items:center; justify-content:center; padding:24px; opacity:0; visibility:hidden; transition:.35s cubic-bezier(.4,0,.2,1); }
.modal-overlay.open { opacity:1; visibility:visible; }
.modal-box { background:#1a1a2e; border:1px solid rgba(99,102,241,.22); border-radius:var(--r-lg); padding:44px 36px; max-width:520px; width:100%; text-align:center; box-shadow:0 24px 72px rgba(0,0,0,.5); transform:scale(.9) translateY(18px); transition:.35s cubic-bezier(.4,0,.2,1); }
.modal-box.modal-simple { max-width:380px; padding:40px 32px; }
.modal-overlay.open .modal-box { transform:scale(1) translateY(0); }

.modal-anim { position:relative; width:96px; height:96px; margin:0 auto 26px; }
.success-ring { position:absolute; inset:0; border-radius:50%; border:3px solid transparent; border-top-color:var(--success); animation:spin .9s ease forwards, ringE .5s .75s ease forwards; }
@keyframes spin { from{transform:rotate(0deg)} to{transform:rotate(360deg)} }
@keyframes ringE { to{border-color:rgba(16,185,129,.28); transform:rotate(360deg) scale(1.09)} }
.success-icon { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-size:2.2rem; background:linear-gradient(135deg,var(--success),#059669); border-radius:50%; color:#fff; box-shadow:0 8px 28px rgba(16,185,129,.38); animation:sPop .4s .65s ease both; }
@keyframes sPop { from{transform:scale(0);opacity:0} to{transform:scale(1);opacity:1} }

.modal-title { font-family:'Poppins',sans-serif; font-size:1.7rem; font-weight:800; margin-bottom:10px; }
.modal-desc { color:var(--text-2); font-size:.88rem; line-height:1.7; margin-bottom:22px; }
.ref-box { background:rgba(99,102,241,.1); border:1px solid rgba(99,102,241,.2); border-radius:var(--r-sm); padding:14px 22px; margin-bottom:22px; display:flex; align-items:center; justify-content:space-between; }
.ref-label { font-size:.78rem; color:var(--text-3); font-weight:600; letter-spacing:.05em; text-transform:uppercase; }
.ref-num { font-family:'Poppins',sans-serif; font-size:1.1rem; font-weight:700; color:var(--primary-light); letter-spacing:.08em; }

.modal-summary { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--r-sm); padding:18px; margin-bottom:26px; text-align:left; }
.summary-item { display:flex; justify-content:space-between; gap:10px; padding:6px 0; border-bottom:1px solid var(--border); font-size:.82rem; }
.summary-item:last-child { border-bottom:none; }
.summary-key { color:var(--text-3); font-weight:500; flex-shrink:0; }
.summary-val { color:var(--text-1); font-weight:600; text-align:right; }
.modal-actions { display:flex; gap:10px; }

/* ── Footer ── */
.app-footer { text-align:center; padding:26px 24px; color:var(--text-3); font-size:.78rem; border-top:1px solid var(--border); position:relative; z-index:1; }

/* ── Pill Group ── */
.pill-group { display:flex; flex-wrap:wrap; gap:8px; }
.pill-group.wrap { flex-wrap:wrap; }
.pill-card { cursor:pointer; }
.pill-card input { display:none; }
.pill-card span {
  display:inline-flex; align-items:center; justify-content:center;
  padding:9px 18px; border-radius:999px;
  border:1.5px solid var(--border); background:var(--bg-input);
  font-size:.84rem; font-weight:700; color:var(--text-2);
  transition:var(--t); white-space:nowrap; letter-spacing:.03em;
}
.pill-card input:checked + span {
  background:linear-gradient(135deg,var(--primary),var(--secondary));
  border-color:transparent; color:#fff;
  box-shadow:0 4px 14px rgba(99,102,241,.35);
}
.pill-card:hover span { border-color:var(--primary-light); color:var(--text-1); }
.pill-card.size span { min-width:52px; font-size:.9rem; }

/* ── Doc List & Toggle ── */
.doc-list { display:flex; flex-direction:column; gap:0; }
.doc-row {
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0; border-bottom:1px solid var(--border); gap:12px;
}
.doc-row:last-child { border-bottom:none; }
.doc-name { font-size:.88rem; font-weight:600; color:var(--text-1); flex:1; }
.doc-name em { font-style:normal; font-weight:400; color:var(--text-3); font-size:.78rem; margin-left:4px; }
.toggle-group { display:flex; gap:6px; flex-shrink:0; }
.tog { cursor:pointer; }
.tog input { display:none; }
.tog-btn {
  display:inline-flex; align-items:center; justify-content:center;
  padding:7px 16px; border-radius:999px; font-size:.78rem; font-weight:700;
  border:1.5px solid var(--border); background:var(--bg-input);
  color:var(--text-3); transition:var(--t); letter-spacing:.04em;
}
.tog input:checked + .tog-btn.ya { background:rgba(16,185,129,.15); border-color:#10b981; color:#34d399; }
.tog input:checked + .tog-btn.tiada { background:rgba(239,68,68,.12); border-color:#ef4444; color:#f87171; }
.tog:hover .tog-btn { border-color:var(--primary-light); color:var(--text-1); }

/* ── Saiz Inline (dalam Bayaran) ── */
.saiz-inline {
  padding: 14px 16px;
  background: rgba(99,102,241,.06);
  border: 1px dashed rgba(99,102,241,.25);
  border-radius: var(--r-sm);
  margin: 4px 0 8px;
  animation: fadeSlideIn .2s ease;
}
@keyframes fadeSlideIn { from{opacity:0;transform:translateY(-6px)} to{opacity:1;transform:translateY(0)} }

/* ── Responsive ── */
@media(max-width:680px){
  .form-grid { grid-template-columns:1fr; }
  .fg.full { grid-column:1; }
  .submit-row { flex-direction:column; }
  .btn-reset,.btn-submit { width:100%; justify-content:center; }
  .modal-box { padding:32px 20px; }
  .modal-actions { flex-direction:column; }
  .header-inner { flex-direction:column; gap:10px; }
  .doc-row { flex-direction:column; align-items:flex-start; gap:8px; }
}

/* ── Print ── */
@media print {
  body { background:#fff; color:#111; }
  .app-header,.app-footer,.modal-overlay { display:none !important; }
  form { display:none !important; }
  .main-content { padding:0; }
  #printArea { display:block !important; }
}
