@import "https://fonts.googleapis.com/css2?family=Noto+Sans+SC:wght@400;500;700;800&family=Outfit:wght@500;600;700;800&display=swap";:root{color:#102b1e;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f9fbf8}html,body,#root{min-height:100%}body{margin:0}a{color:inherit}.react-calendar{background:#fff;border:1px solid #a0a096;width:350px;max-width:100%;font-family:Arial,Helvetica,sans-serif;line-height:1.125em}.react-calendar--doubleView{width:700px}.react-calendar--doubleView .react-calendar__viewContainer{margin:-.5em;display:flex}.react-calendar--doubleView .react-calendar__viewContainer>*{width:50%;margin:.5em}.react-calendar,.react-calendar *,.react-calendar :before,.react-calendar :after{box-sizing:border-box}.react-calendar button{border:0;outline:none;margin:0}.react-calendar button:enabled:hover{cursor:pointer}.react-calendar__navigation{height:44px;margin-bottom:1em;display:flex}.react-calendar__navigation button{background:0 0;min-width:44px}.react-calendar__navigation button:disabled{background-color:#f0f0f0}.react-calendar__navigation button:enabled:hover,.react-calendar__navigation button:enabled:focus{background-color:#e6e6e6}.react-calendar__month-view__weekdays{text-align:center;text-transform:uppercase;font:inherit;font-size:.75em;font-weight:700}.react-calendar__month-view__weekdays__weekday{padding:.5em}.react-calendar__month-view__weekNumbers .react-calendar__tile{font:inherit;justify-content:center;align-items:center;font-size:.75em;font-weight:700;display:flex}.react-calendar__month-view__days__day--weekend{color:#d10000}.react-calendar__month-view__days__day--neighboringMonth,.react-calendar__decade-view__years__year--neighboringDecade,.react-calendar__century-view__decades__decade--neighboringCentury{color:#757575}.react-calendar__year-view .react-calendar__tile,.react-calendar__decade-view .react-calendar__tile,.react-calendar__century-view .react-calendar__tile{padding:2em .5em}.react-calendar__tile{text-align:center;max-width:100%;font:inherit;background:0 0;padding:10px 6.6667px;font-size:.833em}.react-calendar__tile:disabled{color:#ababab;background-color:#f0f0f0}.react-calendar__month-view__days__day--neighboringMonth:disabled,.react-calendar__decade-view__years__year--neighboringDecade:disabled,.react-calendar__century-view__decades__decade--neighboringCentury:disabled{color:#cdcdcd}.react-calendar__tile:enabled:hover,.react-calendar__tile:enabled:focus{background-color:#e6e6e6}.react-calendar__tile--now:enabled:hover,.react-calendar__tile--now:enabled:focus{background:#ffffa9}.react-calendar__tile--hasActive{background:#76baff}.react-calendar__tile--hasActive:enabled:hover,.react-calendar__tile--hasActive:enabled:focus{background:#a9d4ff}.react-calendar__tile--active{color:#fff;background:#006edc}.react-calendar__tile--active:enabled:hover,.react-calendar__tile--active:enabled:focus{background:#1087ff}.react-calendar--selectRange .react-calendar__tile--hover{background-color:#e6e6e6}:root{--primary:#2bc173;--primary-pressed:#1a9655;--accent:#ff7a45;--text:#102b1e;--background:#f9fbf8;--surface:#ebf7f0;--muted:#758a7e;--border:#e1ebe5;--white:#fff;--shadow:0 18px 46px #102b1e17}*{box-sizing:border-box}html{scroll-behavior:smooth}body{min-width:320px;color:var(--text);background:radial-gradient(circle at 82% 18%,#2bc17324,#0000 30rem),linear-gradient(#f9fbf8 0%,#f4faf6 100%);margin:0;font-family:Outfit,Noto Sans SC,PingFang SC,system-ui,sans-serif;line-height:1.6}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{width:min(1440px,100%);margin:0 auto;padding:22px clamp(16px,3vw,38px) 34px}.topbar{justify-content:space-between;align-items:center;gap:24px;padding:8px 0 20px;display:flex}.brand-lockup{align-items:center;gap:12px;min-width:0;display:inline-flex}.brand-lockup strong{color:var(--text);font-size:24px;font-weight:800;line-height:1.1;display:block}.brand-lockup span{color:var(--muted);font-size:13px;line-height:1.2;display:block}.brand-lockup--compact strong{font-size:15px}.brand-mark{background:linear-gradient(135deg, var(--primary), var(--primary-pressed));border-radius:999px;flex:none;width:52px;height:32px;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #ffffff59,0 10px 26px #2bc17347}.brand-lockup--compact .brand-mark{width:34px;height:22px}.brand-mark:before{content:"";background:#ffffff47;position:absolute;inset:0 50% 0 0}.brand-mark__tick{background:#ffffffbf;border-radius:999px;width:2px;height:8px;position:absolute;top:7px}.brand-mark__tick--one{left:16px}.brand-mark__tick--two{left:25px}.brand-mark__leaf{background:#fff;border-radius:12px 12px 2px;width:11px;height:14px;position:absolute;top:8px;right:15px;transform:rotate(36deg)}.brand-mark__check{border-bottom:3px solid #fff;border-left:3px solid #fff;width:15px;height:8px;position:absolute;bottom:8px;right:8px;transform:rotate(-45deg)}.topbar__nav{border:1px solid var(--border);background:#ffffffb8;border-radius:999px;gap:8px;padding:6px;display:flex}.topbar__nav a{min-width:56px;color:var(--muted);text-align:center;border-radius:999px;padding:8px 14px;font-weight:700;text-decoration:none}.topbar__nav a:hover{background:var(--surface);color:var(--primary-pressed)}.hero{grid-template-columns:minmax(0,.92fr) minmax(360px,.78fr);align-items:center;gap:clamp(24px,5vw,74px);min-height:430px;padding:clamp(28px,5vw,64px) 0 clamp(22px,4vw,48px);display:grid}.hero__copy{max-width:740px}.eyebrow,.section-label{color:var(--primary-pressed);letter-spacing:.08em;font-size:13px;font-weight:800}.hero h1{color:var(--text);letter-spacing:0;margin:14px 0 18px;font-size:clamp(40px,5.7vw,78px);font-weight:800;line-height:1.04}.hero p{width:min(620px,100%);color:var(--muted);margin:0;font-size:clamp(17px,1.7vw,21px);line-height:1.8}.hero__actions{flex-wrap:wrap;align-items:center;gap:18px;margin-top:34px;display:flex}.primary-action,.record-button{background:var(--primary);min-height:58px;color:var(--white);border:0;border-radius:16px;font-size:18px;font-weight:800;transition:transform .18s,background .18s,box-shadow .18s;box-shadow:0 14px 26px #2bc17347}.primary-action{align-items:center;gap:10px;padding:0 26px;display:inline-flex}.button-icon{border-bottom:4px solid;border-right:4px solid;width:18px;height:18px;transform:rotate(45deg)translateY(-2px)}.primary-action:hover,.record-button:hover{background:var(--primary-pressed);transform:translateY(-2px);box-shadow:0 18px 34px #1a96554d}.primary-action:disabled,.record-button:disabled{cursor:wait;opacity:.72;transform:none}.hero__domain{color:var(--muted);font-weight:700}.hero__visual{place-items:center;min-height:360px;display:grid;position:relative}.hero__visual:before{aspect-ratio:1;content:"";background:radial-gradient(circle,#2bc17338,#ebf7f000 68%);border-radius:50%;width:min(92%,470px);position:absolute}.hero__visual img{filter:drop-shadow(0 26px 42px #102b1e2e);width:min(100%,560px);height:auto;position:relative}.workspace{grid-template-columns:340px minmax(420px,1fr) 360px;align-items:stretch;gap:20px;display:grid}.today-panel,.calendar-panel,.history-panel{border:1px solid var(--border);min-width:0;box-shadow:var(--shadow);background:#ffffffd6;border-radius:8px}.today-panel{background:linear-gradient(180deg, var(--surface), #ffffffe6);flex-direction:column;gap:16px;padding:20px;display:flex}.progress-card{background:var(--white);border:1px solid #2bc1732e;border-radius:8px;padding:20px}.progress-card__count{align-items:baseline;gap:8px;display:flex}.progress-card__count strong{color:var(--primary);font-size:76px;font-weight:800;line-height:.95}.progress-card__count span{color:var(--text);font-size:27px;font-weight:800}.progress-track{background:var(--border);border-radius:999px;height:12px;margin:18px 0 14px;overflow:hidden}.progress-track span{border-radius:inherit;background:linear-gradient(90deg, var(--primary), var(--primary-pressed));height:100%;display:block}.progress-card p{color:var(--muted);margin:0;font-size:15px}.medicine-stack{gap:12px;display:grid}.medicine-card{background:#ffffffbf;border:1px solid #e1ebe5e6;border-radius:8px;justify-content:space-between;align-items:center;gap:14px;padding:16px;display:flex}.medicine-card h2{margin:0 0 4px;font-size:17px;line-height:1.25}.medicine-card span{color:var(--muted);font-size:15px;font-weight:700}.medicine-card__meta{justify-items:end;gap:7px;display:grid}.medicine-card__meta strong{font-size:25px;font-weight:800;line-height:1}.status-pill{border-radius:999px;padding:4px 10px;font-size:12px;font-style:normal;font-weight:800}.status-pill--success{color:var(--primary-pressed);background:#2bc17321}.status-pill--warning{color:#bd4e25;background:#ff7a4524}.status-pill--neutral{color:var(--muted);background:#edf1ee}.record-button{width:100%;margin-top:auto}.error-message{color:#a54521;background:#ff7a451a;border:1px solid #ff7a454d;border-radius:8px;margin:0;padding:12px 14px;font-weight:700}.calendar-panel,.history-panel{padding:20px}.panel-heading{justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:18px;display:flex}.panel-heading h2{margin:5px 0 0;font-size:26px;line-height:1.2}.calendar-legend{color:var(--muted);gap:8px;font-size:13px;font-weight:800;display:flex}.calendar-legend span{align-items:center;gap:5px;display:inline-flex}.calendar-legend span:before{content:"";border-radius:50%;width:9px;height:9px}.legend-success:before{background:var(--primary)}.legend-warning:before{background:var(--accent)}.react-calendar{color:var(--text);font-family:inherit;background:0 0!important;border:0!important;width:100%!important}.react-calendar__navigation{align-items:center;gap:8px;height:46px;margin-bottom:14px!important}.react-calendar__navigation button{min-width:42px;color:var(--text);border-radius:8px;font-size:18px;font-weight:800}.react-calendar__navigation button:enabled:hover,.react-calendar__navigation button:enabled:focus{background:var(--surface)!important}.react-calendar__month-view__weekdays{color:var(--muted);font-size:13px;font-weight:800}.react-calendar__month-view__weekdays abbr{text-decoration:none}.react-calendar__tile{height:clamp(58px,6.2vw,78px);position:relative;color:var(--text)!important;border-radius:8px!important;font-size:clamp(16px,1.4vw,20px)!important;font-weight:800!important}.react-calendar__tile:enabled:hover,.react-calendar__tile:enabled:focus{background:var(--surface)!important}.react-calendar__tile--now{background:#2bc1731c!important}.react-calendar__tile--active{background:var(--text)!important;color:var(--white)!important}.react-calendar__tile--has-medication{background:var(--surface)!important;color:var(--primary-pressed)!important}.react-calendar__tile--has-medication:after{background:var(--primary);width:19px;height:19px;color:var(--white);content:"✓";border-radius:50%;place-items:center;font-size:12px;line-height:1;display:grid;position:absolute;top:9px;right:9px}.react-calendar__tile--missed:after{background:var(--accent);content:"";border-radius:50%;width:9px;height:9px;position:absolute;top:11px;right:11px}.history-panel{flex-direction:column;min-height:520px;display:flex}.log-list{gap:12px;margin:0;padding:0;list-style:none;display:grid;overflow:auto}.log-item{border:1px solid var(--border);background:var(--background);border-radius:8px;grid-template-columns:96px 1fr;align-items:center;gap:16px;padding:16px;display:grid}.log-time{color:var(--text);font-size:31px;font-weight:800;line-height:1}.log-item strong,.log-item span{display:block}.log-item strong{color:var(--primary-pressed);font-size:17px}.log-item span{color:var(--muted);font-size:14px;font-weight:700}.empty-state{background:var(--background);text-align:center;border:1px dashed #758a7e66;border-radius:8px;flex:1;place-content:center;gap:8px;min-height:280px;padding:24px;display:grid}.empty-state strong{font-size:22px}.empty-state span{color:var(--muted);font-weight:700}@media (width<=1180px){.hero{grid-template-columns:1fr;min-height:0}.hero__visual{min-height:280px}.workspace{grid-template-columns:minmax(300px,.72fr) minmax(420px,1fr)}.history-panel{grid-column:1/-1;min-height:360px}}@media (width<=760px){.app-shell{padding:14px 12px 24px}.topbar{flex-direction:column;align-items:flex-start}.topbar__nav{justify-content:space-between;width:100%}.topbar__nav a{flex:1;min-width:0}.brand-lockup strong{font-size:21px}.hero{gap:12px;padding-top:18px}.hero h1{font-size:40px}.hero p{font-size:16px}.hero__actions{flex-direction:column;align-items:stretch;gap:12px}.primary-action{justify-content:center;width:100%}.hero__visual{min-height:220px}.hero__visual img{width:min(92%,360px)}.workspace{grid-template-columns:1fr}.today-panel,.calendar-panel,.history-panel{padding:16px}.panel-heading{flex-direction:column;align-items:flex-start;gap:10px}.calendar-legend{justify-content:flex-start;align-self:stretch}.progress-card__count strong{font-size:64px}.medicine-card{flex-direction:column;align-items:flex-start}.medicine-card__meta{grid-template-columns:1fr auto;place-items:center start;width:100%}.react-calendar__tile{height:54px;font-size:16px!important}.react-calendar__tile--has-medication:after{width:16px;height:16px;font-size:10px;top:5px;right:5px}.log-item{grid-template-columns:82px 1fr}.log-time{font-size:27px}}
