*{box-sizing:border-box}body,html{margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;background:#fffcf8;color:#1f2937}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.container{max-width:980px;margin:0 auto;padding:16px}.app-header{display:flex;margin:6px 0 14px}.app-header,.logo{align-items:center;gap:10px}.logo{display:inline-flex;font-weight:800}.logo,.logo-text{font-size:22px}.logo-img{width:40px;height:40px;border-radius:12px;background:#fff2de;border:1px solid #f2dec2;padding:4px}.stack{display:grid;grid-gap:14px;gap:14px}.page-home{padding-bottom:96px}.row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.card{background:#fff;border:1px solid #f2e7d8;border-radius:18px;padding:16px;box-shadow:0 2px 12px rgba(40,22,5,.04)}.section-title{align-items:center;gap:8px}.heatmap-header,.section-title{display:flex;justify-content:space-between}.heatmap-header{align-items:flex-start;gap:12px;flex-wrap:wrap}.heatmap-title{align-items:center}.heatmap-title h2{font-size:22px}.btn{border:0;border-radius:12px;min-height:42px;padding:10px 14px;cursor:pointer;background:#f59e0b;color:#fff;font-weight:600}.btn.secondary{background:#fff5e5;color:#7c4a0a;border:1px solid #f2dec2}.btn.danger{background:#dc2626;color:#fff}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:12px;border:1px solid #f2dec2;background:#fff6e8;color:#8a560b;font-size:20px}.text-btn{background:transparent;border:0;padding:0;color:inherit;font:inherit;cursor:pointer;text-align:left;width:100%}.input,.select,.textarea{width:100%;min-height:42px;border-radius:12px;border:1px solid #ecdcc6;background:#fffdfa;padding:10px 12px}.textarea{resize:vertical}.grid{display:grid;grid-gap:10px;gap:10px}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.legend,.muted{font-size:14px;color:#6b7280}.legend{gap:16px}.dot{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:6px}.dot.healthy{background:#d6e9df}.dot.unhealthy{background:#e8a770}.heatmap{--cell:10px;--gap:3px;display:grid;grid-gap:var(--gap);gap:var(--gap);width:100%;align-content:start;justify-content:start;grid-auto-rows:var(--cell)}.day{width:var(--cell);height:var(--cell);border-radius:3px;background:#d6e9df}.day.unhealthy{background:#e8a770}.event-link{display:grid;grid-gap:5px;gap:5px;border-bottom:1px solid #f3eadf;padding:12px 0}.event-link:last-child{border-bottom:none}.event-title{font-size:28px;font-weight:800}.event-sub{color:#5b6472;font-size:14px}.detail-list{display:grid;grid-gap:10px;gap:10px}.detail-item{border:1px solid #f2e8db;border-radius:12px;padding:12px;background:#fffdfa}.detail-label{font-size:13px;color:#6b7280;margin-bottom:4px}.detail-value{font-size:18px;color:#1f2937;white-space:pre-wrap;word-break:break-word}.page-header{display:grid;grid-template-columns:42px 1fr auto;align-items:center;grid-gap:12px;gap:12px}.list-row{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid #f3eadf}.list-row:last-child{border-bottom:none}.list-row.full-row{width:100%;border-bottom:1px solid #f3eadf}.list-title{font-size:22px;font-weight:800}.info-box{border:1px solid #f2e8db;border-radius:14px;padding:12px;background:#fffdfa}.info-label{font-size:14px;color:#6b7280}.info-value{margin-top:6px;font-size:20px;font-weight:600}.danger-zone{border:1px solid #ffd7d7;background:#fff8f8;border-radius:14px;padding:12px;display:grid;grid-gap:10px;gap:10px}.side-toggle{width:44px;height:44px;border-radius:12px;border:1px solid #ecdcc6;background:#fffaf1;color:#7c4a0a;font-size:18px;cursor:pointer}.fab{right:calc(20px + env(safe-area-inset-right));bottom:calc(20px + env(safe-area-inset-bottom));width:60px;height:60px;border-radius:999px;background:#f59e0b;color:#fff;align-items:center;justify-content:center;font-size:32px;font-weight:700;box-shadow:0 8px 24px rgba(245,158,11,.35)}.fab,.side-nav{position:fixed;display:flex}.side-nav{inset:0 auto 0 0;width:250px;padding:18px 14px;background:#fffdf9;border-right:1px solid #f0e1cd;transform:translateX(-100%);transition:transform .22s ease;z-index:1300;flex-direction:column;gap:8px}.side-nav.open{transform:translateX(0)}.side-title{font-size:14px;color:#6b7280;padding:10px 8px}.side-item{border-radius:10px;padding:10px 8px}.side-item.active{background:#fff1da;color:#7c4a0a;font-weight:600}.side-footer{margin-top:auto;padding-top:12px;display:grid;grid-gap:12px;gap:12px;border-top:1px solid #f0e1cd}.side-link{color:#1f2937;font-weight:600}.side-mask{position:fixed;inset:0;background:rgba(12,11,9,.34);z-index:1200}@media (max-width:768px){.container{padding:12px}.logo-text{font-size:20px}.grid-2{grid-template-columns:minmax(0,1fr)}.card{padding:14px}.event-title{font-size:22px}.page-header{grid-template-columns:42px 1fr auto}}