*{box-sizing:border-box}
html,body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial,sans-serif;color:#111}
header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #eee;position:sticky;top:0;background:#fff;z-index:5}
h1{margin:0;font-size:1.4rem}
.actions button,.file-label{margin-left:8px}
.file-label{border:1px solid #ddd;border-radius:8px;padding:8px 12px;cursor:pointer}
.file-label input{display:none}
main{max-width:1100px;margin:24px auto;padding:0 16px}
.panel{border:1px solid #eee;border-radius:12px;padding:16px 16px 8px;margin-bottom:18px;background:#fff}
.grid{display:grid;gap:12px}
.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}
.col-span-2{grid-column:span 2}
.col-span-3{grid-column:span 3}
label{display:flex;flex-direction:column;font-size:.9rem;gap:6px}
input,select,button{border:1px solid #ddd;border-radius:8px;padding:10px;font-size:1rem}
button{cursor:pointer;background:#111;color:#fff;border-color:#111}
button.danger{background:#b00020;border-color:#b00020}
.toolbar{display:flex;gap:8px;align-items:center;margin:8px 0 4px;flex-wrap:wrap}
.badge{background:#eef7ff;color:#14509f;border-radius:999px;padding:4px 10px;font-size:.85rem}
#pup-list{display:flex;flex-direction:column;gap:10px}
.pup{border:1px solid #eee;border-radius:12px;overflow:hidden}
.summary-row{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;background:#fafafa}
.summary-row .stats{display:flex;gap:10px;font-size:.9rem;color:#333}
.pup-body{padding:12px 14px 16px}
.table{width:100%;border-collapse:collapse;margin-top:10px}
.table th,.table td{border-bottom:1px solid #eee;padding:8px;text-align:left}
.chart-wrap{width:100%;overflow-x:auto}
.chart{width:100%;height:220px;background:#fff}
.stat{background:#f1f1f1;border-radius:999px;padding:4px 10px}
footer{max-width:1100px;margin:24px auto;padding:0 16px 30px;color:#666}
@media (max-width:720px){.grid.two,.grid.three{grid-template-columns:1fr}}
/* Menu */
.menu-wrap{position:relative}
#menu-button{border:1px solid #ddd;border-radius:10px;padding:8px 12px;background:#fff;cursor:pointer}
#menu{position:absolute;right:0;top:44px;background:#fff;border:1px solid #eee;border-radius:12px;box-shadow:0 8px 20px rgba(0,0,0,.08);min-width:220px;display:none;z-index:10}
#menu.open{display:block}
#menu .group{padding:8px;border-top:1px solid #f2f2f2}
#menu .group:first-child{border-top:none}
#menu button,#menu a{display:block;width:100%;text-align:left;background:none;border:0;padding:10px 12px;border-radius:10px;cursor:pointer}
#menu button:hover,#menu a:hover{background:#f7f7f7}
#menu .label{font-size:.75rem;color:#666;padding:6px 12px 2px}
#menu input[type=file]{display:none}
/* Fix menu text colors */
#menu button, #menu a { 
  color: #111 !important; 
  background: #fff; 
}
#menu button:hover, #menu a:hover { 
  background: #f7f7f7; 
}
#menu { 
  color: #111; 
}
#menu-button { 
  background: #fff; 
  color: #111; 
  border: 1px solid #ddd; 
}
/* ---- Menu overrides (force readable text) ---- */
.menu-wrap #menu button,
.menu-wrap #menu a {
  color: #111 !important;
  background: #fff !important;
  border: 1px solid #ddd !important;
}

.menu-wrap #menu button:hover,
.menu-wrap #menu a:hover {
  background: #f7f7f7 !important;
}

#menu-button {
  color: #111 !important;
  background: #fff !important;
  border: 1px solid #ddd !important;
}
