/* PPJ Unsoed - minimal stylesheet */
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:#1f2937;background:#f5f7fa;line-height:1.5}
a{color:#1d4ed8;text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:1200px;margin:0 auto;padding:0 20px}
.muted{color:#6b7280}
.small{font-size:.85em}
.num{text-align:right;font-variant-numeric:tabular-nums}

/* Topbar */
.topbar{background:#1e3a8a;color:#fff;padding:12px 0;margin-bottom:24px}
.topbar a{color:#fff}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.brand a{font-weight:700;font-size:18px}
.nav{display:flex;gap:18px;flex-wrap:wrap}
.nav a{font-size:14px;padding:6px 0;border-bottom:2px solid transparent}
.nav a:hover{border-bottom-color:#fff;text-decoration:none}
.nav a.logout{color:#fecaca}

/* Page */
.page-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;flex-wrap:wrap}
.page-head h1{margin:0;font-size:22px}
h2{font-size:18px;margin:24px 0 12px}

/* Buttons */
.btn{display:inline-block;padding:7px 14px;border:1px solid #d1d5db;background:#fff;color:#1f2937;border-radius:6px;font-size:14px;cursor:pointer;text-decoration:none}
.btn:hover{background:#f3f4f6;text-decoration:none}
.btn-primary{background:#1d4ed8;border-color:#1d4ed8;color:#fff}
.btn-primary:hover{background:#1e40af;color:#fff}
.btn-danger{background:#dc2626;border-color:#dc2626;color:#fff}
.btn-danger:hover{background:#b91c1c;color:#fff}
.btn-sm{padding:4px 10px;font-size:12px}
.btn-block{width:100%;display:block}

/* Forms */
.form-grid{background:#fff;padding:20px;border-radius:8px;border:1px solid #e5e7eb}
.form-grid fieldset{border:1px solid #e5e7eb;border-radius:6px;padding:14px 16px;margin-bottom:16px}
.form-grid legend{padding:0 6px;font-weight:600;font-size:14px;color:#374151}
.form-grid label{display:block;margin-bottom:12px;font-size:14px;color:#374151}
.form-grid input[type=text],
.form-grid input[type=email],
.form-grid input[type=url],
.form-grid input[type=password],
.form-grid textarea{width:100%;padding:8px 10px;border:1px solid #d1d5db;border-radius:5px;font-size:14px;font-family:inherit;margin-top:4px}
.form-grid input:focus,.form-grid textarea:focus{outline:none;border-color:#1d4ed8;box-shadow:0 0 0 3px rgba(29,78,216,.15)}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.row-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:640px){.row-2,.row-3{grid-template-columns:1fr}}
.form-actions{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}

/* Tables */
.table-wrap{overflow-x:auto;background:#fff;border-radius:8px;border:1px solid #e5e7eb}
.table{width:100%;border-collapse:collapse;font-size:14px}
.table th,.table td{padding:10px 12px;text-align:left;border-bottom:1px solid #f1f5f9;vertical-align:top}
.table th{background:#f9fafb;font-weight:600;color:#374151;font-size:13px}
.table tbody tr:hover{background:#f9fafb}
.actions{white-space:nowrap}

/* Cards */
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin:16px 0 24px}
.card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:14px 16px}
.card h3{margin:0 0 10px;font-size:14px;color:#1e3a8a;text-transform:uppercase;letter-spacing:.5px}
.card dl{margin:0;display:grid;grid-template-columns:120px 1fr;gap:6px 12px;font-size:14px}
.card dt{color:#6b7280}
.card dd{margin:0}

/* Alerts */
.alert{padding:10px 14px;border-radius:6px;margin-bottom:16px;font-size:14px}
.alert-info{background:#dbeafe;color:#1e3a8a;border:1px solid #bfdbfe}
.alert-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}
.alert ul{margin:0;padding-left:20px}

/* Badges */
.badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;text-transform:uppercase}
.badge-success{background:#d1fae5;color:#065f46}
.badge-failed{background:#fee2e2;color:#991b1b}
.badge-partial{background:#fef3c7;color:#92400e}

/* Empty */
.empty{background:#fff;padding:40px;text-align:center;border:1px dashed #d1d5db;border-radius:8px;color:#6b7280}
.empty p{margin:0 0 12px}

/* Footer */
.footer{margin-top:40px;padding:16px 0;color:#6b7280;font-size:13px;text-align:center}

/* Icons inline */
.ico{display:inline-block;font-style:normal;margin-right:4px;font-size:1em;line-height:1;vertical-align:-1px}
.card h3 .ico{margin-right:6px}
.btn .ico{margin-right:2px}

/* External links pada card editor */
.link-ext{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:4px;background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8;font-size:13px;text-decoration:none}
.link-ext:hover{background:#dbeafe;text-decoration:none}
.link-ext .ext-arrow{font-size:10px;opacity:.7}
.link-empty{display:inline-block;padding:2px 8px;border-radius:4px;background:#f3f4f6;color:#9ca3af;font-size:12px;font-style:italic;border:1px dashed #d1d5db}

/* Card dl: spacing lebih nyaman dengan icon */
.card dl{grid-template-columns:140px 1fr}
.card dt{display:flex;align-items:center;gap:2px}

/* Dashboard riwayat terbitan */
.dashboard{margin:16px 0 24px}
.dash-toolbar{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;background:#fff;padding:12px 16px;border:1px solid #e5e7eb;border-radius:8px 8px 0 0;border-bottom:none}
.filter-label{display:flex;align-items:center;gap:8px;font-size:14px;color:#374151;font-weight:500}
.filter-label select{padding:6px 10px;border:1px solid #d1d5db;border-radius:5px;font-size:14px;background:#fff;cursor:pointer}
.filter-label select:focus{outline:none;border-color:#1d4ed8;box-shadow:0 0 0 3px rgba(29,78,216,.15)}
.dash-stats{display:flex;gap:16px;flex-wrap:wrap}
.dash-stat{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;background:#f1f5f9;border-radius:20px;font-size:13px;color:#334155}
.dash-stat strong{color:#1e3a8a;font-size:15px}

.chart-card{background:#fff;padding:18px 20px;border:1px solid #e5e7eb;border-top:none;border-radius:0 0 8px 8px;position:relative}

/* Pure CSS bar chart */
.chart-legend{display:flex;justify-content:center;gap:24px;margin-bottom:14px;font-size:13px;color:#374151}
.legend-item{display:inline-flex;align-items:center;gap:6px}
.legend-swatch{display:inline-block;width:14px;height:14px;border-radius:3px}
.sw-issues{background:rgba(29,78,216,.85);border:1px solid rgba(29,78,216,1)}
.sw-articles{background:rgba(16,185,129,.85);border:1px solid rgba(16,185,129,1)}

.bar-chart{display:flex;align-items:flex-end;justify-content:flex-start;gap:18px;height:260px;padding:10px 4px 0;border-bottom:1px solid #e5e7eb;overflow-x:auto}
.bar-group{flex:0 0 auto;min-width:60px;display:flex;flex-direction:column;align-items:center;cursor:pointer;height:100%;justify-content:flex-end;padding:4px;border-radius:6px;transition:background .15s,opacity .25s}
.bar-group:hover{background:#f1f5f9}
.bar-group:focus{outline:2px solid #1d4ed8;outline-offset:2px}
.bar-group.active{background:#dbeafe}
.bar-group.dim{opacity:.35}
.bar-group .bars{display:flex;align-items:flex-end;gap:4px;height:calc(100% - 26px);width:100%;justify-content:center}
.bar-group .bar{width:22px;min-height:2px;border-radius:4px 4px 0 0;position:relative;transition:height .35s ease;display:flex;justify-content:center;align-items:flex-start}
.bar-issues{background:rgba(29,78,216,.85);border:1px solid rgba(29,78,216,1)}
.bar-articles{background:rgba(16,185,129,.85);border:1px solid rgba(16,185,129,1)}
.bar-label{position:absolute;top:-18px;font-size:11px;font-weight:600;color:#374151;white-space:nowrap}
.bar-year{margin-top:6px;font-size:13px;font-weight:600;color:#1f2937}
.chart-hint{margin:10px 0 0;text-align:center}

.table-section{margin-top:24px}
.table-section h3{font-size:15px;margin:0 0 10px;color:#374151}
.table-section h3 #tableYearLabel{color:#1d4ed8;font-weight:600}

/* Pagination */
.pagination{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-top:14px;padding:10px 4px}
.pg-info{display:flex;align-items:center;gap:14px;flex-wrap:wrap;font-size:13px;color:#374151}
.pg-pagesize select{padding:4px 8px;border:1px solid #d1d5db;border-radius:4px;font-size:13px;margin:0 4px}
.pg-summary{color:#6b7280}
.pg-buttons{display:flex;gap:4px;align-items:center;flex-wrap:wrap}
.pg-btn{padding:6px 11px;border:1px solid #d1d5db;background:#fff;border-radius:5px;font-size:13px;cursor:pointer;min-width:32px;color:#1f2937;font-family:inherit}
.pg-btn:hover:not(.active):not(.disabled){background:#f3f4f6}
.pg-btn.active{background:#1d4ed8;border-color:#1d4ed8;color:#fff;font-weight:600}
.pg-btn.disabled,.pg-btn:disabled{opacity:.4;cursor:not-allowed}
.pg-dots{padding:0 6px;color:#9ca3af;font-size:13px}

@media(max-width:640px){
  .dash-toolbar{flex-direction:column;align-items:stretch}
  .bar-chart{height:220px;gap:10px}
  .bar-group{min-width:48px}
  .bar-group .bar{width:16px}
  .pagination{flex-direction:column;align-items:flex-start}
}

/* Akreditasi badges */
.akr-badge{display:inline-block;padding:3px 9px;border-radius:12px;font-size:11px;font-weight:700;letter-spacing:.3px;white-space:nowrap;border:1px solid transparent}
.akr-sinta-1{background:#fef3c7;color:#78350f;border-color:#fcd34d}
.akr-sinta-2{background:#fde68a;color:#78350f;border-color:#f59e0b}
.akr-sinta-3{background:#dbeafe;color:#1e3a8a;border-color:#93c5fd}
.akr-sinta-4{background:#e0e7ff;color:#3730a3;border-color:#a5b4fc}
.akr-sinta-5{background:#f3e8ff;color:#581c87;border-color:#c4b5fd}
.akr-sinta-6{background:#fce7f3;color:#831843;border-color:#f9a8d4}
.akr-scopus-q1{background:#dcfce7;color:#14532d;border-color:#86efac}
.akr-scopus-q2{background:#a7f3d0;color:#064e3b;border-color:#34d399}
.akr-scopus-q3{background:#fef9c3;color:#713f12;border-color:#fde047}
.akr-scopus-q4{background:#fed7aa;color:#7c2d12;border-color:#fb923c}
.akr-belum{background:#f3f4f6;color:#6b7280;border-color:#d1d5db}

/* Akreditasi conditional boxes pada form */
.akr-box{margin-top:10px;padding:12px;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:6px}

/* Filter pills (dashboard) */
.filter-pills{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.pill{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:#fff;border:1px solid #d1d5db;border-radius:20px;font-size:13px;color:#374151;text-decoration:none;transition:all .15s}
.pill:hover{background:#f3f4f6;text-decoration:none}
.pill.active{background:#1d4ed8;border-color:#1d4ed8;color:#fff;font-weight:600}
.pill.active .pill-count{background:rgba(255,255,255,.25);color:#fff}
.pill-count{display:inline-block;padding:1px 8px;background:#e5e7eb;color:#374151;border-radius:10px;font-size:11px;font-weight:700}

/* Login */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#1e3a8a 0%,#1d4ed8 100%);padding:20px}
.login-card{background:#fff;padding:32px;border-radius:10px;box-shadow:0 10px 25px rgba(0,0,0,.15);width:100%;max-width:380px}
.login-card h1{margin:0 0 4px;font-size:22px;color:#1e3a8a}
.login-card p{margin:0 0 20px;font-size:14px}
.login-card label{display:block;margin-bottom:14px;font-size:14px;color:#374151}
.login-card input{width:100%;padding:9px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;margin-top:5px}
.login-card input:focus{outline:none;border-color:#1d4ed8;box-shadow:0 0 0 3px rgba(29,78,216,.15)}
