:root{font-family:Inter,Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color:#0f172a;background-color:#e2e8f0;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;font-synthesis:none}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background-color:#e2e8f0}#root{min-height:100vh}button{font-family:inherit}:root{--page-bg: radial-gradient(circle at top, #fdf4ff 0%, #e0e7ff 45%, #c7d2fe 100%);--text-primary: #0f172a;--text-muted: #475569;--text-soft: #94a3b8;--surface: rgba(255, 255, 255, .95);--surface-muted: rgba(244, 247, 255, .85);--surface-subtle: rgba(232, 238, 255, .65);--surface-border: rgba(99, 102, 241, .25);--surface-border-strong: rgba(79, 70, 229, .35);--surface-shadow: rgba(15, 23, 42, .08);--grid-header-bg: rgba(79, 70, 229, .08);--grid-spacer-bg: rgba(236, 241, 255, .9);--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px}.app{min-height:100vh;padding:2.5rem 1.5rem 3rem;background:var(--page-bg);color:var(--text-primary)}.app__container{max-width:72rem;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem}.app__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}.app__title{margin:0;font-size:clamp(2rem,4vw,2.75rem)}.app__subtitle{margin:.75rem 0 0;max-width:36rem;color:var(--text-muted);line-height:1.6}.app__buttons{display:flex;gap:.75rem;flex-wrap:wrap}.app__button{border:1px solid #cbd5f5;background:#fff;color:#0f172a;border-radius:999px;padding:.6rem 1.5rem;font-weight:600;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;box-shadow:0 10px 25px #0f172a0f}.app__button--primary{background:#111827;color:#fff;border-color:#111827}.app__button:hover{transform:translateY(-1px);box-shadow:0 12px 30px #0f172a26}.app__section{background:var(--surface);border:1px solid var(--surface-border);border-radius:1.25rem;padding:1.5rem;box-shadow:0 15px 45px var(--surface-shadow);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.app__section--legend{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.25rem}.app__section--grid{padding:1rem}.legend{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}.legend__item{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text-muted)}.legend__swatch{width:1rem;height:1rem;border-radius:.35rem;box-shadow:inset 0 0 1px #0f172a66}.grid-wrapper{width:100%;overflow-x:auto}.grid{display:grid;gap:0;border:1px solid var(--surface-border);border-radius:.75rem;overflow:hidden;min-width:520px}.grid__spacer{background:var(--grid-spacer-bg);border-bottom:1px solid var(--surface-border)}.grid__header{padding:.8rem .4rem;text-align:center;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.02em;background:var(--grid-header-bg);border-bottom:1px solid var(--surface-border);color:var(--text-muted)}.grid__month{position:sticky;left:0;background:var(--surface);padding:.8rem;font-weight:600;font-size:.95rem;border-bottom:1px solid var(--surface-border);z-index:1}.grid__month--total{background:var(--surface-muted);border-top:2px solid var(--surface-border)}.grid__cell{height:56px;display:flex;align-items:center;justify-content:center;border-left:1px solid rgba(15,23,42,.05);border-bottom:1px solid rgba(15,23,42,.05)}.grid__cell--total{border-top:2px solid rgba(15,23,42,.15)}.grid__value{font-size:.75rem;font-weight:600;color:#fff}.selector{text-align:center;background:var(--surface);border:1px solid var(--surface-border);border-radius:1.5rem;padding:2.5rem 2rem 2.25rem;box-shadow:0 15px 45px var(--surface-shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.selector__eyebrow{margin:0;text-transform:uppercase;letter-spacing:.3em;font-size:.75rem;color:var(--text-soft)}.selector__title{margin:.75rem 0 0;font-size:clamp(2.1rem,6vw,3.1rem)}.selector__options{margin-top:0;display:flex;justify-content:center;flex-wrap:wrap;gap:1rem}.selector__group{margin-top:1.75rem;display:flex;flex-direction:column;gap:.75rem}.selector__group:first-of-type{margin-top:2rem}.selector__group-label{margin:0;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-soft);font-weight:600}.selector__button{background:var(--surface-muted);border:2px solid transparent;border-radius:1rem;padding:.75rem 1.5rem 1rem;min-width:110px;display:flex;flex-direction:column;align-items:center;gap:.65rem;cursor:pointer;transition:transform .2s ease,border-color .2s ease;color:inherit}.selector__button:hover{transform:translateY(-3px)}.selector__button--active{border-color:var(--mood-color);background:#4f46e51f;box-shadow:0 15px 30px #0f172a26}.selector__swatch{width:3.25rem;height:3.25rem;border-radius:999px;background:var(--mood-color);box-shadow:inset 0 0 0 4px #ffffff40}.selector__label{font-weight:600;font-size:.95rem}.selector__caption{margin-top:1.5rem;color:var(--text-muted);font-size:.95rem}.selector__dual{margin-top:1.25rem;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-size:.85rem;font-weight:600;color:var(--text-muted)}.selector__dual input{width:1rem;height:1rem;accent-color:#111827}.selector__dual input:disabled+span{opacity:.45}.selector__note-group{margin-top:1.75rem;display:flex;flex-direction:column;gap:.5rem;text-align:left}.selector__note-label{font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-soft);font-weight:600;margin-left:.25rem}.selector__note-input{width:100%;padding:.85rem 1rem;border:2px solid var(--surface-border);border-radius:.75rem;background:var(--surface-muted);color:var(--text-primary);font-family:inherit;font-size:.95rem;line-height:1.5;resize:vertical;min-height:80px;transition:border-color .2s ease,background .2s ease}.selector__note-input:focus{outline:none;border-color:var(--surface-border-strong);background:var(--surface)}.selector__note-input::placeholder{color:var(--text-soft);opacity:.6}.selector__note-counter{font-size:.75rem;color:var(--text-soft);align-self:flex-end;margin-right:.25rem}.settings-menu{position:fixed;top:2rem;right:2rem;z-index:100}.settings-menu__trigger{width:48px;height:48px;border-radius:50%;border:1px solid var(--surface-border);background:var(--surface);color:var(--text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 12px 32px var(--surface-shadow),0 0 0 1px #ffffff1a;transition:transform .15s ease,box-shadow .15s ease;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.settings-menu__trigger:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 16px 40px var(--surface-shadow),0 0 0 1px #fff3}.settings-menu__trigger svg{width:24px;height:24px}.settings-menu__items{position:absolute;top:calc(100% + .5rem);right:0;min-width:160px;background:var(--surface);border:1px solid var(--surface-border);border-radius:.75rem;padding:.5rem 0;box-shadow:0 20px 50px var(--surface-shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);outline:none}.settings-menu__item{width:100%;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border:none;background:transparent;color:var(--text-primary);font-size:.9rem;font-weight:500;cursor:pointer;transition:background .1s ease;text-align:left}.settings-menu__item:hover,.settings-menu__item--active{background:var(--surface-muted)}.settings-menu__item svg{width:20px;height:20px;flex-shrink:0}.settings-menu__item--danger{color:#dc2626}.settings-menu__item--danger svg{color:#dc2626}.settings-menu__separator{height:1px;background:var(--surface-border);margin:.5rem 0}.confirm-modal-backdrop{position:fixed;inset:0;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem;animation:fade-in .15s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.confirm-modal{background:var(--surface);border:1px solid var(--surface-border);border-radius:1rem;padding:1.5rem;max-width:400px;width:100%;box-shadow:0 25px 50px #0f172a40;animation:slide-up .2s ease}@keyframes slide-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.confirm-modal__title{margin:0 0 .75rem;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.confirm-modal__message{margin:0 0 1.5rem;font-size:.95rem;line-height:1.6;color:var(--text-muted);white-space:pre-wrap}.confirm-modal__actions{display:flex;gap:.75rem;justify-content:flex-end}.confirm-modal__button{border:none;border-radius:.5rem;padding:.6rem 1.25rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:transform .1s ease,box-shadow .1s ease}.confirm-modal__button:hover{transform:translateY(-1px)}.confirm-modal__button--cancel{background:var(--surface-muted);color:var(--text-muted);border:1px solid var(--surface-border)}.confirm-modal__button--confirm{background:#111827;color:#fff;box-shadow:0 4px 12px #0f172a33}.confirm-modal__button--confirm:hover{box-shadow:0 6px 16px #0f172a40}@media(max-width:768px){.confirm-modal{padding:1.25rem}.confirm-modal__actions{flex-direction:column-reverse}.confirm-modal__button{width:100%;padding:.75rem}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.year-selector{align-self:center;position:relative;display:inline-flex;align-items:center;gap:.5rem}.year-selector__dropdown{appearance:none;background:transparent;border:none;color:var(--text-muted);font-size:.95rem;font-weight:600;padding:.5rem 1.75rem .5rem .5rem;cursor:pointer;font-family:inherit;transition:color .2s ease}.year-selector__dropdown:hover{color:var(--text-primary)}.year-selector__dropdown:focus{outline:none;color:var(--text-primary)}.year-selector__icon{position:absolute;right:0;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--text-soft);transition:transform .2s ease,color .2s ease}.year-selector__dropdown:hover+.year-selector__icon,.year-selector__dropdown:focus+.year-selector__icon{color:var(--text-muted)}.overview-toggle{align-self:center;border:none;background:#111827;color:#fff;border-radius:999px;padding:.85rem 1.75rem;font-size:.95rem;font-weight:600;cursor:pointer;box-shadow:0 12px 30px #0f172a33;transition:transform .15s ease,box-shadow .15s ease}.overview-toggle:hover{transform:translateY(-2px);box-shadow:0 16px 30px #0f172a40}.overview{background:var(--surface);border:1px solid var(--surface-border);border-radius:1.5rem;padding:2rem;box-shadow:0 15px 45px var(--surface-shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;flex-direction:column;gap:1.5rem}.overview__header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}.overview__eyebrow{margin:0;text-transform:uppercase;letter-spacing:.3em;font-size:.7rem;color:#cbd5f5}.overview__title{margin:.35rem 0 0;font-size:1.35rem}.overview__panel{background:var(--surface-muted);border:1px solid var(--surface-border);border-radius:1rem;padding:1rem}.overview__panel-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}.overview__empty{margin:0;padding:1.2rem;border-radius:1rem;background:var(--surface-subtle);text-align:center;color:var(--text-muted)}.year-grid{width:100%;overflow-x:auto}.year-grid__viewport{display:none}.year-grid__viewport--active{display:block}.year-grid__table{display:grid;border:1px solid var(--surface-border);border-radius:.75rem;overflow:hidden;background:var(--surface);min-width:900px}.year-grid__corner{padding:.6rem;font-size:.85rem;font-weight:600;background:var(--grid-header-bg);border-bottom:1px solid var(--surface-border)}.year-grid__day-header{padding:.35rem;text-align:center;font-size:.7rem;font-weight:600;letter-spacing:.02em;background:var(--grid-header-bg);border-left:1px solid var(--surface-border);border-bottom:1px solid var(--surface-border)}.year-grid__row{display:contents}.year-grid__month{padding:.5rem .6rem;font-size:.85rem;font-weight:600;background:var(--surface-muted);border-top:1px solid var(--surface-border)}.year-grid__cell{min-height:28px;width:100%;display:block;border:none;transition:transform .1s ease,box-shadow .1s ease,background .1s ease;position:relative;overflow:hidden;padding:0;background:transparent;cursor:pointer;font:inherit;color:inherit}.year-grid__cell:focus-visible{outline:2px solid rgba(59,130,246,.8);outline-offset:-2px}.year-grid__cell:disabled{cursor:default}.year-grid__cell--empty{background:#94a3b81a}.year-grid__cell--note-only{background:#9ca3af}.year-grid__cell--disabled{background:#94a3b80d;opacity:.4}.year-grid__cell--today{box-shadow:inset 0 0 0 2px #ffffffe6;transform:scale(1.05)}.year-grid__cell--selected{box-shadow:inset 0 0 0 2px #38bdf8e6;transform:scale(1.05)}.year-grid__cell--split{background-image:linear-gradient(to bottom right,var(--primary-color, transparent) 0%,var(--primary-color, transparent) 50%,var(--secondary-color, transparent) 50%,var(--secondary-color, transparent) 100%);background-repeat:no-repeat;background-size:100% 100%}.year-grid__toggle{border:none;border-radius:999px;background:#0f172ad9;color:#fff;font-size:.85rem;font-weight:600;padding:.45rem .95rem;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;box-shadow:0 8px 20px #0f172a26}.year-grid__toggle:hover{transform:translateY(-1px);box-shadow:0 10px 24px #0f172a33}.pills{display:flex;flex-wrap:wrap;gap:.75rem}.pill{padding:.4rem 1rem;border-radius:999px;font-size:.85rem;font-weight:600;border:1px solid transparent}.pill--best{background:#dbeafe;color:#1d4ed8;border-color:#bfdbfe}.pill--tough{background:#ffe4e6;color:#be123c;border-color:#fecdd3}.pill--neutral{background:#e2e8f0;color:#0f172a;border-color:#cbd5f5}.section-title{margin:0 0 1rem;font-size:1.25rem}.chart{width:100%;height:18rem}.app__footer{font-size:.8rem;color:#64748b;text-align:center}@media(max-width:768px){.app{padding:1.5rem 1rem 2.5rem}.settings-menu{top:1rem;right:1rem}.settings-menu__trigger{width:40px;height:40px}.settings-menu__trigger svg{width:20px;height:20px}.settings-menu__items{min-width:140px}.settings-menu__item{padding:.6rem .85rem;font-size:.85rem}.app__header{flex-direction:column}.app__buttons{width:100%}.app__button{flex:1;text-align:center}.selector{padding:2rem 1.25rem}.selector__button{width:calc(50% - .5rem)}.overview{padding:1.25rem}.selector__note-input{font-size:16px}}@media(max-width:640px){.year-grid__viewport--months{display:none!important}.year-grid__viewport--days{display:block!important}.year-grid__toggle{display:none}}@media(prefers-color-scheme:dark){:root{--page-bg: radial-gradient(circle at top, #0f172a 0%, #0b1324 60%, #020617 100%);--text-primary: #e2e8f0;--text-muted: #cbd5f5;--text-soft: #a5b4fc;--surface: rgba(15, 23, 42, .9);--surface-muted: rgba(26, 34, 53, .85);--surface-subtle: rgba(148, 163, 184, .2);--surface-border: rgba(148, 163, 184, .25);--surface-border-strong: rgba(148, 163, 184, .4);--surface-shadow: rgba(2, 6, 23, .6);--grid-header-bg: rgba(15, 23, 42, .85);--grid-spacer-bg: rgba(15, 23, 42, .7)}.pill--neutral{background:#94a3b840;color:#f8fafc}.year-grid__cell--empty{background:#94a3b826}.year-grid__cell--disabled{background:#0f172a99}.year-grid__toggle{background:#94a3b833;color:#e2e8f0;box-shadow:0 8px 20px #02061780}}
