/* smpn-sleman.css - Stylesheet untuk SPMB Sleman Logic System */
:root{
  --primary:#1d4ed8;
  --primary-dark:#1e3a8a;
  --bg:#eef4ff;
  --card:#ffffff;
  --success:#16a34a;
  --danger:#dc2626;
  --warning:#d97706;
  --text:#111827;
  --muted:#6b7280;
  --border:#dbe4f0;
}
*{box-sizing:border-box}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}
.container{width:min(1200px,95%);margin:auto;padding:20px 0 80px}
.hero{background:linear-gradient(135deg,var(--primary),#2563eb);color:white;border-radius:24px;padding:28px;margin-bottom:20px}
.hero h1{margin:0 0 10px;font-size:2.1rem}
.hero p{margin:0;opacity:.95}
.card{background:var(--card);border-radius:20px;padding:22px;margin-bottom:18px;box-shadow:0 5px 18px rgba(0,0,0,.06)}
.card h2{margin-top:0}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:900px){.grid{grid-template-columns:1fr}}
label{display:block;margin-bottom:6px;font-weight:bold}
input,select{width:100%;padding:12px;border-radius:12px;border:1px solid var(--border);font-size:15px}
.section-title{margin-top:30px;margin-bottom:10px;font-size:1.1rem;color:var(--primary-dark)}
.checks{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:700px){.checks{grid-template-columns:1fr}}
.check-item{background:#f8fbff;border:1px solid var(--border);border-radius:14px;padding:12px}
button{border:none;background:var(--primary);color:white;padding:15px 24px;border-radius:14px;font-size:16px;font-weight:bold;cursor:pointer}
button:hover{background:var(--primary-dark)}
.route{border-radius:18px;padding:20px;margin-bottom:18px;border:2px solid var(--border)}
.route.allowed{border-color:var(--success);background:#f0fff5}
.route.denied{border-color:var(--danger);background:#fff5f5}
.badge{display:inline-block;padding:7px 12px;border-radius:999px;font-size:13px;font-weight:bold;margin-bottom:10px}
.badge.ok{background:#dcfce7;color:#166534}
.badge.no{background:#fee2e2;color:#991b1b}
.timeline{margin-top:10px}
.timeline-item{border-left:4px solid var(--primary);padding-left:14px;margin-bottom:14px}
.small{color:var(--muted);font-size:14px}
.notice{background:#fff7ed;border:1px solid #fdba74;border-radius:14px;padding:16px}
.footer{text-align:center;margin-top:40px;color:var(--muted);font-size:14px}
a{color:var(--primary);text-decoration:none}
ul{padding-left:20px}
.table-wrap{overflow:auto}
table{width:100%;border-collapse:collapse}
table th,table td{border:1px solid var(--border);padding:10px;text-align:left}
th{background:#eff6ff}
.wa-share-btn{display:inline-flex;align-items:center;gap:8px;background:#25D366;color:white;padding:12px 20px;border-radius:12px;font-weight:bold;text-decoration:none;margin-top:10px;transition:background 0.2s}
.wa-share-btn:hover{background:#128C7E}
#domisili-dropdowns select{background:white;cursor:pointer}
#domisili-dropdowns select:disabled{background:#f3f4f6;cursor:not-allowed;color:#9ca3af}
#domisili-dropdowns select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px rgba(29,78,216,0.1)}
.prediction-section{background:#f8fbff;border:1px solid var(--border);border-radius:14px;padding:16px;margin:16px 0}
.prediction-section h4{margin:0 0 12px;color:var(--primary-dark)}
.school-pred{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px dashed #eee}
.school-pred:last-child{border-bottom:none}
.school-name{font-weight:600}
.school-prob{font-size:13px}
.prob-bar{height:6px;background:#e9ecef;border-radius:3px;overflow:hidden;margin-top:4px}
.prob-fill{height:100%;background:linear-gradient(90deg,#28a745,#20c997);transition:width 0.3s}
.optimism-control{display:flex;align-items:center;gap:12px;margin:12px 0}
.optimism-control input[type="range"]{flex:1}
.prediction-section {
  background: #f8fbff;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 16px;
  margin: 16px 0;
}

.prediction-section h4 {
  margin: 0 0 12px;
  color: var(--primary-dark);
  font-size: 16px;
}

.prob-bar {
  height: 6px;
  background: #e9ecef;
  border-radius: 3px;
  overflow: hidden;
  margin-top: 4px;
}

.prob-fill {
  height: 100%;
  background: linear-gradient(90deg, #28a745, #20c997);
  transition: width 0.5s ease;
}
