*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fdf2f8;--period:#f43f5e;--ovulation:#a855f7;--fertile:#fb923c;--text:#333;--text-muted:#888;--border:#f3e8ee;--card-bg:#fff;--shadow:0 2px 12px #f43f5e14}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif}#app{width:100%}button,input{font-family:inherit}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#f0c0cc;border-radius:2px}.calendar-view.svelte-1taj9dl{flex-direction:column;gap:16px;padding:16px;display:flex}.card.svelte-1taj9dl{background:#fff;border-radius:16px;padding:16px;box-shadow:0 2px 12px #f43f5e14}.month-nav.svelte-1taj9dl{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.month-title.svelte-1taj9dl{color:#333;font-size:17px;font-weight:600}.nav-btn.svelte-1taj9dl{color:var(--period);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:24px;transition:background .15s;display:flex}.nav-btn.svelte-1taj9dl:hover{background:#fde8ee}.weekday-grid.svelte-1taj9dl{grid-template-columns:repeat(7,1fr);margin-bottom:4px;display:grid}.weekday-label.svelte-1taj9dl{text-align:center;color:#aaa;padding:4px 0;font-size:12px}.days-grid.svelte-1taj9dl{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.day-cell.svelte-1taj9dl{aspect-ratio:1;cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:opacity .15s;display:flex}.day-cell.empty.svelte-1taj9dl{cursor:default}.day-num.svelte-1taj9dl{color:#444;z-index:1;font-size:13px;position:relative}.day-cell.period.svelte-1taj9dl{background:var(--period)}.day-cell.period.svelte-1taj9dl .day-num:where(.svelte-1taj9dl){color:#fff}.day-cell.predicted-period.svelte-1taj9dl{border:2px dashed var(--period);background:#f43f5e14}.day-cell.predicted-period.svelte-1taj9dl .day-num:where(.svelte-1taj9dl){color:var(--period)}.day-cell.ovulation.svelte-1taj9dl{background:var(--ovulation)}.day-cell.ovulation.svelte-1taj9dl .day-num:where(.svelte-1taj9dl){color:#fff}.day-cell.predicted-ovulation.svelte-1taj9dl{border:2px dashed var(--ovulation);background:#a855f71a}.day-cell.predicted-ovulation.svelte-1taj9dl .day-num:where(.svelte-1taj9dl){color:var(--ovulation)}.day-cell.fertile.svelte-1taj9dl{background:var(--fertile)}.day-cell.fertile.svelte-1taj9dl .day-num:where(.svelte-1taj9dl){color:#fff}.day-cell.predicted-fertile.svelte-1taj9dl{border:2px dashed var(--fertile);background:#fb923c1a}.day-cell.predicted-fertile.svelte-1taj9dl .day-num:where(.svelte-1taj9dl){color:var(--fertile)}.day-cell.is-today.svelte-1taj9dl:not(.period):not(.ovulation):not(.fertile){border:2px solid #333}.day-cell.is-today.period.svelte-1taj9dl,.day-cell.is-today.ovulation.svelte-1taj9dl,.day-cell.is-today.fertile.svelte-1taj9dl{outline-offset:1px;outline:2px solid #333}.legend.svelte-1taj9dl{border-top:1px solid #fce7f0;flex-wrap:wrap;gap:8px 16px;margin-top:12px;padding-top:12px;display:flex}.legend-item.svelte-1taj9dl{color:#888;align-items:center;gap:5px;font-size:11px;display:flex}.dot.svelte-1taj9dl{border-radius:50%;flex-shrink:0;width:10px;height:10px}.period-dot.svelte-1taj9dl{background:var(--period)}.predicted-dot.svelte-1taj9dl{border:1.5px dashed var(--period);background:#f43f5e33}.fertile-dot.svelte-1taj9dl{background:var(--fertile)}.ovulation-dot.svelte-1taj9dl{background:var(--ovulation)}.status-title.svelte-1taj9dl{color:#666;margin-bottom:12px;font-size:14px;font-weight:600}.status-grid.svelte-1taj9dl{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px;display:grid}.status-item.svelte-1taj9dl{text-align:center;background:#fdf2f8;border-radius:12px;padding:12px}.status-number.svelte-1taj9dl{color:var(--period);font-size:32px;font-weight:700;line-height:1.1;display:block}.status-number.soon.svelte-1taj9dl{color:#f97316}.status-label.svelte-1taj9dl{color:#aaa;margin-top:4px;font-size:11px;display:block}.predictions.svelte-1taj9dl{flex-direction:column;gap:8px;display:flex}.pred-item.svelte-1taj9dl{background:#fdf9ff;border-radius:10px;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.pred-label.svelte-1taj9dl{color:#888;font-size:13px}.pred-date.svelte-1taj9dl{font-size:13px;font-weight:600}.period-text.svelte-1taj9dl{color:var(--period)}.ovulation-text.svelte-1taj9dl{color:var(--ovulation)}.fertile-text.svelte-1taj9dl{color:var(--fertile)}.no-data.svelte-1taj9dl{text-align:center;color:#ccc;padding:16px 0;font-size:13px}.log-panel.svelte-1kkdpgo{flex-direction:column;gap:16px;padding:16px;display:flex}.card.svelte-1kkdpgo{background:#fff;border-radius:16px;padding:16px;box-shadow:0 2px 12px #f43f5e14}.add-btn.svelte-1kkdpgo{color:#fff;cursor:pointer;background:linear-gradient(135deg,#f43f5e,#fb7185);border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;padding:14px;font-size:15px;font-weight:600;transition:opacity .15s;display:flex}.add-btn.svelte-1kkdpgo:hover{opacity:.9}.form-title.svelte-1kkdpgo{color:#333;margin-bottom:16px;font-size:16px;font-weight:600}.form-group.svelte-1kkdpgo{margin-bottom:12px}.form-label.svelte-1kkdpgo{color:#888;margin-bottom:6px;font-size:13px;display:block}.form-input.svelte-1kkdpgo{color:#333;box-sizing:border-box;background:#fdf9fb;border:1.5px solid #f3e8ee;border-radius:10px;outline:none;width:100%;padding:10px 12px;font-size:15px;transition:border-color .15s}.form-input.svelte-1kkdpgo:focus{border-color:var(--period)}.form-actions.svelte-1kkdpgo{gap:10px;margin-top:16px;display:flex}.btn-cancel.svelte-1kkdpgo{color:#888;cursor:pointer;background:#f5f5f5;border:none;border-radius:10px;flex:1;padding:12px;font-size:15px}.btn-save.svelte-1kkdpgo{background:var(--period);color:#fff;cursor:pointer;border:none;border-radius:10px;flex:2;padding:12px;font-size:15px;font-weight:600;transition:opacity .15s}.btn-save.svelte-1kkdpgo:disabled{opacity:.5;cursor:not-allowed}.section-title.svelte-1kkdpgo{color:#666;margin-bottom:12px;font-size:14px;font-weight:600}.setting-item.svelte-1kkdpgo{border-bottom:1px solid #fce7f0;justify-content:space-between;align-items:center;padding:10px 0;display:flex}.setting-item.svelte-1kkdpgo:last-child{border-bottom:none}.setting-label.svelte-1kkdpgo{color:#444;font-size:14px}.setting-input-group.svelte-1kkdpgo{align-items:center;gap:6px;display:flex}.setting-input.svelte-1kkdpgo{text-align:center;color:#333;border:1.5px solid #f3e8ee;border-radius:8px;outline:none;width:60px;padding:6px 10px;font-size:15px}.setting-input.svelte-1kkdpgo:focus{border-color:var(--period)}.setting-unit.svelte-1kkdpgo{color:#aaa;font-size:13px}.empty-text.svelte-1kkdpgo{text-align:center;color:#ccc;padding:20px 0;font-size:13px}.entries-list.svelte-1kkdpgo{flex-direction:column;gap:8px;display:flex}.entry-item.svelte-1kkdpgo{background:#fdf9fb;border-radius:12px;align-items:center;gap:12px;padding:12px;display:flex}.entry-icon.svelte-1kkdpgo{flex-shrink:0;font-size:20px}.entry-info.svelte-1kkdpgo{flex:1}.entry-dates.svelte-1kkdpgo{color:#333;font-size:14px;font-weight:500}.entry-duration.svelte-1kkdpgo{color:#aaa;margin-top:2px;font-size:12px}.delete-btn.svelte-1kkdpgo{color:#ddd;cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;padding:6px;transition:color .15s,background .15s;display:flex}.delete-btn.svelte-1kkdpgo:hover{color:var(--period);background:#fde8ee}.stats-panel.svelte-4ov0mh{flex-direction:column;gap:16px;padding:16px;display:flex}.card.svelte-4ov0mh{background:#fff;border-radius:16px;padding:16px;box-shadow:0 2px 12px #f43f5e14}.big-stats-grid.svelte-4ov0mh{grid-template-columns:1fr 1fr;gap:12px;display:grid}.big-stat.svelte-4ov0mh{text-align:center;padding:20px 16px}.big-number.svelte-4ov0mh{color:#a855f7;font-size:48px;font-weight:700;line-height:1}.big-number.period-color.svelte-4ov0mh{color:var(--period)}.big-label.svelte-4ov0mh{color:#aaa;margin-top:8px;font-size:12px}.count-card.svelte-4ov0mh{padding:14px 16px}.count-row.svelte-4ov0mh{justify-content:space-between;align-items:center;display:flex}.count-label.svelte-4ov0mh{color:#666;font-size:14px}.count-value.svelte-4ov0mh{color:var(--period);font-size:16px;font-weight:600}.section-title.svelte-4ov0mh{color:#666;margin-bottom:16px;font-size:14px;font-weight:600}.bar-chart.svelte-4ov0mh{justify-content:space-around;align-items:flex-end;height:100px;padding:0 8px;display:flex}.bar-column.svelte-4ov0mh{flex-direction:column;flex:1;align-items:center;gap:4px;display:flex}.bar-value.svelte-4ov0mh{color:#aaa;font-size:11px}.bar.svelte-4ov0mh{background:linear-gradient(#fb7185,#f43f5e);border-radius:4px 4px 0 0;width:24px;min-height:8px;transition:height .3s}.bar-label.svelte-4ov0mh{color:#bbb;font-size:10px}.chart-note.svelte-4ov0mh{text-align:right;color:#ccc;margin-top:4px;font-size:10px}.recent-list.svelte-4ov0mh{flex-direction:column;gap:8px;display:flex}.recent-item.svelte-4ov0mh{background:#fdf9fb;border-radius:10px;align-items:center;gap:12px;padding:10px 12px;display:flex}.recent-index.svelte-4ov0mh{color:#ccc;text-align:center;width:24px;font-size:12px}.recent-info.svelte-4ov0mh{flex:1}.recent-date.svelte-4ov0mh{color:#333;font-size:14px;font-weight:500}.recent-meta.svelte-4ov0mh{color:#aaa;margin-top:2px;font-size:11px}.cycle-badge.svelte-4ov0mh{color:#a855f7;white-space:nowrap;background:#a855f71a;border-radius:20px;padding:3px 8px;font-size:11px}.empty-card.svelte-4ov0mh{text-align:center;padding:40px 16px}.empty-icon.svelte-4ov0mh{margin-bottom:12px;font-size:40px}.empty-text.svelte-4ov0mh{color:#ccc;font-size:14px;line-height:1.6}.navbar.svelte-rwygme{z-index:100;background:#fff;border-top:1px solid #f3e8ee;width:100%;max-width:430px;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%);box-shadow:0 -2px 12px #f43f5e14}.tab-btn.svelte-rwygme{cursor:pointer;color:#bbb;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:10px 0 14px;font-size:11px;transition:color .2s;display:flex}.tab-btn.active.svelte-rwygme{color:var(--period)}.tab-btn.svelte-rwygme:hover{color:#f87171}.app.svelte-1n46o8q{background:var(--bg);flex-direction:column;max-width:430px;min-height:100vh;margin:0 auto;display:flex;position:relative}.content.svelte-1n46o8q{flex:1;padding-bottom:72px;overflow-y:auto}
