@charset "UTF-8";*{margin:0;padding:0;box-sizing:border-box}html,body{overflow-x:hidden;width:100%}:root{--color-primary: #FF6B9D;--color-secondary: #FEC163;--color-tertiary: #845EC2;--color-accent: #4FFBDF;--color-success: #00D2A0;--color-bg: #FFF5F8;--color-card: #FFFFFF;--color-text: #2C2C54;--color-text-light: #706C8A;--shadow-sm: 0 2px 8px rgba(132, 94, 194, .1);--shadow-md: 0 4px 16px rgba(132, 94, 194, .15);--shadow-lg: 0 8px 32px rgba(132, 94, 194, .2);--border-radius: 24px}body{font-family:Fredoka,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--color-bg);color:var(--color-text);min-height:100vh}button{font-family:Fredoka,sans-serif;cursor:pointer;border:none;transition:all .3s cubic-bezier(.68,-.55,.265,1.55)}button:hover{transform:translateY(-2px) scale(1.02)}button:active{transform:translateY(0) scale(.98)}input,select{font-family:Fredoka,sans-serif}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-tertiary);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}.app{min-height:100vh;padding-bottom:40px;overflow-x:hidden;width:100%}.main-content{padding:20px}.container{max-width:1200px;margin:0 auto}.auth-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,var(--color-tertiary) 0%,var(--color-primary) 100%);color:#fff}.auth-loading p{font-size:20px;font-weight:600;margin-top:20px}.auth-loading .spinner{border-color:#ffffff4d;border-top-color:#fff}.loading-state{text-align:center;padding:80px 20px}.spinner{width:50px;height:50px;margin:0 auto 20px;border:4px solid rgba(132,94,194,.2);border-top-color:var(--color-tertiary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-state p{font-size:16px;color:var(--color-text-light)}.error-state{text-align:center;padding:80px 20px}.error-message{font-size:18px;color:#e74c3c;margin-bottom:20px}.retry-btn{padding:12px 32px;background:var(--color-tertiary);color:#fff;border-radius:12px;font-size:16px;font-weight:600;transition:all .3s ease}.retry-btn:hover{background:var(--color-primary);transform:translateY(-2px)}.empty-state{text-align:center;padding:80px 20px;animation:fadeIn .6s ease-in}.empty-icon{font-size:120px;width:120px;height:120px;margin:0 auto 24px;color:var(--color-primary);animation:bounce 2s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.empty-state h2{font-size:32px;font-weight:600;color:var(--color-text);margin-bottom:12px}.empty-state p{font-size:18px;color:var(--color-text-light);font-weight:400}.view-controls{display:flex;gap:12px;justify-content:center;margin-bottom:24px;padding:8px;background:#fff;border-radius:16px;width:fit-content;margin-left:auto;margin-right:auto;box-shadow:var(--shadow-sm)}.view-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:12px;background:transparent;color:var(--color-text-light);font-size:14px;font-weight:600;transition:all .3s ease;border:2px solid transparent}.view-btn:hover{background:#845ec21a;color:var(--color-tertiary)}.view-btn.active{background:var(--color-tertiary);color:#fff;border-color:var(--color-tertiary)}.view-btn svg{width:20px;height:20px}.add-pill-btn{position:fixed;bottom:32px;right:32px;width:64px;height:64px;display:flex;align-items:center;justify-content:center;color:#fff;background:var(--color-tertiary);border-radius:50%;box-shadow:0 8px 24px #845ec266;z-index:100;transition:all .3s cubic-bezier(.68,-.55,.265,1.55)}.add-pill-btn:hover{box-shadow:0 12px 32px #845ec280;background:var(--color-primary);transform:scale(1.1) rotate(90deg)}.add-pill-btn:active{transform:scale(.95) rotate(90deg)}.add-icon{font-size:32px;width:32px;height:32px}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .3s ease-out}.modal-content{width:100%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideInScale .3s ease-out;scrollbar-width:thin;scrollbar-color:var(--color-tertiary) transparent}.modal-content::-webkit-scrollbar{width:8px}.modal-content::-webkit-scrollbar-track{background:transparent}.modal-content::-webkit-scrollbar-thumb{background:var(--color-tertiary);border-radius:10px}.modal-content::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}@keyframes slideInScale{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}@media (max-width: 768px){.main-content{padding:16px}.empty-state{padding:60px 20px}.empty-icon{font-size:80px;width:80px;height:80px}.empty-state h2{font-size:24px}.empty-state p{font-size:16px}.add-pill-btn{bottom:20px;right:20px;width:56px;height:56px}.add-icon{font-size:28px;width:28px;height:28px}.modal-overlay{padding:8px}.modal-content{width:90%;max-height:92vh}.view-controls{margin-bottom:16px}.view-btn{padding:8px 16px;font-size:13px;gap:6px}.view-btn span{display:none}}.react-datepicker__navigation-icon:before,.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{border-color:#ccc;border-style:solid;border-width:3px 3px 0 0;content:"";display:block;height:9px;position:absolute;top:6px;width:9px}.react-datepicker__sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip-path:inset(50%);white-space:nowrap;border:0}.react-datepicker-wrapper{display:inline-block;padding:0;border:0}.react-datepicker{font-family:Helvetica Neue,helvetica,arial,sans-serif;font-size:.8rem;background-color:#fff;color:#000;border:1px solid #aeaeae;border-radius:.3rem;display:inline-block;position:relative;line-height:initial}.react-datepicker--time-only .react-datepicker__time-container{border-left:0}.react-datepicker--time-only .react-datepicker__time,.react-datepicker--time-only .react-datepicker__time-box{border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem}.react-datepicker-popper{z-index:1;line-height:0}.react-datepicker-popper .react-datepicker__triangle{stroke:#aeaeae}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle{fill:#fff;color:#fff}.react-datepicker__header{text-align:center;background-color:#f0f0f0;border-bottom:1px solid #aeaeae;border-top-left-radius:.3rem;padding:8px 0;position:relative}.react-datepicker__header--time{padding-bottom:8px;padding-left:5px;padding-right:5px}.react-datepicker__header--time:not(.react-datepicker__header--time--only){border-top-left-radius:0}.react-datepicker__header:not(.react-datepicker__header--has-time-select){border-top-right-radius:.3rem}.react-datepicker__year-dropdown-container--select,.react-datepicker__month-dropdown-container--select,.react-datepicker__month-year-dropdown-container--select,.react-datepicker__year-dropdown-container--scroll,.react-datepicker__month-dropdown-container--scroll,.react-datepicker__month-year-dropdown-container--scroll{display:inline-block;margin:0 15px}.react-datepicker__current-month,.react-datepicker-time__header,.react-datepicker-year-header{margin-top:0;color:#000;font-weight:700;font-size:.944rem}h2.react-datepicker__current-month{padding:0;margin:0}.react-datepicker-time__header{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.react-datepicker__navigation{align-items:center;background:none;display:flex;justify-content:center;text-align:center;cursor:pointer;position:absolute;top:2px;padding:0;border:none;z-index:1;height:32px;width:32px;text-indent:-999em;overflow:hidden}.react-datepicker__navigation--previous{left:2px}.react-datepicker__navigation--next{right:2px}.react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:85px}.react-datepicker__navigation--years{position:relative;top:0;display:block;margin-left:auto;margin-right:auto}.react-datepicker__navigation--years-previous{top:4px}.react-datepicker__navigation--years-upcoming{top:-4px}.react-datepicker__navigation:hover *:before{border-color:#a6a6a6}.react-datepicker__navigation-icon{position:relative;top:-1px;font-size:20px;width:0}.react-datepicker__navigation-icon--next{left:-2px}.react-datepicker__navigation-icon--next:before{transform:rotate(45deg);left:-7px}.react-datepicker__navigation-icon--previous{right:-2px}.react-datepicker__navigation-icon--previous:before{transform:rotate(225deg);right:-7px}.react-datepicker__month-container{float:left}.react-datepicker__year{margin:.4rem;text-align:center}.react-datepicker__year-wrapper{display:flex;flex-wrap:wrap;max-width:180px}.react-datepicker__year .react-datepicker__year-text{display:inline-block;width:4rem;margin:2px}.react-datepicker__month{margin:.4rem;text-align:center}.react-datepicker__month .react-datepicker__month-text,.react-datepicker__month .react-datepicker__quarter-text{display:inline-block;width:4rem;margin:2px}.react-datepicker__input-time-container{clear:both;width:100%;float:left;margin:5px 0 10px 15px;text-align:left}.react-datepicker__input-time-container .react-datepicker-time__caption,.react-datepicker__input-time-container .react-datepicker-time__input-container{display:inline-block}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input{display:inline-block;margin-left:10px}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input{width:auto}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-inner-spin-button,.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]{-moz-appearance:textfield}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__delimiter{margin-left:5px;display:inline-block}.react-datepicker__time-container{float:right;border-left:1px solid #aeaeae;width:85px}.react-datepicker__time-container--with-today-button{display:inline;border:1px solid #aeaeae;border-radius:.3rem;position:absolute;right:-87px;top:0}.react-datepicker__time-container .react-datepicker__time{position:relative;background:#fff;border-bottom-right-radius:.3rem}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box{width:85px;overflow-x:hidden;margin:0 auto;text-align:center;border-bottom-right-radius:.3rem}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list{list-style:none;margin:0;height:calc(195px + .85rem);overflow-y:scroll;padding-right:0;padding-left:0;width:100%;box-sizing:content-box}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item{height:30px;padding:5px 10px;white-space:nowrap}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item:hover{cursor:pointer;background-color:#f0f0f0}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected{background-color:#216ba5;color:#fff;font-weight:700}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected:hover{background-color:#216ba5}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled{color:#ccc}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled:hover{cursor:default;background-color:transparent}.react-datepicker__week-number{color:#ccc;display:inline-block;width:1.7rem;line-height:1.7rem;text-align:center;margin:.166rem}.react-datepicker__week-number.react-datepicker__week-number--clickable{cursor:pointer}.react-datepicker__week-number.react-datepicker__week-number--clickable:not(.react-datepicker__week-number--selected):hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__week-number--selected{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__week-number--selected:hover{background-color:#1d5d90}.react-datepicker__day-names{text-align:center;white-space:nowrap;margin-bottom:-8px}.react-datepicker__week{white-space:nowrap}.react-datepicker__day-name,.react-datepicker__day,.react-datepicker__time-name{color:#000;display:inline-block;width:1.7rem;line-height:1.7rem;text-align:center;margin:.166rem}.react-datepicker__day-name--disabled,.react-datepicker__day--disabled,.react-datepicker__time-name--disabled{cursor:default;color:#ccc}.react-datepicker__day,.react-datepicker__month-text,.react-datepicker__quarter-text,.react-datepicker__year-text{cursor:pointer}.react-datepicker__day:not([aria-disabled=true]):hover,.react-datepicker__month-text:not([aria-disabled=true]):hover,.react-datepicker__quarter-text:not([aria-disabled=true]):hover,.react-datepicker__year-text:not([aria-disabled=true]):hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__day--today,.react-datepicker__month-text--today,.react-datepicker__quarter-text--today,.react-datepicker__year-text--today{font-weight:700}.react-datepicker__day--highlighted,.react-datepicker__month-text--highlighted,.react-datepicker__quarter-text--highlighted,.react-datepicker__year-text--highlighted{border-radius:.3rem;background-color:#3dcc4a;color:#fff}.react-datepicker__day--highlighted:not([aria-disabled=true]):hover,.react-datepicker__month-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__year-text--highlighted:not([aria-disabled=true]):hover{background-color:#32be3f}.react-datepicker__day--highlighted-custom-1,.react-datepicker__month-text--highlighted-custom-1,.react-datepicker__quarter-text--highlighted-custom-1,.react-datepicker__year-text--highlighted-custom-1{color:#f0f}.react-datepicker__day--highlighted-custom-2,.react-datepicker__month-text--highlighted-custom-2,.react-datepicker__quarter-text--highlighted-custom-2,.react-datepicker__year-text--highlighted-custom-2{color:green}.react-datepicker__day--holidays,.react-datepicker__month-text--holidays,.react-datepicker__quarter-text--holidays,.react-datepicker__year-text--holidays{position:relative;border-radius:.3rem;background-color:#ff6803;color:#fff}.react-datepicker__day--holidays .overlay,.react-datepicker__month-text--holidays .overlay,.react-datepicker__quarter-text--holidays .overlay,.react-datepicker__year-text--holidays .overlay{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px;border-radius:4px;white-space:nowrap;visibility:hidden;opacity:0;transition:visibility 0s,opacity .3s ease-in-out}.react-datepicker__day--holidays:not([aria-disabled=true]):hover,.react-datepicker__month-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__year-text--holidays:not([aria-disabled=true]):hover{background-color:#cf5300}.react-datepicker__day--holidays:hover .overlay,.react-datepicker__month-text--holidays:hover .overlay,.react-datepicker__quarter-text--holidays:hover .overlay,.react-datepicker__year-text--holidays:hover .overlay{visibility:visible;opacity:1}.react-datepicker__day--selected,.react-datepicker__day--in-selecting-range,.react-datepicker__day--in-range,.react-datepicker__month-text--selected,.react-datepicker__month-text--in-selecting-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--selected,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--selected,.react-datepicker__year-text--in-selecting-range,.react-datepicker__year-text--in-range{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__day--selected:not([aria-disabled=true]):hover,.react-datepicker__day--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__day--in-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-range:not([aria-disabled=true]):hover{background-color:#1d5d90}.react-datepicker__day--keyboard-selected,.react-datepicker__month-text--keyboard-selected,.react-datepicker__quarter-text--keyboard-selected,.react-datepicker__year-text--keyboard-selected{border-radius:.3rem;background-color:#bad9f1;color:#000}.react-datepicker__day--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--keyboard-selected:not([aria-disabled=true]):hover{background-color:#1d5d90}.react-datepicker__day--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__month-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__quarter-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__year-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range){background-color:#216ba580}.react-datepicker__month--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range){background-color:#f0f0f0;color:#000}.react-datepicker__day--disabled,.react-datepicker__month-text--disabled,.react-datepicker__quarter-text--disabled,.react-datepicker__year-text--disabled{cursor:default;color:#ccc}.react-datepicker__day--disabled .overlay,.react-datepicker__month-text--disabled .overlay,.react-datepicker__quarter-text--disabled .overlay,.react-datepicker__year-text--disabled .overlay{position:absolute;bottom:70%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px;border-radius:4px;white-space:nowrap;visibility:hidden;opacity:0;transition:visibility 0s,opacity .3s ease-in-out}.react-datepicker__input-container{position:relative;display:inline-block;width:100%}.react-datepicker__input-container .react-datepicker__calendar-icon{position:absolute;padding:.5rem;box-sizing:content-box}.react-datepicker__view-calendar-icon input{padding:6px 10px 5px 25px}.react-datepicker__year-read-view,.react-datepicker__month-read-view,.react-datepicker__month-year-read-view{border:1px solid transparent;border-radius:.3rem;position:relative}.react-datepicker__year-read-view:hover,.react-datepicker__month-read-view:hover,.react-datepicker__month-year-read-view:hover{cursor:pointer}.react-datepicker__year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__month-read-view--down-arrow{border-top-color:#b3b3b3}.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{transform:rotate(135deg);right:-16px;top:0}.react-datepicker__year-dropdown,.react-datepicker__month-dropdown,.react-datepicker__month-year-dropdown{background-color:#f0f0f0;position:absolute;width:50%;left:25%;top:30px;z-index:1;text-align:center;border-radius:.3rem;border:1px solid #aeaeae}.react-datepicker__year-dropdown:hover,.react-datepicker__month-dropdown:hover,.react-datepicker__month-year-dropdown:hover{cursor:pointer}.react-datepicker__year-dropdown--scrollable,.react-datepicker__month-dropdown--scrollable,.react-datepicker__month-year-dropdown--scrollable{height:150px;overflow-y:scroll}.react-datepicker__year-option,.react-datepicker__month-option,.react-datepicker__month-year-option{line-height:20px;width:100%;display:block;margin-left:auto;margin-right:auto}.react-datepicker__year-option:first-of-type,.react-datepicker__month-option:first-of-type,.react-datepicker__month-year-option:first-of-type{border-top-left-radius:.3rem;border-top-right-radius:.3rem}.react-datepicker__year-option:last-of-type,.react-datepicker__month-option:last-of-type,.react-datepicker__month-year-option:last-of-type{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem}.react-datepicker__year-option:hover,.react-datepicker__month-option:hover,.react-datepicker__month-year-option:hover{background-color:#ccc}.react-datepicker__year-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-upcoming{border-bottom-color:#b3b3b3}.react-datepicker__year-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-previous{border-top-color:#b3b3b3}.react-datepicker__year-option--selected,.react-datepicker__month-option--selected,.react-datepicker__month-year-option--selected{position:absolute;left:15px}.react-datepicker__close-icon{cursor:pointer;background-color:transparent;border:0;outline:0;padding:0 6px 0 0;position:absolute;top:0;right:0;height:100%;display:table-cell;vertical-align:middle}.react-datepicker__close-icon:after{cursor:pointer;background-color:#216ba5;color:#fff;border-radius:50%;height:16px;width:16px;padding:2px;font-size:12px;line-height:1;text-align:center;display:table-cell;vertical-align:middle;content:"×"}.react-datepicker__close-icon--disabled{cursor:default}.react-datepicker__close-icon--disabled:after{cursor:default;background-color:#ccc}.react-datepicker__today-button{background:#f0f0f0;border-top:1px solid #aeaeae;cursor:pointer;text-align:center;font-weight:700;padding:5px 0;clear:left}.react-datepicker__portal{position:fixed;width:100vw;height:100vh;background-color:#000c;left:0;top:0;justify-content:center;align-items:center;display:flex;z-index:2147483647}.react-datepicker__portal .react-datepicker__day-name,.react-datepicker__portal .react-datepicker__day,.react-datepicker__portal .react-datepicker__time-name{width:3rem;line-height:3rem}@media (max-width: 400px),(max-height: 550px){.react-datepicker__portal .react-datepicker__day-name,.react-datepicker__portal .react-datepicker__day,.react-datepicker__portal .react-datepicker__time-name{width:2rem;line-height:2rem}}.react-datepicker__portal .react-datepicker__current-month,.react-datepicker__portal .react-datepicker-time__header{font-size:1.44rem}.react-datepicker__children-container{width:13.8rem;margin:.4rem;padding-right:.2rem;padding-left:.2rem;height:auto}.react-datepicker__aria-live{position:absolute;clip-path:circle(0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;width:1px;white-space:nowrap}.react-datepicker__calendar-icon{width:1em;height:1em;vertical-align:-.125em}.custom-datepicker-wrapper{position:relative;display:inline-block;width:100%}.custom-datepicker-wrapper .calendar-icon{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--color-tertiary);font-size:18px;pointer-events:none;transition:all .3s ease}.custom-datepicker-wrapper:hover .calendar-icon{transform:translateY(-50%) scale(1.1);filter:drop-shadow(0 2px 4px rgba(132,94,194,.3))}.datepicker-wrapper{width:100%}.datepicker-wrapper input{width:100%;padding:12px 40px 12px 12px;border:2px solid #e0e0e0;border-radius:12px;font-size:15px;font-family:Fredoka,sans-serif;font-weight:500;color:var(--color-text);background:#fff;cursor:pointer;transition:all .3s ease}.datepicker-wrapper input:hover{border-color:var(--color-tertiary);box-shadow:0 2px 8px #845ec226}.datepicker-wrapper input:focus{outline:none;border-color:var(--color-tertiary);box-shadow:0 0 0 3px #845ec21a}.pillbox-calendar{font-family:Fredoka,sans-serif;border:none!important;border-radius:16px!important;box-shadow:0 8px 32px #00000026!important;overflow:hidden;background:#fff}.pillbox-calendar .react-datepicker__header{background:var(--color-tertiary)!important;border-bottom:none!important;padding:20px 16px 12px!important;border-radius:0!important}.pillbox-calendar .react-datepicker__current-month{color:#fff!important;font-size:18px!important;font-weight:600!important;margin-bottom:12px!important}.pillbox-calendar .react-datepicker__navigation{top:20px!important;width:32px;height:32px;border-radius:8px;transition:all .3s ease}.pillbox-calendar .react-datepicker__navigation:hover{background:#fff3!important;transform:scale(1.1)}.pillbox-calendar .react-datepicker__navigation-icon:before{border-color:#fff!important;border-width:2px 2px 0 0!important;width:8px;height:8px;top:10px}.pillbox-calendar .react-datepicker__day-names{margin-top:8px;display:flex;justify-content:space-around}.pillbox-calendar .react-datepicker__day-name{color:#fff!important;font-size:13px!important;font-weight:600!important;width:36px!important;margin:0 2px!important;opacity:.9}.pillbox-calendar .react-datepicker__month{margin:16px!important;padding:0!important}.pillbox-calendar .react-datepicker__week{display:flex;justify-content:space-around;margin-bottom:4px}.pillbox-calendar .react-datepicker__day{width:36px!important;height:36px!important;line-height:36px!important;margin:2px!important;border-radius:10px!important;font-size:14px!important;font-weight:500!important;color:var(--color-text)!important;transition:all .3s ease!important;cursor:pointer}.pillbox-calendar .react-datepicker__day:hover{background:#845ec21a!important;transform:scale(1.1);color:var(--color-tertiary)!important}.pillbox-calendar .react-datepicker__day--selected{background:var(--color-tertiary)!important;color:#fff!important;font-weight:600!important;box-shadow:0 4px 12px #845ec266!important}.pillbox-calendar .react-datepicker__day--selected:hover{background:var(--color-tertiary)!important;transform:scale(1.05)}.pillbox-calendar .react-datepicker__day--today{background:var(--color-secondary)!important;color:#fff!important;font-weight:600!important}.pillbox-calendar .react-datepicker__day--today:hover{background:var(--color-secondary)!important;opacity:.9}.pillbox-calendar .react-datepicker__day--keyboard-selected{background:#845ec233!important;color:var(--color-tertiary)!important}.pillbox-calendar .react-datepicker__day--outside-month{color:#ccc!important;opacity:.5}.pillbox-calendar .react-datepicker__day--outside-month:hover{background:#845ec20d!important}.pillbox-calendar .react-datepicker__day--disabled{color:#ddd!important;cursor:not-allowed!important;opacity:.3}.pillbox-calendar .react-datepicker__day--disabled:hover{background:transparent!important;transform:none!important}.pillbox-calendar .react-datepicker__day--weekend{color:var(--color-tertiary)!important}.pillbox-calendar .react-datepicker__triangle{display:none!important}.react-datepicker-popper{z-index:1000!important;animation:datePickerFadeIn .3s ease!important}@keyframes datePickerFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 480px){.pillbox-calendar{font-size:14px}.pillbox-calendar .react-datepicker__day{width:32px!important;height:32px!important;line-height:32px!important}.pillbox-calendar .react-datepicker__current-month{font-size:16px!important}}.pill-card{background:var(--color-card);border-radius:var(--border-radius);overflow:hidden;box-shadow:var(--shadow-md);transition:all .3s ease;animation:slideIn .4s ease-out;position:relative}.pill-card.low-supply{box-shadow:0 0 0 3px #ff4d6d,var(--shadow-md)}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.pill-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.pill-card.editing{border:3px solid var(--color-tertiary)}.pill-card.not-today .card-body>*:not(.action-buttons),.pill-card.not-today .card-header{opacity:.5;filter:grayscale(.7)}.pill-card.not-today:hover .card-body>*:not(.action-buttons),.pill-card.not-today:hover .card-header{opacity:.6;filter:grayscale(.5)}.pill-card.not-today .skip-btn{opacity:.5;filter:grayscale(.7)}.pill-card.not-today.editing .card-body,.pill-card.not-today.editing .card-header{opacity:1;filter:none}.pill-card.not-today .break-btn.on-break{opacity:1!important;filter:none!important;position:relative;z-index:5;box-shadow:0 4px 16px #00d2a066!important}.pill-card.not-today .break-btn.on-break:hover{box-shadow:0 6px 20px #00d2a080!important;transform:translateY(-2px) scale(1.05)!important}.card-header{padding:24px;color:#fff;position:relative;display:flex;align-items:center;gap:16px}.pill-icon-wrapper{background:#ffffff4d;border-radius:16px;width:56px;height:56px;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.pill-icon{font-size:32px;width:32px;height:32px}.pill-name{flex:1;font-size:24px;font-weight:600;text-shadow:1px 1px 2px rgba(0,0,0,.1);word-break:break-word}.card-header,.card-body{position:relative;z-index:2}.card-actions{display:flex;gap:8px}.edit-btn,.delete-btn{background:#ffffff4d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:none;width:40px;height:40px;border-radius:12px;font-size:20px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.edit-btn svg,.delete-btn svg{width:20px;height:20px}.edit-btn:hover,.delete-btn:hover{background:#ffffff80;transform:scale(1.1)}.card-body{padding:24px}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}.info-item{display:flex;flex-direction:column;gap:6px}.info-label{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-light);font-weight:500}.info-value{font-size:20px;font-weight:600;color:var(--color-text)}.schedule-info{margin-bottom:20px;display:flex;flex-direction:column;gap:10px}.schedule-badge{display:inline-flex;padding:8px 16px;background:var(--color-secondary);color:#fff;border-radius:12px;font-weight:600;font-size:15px;width:fit-content;transition:all .3s ease}.schedule-badge.today{background:var(--color-success);animation:pulse-glow 2s ease-in-out infinite}.schedule-badge.empty{background:#ff4d6d}@keyframes pulse-glow{0%,to{box-shadow:0 0 #00d2a066}50%{box-shadow:0 0 12px #00d2a099}}.next-dose-wrapper{display:flex;flex-direction:column;gap:10px;align-items:flex-start}.days-badges{display:flex;flex-wrap:wrap;gap:8px}.day-badge{padding:6px 12px;background:var(--color-tertiary);color:#fff;border-radius:10px;font-size:13px;font-weight:500}.day-badge-small{padding:6px 12px;background:#845ec226;color:var(--color-tertiary);border-radius:10px;font-size:13px;font-weight:600;border:2px solid transparent;transition:all .3s ease}.scheduled-doses{display:flex;flex-wrap:wrap;gap:8px}.dose-badge{padding:6px 12px;background:#845ec226;color:var(--color-tertiary);border-radius:10px;font-size:13px;font-weight:600;border:2px solid transparent;transition:all .3s ease}.dose-badge.today{background:var(--color-success);color:#fff;border-color:var(--color-success);box-shadow:0 0 8px #00d2a066}.depletion-info{margin-top:20px}.supply-progress{margin:12px 0 14px}.progress-track{width:100%;height:12px;background:#f0f0f0;border-radius:999px;overflow:hidden}.progress-fill{height:100%;border-radius:999px;transition:width .3s ease;background:var(--color-primary)}.depletion-message{padding:16px;border-radius:12px;margin-bottom:12px;font-weight:600}.depletion-text{font-size:16px;color:var(--color-text)}.depletion-details{display:flex;flex-direction:column;gap:8px}.detail-item{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--color-text-light)}.detail-icon{font-size:18px;width:18px;height:18px;flex-shrink:0}.edit-name-input{flex:1;background:#ffffff4d;border:2px solid rgba(255,255,255,.5);color:#fff;font-size:22px;font-weight:600;padding:12px 16px;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.edit-name-input::placeholder{color:#ffffffb3}.edit-field{margin-bottom:16px}.edit-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.edit-field label{display:block;margin-bottom:8px;font-size:14px;font-weight:500;color:var(--color-text)}.edit-field input,.edit-field select{width:100%;padding:12px 16px;border:2px solid #E0E0E0;border-radius:12px;font-size:16px;transition:border-color .3s ease;background:#fff;color:var(--color-text)}.edit-field input:focus,.edit-field select:focus{outline:none;border-color:var(--color-tertiary)}.date-picker::-webkit-calendar-picker-indicator{cursor:pointer;border-radius:8px;padding:6px;margin-left:8px;transition:all .3s ease;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23845EC2'%3E%3Cpath d='M19 4h-1V2h-2v2H8V2H6v2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm0 16H5V10h14v10zM5 8V6h14v2H5zm2 4h10v2H7v-2z'/%3E%3C/svg%3E");width:20px;height:20px}.schedule-type-selector-edit{display:grid;grid-template-columns:1fr 1fr;gap:12px}.schedule-type-btn-edit{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;background:#f5f5f5;border:3px solid transparent;border-radius:12px;transition:all .3s ease;cursor:pointer}.schedule-type-btn-edit:hover{background:#ececec;transform:translateY(-2px)}.schedule-type-btn-edit.active{background:#845ec226;border-color:var(--color-tertiary)}.schedule-type-btn-edit .btn-icon{font-size:24px;width:24px;height:24px}.schedule-type-btn-edit .btn-text{font-size:13px;font-weight:600;color:var(--color-text)}.days-selector-edit{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.day-selector-btn-edit{padding:10px 6px;background:#f5f5f5;border:2px solid transparent;border-radius:10px;font-size:12px;font-weight:600;color:var(--color-text);transition:all .3s ease;cursor:pointer}.day-selector-btn-edit:hover{background:#ececec;transform:scale(1.05)}.day-selector-btn-edit.selected{background:var(--color-tertiary);color:#fff;border-color:var(--color-tertiary)}.edit-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:20px}.save-btn{background:var(--color-success);color:#fff;padding:14px;border-radius:12px;font-size:16px;font-weight:600}.save-btn:hover{background:var(--color-accent)}.cancel-btn{background:#f0f0f0;color:var(--color-text);padding:14px;border-radius:12px;font-size:16px;font-weight:600}.action-buttons{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:20px;padding-top:20px;border-top:2px solid #F0F0F0}.action-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 12px;border-radius:14px;font-weight:600;transition:all .3s ease}.skip-btn{background:var(--color-secondary);color:#fff}.skip-btn:hover:not(:disabled){background:gold;box-shadow:var(--shadow-md)}.skip-btn:disabled{opacity:.5;cursor:not-allowed}.break-btn{background:var(--color-tertiary);color:#fff}.break-btn.on-break{background:var(--color-success)}.break-btn:hover{box-shadow:var(--shadow-md)}.break-btn:not(.on-break):hover{background:var(--color-primary)}.break-btn.on-break:hover{background:var(--color-accent)}.action-btn .btn-icon{font-size:22px;width:22px;height:22px}.action-btn .btn-label{font-size:14px}.save-btn,.cancel-btn{display:flex;align-items:center;justify-content:center;gap:8px}.save-btn .btn-icon,.cancel-btn .btn-icon{width:18px;height:18px}.delete-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .3s ease;padding:20px}.delete-modal-content{background:#fff;border-radius:20px;padding:32px;max-width:400px;width:100%;box-shadow:0 12px 40px #0003;animation:slideUp .3s ease;text-align:center}.delete-modal-icon{width:64px;height:64px;margin:0 auto 20px;background:#ff4757;border-radius:50%;display:flex;align-items:center;justify-content:center;animation:pulse 1s ease infinite}.delete-modal-icon svg{font-size:32px;color:#fff}.delete-modal-content h3{font-size:24px;font-weight:700;color:var(--color-text);margin:0 0 12px}.delete-modal-content p{font-size:15px;color:#666;margin:0 0 24px;line-height:1.5}.delete-modal-actions{display:flex;gap:12px;justify-content:center}.confirm-delete-btn,.cancel-delete-btn{padding:12px 24px;border-radius:12px;border:none;font-family:Fredoka,sans-serif;font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .3s ease}.confirm-delete-btn{background:#ff4757;color:#fff;flex:1}.confirm-delete-btn:hover{background:#ff3838;transform:translateY(-2px);box-shadow:0 4px 12px #ff47574d}.confirm-delete-btn:active{transform:translateY(0)}.cancel-delete-btn{background:#e0e0e0;color:var(--color-text);flex:1}.cancel-delete-btn:hover{background:#d0d0d0;transform:translateY(-2px)}.cancel-delete-btn:active{transform:translateY(0)}.schedule-info.skipping{animation:scheduleShake .6s ease}.shift-animation{animation:shiftLeft .6s cubic-bezier(.68,-.55,.265,1.55)}@keyframes scheduleShake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-3px)}20%,40%,60%,80%{transform:translate(3px)}}@keyframes shiftLeft{0%{transform:translate(0);opacity:1}30%{transform:translate(-20px) scale(.9);opacity:.3}50%{transform:translate(-40px) scale(.8);opacity:0}51%{transform:translate(40px) scale(.8);opacity:0}70%{transform:translate(20px) scale(.9);opacity:.3}to{transform:translate(0) scale(1);opacity:1}}.dose-badge,.day-badge-small{animation:badgePop .6s cubic-bezier(.68,-.55,.265,1.55)}@keyframes badgePop{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}@media (max-width: 768px){.card-header{padding:20px}.pill-icon-wrapper{width:48px;height:48px}.pill-icon{font-size:28px;width:28px;height:28px}.pill-name{font-size:20px}.card-body{padding:20px}.info-grid{gap:12px}.action-buttons{gap:10px}.action-btn{padding:12px 10px}.action-btn .btn-icon{font-size:20px;width:20px;height:20px}.action-btn .btn-label{font-size:13px}.edit-btn svg,.delete-btn svg{width:18px;height:18px}.schedule-type-selector-edit{grid-template-columns:1fr}.days-selector-edit{grid-template-columns:repeat(4,1fr)}.day-selector-btn-edit{padding:12px 8px;font-size:11px}}.pill-list-item{background:var(--color-card);border-radius:16px;padding:16px 20px;margin-bottom:12px;box-shadow:var(--shadow-sm);transition:all .3s ease;position:relative;animation:slideIn .3s ease-out}.pill-list-item:hover{box-shadow:var(--shadow-md);transform:translate(4px)}.pill-list-item.not-today .list-item-main{opacity:.5;filter:grayscale(.7)}.pill-list-item.not-today:hover .list-item-main{opacity:.6;filter:grayscale(.5)}.pill-list-item.not-today .break-btn.on-break{opacity:1!important;filter:none!important}.not-today-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000bf;color:#fff;padding:6px 16px;border-radius:10px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;z-index:5;pointer-events:none;box-shadow:0 4px 12px #0000004d}.list-item-main{display:flex;align-items:center;gap:16px}.list-item-indicator{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;flex-shrink:0}.list-item-content{flex:1;min-width:0}.list-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:16px}.list-item-name{font-size:18px;font-weight:600;color:var(--color-text);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-item-actions{display:flex;gap:8px;flex-shrink:0}.list-action-btn{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .2s ease;background:#f5f5f5;color:var(--color-text)}.list-action-btn:hover{transform:scale(1.1)}.list-action-btn.edit-btn:hover{background:var(--color-tertiary);color:#fff}.list-action-btn.delete-btn:hover{background:var(--color-primary);color:#fff}.list-item-info{display:flex;flex-wrap:wrap;gap:12px 20px;font-size:13px;color:var(--color-text-light)}.list-info-item strong{color:var(--color-text);font-weight:600;margin-right:4px}.list-info-item.schedule-line{color:var(--color-text);font-weight:700}.list-progress{margin-top:16px}.list-progress-track{width:100%;height:10px;background:#f0f0f0;border-radius:999px;overflow:hidden}.list-progress-fill{height:100%;border-radius:999px;transition:width .3s ease;background:var(--color-primary)}.list-info-item.shift-animation{animation:shiftLeft .6s cubic-bezier(.68,-.55,.265,1.55)}@keyframes shiftLeft{0%{transform:translate(0);opacity:1}30%{transform:translate(-20px) scale(.95);opacity:.3}50%{transform:translate(-40px) scale(.9);opacity:0}51%{transform:translate(40px) scale(.9);opacity:0}70%{transform:translate(20px) scale(.95);opacity:.3}to{transform:translate(0) scale(1);opacity:1}}.pill-list-item .delete-modal-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10;animation:fadeIn .3s ease;padding:20px;border-radius:16px}.pill-list-item .delete-modal-content{background:#fff;border-radius:20px;padding:24px;max-width:90%;width:100%;box-shadow:0 12px 40px #0003;animation:slideUp .3s ease;text-align:center}.pill-list-item .delete-modal-icon{width:56px;height:56px;margin:0 auto 16px;background:#ff4757;border-radius:50%;display:flex;align-items:center;justify-content:center;animation:pulse 1s ease infinite}.pill-list-item .delete-modal-icon svg{font-size:28px;color:#fff}.pill-list-item .delete-modal-content h3{font-size:20px;font-weight:700;color:var(--color-text);margin:0 0 10px}.pill-list-item .delete-modal-content p{font-size:14px;color:#666;margin:0 0 20px;line-height:1.5}.pill-list-item .delete-modal-actions{display:flex;gap:10px;justify-content:center}.pill-list-item .confirm-delete-btn,.pill-list-item .cancel-delete-btn{padding:10px 20px;border-radius:12px;border:none;font-family:Fredoka,sans-serif;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .3s ease}.pill-list-item .confirm-delete-btn{background:#ff4757;color:#fff;flex:1}.pill-list-item .confirm-delete-btn:hover{background:#ff3838;transform:translateY(-2px);box-shadow:0 4px 12px #ff47574d}.pill-list-item .confirm-delete-btn:active{transform:translateY(0)}.pill-list-item .cancel-delete-btn{background:#e0e0e0;color:var(--color-text);flex:1}.pill-list-item .cancel-delete-btn:hover{background:#d0d0d0;transform:translateY(-2px)}.pill-list-item .cancel-delete-btn:active{transform:translateY(0)}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.pill-list-item .edit-modal{max-width:90%}.pill-list-item .edit-form{margin:16px 0;display:flex;flex-direction:column;gap:12px}.pill-list-item .edit-field-group{display:flex;flex-direction:column;align-items:flex-start;text-align:left}.pill-list-item .edit-field-group label{font-size:13px;font-weight:600;color:var(--color-text);margin-bottom:6px}.pill-list-item .edit-field-group input{width:100%;padding:10px;border:2px solid #e0e0e0;border-radius:10px;font-size:14px;font-family:Fredoka,sans-serif;font-weight:500;color:var(--color-text);background:#fff;transition:all .3s ease}.pill-list-item .edit-field-group input:hover{border-color:var(--color-tertiary)}.pill-list-item .edit-field-group input:focus{outline:none;border-color:var(--color-tertiary);box-shadow:0 0 0 3px #845ec21a}.pill-list-item .edit-field-group select{width:100%;padding:10px;border:2px solid #e0e0e0;border-radius:10px;font-size:14px;font-family:Fredoka,sans-serif;font-weight:500;color:var(--color-text);background:#fff;transition:all .3s ease;cursor:pointer}.pill-list-item .edit-field-group select:hover{border-color:var(--color-tertiary)}.pill-list-item .edit-field-group select:focus{outline:none;border-color:var(--color-tertiary);box-shadow:0 0 0 3px #845ec21a}.pill-list-item .schedule-type-selector-edit{display:grid;grid-template-columns:1fr 1fr;gap:8px}.pill-list-item .schedule-type-btn-edit{padding:8px 12px;border:2px solid #e0e0e0;border-radius:10px;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;font-family:Fredoka,sans-serif;font-size:12px;font-weight:600;color:var(--color-text);transition:all .3s ease}.pill-list-item .schedule-type-btn-edit svg{font-size:16px}.pill-list-item .schedule-type-btn-edit:hover{border-color:var(--color-tertiary);background:#845ec20d}.pill-list-item .schedule-type-btn-edit.active{background:var(--color-tertiary);color:#fff;border-color:var(--color-tertiary)}.pill-list-item .days-selector-edit{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.pill-list-item .day-selector-btn-edit{padding:8px 4px;border:2px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer;font-family:Fredoka,sans-serif;font-size:11px;font-weight:600;color:var(--color-text);transition:all .3s ease}.pill-list-item .day-selector-btn-edit:hover{border-color:var(--color-tertiary);background:#845ec21a}.pill-list-item .day-selector-btn-edit.selected{background:var(--color-tertiary);color:#fff;border-color:var(--color-tertiary)}@media (max-width: 768px){.pill-list-item{padding:14px 16px}.list-item-main{gap:12px}.list-item-indicator{width:40px;height:40px;font-size:20px}.list-item-name{font-size:16px}.list-action-btn{width:32px;height:32px;font-size:14px}.list-item-info{flex-direction:column;gap:6px}.not-today-label{font-size:11px;padding:5px 12px}}.pill-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:24px;margin-bottom:32px;animation:fadeIn .6s ease-in}.pill-list-view{margin-bottom:32px;animation:fadeIn .6s ease-in}@media (max-width: 768px){.pill-list{grid-template-columns:1fr;gap:16px}}.add-pill-form{background:var(--color-card);border-radius:var(--border-radius);box-shadow:0 10px 40px #0000004d;overflow:hidden;width:100%}.form-header{background:var(--color-tertiary);padding:16px 20px;display:flex;align-items:center;justify-content:center;gap:8px}.form-header-icon{font-size:24px;width:24px;height:24px;color:#fff}.form-header h2{color:#fff;font-size:20px;font-weight:600;text-shadow:1px 1px 2px rgba(0,0,0,.1)}.form-body{padding:20px}.form-field{margin-bottom:16px}.form-field label{display:block;margin-bottom:6px;font-size:14px;font-weight:600;color:var(--color-text)}.form-field input,.form-field select{width:100%;padding:10px 14px;border:2px solid #E8E8E8;border-radius:12px;font-size:15px;transition:all .3s ease;background:#fff;color:var(--color-text)}.form-field input:focus,.form-field select:focus{outline:none;border-color:var(--color-tertiary);box-shadow:0 0 0 3px #845ec21a}.form-field input::placeholder{color:#b0b0b0}.field-hint{display:block;margin-top:6px;font-size:13px;color:#888;font-style:italic}.date-picker{background:#fff;color:var(--color-text);cursor:pointer;font-family:Fredoka,sans-serif;font-weight:500;position:relative}.date-picker::-webkit-calendar-picker-indicator{cursor:pointer;border-radius:8px;padding:6px;margin-left:8px;transition:all .3s ease;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23845EC2'%3E%3Cpath d='M19 4h-1V2h-2v2H8V2H6v2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm0 16H5V10h14v10zM5 8V6h14v2H5zm2 4h10v2H7v-2z'/%3E%3C/svg%3E");width:20px;height:20px}.date-picker::-webkit-calendar-picker-indicator:hover{background-color:#845ec226;transform:scale(1.1);box-shadow:0 2px 8px #845ec233}.date-picker::-webkit-calendar-picker-indicator:active{transform:scale(.95)}.date-picker:focus{border-color:var(--color-tertiary);box-shadow:0 0 0 3px #845ec21a}.date-picker::-webkit-datetime-edit{padding:2px}.date-picker::-webkit-datetime-edit-fields-wrapper{padding:0}.date-picker::-webkit-datetime-edit-text{color:var(--color-text-light);padding:0 4px}.date-picker::-webkit-datetime-edit-month-field,.date-picker::-webkit-datetime-edit-day-field,.date-picker::-webkit-datetime-edit-year-field{color:var(--color-text);font-weight:600;padding:2px;border-radius:4px;transition:background .2s ease}.date-picker::-webkit-datetime-edit-month-field:hover,.date-picker::-webkit-datetime-edit-day-field:hover,.date-picker::-webkit-datetime-edit-year-field:hover{background:#845ec21a}.date-picker::-webkit-datetime-edit-month-field:focus,.date-picker::-webkit-datetime-edit-day-field:focus,.date-picker::-webkit-datetime-edit-year-field:focus{background:#845ec233;color:var(--color-tertiary);outline:none}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.schedule-type-selector{display:grid;grid-template-columns:1fr 1fr;gap:8px}.schedule-type-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px;background:#f5f5f5;border:2px solid transparent;border-radius:12px;transition:all .3s ease}.schedule-type-btn:hover{background:#ececec;transform:translateY(-2px)}.schedule-type-btn.active{background:#845ec226;border-color:var(--color-tertiary)}.schedule-type-btn .btn-icon{font-size:22px;width:22px;height:22px}.schedule-type-btn .btn-text{font-size:13px;font-weight:600;color:var(--color-text)}.days-selector{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.day-selector-btn{padding:8px 6px;background:#f5f5f5;border:2px solid transparent;border-radius:10px;font-size:12px;font-weight:600;color:var(--color-text);transition:all .3s ease}.day-selector-btn:hover{background:#ececec;transform:scale(1.05)}.day-selector-btn.selected{background:var(--color-tertiary);color:#fff;border-color:var(--color-tertiary)}.form-actions{display:grid;grid-template-columns:2fr 1fr;gap:10px;margin-top:20px}.submit-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;background:var(--color-success);color:#fff;border-radius:12px;font-size:16px;font-weight:600;box-shadow:var(--shadow-md)}.submit-btn:hover{box-shadow:var(--shadow-lg);background:var(--color-accent)}.submit-btn .btn-icon{font-size:18px;width:18px;height:18px}.cancel-form-btn{padding:12px 20px;background:#f0f0f0;color:var(--color-text);border-radius:12px;font-size:15px;font-weight:600;transition:all .3s ease}.cancel-form-btn:hover{background:#e0e0e0}@media (max-width: 768px){.form-header{padding:10px 12px}.form-header-icon{font-size:18px;width:18px;height:18px}.form-header h2{font-size:16px}.form-body{padding:12px}.form-field{margin-bottom:10px}.form-field label{margin-bottom:4px;font-size:13px}.form-field input,.form-field select{padding:8px 12px;font-size:14px}.field-hint{font-size:11px;margin-top:4px}.form-row{grid-template-columns:1fr;gap:8px}.schedule-type-selector{grid-template-columns:1fr;gap:6px}.schedule-type-btn{padding:8px;gap:4px}.schedule-type-btn .btn-icon{font-size:18px;width:18px;height:18px}.schedule-type-btn .btn-text{font-size:12px}.days-selector{grid-template-columns:repeat(7,1fr);gap:4px}.day-selector-btn{padding:6px 2px;font-size:10px}.form-actions{grid-template-columns:1fr;gap:6px;margin-top:12px}.submit-btn,.cancel-form-btn{padding:10px 16px;font-size:14px}.submit-btn .btn-icon{font-size:16px;width:16px;height:16px}}.calendar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1002;animation:fadeIn .3s ease;padding:20px}.calendar-container{background:#fff;border-radius:24px;padding:24px;max-width:500px;width:100%;box-shadow:0 12px 48px #0003;animation:slideUp .3s ease}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:12px}.calendar-title{font-family:Fredoka,sans-serif;font-size:20px;font-weight:700;color:var(--color-text);margin:0;flex:1;text-align:center}.calendar-nav-btn,.calendar-close-btn{background:var(--color-tertiary);color:#fff;border:none;width:36px;height:36px;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;font-size:20px}.calendar-nav-btn:hover,.calendar-close-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #845ec24d}.calendar-nav-btn:active,.calendar-close-btn:active{transform:translateY(0)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:16px}.calendar-day-header{font-family:Fredoka,sans-serif;font-size:12px;font-weight:600;color:#666;text-align:center;padding:8px 0}.calendar-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:12px;cursor:pointer;position:relative;transition:all .3s ease;background:#f5f5f5;border:2px solid transparent}.calendar-day.other-month{opacity:.3}.calendar-day.fill-1-3{background:#c9f3d6;color:#1f3526;font-weight:600}.calendar-day.fill-4-plus{background:#c8e4ff;color:#1f3046;font-weight:600}.calendar-day.cycle-off.fill-1-3{background:linear-gradient(135deg,#e1e1e1 50%,#c9f3d6 50%);color:#1f3526;font-weight:700}.calendar-day.cycle-off.fill-4-plus{background:linear-gradient(135deg,#e1e1e1 50%,#c8e4ff 50%);color:#1f3046;font-weight:700}.calendar-day.cycle-off{background:#e1e1e1;color:#4a4a4a;font-weight:700}.calendar-day.today{background:#ffc7dd;color:#b0155c;font-weight:800;font-size:16px}.calendar-day.cycle-off.today{background:linear-gradient(135deg,#dcdcdc 50%,#ffc7dd 50%);color:#b0155c;border:2px solid #b0155c}.calendar-day.today .day-number{text-decoration:underline;text-decoration-thickness:2px}.calendar-day:hover:not(.other-month){transform:scale(1.1);box-shadow:0 4px 12px #00000026;z-index:1}.day-number{font-family:Fredoka,sans-serif;font-size:14px;font-weight:600}.pill-dot{position:absolute;top:4px;right:4px;background:#fffffff2;font-size:9px;font-weight:700;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid white;box-shadow:0 1px 3px #0003}.calendar-day.fill-1-3 .pill-dot{color:#2d8659;font-weight:800}.calendar-day.fill-4-plus .pill-dot{color:#2d72b8;font-weight:800}.calendar-day.today .pill-dot{background:#ffffffe6;border-color:var(--color-primary);color:var(--color-primary)}.calendar-tooltip{position:fixed;background:#fff;border-radius:16px;padding:12px 16px;box-shadow:0 8px 24px #0003;z-index:1003;transform:translate(-50%,-100%);animation:tooltipSlide .2s ease;max-width:200px;pointer-events:none}.calendar-tooltip:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid white}.tooltip-date{font-family:Fredoka,sans-serif;font-size:13px;font-weight:700;color:var(--color-tertiary);margin-bottom:8px}.tooltip-pills{display:flex;flex-direction:column;gap:4px}.tooltip-pill-item{font-family:Fredoka,sans-serif;font-size:12px;font-weight:500;color:var(--color-text)}.tooltip-pill-item.cycle-off{color:#4a4a4a;font-weight:700}.calendar-legend{padding-top:16px;border-top:1px solid #e0e0e0}.legend-title{font-family:Fredoka,sans-serif;font-size:13px;font-weight:700;color:var(--color-text);margin-bottom:10px;text-align:center}.legend-items{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;align-items:center}.legend-item{display:flex;align-items:center;gap:5px;font-family:Fredoka,sans-serif;font-size:11px;font-weight:600;color:#666}.legend-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0}.legend-dot.fill-1-3-dot{background:#c9f3d6}.legend-dot.fill-4-plus-dot{background:#c8e4ff}.legend-dot.cycle-off-dot{background:#e1e1e1}.legend-today{font-family:Fredoka,sans-serif;font-weight:800;font-size:14px;color:#b0155c;text-decoration:underline;text-decoration-thickness:2px}.legend-divider{width:1px;height:16px;background:#e0e0e0;margin:0 4px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes tooltipSlide{0%{opacity:0;transform:translate(-50%,calc(-100% - 10px))}to{opacity:1;transform:translate(-50%,-100%)}}@media (max-width: 768px){.calendar-container{padding:20px;max-width:100%}.calendar-title{font-size:18px}.calendar-grid{gap:4px}.calendar-day{border-radius:8px}.calendar-day.has-scheduled{cursor:pointer}.calendar-day.has-scheduled:active{transform:scale(.95)}.day-number,.legend-title{font-size:12px}.legend-items{gap:10px}.legend-item{font-size:10px}.pill-dot{width:14px;height:14px;font-size:8px;top:2px;right:2px}.calendar-nav-btn,.calendar-close-btn{width:32px;height:32px;font-size:18px}.calendar-tooltip{max-width:180px;font-size:12px}.tooltip-date{font-size:12px}.tooltip-pill-item{font-size:11px}.legend-title{font-size:12px;margin-bottom:8px}.legend-items{gap:8px}.legend-item{font-size:10px;gap:4px}.legend-dot{width:12px;height:12px}.legend-divider{height:14px}}.header{background:var(--color-tertiary);padding:32px 20px;box-shadow:var(--shadow-lg);position:relative}.header-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;position:relative;z-index:1}.header-left{flex:1}.logo{display:flex;align-items:center;gap:16px;margin-bottom:8px}.logo-icon{font-size:48px;width:48px;height:48px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.logo-text{font-size:42px;font-weight:700;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.tagline{font-size:18px;color:#fffffff2;font-weight:400;margin-left:64px}.header-right{display:flex;align-items:center;gap:16px;position:relative}.menu-container{position:relative}.menu-button{background:#ffffff40;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:28px;transition:all .3s ease;border:2px solid rgba(255,255,255,.3)}.menu-button:hover{background:#ffffff59;transform:rotate(90deg)}.menu-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;z-index:998}.menu-dropdown{position:absolute;top:calc(100% + 12px);right:0;background:#fff;border-radius:16px;box-shadow:0 8px 32px #0003;min-width:200px;overflow:hidden;z-index:1001;animation:dropdownSlide .3s ease-out}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.menu-item{display:flex;align-items:center;gap:12px;width:100%;padding:14px 18px;background:#fff;color:var(--color-text);font-size:14px;font-weight:500;text-align:left;border:none;transition:all .2s ease;cursor:pointer}.menu-item:hover{background:#845ec21a;color:var(--color-tertiary)}.menu-item svg{font-size:20px;width:20px;height:20px}.menu-item.danger{color:#e74c3c}.menu-item.danger:hover{background:#e74c3c1a;color:#c0392b}.menu-item.user-info-item{cursor:default;background:#f9f9f9;padding:16px 18px}.menu-item.user-info-item:hover{background:#f9f9f9;color:var(--color-text)}.user-info-text{display:flex;flex-direction:column;gap:2px;overflow:hidden}.user-name{font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:12px;color:var(--color-text-light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.menu-divider{height:1px;background:#e0e0e0;margin:4px 0}.today-date{background:#ffffff40;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:16px;border-radius:20px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;border:2px solid rgba(255,255,255,.3);width:120px;height:120px;box-sizing:border-box;transition:all .3s ease}.today-date.clickable{cursor:pointer}.today-date.clickable:hover{transform:translateY(-4px);box-shadow:0 6px 20px #00000026;border-color:#ffffff80;background:#ffffff59}.today-date.clickable:active{transform:translateY(-2px)}.date-icon{font-size:36px;width:36px;height:36px;flex-shrink:0;color:#fff}.date-info{display:flex;flex-direction:column;gap:4px;align-items:center;text-align:center}.date-day{font-size:15px;font-weight:600;color:#fff;line-height:1}.date-full{font-size:11px;color:#ffffffe6;font-weight:400;white-space:nowrap}.pill-counter{background:#ffffff40;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:16px;border-radius:20px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;border:2px solid rgba(255,255,255,.3);width:120px;height:120px;box-sizing:border-box;position:relative}.pill-counter.clickable{cursor:pointer}.counter-label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:#ffffffe6;font-weight:500}.counter-value{font-size:36px;font-weight:700;color:#fff;line-height:1}.counter-text{font-size:11px;color:#ffffffe6;font-weight:500;text-align:center}.counter-alert{position:absolute;top:8px;right:8px;background:#ff4d6d;color:#fff;font-weight:800;font-size:12px;padding:4px 8px;border-radius:999px;box-shadow:0 4px 12px #ff4d6d80;letter-spacing:.5px}.low-supply-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:998}.low-supply-dropdown{position:absolute;top:110%;right:0;background:#fff;color:var(--color-text);border-radius:16px;box-shadow:0 10px 30px #00000040;min-width:220px;padding:12px 14px;z-index:1002;animation:dropdownSlide .2s ease-out}.low-supply-title{font-weight:700;font-size:14px;margin-bottom:8px;color:var(--color-text)}.low-supply-list{display:flex;flex-direction:column;gap:8px}.low-supply-item{display:flex;justify-content:space-between;align-items:center;font-size:13px;padding:8px 10px;border-radius:12px;background:#f9f9fb}.low-supply-name{font-weight:600;color:var(--color-text)}.low-supply-days{font-weight:800;color:#ff4d6d;font-size:12px}@media (max-width: 768px){.header{padding:24px 16px}.header-content{flex-direction:column;gap:20px;align-items:flex-start}.logo-icon{font-size:36px;width:36px;height:36px}.logo-text{font-size:32px}.tagline{font-size:16px;margin-left:52px}.header-right{width:100%;justify-content:space-between;gap:12px;flex-wrap:wrap}.menu-button{width:40px;height:40px;font-size:24px}.menu-dropdown{right:-8px}.today-date{padding:10px;flex:1;width:auto;height:50px;flex-direction:row;gap:10px}.date-info{align-items:flex-start;text-align:left}.date-icon{font-size:24px;width:24px;height:24px}.date-day{font-size:14px}.date-full{font-size:12px;white-space:normal}.pill-counter{padding:10px;flex-direction:row;gap:10px;width:auto;height:50px}.counter-value{font-size:24px}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-tertiary) 0%,var(--color-primary) 100%);padding:20px}.login-box{background:#fff;border-radius:var(--border-radius);box-shadow:0 20px 60px #0000004d;max-width:480px;width:100%;overflow:hidden;animation:slideInScale .5s ease-out}.login-header{background:var(--color-tertiary);color:#fff;padding:40px 32px;text-align:center}.login-logo{font-size:80px;width:80px;height:80px;margin-bottom:16px;animation:bounce 1s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.login-header h1{font-size:48px;margin:0 0 8px;font-weight:700}.login-tagline{font-size:16px;opacity:.95;margin:0}.login-form{padding:40px 32px}.login-form h2{font-size:28px;color:var(--color-text);margin:0 0 24px;text-align:center}.login-error{background:#ffe5e5;border:2px solid #E74C3C;border-radius:12px;padding:12px 16px;color:#c0392b;margin-bottom:20px;font-size:14px;font-weight:600}.form-group{margin-bottom:20px}.form-group label{display:flex;align-items:center;gap:12px;background:#f5f5f5;border-radius:12px;padding:14px 16px;transition:all .3s ease;border:2px solid transparent}.form-group label:focus-within{background:#fff;border-color:var(--color-tertiary);box-shadow:0 0 0 4px #845ec21a}.input-icon{font-size:24px;color:var(--color-text-light);flex-shrink:0}.form-group input{flex:1;border:none;background:transparent;outline:none;font-size:16px;color:var(--color-text);font-family:Fredoka,sans-serif}.form-group input::placeholder{color:var(--color-text-light);opacity:.7}.password-requirements{background:#f0e6ff;border-radius:12px;padding:16px;margin-bottom:20px;font-size:13px;color:var(--color-text)}.password-requirements p{margin:0 0 8px;font-weight:600}.password-requirements ul{margin:0;padding-left:20px;list-style:none}.password-requirements li{margin:4px 0;position:relative;padding-left:8px}.password-requirements li:before{content:"•";position:absolute;left:-12px;color:var(--color-tertiary);font-weight:700}.login-btn{width:100%;padding:16px;background:var(--color-success);color:#fff;border:none;border-radius:12px;font-size:18px;font-weight:700;font-family:Fredoka,sans-serif;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .3s ease;cursor:pointer;margin-bottom:20px}.login-btn:hover:not(:disabled){background:var(--color-accent);transform:translateY(-2px);box-shadow:0 8px 20px #00d2a04d}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-btn .btn-icon{font-size:24px}.toggle-mode{text-align:center;color:var(--color-text-light);font-size:14px}.toggle-btn{background:none;border:none;color:var(--color-tertiary);font-weight:700;font-family:Fredoka,sans-serif;font-size:14px;cursor:pointer;text-decoration:underline;padding:0;transition:color .3s ease}.toggle-btn:hover{color:var(--color-primary)}.login-footer{background:#f9f9f9;padding:20px;text-align:center;border-top:1px solid #E0E0E0}.login-footer p{margin:0;font-size:14px;color:var(--color-text-light)}@media (max-width: 768px){.login-container{padding:0}.login-box{border-radius:0;min-height:100vh;display:flex;flex-direction:column;justify-content:center}.login-header{padding:32px 24px}.login-logo{font-size:60px;width:60px;height:60px}.login-header h1{font-size:36px}.login-form{padding:32px 24px}}
