*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:#0e1726;background:#0b1220}
header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#12223a;color:#e6edf7;border-bottom:1px solid #20334f}
header .brand{display:flex;align-items:center;gap:10px}
header .brand img{height:22px;width:auto}
h1{font-size:18px;margin:0}
.status{display:flex;gap:8px;align-items:center}
.badge{padding:4px 8px;border-radius:10px;background:#3b3b3b;color:#fff;font-size:12px}
.badge.online{background:#1a7f37}
.badge.offline{background:#7f1a1a}
.btn{background:#1f2f4a;border:1px solid #284468;color:#cfe1ff;border-radius:8px;padding:8px 12px;cursor:pointer}
.btn:hover{filter:brightness(1.1)}
.btn.primary{background:#f59e0b;border-color:#f59e0b;color:#0e1726}
.btn.danger{background:#a33232;border-color:#bb3434;color:#fff}
.btn.small{padding:6px 8px;font-size:12px}
.controls{display:flex;gap:8px;padding:12px 16px;background:#0f1a2d;position:sticky;top:0;border-bottom:1px solid #20334f}
.controls input{flex:1;padding:10px;border-radius:8px;border:1px solid #24344e;background:#0a1830;color:#cfe1ff}
.controls input#siteAddress{flex:2}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;padding:12px 16px}
.card{display:grid;grid-template-columns:96px 1fr auto;gap:10px;align-items:center;background:#0f1b33;border:1px solid #20334f;border-radius:12px;padding:10px}
.thumb{width:96px;height:72px;object-fit:cover;border-radius:8px;background:#0a1426}
.meta .title{font-weight:600;color:#e6edf7}
.meta .sub{color:#a9bddf;font-size:13px;margin-top:2px}
.badges{display:flex;gap:6px;margin-top:6px;flex-wrap:wrap}
.badges .pill{font-size:11px;padding:2px 6px;border-radius:6px;background:#15294d;color:#cfe1ff;border:1px solid #20334f}
.actions{display:flex;flex-direction:column;gap:6px}
dialog{border:none;border-radius:12px;padding:0;max-width:520px;width:90vw}
dialog::backdrop{background:rgba(5,10,20,.6)}
#partForm{padding:16px;background:#0f1b33;color:#e6edf7;border:1px solid #20334f;border-radius:12px}
#partForm .row{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}
#partForm input{padding:10px;border-radius:8px;border:1px solid #24344e;background:#0a1830;color:#cfe1ff}
#partForm menu{display:flex;gap:8px;justify-content:flex-end;margin-top:6px}
a, .pill a{color:#f59e0b}


/* Accordion view */
.accordion .section{background:#0f1b33;border:1px solid #20334f;border-radius:12px;margin:8px 0;overflow:hidden}
.accordion details{background:transparent}
.accordion summary{list-style:none;cursor:pointer;padding:10px 14px;font-weight:600;color:#e6edf7;border-bottom:1px solid #20334f;display:flex;justify-content:space-between;align-items:center}
.accordion summary::-webkit-details-marker{display:none}
.accordion .rows{display:flex;flex-direction:column}
.accordion .row-item{display:flex;gap:10px;align-items:center;padding:8px 14px;border-top:1px solid #20334f}
.accordion .row-item:hover{background:#0d1730}
.accordion .row-item .thumb{width:64px;height:48px;border-radius:8px;object-fit:cover;background:#0a1426}
.accordion .row-item .info{flex:1;display:flex;flex-direction:column}
.accordion .row-item .info .title{color:#e6edf7}
.accordion .row-item .info .sub{color:#a9bddf;font-size:12px}
.accordion .row-item .add{white-space:nowrap}
