*,*:before,*:after{box-sizing:border-box}:root{--primary: #6366f1;--primary-hover: #4f46e5;--secondary: #a855f7;--background: #f8fafc;--surface: #ffffff;--text-primary: #1e293b;--text-secondary: #64748b;--border: #e2e8f0;--today-bg: rgba(99, 102, 241, .1);font-family:Outfit,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:var(--text-primary);background-color:var(--background);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body{margin:0;padding:0;overflow-x:hidden;width:100%}body{min-width:320px;min-height:100vh;background-color:var(--background)}#app{width:100%;max-width:1024px;margin:0 auto;padding:.75rem}.glass{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:.75rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}h1{font-size:1.5rem;font-weight:800;margin:0;color:var(--text-primary);letter-spacing:-.02em}.subtitle{font-size:.875rem;color:var(--text-secondary);font-weight:400;margin-top:.125rem}.gradient-text{background:linear-gradient(90deg,var(--primary),var(--secondary));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-weight:800}.calendar-container{margin-top:1rem}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background-color:var(--border);border:1px solid var(--border);border-radius:8px;overflow:hidden}.weekday-header{background-color:#f1f5f9;padding:.5rem .25rem;text-align:center;font-weight:600;font-size:.65rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.02em}.calendar-day{background-color:var(--surface);min-height:50px;padding:.4rem;display:flex;flex-direction:column;transition:background-color .2s}.calendar-day.other-month{color:#cbd5e1;background-color:#fcfdfe}.calendar-day.today{background-color:var(--today-bg)}.day-number{font-weight:600;font-size:.8rem}.today .day-number{color:var(--primary);display:inline-block}.btn-icon{background:#fff;border:1px solid var(--border);width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;color:var(--text-primary)}.btn-icon:hover{border-color:var(--primary);color:var(--primary)}.month-title{font-size:1.125rem;font-weight:700}@media(min-width:640px){#app{padding:1.5rem}.glass{border-radius:16px;padding:1.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}h1{font-size:2.25rem}.subtitle{font-size:1rem}.calendar-container{margin-top:2rem}.calendar-header{margin-bottom:1.5rem}.weekday-header{font-size:.875rem;padding:.75rem}.calendar-day{min-height:100px;padding:.75rem}.day-number{font-size:.9rem}.month-title{font-size:1.25rem}}.calendar-nav[data-v-57b46b2e]{display:flex;align-items:center;gap:.5rem}.calendar-day[data-v-57b46b2e]{cursor:pointer;position:relative;min-height:4.5rem;display:flex;flex-direction:column;padding:.4rem;overflow:hidden;min-width:0}@media(max-width:640px){.calendar-day[data-v-57b46b2e]{min-height:3.5rem;padding:.25rem}}.calendar-day.selected[data-v-57b46b2e]{background-color:#eff6ff;outline:2px solid var(--primary);outline-offset:-2px;z-index:1}.day-number[data-v-57b46b2e]{font-weight:500;font-size:.9rem}.day-icons[data-v-57b46b2e]{display:flex;flex-wrap:wrap;gap:2px;margin-top:auto;justify-content:flex-end;max-width:100%}.calendar-icon[data-v-57b46b2e]{width:12px;height:12px;opacity:.8;flex-shrink:0}.comment-icon[data-v-57b46b2e]{color:var(--text-secondary)}.desktop-only[data-v-57b46b2e]{display:none}@media(min-width:640px){.desktop-only[data-v-57b46b2e]{display:inline}.mobile-only[data-v-57b46b2e]{display:none}.calendar-icon[data-v-57b46b2e]{width:16px;height:16px}}.bs-chart-container[data-v-57b46b2e]{position:absolute;inset:0;pointer-events:none;z-index:0}.bs-chart-svg[data-v-57b46b2e]{width:100%;height:100%}.bs-line[data-v-57b46b2e]{fill:none;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;opacity:.6}.bs-line.continuous-line[data-v-57b46b2e]{stroke:var(--border);stroke-width:1.5;stroke-dasharray:4 4;opacity:.3}.day-number[data-v-57b46b2e],.day-icons[data-v-57b46b2e]{position:relative;z-index:1}.day-details[data-v-bd09425c]{margin-top:1.5rem}.details-title[data-v-bd09425c]{font-size:1.25rem;margin-bottom:1.5rem;color:var(--text-primary)}.form-group[data-v-bd09425c]{margin-bottom:1.5rem}.form-label[data-v-bd09425c]{display:block;font-weight:600;font-size:.875rem;margin-bottom:.75rem;color:var(--text-secondary)}.rating-grid[data-v-bd09425c],.ovulation-grid[data-v-bd09425c]{display:flex;gap:.25rem;margin-bottom:.5rem}.rating-grid[data-v-bd09425c]{flex-wrap:nowrap}.ovulation-grid[data-v-bd09425c]{flex-wrap:wrap}.rating-grid[data-v-bd09425c]::-webkit-scrollbar,.ovulation-grid[data-v-bd09425c]::-webkit-scrollbar{display:none}.rating-btn[data-v-bd09425c]{flex:1 1 0;min-width:0;background:#fff;border:1px solid var(--border);padding:.4rem .15rem;border-radius:8px;font-size:.65rem;cursor:pointer;transition:all .2s;color:var(--text-primary);display:flex;flex-direction:column;align-items:center;gap:.2rem;overflow:hidden}.rating-btn .rating-icon[data-v-bd09425c]{color:var(--active-color);width:24px;height:24px;transition:transform .2s,color .2s}.rating-btn:hover .rating-icon[data-v-bd09425c]{transform:translateY(-2px)}.rating-btn.active .rating-icon[data-v-bd09425c]{color:#fff}.rating-label[data-v-bd09425c]{font-weight:500;font-size:.75rem}@media(min-width:640px){.rating-grid[data-v-bd09425c],.ovulation-grid[data-v-bd09425c]{display:grid;overflow-x:visible;padding-bottom:0}.rating-grid[data-v-bd09425c]{grid-template-columns:repeat(5,1fr)}.ovulation-grid[data-v-bd09425c]{grid-template-columns:repeat(4,1fr)}.rating-btn[data-v-bd09425c]{flex:none;white-space:normal}}.rating-btn.active[data-v-bd09425c]{background-color:var(--active-color, var(--primary));color:#fff;border-color:var(--active-color, var(--primary));box-shadow:0 4px 12px #0000001a}.form-select[data-v-bd09425c],.form-textarea[data-v-bd09425c]{width:100%;padding:.75rem;border-radius:8px;border:1px solid var(--border);font-family:inherit;font-size:1rem;background-color:#fff;color:var(--text-primary)}.form-textarea[data-v-bd09425c]{resize:vertical}.btn-save[data-v-bd09425c]{background-color:var(--primary);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:10px;font-weight:600;cursor:pointer;transition:background-color .2s}.btn-save[data-v-bd09425c]:hover{background-color:var(--primary-hover)}.btn-save[data-v-bd09425c]:disabled{opacity:.7;cursor:not-allowed}.form-footer[data-v-bd09425c]{display:flex;align-items:center;gap:1rem}.status-msg[data-v-bd09425c]{font-size:.875rem;color:#22c55e;font-weight:500}.empty-state[data-v-bd09425c]{margin-top:1.5rem;text-align:center;color:var(--text-secondary);padding:3rem}.fade-enter-active[data-v-bd09425c],.fade-leave-active[data-v-bd09425c]{transition:opacity .3s}.fade-enter-from[data-v-bd09425c],.fade-leave-to[data-v-bd09425c]{opacity:0}.app-layout[data-v-41eb3f62]{opacity:0;transform:translateY(10px);transition:all .6s cubic-bezier(.16,1,.3,1)}.app-layout.fade-in[data-v-41eb3f62]{opacity:1;transform:translateY(0)}.app-header[data-v-41eb3f62]{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0 1.5rem}.brand[data-v-41eb3f62]{display:flex;align-items:center;gap:.75rem}.brand-icon[data-v-41eb3f62]{width:40px;height:40px;border-radius:10px;border:1px solid var(--border);box-shadow:0 4px 12px #0000000d}@media(min-width:640px){.app-header[data-v-41eb3f62]{padding:1rem 0 2rem}.brand[data-v-41eb3f62]{gap:1rem}.brand-icon[data-v-41eb3f62]{width:48px;height:48px;border-radius:12px}}
