/* AI Planning Document Factory — KPU · styles.css */
:root{
  --bg:#f1f5f9; --panel:#ffffff; --ink:#0f172a; --muted:#64748b;
  --line:#e2e8f0; --brand:#1d4ed8; --brand2:#047857; --radius:14px;
  --shadow:0 1px 3px rgba(15,23,42,.08),0 8px 24px rgba(15,23,42,.06);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);line-height:1.5;-webkit-text-size-adjust:100%}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}
.small{font-size:.82rem}
.muted{color:var(--muted)}
.c{text-align:center}.r{text-align:right}

/* Topbar */
.topbar{display:flex;align-items:center;gap:.75rem;padding:.7rem 1rem;background:linear-gradient(100deg,var(--brand),#3b82f6);color:#fff;position:sticky;top:0;z-index:20}
.topbar .logo{font-size:1.6rem}
.topbar h1{font-size:1.05rem;margin:0;font-weight:700}
.topbar .sub{font-size:.72rem;opacity:.9}
.topbar .spacer{flex:1}
.topbar .iconbtn{color:#fff;text-decoration:none;border:1px solid rgba(255,255,255,.5);padding:.35rem .7rem;border-radius:999px;font-size:.8rem}

.wrap{max-width:1000px;margin:0 auto;padding:1rem}

/* Tabs */
.tabs{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}
.tabs button{flex:1;min-width:120px;border:1px solid var(--line);background:#fff;padding:.7rem;border-radius:var(--radius);font-weight:600;color:var(--muted);cursor:pointer;font-size:.9rem}
.tabs button.on{background:var(--brand);color:#fff;border-color:var(--brand)}

/* Panels & cards */
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.1rem;margin-bottom:1rem;box-shadow:var(--shadow)}
.panel h3{margin:.1rem 0 .6rem}.panel h4{margin:.1rem 0 .6rem}
.hero h2{margin:.2rem 0}
.empty{text-align:center;color:var(--muted);padding:2.5rem 1rem}
.bignum{font-size:1.8rem;font-weight:800;color:var(--brand);margin:.2rem 0}

.cards4{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1rem}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:.9rem;text-align:center;box-shadow:var(--shadow)}
.stat-n{font-size:1.8rem;font-weight:800}
.stat-l{font-size:.78rem;color:var(--muted)}

/* Bars */
.bar-row{display:grid;grid-template-columns:1fr 2fr auto;gap:.6rem;align-items:center;margin:.5rem 0;font-size:.85rem}
.bar-lbl{color:var(--muted)}
.bar-track{height:12px;background:#eef2f7;border-radius:999px;overflow:hidden}
.bar-fill{height:100%;border-radius:999px}
.bar-val{font-weight:700;white-space:nowrap}

/* Stepbar */
.stepbar{display:flex;gap:.3rem;overflow-x:auto;padding-bottom:.3rem;margin-bottom:1rem}
.step{display:flex;align-items:center;gap:.4rem;white-space:nowrap;font-size:.78rem;color:var(--muted);background:#fff;border:1px solid var(--line);border-radius:999px;padding:.4rem .7rem;cursor:default}
.step span{display:inline-grid;place-items:center;width:20px;height:20px;border-radius:50%;background:#e2e8f0;font-weight:700;font-size:.72rem}
.step.on{color:var(--brand);border-color:var(--brand)}
.step.on span{background:var(--brand);color:#fff}
.step.done{cursor:pointer;color:var(--brand2)}
.step.done span{background:var(--brand2);color:#fff}

/* Forms */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
label{display:flex;flex-direction:column;font-size:.82rem;font-weight:600;gap:.3rem;color:#334155}
label.full{grid-column:1/-1}
label.hl{grid-column:1/-1;background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;padding:.6rem}
input,select,textarea{font:inherit;font-weight:500;padding:.55rem .65rem;border:1px solid var(--line);border-radius:9px;background:#fff;width:100%}
textarea{min-height:70px;resize:vertical}
input:focus,select:focus,textarea:focus{outline:2px solid #bfdbfe;border-color:var(--brand)}
.callout{background:#f8fafc;border-left:4px solid var(--brand);border-radius:8px;padding:.7rem .9rem;margin-top:.7rem;font-size:.86rem}
.sumber-note{margin-top:.4rem}

/* Buttons */
.btn{border:1px solid var(--line);background:#fff;color:var(--ink);padding:.6rem 1rem;border-radius:10px;font-weight:600;cursor:pointer;font-size:.88rem}
.btn:hover{background:#f8fafc}
.btn.primary{background:var(--brand);color:#fff;border-color:var(--brand)}
.btn.primary:hover{filter:brightness(1.05)}
.btn.big{width:100%;padding:.9rem;font-size:1rem;margin-top:.5rem}
.btn.sm{padding:.35rem .6rem;font-size:.78rem}
.navbtns{display:flex;justify-content:space-between;gap:1rem;margin-top:.5rem}
.del{background:#fee2e2;color:#b91c1c;border:none;border-radius:7px;padding:.25rem .5rem;cursor:pointer;font-weight:700}

/* Pills */
.pill{display:inline-block;padding:.15rem .55rem;border-radius:999px;font-size:.72rem;font-weight:700}
.pill.req{background:#dcfce7;color:#15803d}
.pill.need{background:#fef3c7;color:#b45309}
.pill.opt{background:#e2e8f0;color:#475569}
.pill.err{background:#fee2e2;color:#b91c1c}

/* Tables */
.doc-table{width:100%;border-collapse:collapse;font-size:.84rem;margin:.3rem 0}
.doc-table th,.doc-table td{border:1px solid var(--line);padding:.45rem .55rem;text-align:left}
.doc-table thead th{background:#f1f5f9;font-size:.78rem}
.doc-table tfoot td{background:#f8fafc}
.doc-table.editable td{padding:.25rem}
.cell{padding:.35rem;border:1px solid transparent;border-radius:6px}
.cell:hover{border-color:var(--line)}
.cell.num{text-align:right;max-width:130px}
.sbm-hint{font-size:.68rem;margin-top:2px}
.sbm-hint.ok{color:#16a34a}.sbm-hint.bad{color:#dc2626;font-weight:700}
.badge-err{background:#fee2e2;color:#b91c1c;padding:0 .3rem;border-radius:5px;font-size:.7rem}

.bullet{margin:.3rem 0;padding-left:1.1rem}.bullet li{margin:.2rem 0;font-size:.86rem}
details summary{cursor:pointer;color:var(--brand);font-size:.85rem;margin-top:.4rem}

/* Findings */
.finding{border:1px solid var(--line);border-left-width:4px;border-radius:8px;padding:.6rem .8rem;margin:.4rem 0;font-size:.86rem}
.finding.error{border-left-color:#dc2626;background:#fef2f2}
.finding.warn{border-left-color:#d97706;background:#fffbeb}
.finding.ok{border-left-color:#16a34a;background:#f0fdf4}
.rab-actions{display:flex;gap:.5rem;margin-top:.6rem;flex-wrap:wrap}

/* Doc cards */
.docgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.7rem}
.doccard{display:flex;flex-direction:column;align-items:center;gap:.35rem;background:#fff;border:1px solid var(--line);border-radius:12px;padding:1rem .6rem;cursor:pointer;font-size:.82rem;font-weight:600;text-align:center}
.doccard:hover{border-color:var(--brand);box-shadow:var(--shadow)}
.docicon{font-size:1.6rem}
.preview-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.7rem;flex-wrap:wrap}

/* Score dial */
.scorewrap{display:flex;align-items:center;gap:1.2rem}
.scoredial{--s:0;width:88px;height:88px;border-radius:50%;display:grid;place-items:center;background:conic-gradient(var(--brand) calc(var(--s)*1%),#e2e8f0 0)}
.scoredial span{width:66px;height:66px;border-radius:50%;background:#fff;display:grid;place-items:center;font-weight:800;font-size:1.3rem}
.checklist{list-style:none;padding:0;margin:0;font-size:.84rem}
.checklist li{padding:.3rem 0;border-bottom:1px dashed var(--line)}
.checklist li.fail{color:#b45309}

/* Approval chain */
.approvchain{display:flex;flex-direction:column;gap:.5rem}
.aprow{display:flex;align-items:center;justify-content:space-between;gap:1rem;border:1px solid var(--line);border-radius:10px;padding:.6rem .8rem}
.aprow.setuju{background:#f0fdf4;border-color:#bbf7d0}
.aprow.tolak{background:#fef2f2;border-color:#fecaca}
.aplvl{display:flex;align-items:center;gap:.6rem}
.apno{display:inline-grid;place-items:center;width:26px;height:26px;border-radius:50%;background:var(--brand);color:#fff;font-weight:700;font-size:.8rem}
.apstatus{text-align:right}

/* Arsip final */
.arsip-final{display:flex;gap:1.2rem;flex-wrap:wrap;align-items:flex-start}
.arsip-info{flex:1;min-width:260px}
.qr-wrap{text-align:center}
#qrcode{padding:.5rem;background:#fff;border:1px solid var(--line);border-radius:10px;display:inline-block}

/* Document paper (printable) */
.doc-paper{background:#fff;color:#000;padding:2rem 2.2rem;border:1px solid var(--line);border-radius:8px;font-family:"Times New Roman",Georgia,serif;font-size:.92rem;line-height:1.55}
.doc-kop{display:flex;align-items:center;gap:1rem}
.kop-logo{font-size:2.6rem}
.kop-text{text-align:center;flex:1}
.kop-l1{font-weight:700;font-size:1.1rem}
.kop-l2{font-weight:700;font-size:1rem}
.kop-l3{font-size:.72rem}
.kop-rule{border:none;border-top:3px double #000;margin:.4rem 0 1rem}
.doc-title{text-align:center;text-decoration:underline;margin:.4rem 0;font-size:1.1rem}
.doc-nomor{text-align:center;margin-top:0;font-size:.85rem}
.doc-meta{border:none}.doc-meta td{border:none;padding:.1rem .4rem;vertical-align:top;font-size:.9rem}
.doc-ol{padding-left:1.3rem}.doc-ol>li{margin:.4rem 0}
.doc-ttd{display:flex;justify-content:space-between;margin-top:2rem}
.ttd-box{text-align:left;min-width:240px}
.ttd-space{height:60px}
.ttd-nama{margin-top:.3rem;font-weight:600}
.tte-stamp{border:1.5px dashed #047857;color:#047857;border-radius:8px;padding:.4rem .6rem;margin:.4rem 0;font-size:.78rem}

.printpage{background:#fff;padding:0}
@media print{.printpage .doc-paper{border:none;border-radius:0}}

/* AI status dot in tab */
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#cbd5e1;margin-left:.25rem;vertical-align:middle}
.dot.on{background:#22c55e;box-shadow:0 0 0 3px rgba(34,197,94,.25)}

/* AI Copilot */
.ai-copilot{background:linear-gradient(120deg,#eef2ff,#f0fdfa);border-color:#c7d2fe}
.copilot-row{display:flex;gap:.5rem;margin-top:.3rem}
.copilot-row input{flex:1}
@media (max-width:560px){.copilot-row{flex-direction:column}}

/* Settings */
.cfg-group{display:flex;flex-direction:column;gap:.6rem;background:#f8fafc;border:1px solid var(--line);border-radius:10px;padding:.7rem;margin:.5rem 0}
.preview-bar .spacer{flex:1}

/* AI ringkasan */
.ringkas{margin-top:.6rem;font-size:.9rem;background:#f8fafc;border:1px solid var(--line);border-radius:10px;padding:.2rem .9rem}
.ringkas:empty{display:none}

/* BAS table */
.bas-table td{font-size:.82rem}
.bas-kel td{background:#1d4ed8;color:#fff}
.bas-jenis td{background:#eff6ff}
#bassearch{margin:.4rem 0 .6rem}

/* Responsive */
@media (max-width:720px){
  .grid2,.grid3{grid-template-columns:1fr}
  .cards4{grid-template-columns:1fr 1fr}
  .bar-row{grid-template-columns:1fr;gap:.2rem}
  .doc-paper{padding:1.2rem}
}
