*{box-sizing:border-box}body{margin:0;background:#e9eaed;color:#1f2937;font-family:Arial,Helvetica,sans-serif}.container{width:min(100%,1800px);max-width:none;margin:0 auto;padding:0 clamp(14px,1.8vw,28px)}.topbar{background:#111827;color:#fff;font-size:14px}.topbar-inner{min-height:40px;display:flex;justify-content:space-between;align-items:center;gap:16px}.topbar-link{color:#fff;background:#2563eb;text-decoration:none;padding:7px 12px;border-radius:999px;margin-left:10px;font-weight:700}.site-header{background:#fff;border-bottom:4px solid #2563eb}.brand{display:flex;align-items:center;gap:18px;padding-top:18px;padding-bottom:18px}.brand-logo{width:84px;height:84px;flex:0 0 auto;display:flex;align-items:center;justify-content:center}.brand img{max-width:100%;max-height:100%;width:100%;height:100%;object-fit:contain;display:block}.brand h1{font-size:28px;line-height:1.1;margin:0;text-transform:uppercase}.brand p{margin:7px 0 0;color:#4b5563}.main-nav{background:#1d4ed8;position:sticky;top:0;z-index:5}.nav-row{display:flex;gap:2px;overflow-x:auto}.nav-row a{color:#fff;text-decoration:none;font-weight:700;font-size:14px;padding:15px 18px;white-space:nowrap}.nav-row a:hover,.nav-row a.active{background:#1e40af}.layout{display:grid;grid-template-columns:minmax(0,1fr) clamp(300px,23vw,370px);gap:clamp(18px,1.8vw,32px);padding-top:24px;padding-bottom:24px}.content,.sidebar{min-width:0}.card,.panel{background:#fff;border:1px solid #d1d5db;border-radius:7px;box-shadow:0 1px 2px rgba(0,0,0,.05);overflow:hidden;margin-bottom:20px}.card-header{background:#2563eb;color:#fff;padding:13px 16px;font-weight:800;display:flex;justify-content:space-between;align-items:center;gap:12px}.card-link{display:inline-flex;align-items:center;color:#fff;text-decoration:none;font-size:13px;font-weight:700;padding:6px 10px;border:1px solid rgba(255,255,255,.35);border-radius:999px}.card-link:hover{background:rgba(255,255,255,.14)}.card-body{padding:18px}.panel h3{background:#2563eb;color:#fff;margin:0;padding:11px 14px;font-size:16px}.panel a{display:block;color:#374151;text-decoration:none;padding:10px 14px;border-bottom:1px solid #edf0f4}.panel a:hover,.panel a.active{background:#eff6ff;color:#1d4ed8;border-left:4px solid #2563eb}.desa-list{max-height:310px;overflow:auto}.stats p{display:flex;justify-content:space-between;padding:10px 14px;margin:0;border-bottom:1px solid #edf0f4}.hero{height:330px;background:linear-gradient(to top,rgba(0,0,0,.75),rgba(0,0,0,.05)),url("https://jatengprov.go.id/wp-content/uploads/2020/03/IMG-20200306-WA0012.jpg") center/cover;border-radius:7px;display:flex;align-items:flex-end;padding:24px;color:#fff}.hero h2{font-size:30px;margin:8px 0 0}.badge{display:inline-flex;background:#2563eb;color:#fff;padding:5px 9px;border-radius:5px;font-size:12px;font-weight:800;text-transform:uppercase}.grid{display:grid;gap:16px}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.metric{background:#eff6ff;border:1px solid #bfdbfe;border-radius:7px;padding:18px;text-align:center}.metric.green{background:#ecfdf5;border-color:#bbf7d0}.metric.purple{background:#f5f3ff;border-color:#ddd6fe}.metric strong{display:block;font-size:24px;margin-top:6px}.desa-card{border:1px solid #d1d5db;border-radius:7px;padding:16px;text-decoration:none;color:#1f2937;background:#fff}.desa-card:hover{border-color:#2563eb;box-shadow:0 5px 14px rgba(37,99,235,.14)}.news-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}.news-item{display:flex;flex-direction:column;gap:14px;height:100%;padding:18px;border:1px solid #d1d5db;border-radius:10px;background:#f8fafc}.news-item h3{margin:0;font-size:20px;line-height:1.35}.news-item p{margin:0;color:#4b5563;line-height:1.6}.news-meta{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;color:#6b7280;font-size:13px}.news-tag{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:#dbeafe;color:#1d4ed8;font-weight:700}.empty-state{padding:28px 18px;text-align:center;color:#6b7280;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:10px}.project-report-list{display:grid;gap:28px}.project-report-card{display:grid;gap:20px;padding:24px;border:1px solid #d1d5db;border-radius:18px;background:#fff;box-shadow:0 18px 38px rgba(15,23,42,.08)}.project-report-lead{position:relative;overflow:hidden;border-radius:16px;background:#0f172a;min-height:420px}.project-report-cover-link{display:block;height:100%}.project-report-cover{display:block;width:100%;height:100%;min-height:420px;max-height:620px;object-fit:cover;background:#0f172a}.project-report-cover-empty{display:flex;align-items:center;justify-content:center;padding:24px;color:#cbd5e1;background:linear-gradient(135deg,#1e293b,#0f172a)}.project-report-overlay{position:absolute;inset:auto 0 0 0;padding:28px;background:linear-gradient(180deg,rgba(15,23,42,.08) 0%,rgba(15,23,42,.88) 58%,rgba(15,23,42,.96) 100%);color:#fff}.project-report-head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px}.project-report-head h3{margin:10px 0 0;font-size:34px;line-height:1.15;color:#fff;max-width:900px}.project-report-meta{color:#dbeafe}.project-report-date{font-weight:600}.project-report-side{display:grid;gap:6px;justify-items:end;text-align:right;color:#e5e7eb}.project-report-side strong{font-size:26px;color:#fff}.project-highlight-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.project-highlight-card{display:grid;gap:10px;padding:18px;border-radius:14px;background:#f8fafc;border:1px solid #dbe3f0}.project-highlight-label{font-size:12px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:#64748b}.project-highlight-card strong{font-size:22px;line-height:1.25}.project-gallery{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.project-photo-card{display:grid;gap:10px}.project-photo-label{font-weight:800;color:#1f2937}.project-photo-link{display:block}.project-photo{display:block;width:100%;aspect-ratio:16/11;min-height:240px;object-fit:cover;border-radius:14px;border:1px solid #cbd5e1;background:#fff;box-shadow:0 12px 24px rgba(15,23,42,.08)}.project-photo-empty{display:flex;align-items:center;justify-content:center;width:100%;aspect-ratio:16/11;min-height:240px;border-radius:14px;border:1px dashed #cbd5e1;background:#f8fafc;color:#6b7280;text-align:center;padding:18px}.project-description{display:grid;gap:14px;color:#334155;line-height:1.8;font-size:16px}.project-description p{margin:0}form{margin:0}.inline-form{display:inline}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.photo-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.photo-card{padding:14px;border:1px dashed #cbd5e1;border-radius:10px;background:#f8fafc}.file-input-hidden{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}.photo-actions,.camera-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.photo-placeholder{display:flex;align-items:center;justify-content:center;width:100%;margin-top:12px;aspect-ratio:4/3;border-radius:10px;border:1px dashed #cbd5e1;background:#fff;color:#6b7280;text-align:center;padding:16px}.camera-stage{margin-top:12px}.camera-stage video,.camera-preview{display:block;width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:10px;border:1px solid #cbd5e1;background:#0f172a}.camera-preview{margin-top:12px;background:#fff}.camera-status{margin:10px 0 0}.upload-hint{margin:-4px 0 14px}.field{margin-bottom:16px}.field label{display:block;font-weight:700;font-size:14px;margin-bottom:6px}.field input,.field select,.field textarea,form select,form input{width:100%;padding:10px 11px;border:1px solid #cbd5e1;border-radius:6px;font-size:14px;background:#fff}.field input[type=file]{padding:8px;background:#fff}.field textarea{min-height:96px;resize:vertical}.btn{border:0;background:#2563eb;color:#fff;text-decoration:none;padding:10px 14px;border-radius:6px;font-weight:800;cursor:pointer;display:inline-flex;align-items:center;gap:8px}.btn.small{padding:8px 12px;font-size:13px}.btn:hover{background:#1d4ed8}.btn.secondary{background:#4b5563}.btn.danger{background:#dc2626}.alert{border-radius:7px;padding:12px 14px;margin-bottom:16px}.alert.success{background:#ecfdf5;border:1px solid #86efac;color:#166534}.alert.error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.table-wrap{overflow:auto}.table-actions,.foto-links{display:flex;gap:8px;flex-wrap:wrap;align-items:center}table{width:100%;border-collapse:collapse;background:#fff}th,td{border-bottom:1px solid #e5e7eb;padding:11px 10px;text-align:left;vertical-align:top;font-size:14px}th{background:#f8fafc;font-weight:800}.muted{color:#6b7280}.footer{background:#1f2937;color:#d1d5db;padding:22px 0;margin-top:auto}.actions{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.section-title{font-size:18px;font-weight:800;margin:22px 0 12px;border-bottom:1px solid #e5e7eb;padding-bottom:8px}.ai-score{font-size:42px;font-weight:900;color:#16a34a}.progress{height:11px;background:#e5e7eb;border-radius:999px;overflow:hidden}.progress span{display:block;height:100%;background:#16a34a}@media(max-width:900px){.layout{grid-template-columns:1fr}.brand{align-items:flex-start}.brand-logo{width:68px;height:68px}.brand h1{font-size:22px}.hero{height:250px}.grid-2,.grid-3,.form-grid,.news-list,.photo-grid,.project-gallery,.project-highlight-grid{grid-template-columns:1fr}.project-report-lead{min-height:320px}.project-report-cover{min-height:320px;max-height:none}.project-report-head{grid-template-columns:1fr;display:grid;align-items:start}.project-report-head h3{font-size:26px}.project-report-side{justify-items:start;text-align:left}.project-photo,.project-photo-empty{min-height:220px}.topbar-inner{align-items:flex-start;flex-direction:column;padding-top:8px;padding-bottom:8px}}
