:root{--toastify-color-light: #fff;--toastify-color-dark: #121212;--toastify-color-info: #3498db;--toastify-color-success: #07bc0c;--toastify-color-warning: #f1c40f;--toastify-color-error: #e74c3c;--toastify-color-transparent: rgba(255, 255, 255, .7);--toastify-icon-color-info: var(--toastify-color-info);--toastify-icon-color-success: var(--toastify-color-success);--toastify-icon-color-warning: var(--toastify-color-warning);--toastify-icon-color-error: var(--toastify-color-error);--toastify-toast-width: 320px;--toastify-toast-background: #fff;--toastify-toast-min-height: 64px;--toastify-toast-max-height: 800px;--toastify-font-family: sans-serif;--toastify-z-index: 9999;--toastify-text-color-light: #757575;--toastify-text-color-dark: #fff;--toastify-text-color-info: #fff;--toastify-text-color-success: #fff;--toastify-text-color-warning: #fff;--toastify-text-color-error: #fff;--toastify-spinner-color: #616161;--toastify-spinner-color-empty-area: #e0e0e0;--toastify-color-progress-light: linear-gradient( to right, #4cd964, #5ac8fa, #007aff, #34aadc, #5856d6, #ff2d55 );--toastify-color-progress-dark: #bb86fc;--toastify-color-progress-info: var(--toastify-color-info);--toastify-color-progress-success: var(--toastify-color-success);--toastify-color-progress-warning: var(--toastify-color-warning);--toastify-color-progress-error: var(--toastify-color-error)}.Toastify__toast-container{z-index:var(--toastify-z-index);-webkit-transform:translate3d(0,0,var(--toastify-z-index));position:fixed;padding:4px;width:var(--toastify-toast-width);box-sizing:border-box;color:#fff}.Toastify__toast-container--top-left{top:1em;left:1em}.Toastify__toast-container--top-center{top:1em;left:50%;transform:translate(-50%)}.Toastify__toast-container--top-right{top:1em;right:1em}.Toastify__toast-container--bottom-left{bottom:1em;left:1em}.Toastify__toast-container--bottom-center{bottom:1em;left:50%;transform:translate(-50%)}.Toastify__toast-container--bottom-right{bottom:1em;right:1em}@media only screen and (max-width : 480px){.Toastify__toast-container{width:100vw;padding:0;left:0;margin:0}.Toastify__toast-container--top-left,.Toastify__toast-container--top-center,.Toastify__toast-container--top-right{top:0;transform:translate(0)}.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-right{bottom:0;transform:translate(0)}.Toastify__toast-container--rtl{right:0;left:initial}}.Toastify__toast{position:relative;min-height:var(--toastify-toast-min-height);box-sizing:border-box;margin-bottom:1rem;padding:8px;border-radius:4px;box-shadow:0 1px 10px #0000001a,0 2px 15px #0000000d;display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between;max-height:var(--toastify-toast-max-height);overflow:hidden;font-family:var(--toastify-font-family);cursor:default;direction:ltr;z-index:0}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-body{margin:auto 0;-ms-flex:1 1 auto;flex:1 1 auto;padding:6px;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}.Toastify__toast-body>div:last-child{word-break:break-word;-ms-flex:1;flex:1}.Toastify__toast-icon{-webkit-margin-end:10px;margin-inline-end:10px;width:20px;-ms-flex-negative:0;flex-shrink:0;display:-ms-flexbox;display:flex}.Toastify--animate{animation-fill-mode:both;animation-duration:.7s}.Toastify--animate-icon{animation-fill-mode:both;animation-duration:.3s}@media only screen and (max-width : 480px){.Toastify__toast{margin-bottom:0;border-radius:0}}.Toastify__toast-theme--dark{background:var(--toastify-color-dark);color:var(--toastify-text-color-dark)}.Toastify__toast-theme--light,.Toastify__toast-theme--colored.Toastify__toast--default{background:var(--toastify-color-light);color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{color:var(--toastify-text-color-info);background:var(--toastify-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{color:var(--toastify-text-color-success);background:var(--toastify-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{color:var(--toastify-text-color-warning);background:var(--toastify-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{color:var(--toastify-text-color-error);background:var(--toastify-color-error)}.Toastify__progress-bar-theme--light{background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error{background:var(--toastify-color-transparent)}.Toastify__close-button{color:#fff;background:transparent;outline:none;border:none;padding:0;cursor:pointer;opacity:.7;transition:.3s ease;-ms-flex-item-align:start;align-self:flex-start}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;height:16px;width:14px}.Toastify__close-button:hover,.Toastify__close-button:focus{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{position:absolute;bottom:0;left:0;width:100%;height:5px;z-index:var(--toastify-z-index);opacity:.7;transform-origin:left}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{right:0;left:initial;transform-origin:right}.Toastify__spinner{width:20px;height:20px;box-sizing:border-box;border:2px solid;border-radius:100%;border-color:var(--toastify-spinner-color-empty-area);border-right-color:var(--toastify-spinner-color);animation:Toastify__spin .65s linear infinite}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,0,0)}to{opacity:0;transform:translate3d(2000px,0,0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,0,0)}to{opacity:0;transform:translate3d(-2000px,0,0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,-10px,0)}40%,45%{opacity:1;transform:translate3d(0,20px,0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,10px,0)}40%,45%{opacity:1;transform:translate3d(0,-20px,0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--top-left,.Toastify__bounce-enter--bottom-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--top-right,.Toastify__bounce-enter--bottom-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--top-left,.Toastify__bounce-exit--bottom-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--top-right,.Toastify__bounce-exit--bottom-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{transform:perspective(400px) rotateX(90deg);animation-timing-function:ease-in;opacity:0}40%{transform:perspective(400px) rotateX(-20deg);animation-timing-function:ease-in}60%{transform:perspective(400px) rotateX(10deg);opacity:1}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:perspective(400px)}30%{transform:perspective(400px) rotateX(-20deg);opacity:1}to{transform:perspective(400px) rotateX(90deg);opacity:0}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideOutRight{0%{transform:translateZ(0)}to{visibility:hidden;transform:translate3d(110%,0,0)}}@keyframes Toastify__slideOutLeft{0%{transform:translateZ(0)}to{visibility:hidden;transform:translate3d(-110%,0,0)}}@keyframes Toastify__slideOutDown{0%{transform:translateZ(0)}to{visibility:hidden;transform:translate3d(0,500px,0)}}@keyframes Toastify__slideOutUp{0%{transform:translateZ(0)}to{visibility:hidden;transform:translate3d(0,-500px,0)}}.Toastify__slide-enter--top-left,.Toastify__slide-enter--bottom-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--top-right,.Toastify__slide-enter--bottom-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--top-left,.Toastify__slide-exit--bottom-left{animation-name:Toastify__slideOutLeft}.Toastify__slide-exit--top-right,.Toastify__slide-exit--bottom-right{animation-name:Toastify__slideOutRight}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown}@keyframes Toastify__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #4CAF50;--secondary-color: #2196F3;--danger-color: #f44336;--background-color: #f5f5f5;--card-background: #ffffff;--text-primary: #333333;--text-secondary: #666666;--border-color: #e0e0e0;--shadow: 0 2px 4px rgba(0, 0, 0, .1);--shadow-hover: 0 4px 8px rgba(0, 0, 0, .15)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background-color:var(--background-color);color:var(--text-primary);line-height:1.6}.container{max-width:1200px;margin:0 auto;padding:20px}.btn{padding:10px 20px;border:none;border-radius:5px;font-size:1rem;cursor:pointer;transition:all .3s;font-weight:500}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover{background-color:#45a049;box-shadow:var(--shadow-hover)}.btn-secondary{background-color:var(--secondary-color);color:#fff}.btn-secondary:hover{background-color:#1976d2}.btn-danger{background-color:var(--danger-color);color:#fff}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:5px;font-weight:500;color:var(--text-primary)}.form-group input,.form-group textarea{width:100%;padding:10px;border:2px solid var(--border-color);border-radius:5px;font-size:1rem;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color)}.card{background-color:var(--card-background);padding:25px;border-radius:10px;box-shadow:var(--shadow);margin-bottom:20px}.auth-container{display:flex;justify-content:center;align-items:center;min-height:100vh}.auth-card{width:100%;max-width:400px;padding:40px;background:#fff;border-radius:10px;box-shadow:var(--shadow)}.auth-card h2{text-align:center;color:var(--primary-color);margin-bottom:30px}.error-message{color:var(--danger-color);background-color:#ffebee;padding:10px;border-radius:5px;margin-bottom:15px}.success-message{color:var(--primary-color);background-color:#e8f5e9;padding:10px;border-radius:5px;margin-bottom:15px}.meal-card{background:linear-gradient(135deg,#fff,#fafafa);border:1px solid var(--border-color);border-radius:12px;margin-bottom:12px;overflow:hidden;transition:all .3s ease;box-shadow:0 2px 8px #0000000a}.meal-card:hover{box-shadow:0 4px 16px #00000014;border-color:var(--primary-color)}.meal-card.has-content{border-left:4px solid var(--primary-color)}.meal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;cursor:pointer;background:transparent;transition:background-color .2s ease}.meal-header:hover{background-color:#4caf500a}.meal-header-left{display:flex;align-items:center;gap:12px}.meal-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}.meal-info h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.meal-info .meal-time{font-size:.85rem;color:var(--text-secondary);margin-top:2px}.meal-header-right{display:flex;align-items:center;gap:12px}.meal-status{display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:500}.meal-status.logged{background-color:#e8f5e9;color:#2e7d32}.meal-status.empty{background-color:#f5f5f5;color:#9e9e9e}.expand-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;background-color:#f5f5f5;transition:all .3s ease;font-size:.9rem;color:var(--text-secondary)}.meal-card.expanded .expand-icon{transform:rotate(180deg);background-color:var(--primary-color);color:#fff}.meal-content{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s ease;background-color:#fafafa}.meal-card.expanded .meal-content{max-height:500px;padding:0 20px 20px}.meal-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 600px){.meal-form-grid{grid-template-columns:1fr}}.meal-form-grid .form-field{display:flex;flex-direction:column;gap:6px}.meal-form-grid .form-field.full-width{grid-column:1 / -1}.meal-form-grid .form-field label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.meal-form-grid .form-field input,.meal-form-grid .form-field textarea{padding:12px 14px;border:2px solid #e8e8e8;border-radius:8px;font-size:.95rem;background-color:#fff;transition:all .2s ease}.meal-form-grid .form-field input:focus,.meal-form-grid .form-field textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4caf501a}.meal-form-grid .form-field input::placeholder,.meal-form-grid .form-field textarea::placeholder{color:#bdbdbd}.star-rating{display:flex;align-items:center;gap:2px;flex-wrap:wrap}.star-rating .star{font-size:1.2rem;cursor:pointer;transition:all .15s ease;filter:grayscale(100%);opacity:.3}.star-rating .star:hover{transform:scale(1.2)}.star-rating .star.active{filter:grayscale(0%);opacity:1}.star-rating .rating-text{margin-left:8px;font-size:.85rem;color:var(--text-secondary)}.meals-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.meals-section-header h2{display:flex;align-items:center;gap:10px}.collapse-all-btn{padding:8px 16px;font-size:.85rem;background-color:#f5f5f5;border:1px solid var(--border-color);border-radius:20px;cursor:pointer;transition:all .2s ease;color:var(--text-secondary)}.collapse-all-btn:hover{background-color:#eee;color:var(--text-primary)}.meal-form-grid .form-field select{padding:12px 36px 12px 14px;border:2px solid #e8e8e8;border-radius:8px;font-size:.95rem;background-color:#fff;transition:all .2s ease;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.meal-form-grid .form-field select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4caf501a}.meal-form-grid .form-field .duration-input{max-width:100%}.meal-form-grid .form-field input[type=number]{-moz-appearance:textfield}.meal-form-grid .form-field input[type=number]::-webkit-outer-spin-button,.meal-form-grid .form-field input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.poop-btn{position:relative;padding:10px 16px;font-size:1.4rem;background-color:#8d6e63;border:none;border-radius:5px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.poop-btn.floating{position:fixed;bottom:24px;right:24px;width:60px;height:60px;border-radius:50%;font-size:1.8rem;box-shadow:0 4px 12px #0000004d;z-index:1000}.poop-btn:hover{background-color:#6d4c41;transform:scale(1.05)}.poop-btn.floating:hover{transform:scale(1.1);box-shadow:0 6px 16px #0006}.lang-btn{padding:10px 14px;font-size:1.3rem;background-color:#f5f5f5;border:2px solid var(--border-color);border-radius:5px;cursor:pointer;transition:all .3s ease}.lang-btn:hover{background-color:#e0e0e0;transform:scale(1.05)}.garmin-btn{position:relative;padding:10px 16px;font-size:1.4rem;background-color:#007acc;border:none;border-radius:5px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;color:#fff}.garmin-btn:hover{background-color:#005a9e;transform:scale(1.05)}.garmin-btn.connected{background-color:#4caf50}.garmin-btn.connected:hover{background-color:#388e3c}.garmin-badge{position:absolute;top:-4px;right:-4px;background-color:#fff;color:#4caf50;font-size:.65rem;font-weight:700;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center}.sync-btn{position:relative;min-width:44px;padding:10px 12px}.sync-btn .sync-icon{display:inline-block;font-size:1.2rem;transition:transform .3s ease}.sync-btn.syncing .sync-icon{animation:spin 1s linear infinite}.sync-btn:disabled{opacity:.7;cursor:not-allowed}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.garmin-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.garmin-dialog{background:#fff;border-radius:12px;width:100%;max-width:400px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0003;animation:dialogSlideIn .3s ease}.garmin-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid var(--border-color);background-color:#007acc;color:#fff;border-radius:12px 12px 0 0}.garmin-dialog-header h2{margin:0;font-size:1.25rem}.garmin-dialog-header .close-btn{color:#fff}.garmin-dialog-header .close-btn:hover{color:#fcc}.garmin-dialog-content{padding:20px}.garmin-dialog-content .form-field{margin-bottom:16px}.garmin-dialog-content .form-field label{display:block;font-size:.85rem;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.garmin-dialog-content .form-field input{width:100%;padding:12px 14px;border:2px solid #e8e8e8;border-radius:8px;font-size:.95rem;transition:all .2s ease;box-sizing:border-box}.garmin-dialog-content .form-field input:focus{outline:none;border-color:#007acc;box-shadow:0 0 0 3px #007acc1a}.garmin-info{color:var(--text-secondary);font-size:.9rem;margin-bottom:20px;line-height:1.5}.garmin-connected{text-align:center}.garmin-connected .status-badge{display:inline-block;padding:8px 20px;border-radius:20px;font-weight:600;margin-bottom:15px}.garmin-connected .status-badge.connected{background-color:#e8f5e9;color:#2e7d32}.garmin-connected .last-sync{color:var(--text-secondary);font-size:.85rem;margin-bottom:15px}.garmin-connected .error-message{color:var(--danger-color);font-size:.85rem;margin-bottom:15px;padding:10px;background-color:#ffebee;border-radius:6px}.poop-badge{position:absolute;top:-6px;right:-6px;background-color:var(--primary-color);color:#fff;font-size:.7rem;font-weight:700;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center}.toilet-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.toilet-dialog{background:#fff;border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0003;animation:dialogSlideIn .3s ease}@keyframes dialogSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.toilet-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid var(--border-color)}.toilet-dialog-header h2{margin:0;font-size:1.25rem;color:var(--text-primary)}.close-btn{background:none;border:none;font-size:1.8rem;color:var(--text-secondary);cursor:pointer;padding:0;line-height:1;transition:color .2s}.close-btn:hover{color:var(--danger-color)}.toilet-dialog-content{padding:20px}.toilet-dialog-content .form-field{margin-bottom:20px}.toilet-dialog-content .form-field label{display:block;font-size:.85rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.toilet-dialog-content .form-field input,.toilet-dialog-content .form-field textarea{width:100%;padding:12px 14px;border:2px solid #e8e8e8;border-radius:8px;font-size:.95rem;transition:all .2s ease}.toilet-dialog-content .form-field input:focus,.toilet-dialog-content .form-field textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4caf501a}.bristol-scale{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px}.bristol-type{display:flex;flex-direction:column;align-items:center;padding:12px 8px;border:2px solid #e8e8e8;border-radius:10px;background:#fff;cursor:pointer;transition:all .2s ease}.bristol-type:hover{border-color:#bdbdbd;background-color:#fafafa}.bristol-type.selected{border-color:var(--primary-color);background-color:#4caf5014}.bristol-emoji{font-size:1.4rem;margin-bottom:4px}.bristol-label{font-size:.8rem;font-weight:600;color:var(--text-primary)}.bristol-desc{font-size:.7rem;color:var(--text-secondary);text-align:center;margin-top:2px}.toilet-visits-list{margin-top:24px;padding-top:20px;border-top:1px solid var(--border-color)}.toilet-visits-list h3{font-size:.9rem;color:var(--text-secondary);margin-bottom:12px}.toilet-visit-item{display:flex;align-items:center;justify-content:space-between;padding:12px;background-color:#fafafa;border-radius:8px;margin-bottom:8px}.visit-info{display:flex;flex-direction:column;gap:4px}.visit-time{font-size:.85rem;font-weight:600;color:var(--text-primary)}.visit-type{font-size:.85rem;color:var(--text-secondary)}.visit-notes{font-size:.8rem;color:var(--text-secondary);font-style:italic}.visit-actions{display:flex;gap:8px}.edit-btn,.delete-btn{padding:6px 12px;font-size:.75rem;border:none;border-radius:4px;cursor:pointer;transition:all .2s ease}.edit-btn{background-color:var(--secondary-color);color:#fff}.edit-btn:hover{background-color:#1976d2}.delete-btn{background-color:var(--danger-color);color:#fff}.delete-btn:hover{background-color:#d32f2f}.date-picker-input{padding:10px 15px;border:2px solid var(--border-color);border-radius:8px;font-size:1rem;cursor:pointer;transition:all .2s ease;text-align:center;width:140px}.date-picker-input:hover{border-color:var(--primary-color)}.date-picker-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4caf501a}.react-datepicker{font-family:inherit;border:1px solid var(--border-color);border-radius:10px;box-shadow:0 4px 20px #00000026}.react-datepicker__header{background-color:var(--primary-color);border-bottom:none;border-radius:10px 10px 0 0;padding-top:12px}.react-datepicker__current-month,.react-datepicker__day-name{color:#fff}.react-datepicker__day--selected,.react-datepicker__day--keyboard-selected{background-color:var(--primary-color);border-radius:50%}.react-datepicker__day--selected:hover{background-color:#45a049}.react-datepicker__day:hover{border-radius:50%;background-color:#e8f5e9}.react-datepicker__today-button{background-color:var(--primary-color);color:#fff;border-top:none;border-radius:0 0 10px 10px;padding:8px;font-weight:500}.react-datepicker__today-button:hover{background-color:#45a049}.react-datepicker__navigation-icon:before{border-color:#fff}.react-datepicker__month-dropdown,.react-datepicker__year-dropdown{background-color:#fff;border:1px solid var(--border-color);border-radius:5px}.react-datepicker__month-option--selected_month,.react-datepicker__year-option--selected_year{background-color:var(--primary-color);color:#fff}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.offline-banner{position:fixed;top:0;left:0;right:0;padding:10px 20px;color:#fff;text-align:center;z-index:9999;display:flex;align-items:center;justify-content:center;gap:10px;animation:slideDown .3s ease;transition:background-color .3s ease}.offline-banner.offline{background-color:#ff9800}.offline-banner.online{background-color:#4caf50}.offline-banner-close{background:transparent;border:none;color:#fff;cursor:pointer;font-size:1.2rem;margin-left:10px;padding:0}.sync-status-badge{position:fixed;bottom:90px;right:24px;background-color:#ff9800;color:#fff;padding:8px 16px;border-radius:20px;box-shadow:0 2px 8px #0003;z-index:999;display:flex;align-items:center;gap:8px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.sync-status-badge:hover{transform:scale(1.05);box-shadow:0 4px 12px #0000004d}.sync-status-badge.has-conflicts{background-color:#f44336}.sync-status-badge .sync-icon.spinning{animation:spin 1s linear infinite}.sync-status-badge .sync-hint{font-size:.8em;opacity:.9}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;font-size:1.2rem;color:var(--text-secondary)}.offline-badge{animation:pulse 2s infinite}.offline-disabled{opacity:.5;pointer-events:none;cursor:not-allowed}.conflict-resolver-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:fadeIn .2s ease}.conflict-resolver{background-color:#fff;border-radius:12px;max-width:600px;width:100%;max-height:80vh;overflow:auto;box-shadow:0 10px 40px #0003}.conflict-resolver-header{padding:20px;border-bottom:1px solid #e0e0e0;background-color:#f44336;color:#fff;border-radius:12px 12px 0 0}.conflict-resolver-header h2{margin:0;font-size:1.25rem}.conflict-resolver-header p{margin:8px 0 0;opacity:.9;font-size:.9rem}.conflict-resolver-content{padding:20px}.conflict-date{margin-bottom:20px;color:#666}.conflict-comparison{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}@media (max-width: 500px){.conflict-comparison{grid-template-columns:1fr}}.conflict-option{padding:15px;border-radius:8px;border:2px solid transparent}.conflict-option.local{background-color:#e3f2fd;border-color:#2196f3}.conflict-option.server{background-color:#fff3e0;border-color:#ff9800}.conflict-option h4{margin:0 0 10px;font-size:.95rem}.conflict-option.local h4{color:#1976d2}.conflict-option.server h4{color:#e65100}.conflict-option-content{font-size:.85rem;color:#555}.conflict-summary-list{margin:0;padding-left:20px}.conflict-summary-list li{margin-bottom:4px}.conflict-actions{display:flex;flex-direction:column;gap:10px}.conflict-btn{padding:12px 20px;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;font-size:1rem;transition:all .2s ease}.conflict-btn:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0003}.conflict-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.conflict-btn.local{background-color:#2196f3}.conflict-btn.local:hover:not(:disabled){background-color:#1976d2}.conflict-btn.server{background-color:#ff9800}.conflict-btn.server:hover:not(:disabled){background-color:#e65100}.conflict-btn.merge{background-color:#4caf50}.conflict-btn.merge:hover:not(:disabled){background-color:#388e3c}.conflict-remaining{margin-top:15px;color:#999;font-size:.85rem;text-align:center}.weekly-goals-card{background:linear-gradient(135deg,#fff,#f8f9fa);border:2px solid transparent;transition:all .3s ease}.weekly-goals-card.all-complete{border-color:var(--primary-color);background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}.weekly-goals-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:10px}.weekly-goals-header h2{display:flex;align-items:center;gap:10px;margin:0;font-size:1.25rem}.weekly-goals-stats{display:flex;gap:10px;flex-wrap:wrap}.completion-badge,.streak-badge{padding:6px 12px;border-radius:20px;font-size:.85rem;font-weight:600}.completion-badge{background-color:var(--primary-color);color:#fff}.streak-badge{background-color:#ff9800;color:#fff}.goals-list{display:flex;flex-direction:column;gap:10px}.goal-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fff;border:1px solid #e8e8e8;border-radius:10px;transition:all .2s ease}.goal-item:hover{box-shadow:0 2px 8px #00000014}.goal-item.completed{background-color:#f5f5f5}.goal-item.completed .goal-title{text-decoration:line-through;color:var(--text-secondary)}.goal-checkbox{position:relative;display:flex;align-items:center;cursor:pointer;flex-shrink:0}.goal-checkbox input{position:absolute;opacity:0;cursor:pointer;width:0;height:0}.goal-checkbox .checkmark{width:24px;height:24px;border:2px solid #ddd;border-radius:50%;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.goal-checkbox input:checked+.checkmark{background-color:var(--primary-color);border-color:var(--primary-color)}.goal-checkbox input:checked+.checkmark:after{content:"✓";color:#fff;font-size:14px;font-weight:700}.goal-checkbox:hover .checkmark{border-color:var(--primary-color)}.goal-content{flex:1;display:flex;flex-direction:column;min-width:0}.goal-title{font-weight:500;color:var(--text-primary);word-break:break-word}.goal-description{font-size:.85rem;color:var(--text-secondary);margin-top:2px;word-break:break-word}.goal-delete-btn{background:none;border:none;color:#bbb;font-size:1.5rem;cursor:pointer;padding:0 8px;transition:color .2s;flex-shrink:0;line-height:1}.goal-delete-btn:hover{color:var(--danger-color)}.add-goal-form{display:flex;flex-direction:column;gap:10px;margin-top:16px;padding:16px;background:#fafafa;border-radius:10px}.add-goal-form input{padding:12px;border:2px solid #e8e8e8;border-radius:8px;font-size:.95rem;font-family:inherit}.add-goal-form input:focus{outline:none;border-color:var(--primary-color)}.add-goal-actions{display:flex;gap:10px}.add-goal-btn{margin-top:12px;padding:10px;background:none;border:2px dashed #ddd;border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .2s;font-size:.95rem}.add-goal-btn:hover{border-color:var(--primary-color);color:var(--primary-color)}.weekly-summary{margin-top:20px;padding-top:16px;border-top:1px solid #e8e8e8}.summary-progress{height:8px;background-color:#e8e8e8;border-radius:4px;overflow:hidden;margin-bottom:8px}.summary-progress .progress-bar{height:100%;background:linear-gradient(90deg,var(--primary-color),#81c784);border-radius:4px;transition:width .5s ease}.summary-text{font-size:.85rem;color:var(--text-secondary)}.goals-empty{text-align:center;padding:30px;color:var(--text-secondary)}.goals-empty p{margin-bottom:16px}.goals-loading{text-align:center;padding:20px;color:var(--text-secondary)}.btn-secondary.cancel{background-color:#9e9e9e}.btn-secondary.cancel:hover{background-color:#757575}.add-goal-actions .btn{flex:1}.barcode-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:1.1rem;color:#fff;box-shadow:0 2px 6px #667eea4d}.barcode-btn:hover{transform:scale(1.08);box-shadow:0 4px 12px #667eea66}.barcode-btn:active{transform:scale(.95)}.food-label-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.barcode-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000f2;display:flex;align-items:center;justify-content:center;z-index:10001;animation:fadeIn .2s ease}.barcode-scanner-container{position:relative;width:100%;height:100%;max-width:500px;max-height:100%;display:flex;flex-direction:column}.barcode-close-btn{position:absolute;top:20px;right:20px;z-index:100;background:#fff3;border:none;color:#fff;font-size:2rem;width:48px;height:48px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.barcode-close-btn:hover{background:#ffffff4d;transform:scale(1.1)}.barcode-camera-wrapper{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}.barcode-video{width:100%;height:100%;object-fit:cover}.barcode-video-container{width:100%;height:100%}.barcode-video-container video{width:100%!important;height:100%!important;object-fit:cover!important}#barcode-scanner-element{width:100%!important;min-height:400px}#barcode-scanner-element__scan_region{min-height:350px!important;background:#000}#barcode-scanner-element__scan_region video{object-fit:cover!important}#barcode-scanner-element__dashboard_section,#barcode-scanner-element__dashboard_section_csr,#barcode-scanner-element__header_message{display:none!important}#qr-shaded-region{border:3px solid #4CAF50!important}.scan-instruction-bottom{position:absolute;bottom:30px;left:0;right:0;text-align:center;color:#fff;font-size:1rem;text-shadow:0 2px 4px rgba(0,0,0,.8);padding:10px;background:#00000080}.scan-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.scan-overlay:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(to bottom,rgba(0,0,0,.7) 0%,rgba(0,0,0,.7) calc(50% - 100px),transparent calc(50% - 100px),transparent calc(50% + 100px),rgba(0,0,0,.7) calc(50% + 100px),rgba(0,0,0,.7) 100%)}.scan-frame{position:relative;width:280px;height:180px;display:flex;align-items:center;justify-content:center}.scan-corner{position:absolute;width:30px;height:30px;border:4px solid #4CAF50;animation:pulse-corner 2s ease-in-out infinite}.scan-corner.top-left{top:0;left:0;border-right:none;border-bottom:none;border-radius:8px 0 0}.scan-corner.top-right{top:0;right:0;border-left:none;border-bottom:none;border-radius:0 8px 0 0}.scan-corner.bottom-left{bottom:0;left:0;border-right:none;border-top:none;border-radius:0 0 0 8px}.scan-corner.bottom-right{bottom:0;right:0;border-left:none;border-top:none;border-radius:0 0 8px}@keyframes pulse-corner{0%,to{opacity:1;border-color:#4caf50}50%{opacity:.6;border-color:#81c784}}.scan-line{position:absolute;left:10px;right:10px;height:3px;background:linear-gradient(90deg,transparent 0%,#4CAF50 20%,#81c784 50%,#4CAF50 80%,transparent 100%);box-shadow:0 0 15px #4caf50,0 0 30px #4caf5080;animation:scan-line-move 2s ease-in-out infinite;border-radius:2px}@keyframes scan-line-move{0%{top:10px;opacity:0}10%{opacity:1}90%{opacity:1}to{top:calc(100% - 10px);opacity:0}}.scan-instruction{position:absolute;bottom:calc(50% - 140px);color:#fff;font-size:1rem;text-align:center;text-shadow:0 2px 4px rgba(0,0,0,.5);padding:0 20px}.barcode-status-view{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;text-align:center;color:#fff;flex:1}.barcode-status-view h3{font-size:1.25rem;margin-bottom:10px}.barcode-status-view p{color:#ffffffb3;margin-bottom:20px;max-width:280px}.status-icon{font-size:4rem;margin-bottom:20px}.barcode-loader{width:50px;height:50px;border:4px solid rgba(255,255,255,.2);border-top-color:#4caf50;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}.barcode-result{display:flex;flex-direction:column;padding:20px;flex:1;overflow-y:auto}.product-card{background:#fff;border-radius:16px;padding:20px;display:flex;gap:16px;margin-bottom:20px;box-shadow:0 4px 20px #00000026}.product-image{width:100px;height:100px;object-fit:contain;border-radius:12px;background:#f5f5f5;flex-shrink:0}.product-info{flex:1;display:flex;flex-direction:column;gap:6px;min-width:0}.product-name{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0;line-height:1.3}.product-brand{font-size:.9rem;color:var(--text-secondary);margin:0}.product-quantity{font-size:.85rem;color:var(--text-secondary);margin:0}.nutri-score{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:6px;font-size:.75rem;font-weight:700;color:#fff;margin-top:6px;width:fit-content}.nutri-score-a{background-color:#038141}.nutri-score-b{background-color:#85bb2f}.nutri-score-c{background-color:#fecb02;color:#333}.nutri-score-d{background-color:#ee8100}.nutri-score-e{background-color:#e63e11}.nutrition-summary{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px;font-size:.8rem;color:var(--text-secondary)}.nutrition-summary span{background:#f5f5f5;padding:4px 8px;border-radius:4px}.barcode-actions{display:flex;flex-direction:column;gap:12px}.barcode-actions .btn{padding:14px 20px;font-size:1rem;border-radius:12px}.barcode-actions .btn-primary{background:linear-gradient(135deg,#4caf50,#66bb6a);box-shadow:0 4px 15px #4caf504d}.barcode-actions .btn-primary:hover{box-shadow:0 6px 20px #4caf5066}.barcode-actions .btn-secondary{background:#ffffff1a;border:2px solid rgba(255,255,255,.3);color:#fff}.barcode-actions .btn-secondary:hover{background:#fff3}.barcode-captured-view{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;flex:1}.captured-image-container{position:relative;width:90%;max-width:350px;border-radius:16px;overflow:hidden;box-shadow:0 10px 40px #00000080;animation:capturedPop .3s ease-out}@keyframes capturedPop{0%{transform:scale(.8);opacity:0}50%{transform:scale(1.05)}to{transform:scale(1);opacity:1}}.captured-barcode-image{width:100%;display:block;border-radius:16px}.captured-placeholder{width:100%;height:200px;background:linear-gradient(135deg,#2a2a2a,#1a1a1a);border-radius:16px}.scan-line-animated{position:absolute;left:0;width:100%;height:4px;background:linear-gradient(90deg,transparent 0%,rgba(76,175,80,.8) 20%,rgba(129,199,132,1) 50%,rgba(76,175,80,.8) 80%,transparent 100%);box-shadow:0 0 20px #4caf50cc,0 0 40px #4caf5066;animation:scanPulse .8s ease-in-out}@keyframes scanPulse{0%{top:0;opacity:0}20%{opacity:1}to{top:100%;opacity:0}}.scan-success-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:#4caf5033;animation:successFade .8s ease-out .3s forwards;opacity:0}@keyframes successFade{0%{opacity:0;background:#4caf5033}50%{opacity:1;background:#4caf504d}to{opacity:1;background:#4caf5026}}.checkmark{font-size:4rem;color:#4caf50;text-shadow:0 0 30px rgba(76,175,80,.8);animation:checkmarkPop .4s ease-out .5s forwards;transform:scale(0);opacity:0}@keyframes checkmarkPop{0%{transform:scale(0);opacity:0}60%{transform:scale(1.2);opacity:1}to{transform:scale(1);opacity:1}}.barcode-number{margin-top:24px;font-family:SF Mono,Menlo,Monaco,monospace;font-size:1.2rem;color:#ffffffe6;letter-spacing:3px;animation:fadeInUp .5s ease-out .2s forwards;opacity:0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 500px){.scan-frame{width:240px;height:150px}.product-card{flex-direction:column;align-items:center;text-align:center}.product-image{width:120px;height:120px}.product-info{align-items:center}}.notification-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease}.notification-dialog{background:#fff;border-radius:12px;width:90%;max-width:400px;max-height:80vh;overflow-y:auto;box-shadow:0 10px 40px #0003;animation:dialogSlideIn .3s ease}.notification-dialog-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #eee}.notification-dialog-header h2{margin:0;font-size:1.25rem;color:var(--text-primary)}.notification-dialog-content{padding:20px}.notification-toggle{display:flex;justify-content:space-between;align-items:center;gap:20px}.toggle-info h3{margin:0 0 8px;font-size:1rem;color:var(--text-primary)}.toggle-info p{margin:0;color:var(--text-secondary);font-size:.875rem;line-height:1.5}.notification-unsupported,.notification-denied{text-align:center;padding:20px 0}.notification-unsupported p,.notification-denied p{color:var(--text-secondary);margin:0 0 10px}.notification-denied .help-text{font-size:.85rem;color:#999}.switch{position:relative;display:inline-block;width:50px;height:28px;flex-shrink:0}.switch input{opacity:0;width:0;height:0}.switch .slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;transition:.3s;border-radius:28px}.switch .slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;transition:.3s;border-radius:50%}.switch input:checked+.slider{background-color:#4caf50}.switch input:checked+.slider:before{transform:translate(22px)}.switch input:disabled+.slider{opacity:.6;cursor:not-allowed}.notification-test{margin-top:20px;padding-top:20px;border-top:1px solid var(--border-color)}.test-notification-btn{width:100%;padding:12px 20px;background-color:var(--secondary-color);color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background-color .2s,transform .1s}.test-notification-btn:hover:not(:disabled){background-color:#1976d2;transform:translateY(-1px)}.test-notification-btn:disabled{opacity:.6;cursor:not-allowed}.notification-btn{font-size:1.2rem;padding:10px 14px}
