.calendar-dash *{box-sizing:border-box;margin:0;padding:0}.calendar-dash{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;display:grid;grid-template-columns:1fr 280px;gap:24px;max-width:900px;margin:0 auto}.calendar-card{background:#fff;border-radius:20px;border:1px solid #f3f4f6;box-shadow:0 8px 24px #0000000f;padding:24px}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.calendar-month{font-size:18px;font-weight:700;color:#111827}.calendar-nav{display:flex;gap:8px}.calendar-nav button{width:32px;height:32px;border-radius:8px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.calendar-nav button:hover{background:#f3f4f6}.calendar-nav button svg{width:16px;height:16px;color:#6b7280}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-day-header{text-align:center;font-size:11px;font-weight:600;color:#9ca3af;padding:8px 0}.calendar-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:10px;font-size:13px;color:#374151;cursor:pointer;transition:all .2s ease;position:relative}.calendar-day:hover{background:#f3f4f6}.calendar-day.today{background:linear-gradient(135deg,#6b4eff,#8b5cf6);color:#fff;font-weight:600}.calendar-day.has-report:after{content:"";position:absolute;bottom:4px;width:6px;height:6px;border-radius:50%;background:#6b4eff}.calendar-day.today.has-report:after{background:#fff}.calendar-day.other-month{color:#d1d5db}.upcoming-card{background:#fff;border-radius:20px;border:1px solid #f3f4f6;box-shadow:0 8px 24px #0000000f;padding:24px}.upcoming-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.upcoming-title{font-size:15px;font-weight:700;color:#111827}.upcoming-badge{padding:4px 10px;background:#ede9fe;color:#6b4eff;font-size:11px;font-weight:600;border-radius:10px}.report-item{padding:14px;background:#f9fafb;border-radius:12px;margin-bottom:12px;transition:all .2s ease;cursor:pointer}.report-item:hover{background:#f3f0ff;transform:translate(4px)}.report-item:last-child{margin-bottom:0}.report-time{font-size:10px;font-weight:600;color:#6b4eff;margin-bottom:4px}.report-name{font-size:13px;font-weight:600;color:#111827}.report-meta{font-size:11px;color:#6b7280;margin-top:4px}.report-tags{display:flex;gap:6px;margin-top:8px}.report-tag{padding:3px 8px;font-size:10px;font-weight:500;border-radius:6px}.report-tag.daily{background:#dbeafe;color:#2563eb}.report-tag.weekly{background:#d1fae5;color:#059669}.report-tag.monthly{background:#fef3c7;color:#d97706}@media(max-width:768px){.calendar-dash{grid-template-columns:1fr}}.sparklines-card *{box-sizing:border-box;margin:0;padding:0}.sparklines-card{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:#fff;border-radius:20px;border:1px solid #f3f4f6;box-shadow:0 8px 24px #0000000f;padding:28px;max-width:500px;margin:0 auto}.sparklines-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.sparklines-title{font-size:15px;font-weight:700;color:#111827}.sparklines-badge{padding:6px 12px;background:#f3f4f6;color:#6b7280;font-size:11px;font-weight:600;border-radius:12px}.sparkline-item{display:flex;align-items:center;gap:16px;padding:16px;background:#f9fafb;border-radius:14px;margin-bottom:12px}.sparkline-item:last-child{margin-bottom:0}.sparkline-info{width:120px}.sparkline-label{font-size:12px;color:#6b7280;margin-bottom:4px}.sparkline-value{font-size:24px;font-weight:800;color:#111827}.sparkline-change{display:inline-flex;align-items:center;gap:2px;font-size:11px;font-weight:600;margin-top:4px}.sparkline-change.up{color:#059669}.sparkline-change.down{color:#dc2626}.sparkline-change svg{width:12px;height:12px}.sparkline-chart{flex:1;height:50px}.sparkline-svg{width:100%;height:100%}.sparkline-line{fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.sparkline-area{opacity:.1}.sparkline-line.purple{stroke:#6b4eff}.sparkline-area.purple{fill:#6b4eff}.sparkline-line.emerald{stroke:#10b981}.sparkline-area.emerald{fill:#10b981}.sparkline-line.amber{stroke:#f59e0b}.sparkline-area.amber{fill:#f59e0b}
