*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#0f1117;color:#e2e8f0;min-height:100vh;padding:2rem 1rem}h1{font-size:1.5rem;font-weight:600;margin-bottom:.25rem;color:#f8fafc}.subtitle{font-size:.85rem;color:#64748b;margin-bottom:2rem}.card{background:#1e2130;border:1px solid #2d3148;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.card h2{font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8;margin-bottom:0}.bedtime-setting{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:#64748b}.bedtime-setting input[type=time]{width:auto;padding:.3rem .5rem;font-size:.8rem;border-color:#a78bfa44}.bedtime-setting input[type=time]:focus{border-color:#a78bfa}table{width:100%;border-collapse:collapse}th{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#64748b;text-align:left;padding:0 .5rem .75rem}td{padding:.3rem .5rem}tr:not(:last-child) td{border-bottom:1px solid #2d3148}select,input[type=time],input[type=number],input[type=date]{background:#0f1117;border:1px solid #2d3148;border-radius:6px;color:#e2e8f0;font-size:.875rem;padding:.4rem .6rem;width:100%;outline:none;transition:border-color .15s}select:focus,input:focus{border-color:#6366f1}.col-drink{width:34%}.col-date{width:18%}.col-time{width:16%}.col-mg{width:14%}.col-action{width:6%;text-align:center}.btn-remove{background:none;border:none;color:#ef4444;cursor:pointer;font-size:1.1rem;padding:.2rem .4rem;border-radius:4px;transition:background .15s}.btn-remove:hover{background:#2d1f1f}.btn-add{margin-top:1rem;background:#6366f1;color:#fff;border:none;border-radius:8px;padding:.55rem 1.2rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s}.btn-add:hover{background:#4f52d1}.btn-row{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1rem}.btn-row .btn-add{margin-top:0}.btn-secondary{background:none;color:#6366f1;border:1px solid #6366f1;border-radius:8px;padding:.55rem 1.2rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.btn-secondary:hover{background:#6366f11a}.chart-wrap{position:relative;height:320px}.stats{display:flex;gap:1.5rem;flex-wrap:wrap}.stat{display:flex;flex-direction:column;gap:.15rem}.stat-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:#64748b}.stat-value{font-size:1.25rem;font-weight:600;color:#a5b4fc}.stat-value.quality-good{color:#4ade80}.stat-value.quality-fair{color:#facc15}.stat-value.quality-poor{color:#f87171}.legend{display:flex;gap:1.2rem;flex-wrap:wrap;margin-top:.75rem;font-size:.75rem;color:#64748b}.legend-item{display:flex;align-items:center;gap:.4rem}.legend-dot{width:10px;height:10px;border-radius:2px;flex-shrink:0}.thresh-input{display:none;background:transparent;border:none;border-bottom:1px dashed transparent;color:#64748b;font-size:.75rem;width:3.5ch;padding:0 1px;text-align:center;outline:none;cursor:pointer;transition:border-color .15s,color .15s;-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.thresh-input::-webkit-outer-spin-button,.thresh-input::-webkit-inner-spin-button{-webkit-appearance:none}.thresh-input:hover{border-bottom-color:#475569}.thresh-input:focus{border-bottom-color:#94a3b8;color:#94a3b8;cursor:text}.legend.thresh-open .thresh-input{display:inline}.legend.thresh-open .thresh-static{display:none}.thresh-toggle{margin-left:auto;background:none;border:none;color:#475569;cursor:pointer;font-size:.85rem;padding:0 .1rem;line-height:1;transition:color .15s}.thresh-toggle:hover{color:#94a3b8}.empty-hint{text-align:center;color:#475569;font-size:.875rem;padding:3rem 0}
