body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}body{background-color:#f8f9fa;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.App{margin:0 auto;max-width:414px;min-height:100vh;padding:12px}.app-header{border-bottom:1px solid #e0e0e0;margin-bottom:20px;padding:16px 0;position:relative;text-align:center}.app-header h1{color:#2c3e50;font-size:32px;font-weight:700;margin-bottom:8px}.app-header p{color:#7f8c8d;font-size:16px;margin-bottom:4px}.welcome-text{color:#27ae60;font-size:18px;font-weight:500}.settings-btn{align-items:center;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;color:#7f8c8d;cursor:pointer;display:flex;font-size:14px;gap:6px;padding:8px 12px;position:absolute;right:0;top:16px;transition:all .3s}.settings-btn:hover{background:#e9ecef;border-color:#d5dbdb;color:#5a6c7d}.settings-btn svg{stroke:currentColor;flex-shrink:0}.main-content{padding:0 4px}.calendar-container{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:20px;padding:20px}.calendar-header{justify-content:space-between;margin-bottom:20px}.calendar-header,.nav-button{align-items:center;display:flex}.nav-button{background:none;border:none;color:#7f8c8d;cursor:pointer;font-size:24px;height:40px;justify-content:center;transition:color .3s;width:40px}.nav-button:hover{color:#5a6c7d}.month-title{color:#2c3e50;cursor:pointer;font-size:20px;font-weight:600}.month-title:hover{color:#3498db}.calendar-weekdays{grid-gap:2px;display:grid;gap:2px;grid-template-columns:repeat(7,1fr);margin-bottom:8px}.calendar-weekdays div{color:#7f8c8d;font-size:14px;font-weight:600;padding:8px 4px;text-align:center}.calendar-grid{grid-gap:2px;display:grid;gap:2px;grid-template-columns:repeat(7,1fr)}.calendar-day{align-items:center;aspect-ratio:1;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;display:flex;font-size:16px;font-weight:500;justify-content:center;position:relative;transition:all .3s}.calendar-day.empty{border:none;cursor:default}.calendar-day:hover:not(.empty){background:#ecf0f1;transform:scale(1.05)}.calendar-day.today{background:#3498db;color:#fff;font-weight:700}.calendar-day.taken{background:#27ae60;color:#fff}.calendar-day.has-memo{border:2px solid #f39c12}.check-mark{color:#fff;font-size:12px;position:absolute;right:2px;top:2px}.memo-indicator{bottom:1px;font-size:10px;position:absolute;right:1px}.stats{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;margin-top:20px;padding:16px}.total-stats{border-bottom:1px solid #e0e0e0;margin-bottom:12px;padding-bottom:12px}.total-days,.total-rate{color:#2c3e50;font-size:16px;margin-bottom:4px}.total-rate{color:#27ae60;font-weight:600}.monthly-stats p{color:#7f8c8d;font-size:14px}.motivation-message{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;margin-top:16px;padding:12px;text-align:center}.motivation-message p{color:#fff;font-size:14px;font-weight:500;line-height:1.4}.share-section{margin-top:20px;text-align:center}.share-section h3{color:#2c3e50;font-size:18px;margin-bottom:12px}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;max-height:90vh;max-width:400px;overflow-y:auto;padding:24px;width:100%}.modal-content h3{color:#2c3e50;font-size:20px;margin-bottom:16px;text-align:center}.modal-section{margin-bottom:20px}.modal-section label{color:#2c3e50;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.modal-section input[type=date],.modal-section input[type=email],.modal-section input[type=text],.modal-section input[type=time],.modal-section textarea{-webkit-appearance:none;appearance:none;background-color:#fff;border:2px solid #e0e0e0;border-radius:8px;box-sizing:border-box;font-size:16px;padding:12px;position:relative;transition:border-color .3s;width:100%;z-index:1}.modal-section input:focus,.modal-section textarea:focus{zoom:1;border-color:#3498db;outline:none;transform:none}.modal-section small{color:#7f8c8d;display:block;font-size:12px;line-height:1.3;margin-top:4px}.modal-section textarea{min-height:80px;resize:vertical}.checkbox-label{align-items:center;cursor:pointer;display:flex;margin-bottom:0}.checkbox-label input[type=checkbox]{margin-right:8px;transform:scale(1.2)}.time-checkboxes{grid-gap:8px;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;display:grid;gap:8px;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr);margin:0 auto;max-width:320px;padding:12px;width:100%}.time-checkbox{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:8px;box-sizing:border-box;cursor:pointer;display:flex;gap:6px;justify-content:flex-start;min-height:44px;padding:8px 12px;transition:all .3s}.time-checkbox:hover{background:#f8f9fa;border-color:#3498db}.time-checkbox label{color:#2c3e50;cursor:pointer;font-size:12px;font-weight:500;margin:0;text-align:left;white-space:nowrap}.time-checkbox input[type=checkbox]{accent-color:#3498db;cursor:pointer;flex-shrink:0;height:16px;margin:0;width:16px}.time-checkbox:nth-child(4){grid-column:1/2;grid-row:2/3}.time-checkbox:nth-child(5){grid-column:2/3;grid-row:2/3}.time-checkbox:has(input[type=checkbox]:checked){background:#3498db;border-color:#3498db}.time-checkbox:has(input[type=checkbox]:checked) label{color:#fff;font-weight:600}@supports not (selector(:has(input))){.time-checkbox input[type=checkbox]:checked+label{color:#3498db;font-weight:600}}.modal-buttons{display:flex;gap:12px;margin-top:24px}.btn-primary,.btn-secondary{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;padding:12px 16px;transition:all .3s}.btn-primary{background:#3498db;color:#fff}.btn-primary:hover:not(:disabled){background:#2980b9}.btn-primary:disabled{background:#bdc3c7;cursor:not-allowed}.btn-secondary{background:#ecf0f1;color:#2c3e50}.btn-secondary:hover{background:#d5dbdb}.supplement-options{display:flex;flex-direction:column;gap:12px}.supplement-option{border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;padding:12px;transition:all .3s}.supplement-option:hover{border-color:#3498db}.supplement-option.recommended{background:#fef9e7;border-color:#f39c12}.option-header{align-items:center;display:flex;gap:8px;margin-bottom:4px}.supplement-name{color:#2c3e50;font-weight:600}.supplement-badge{background:#f39c12;border-radius:12px;color:#fff;font-size:12px;font-weight:600;padding:2px 8px}.store-link{margin-top:8px}.store-link a{color:#3498db;font-size:12px;text-decoration:none}.store-link a:hover{text-decoration:underline}.custom-supplement-input{border:1px solid #e0e0e0;border-radius:6px;font-size:14px;margin-top:8px;padding:8px;width:100%}.welcome-modal{max-width:450px}.email-usage-notice{background:#e3f2fd;border-radius:6px;margin-top:8px;padding:12px}.email-usage-notice p{color:#1976d2;font-size:12px;line-height:1.4;margin-bottom:4px}.email-usage-notice p:last-child{color:#388e3c;font-weight:500;margin-bottom:0}.privacy-consent-label{align-items:flex-start;cursor:pointer;display:flex;gap:12px;line-height:1.4}.privacy-consent-label input[type=checkbox]{-webkit-appearance:none;appearance:none;background:#fff;border:2px solid #e0e0e0;border-radius:4px;cursor:pointer;flex-shrink:0;height:20px;margin:0;position:relative;transition:all .3s;width:20px}.privacy-consent-label input[type=checkbox]:checked{background:#3498db;border-color:#3498db}.privacy-consent-label input[type=checkbox]:checked:after{color:#fff;content:"✓";font-size:14px;font-weight:700;left:4px;position:absolute;top:0}.consent-text{color:#2c3e50;font-size:14px}.consent-text a{color:#3498db;text-decoration:none}.consent-text a:hover{text-decoration:underline}.tutorial-modal{max-width:420px}.tutorial-progress{align-items:center;display:flex;gap:12px;margin-bottom:20px}.progress-bar{background:#e0e0e0;border-radius:3px;flex:1 1;height:6px;overflow:hidden}.progress-fill{background:#3498db;height:100%;transition:width .3s}.progress-text{color:#7f8c8d;font-size:14px;font-weight:600}.tutorial-content{margin-bottom:20px}.tutorial-content p{color:#2c3e50;font-size:15px;line-height:1.6;margin-bottom:8px}.tutorial-content p:last-child{margin-bottom:0}.tutorial-name-input{margin:20px 0}.tutorial-name-input input{border:2px solid #3498db;border-radius:8px;font-size:16px;padding:12px 16px;text-align:center;transition:border-color .3s;width:100%}.tutorial-name-input input:focus{border-color:#2980b9;box-shadow:0 0 0 3px #3498db1a;outline:none}.tutorial-buttons{display:flex;gap:12px;margin-top:24px}.tutorial-buttons .advanced-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff}.tutorial-buttons .advanced-btn:hover{background:linear-gradient(135deg,#5a6fd8,#6a4190);transform:translateY(-1px)}.login-modal,.pin-modal{max-width:400px}.login-modal p,.pin-modal p{color:#7f8c8d;line-height:1.4;margin-bottom:20px;text-align:center}.pin-modal input[type=text]{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:24px;font-weight:600;letter-spacing:8px;text-align:center}.error-message{background:#fee;border:1px solid #fcc;border-radius:6px;color:#c44;font-size:14px;margin:12px 0;padding:12px;text-align:center}.login-info{margin-top:16px;text-align:center}.login-info p{color:#7f8c8d;font-size:12px;margin-bottom:8px}.resend-pin-btn{background:none;border:none;color:#3498db;cursor:pointer;font-size:14px;padding:4px 0;text-decoration:underline}.resend-pin-btn:hover:not(:disabled){color:#2980b9}.resend-pin-btn:disabled{color:#bdc3c7;cursor:not-allowed}.app-footer{background:#2c3e50;border-radius:12px;color:#fff;margin-top:20px;padding:32px 20px 20px}.footer-content{align-items:flex-start;display:flex;gap:24px;justify-content:space-between;margin-bottom:20px}.footer-section h4{color:#ecf0f1;font-size:16px;margin-bottom:12px}.footer-section p{color:#bdc3c7;font-size:14px;line-height:1.4;margin-bottom:6px}.footer-section a{color:#3498db;text-decoration:none}.footer-section a:hover{text-decoration:underline}.footer-bottom{border-top:1px solid #34495e;padding-top:16px;text-align:center}.footer-bottom p{color:#95a5a6;font-size:12px;margin-bottom:4px}.logout-section{border-top:1px solid #e0e0e0;margin-top:32px;padding-top:24px;text-align:center}.logout-section .logout-btn{background:none;border:none;color:#7f8c8d;cursor:pointer;font-size:14px;margin-bottom:8px;padding:0;text-decoration:underline;transition:color .3s}.logout-section .logout-btn:hover{color:#e74c3c}.logout-section small{color:#7f8c8d;display:block;font-size:12px;line-height:1.3}.privacy-notice{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;font-size:13px;line-height:1.4;margin-top:12px;padding:16px}.privacy-notice-header{align-items:center;color:#495057;display:flex;font-weight:600;gap:8px;margin-bottom:12px}.privacy-notice-header svg{color:#6c757d;flex-shrink:0}.privacy-notice-content p{color:#6c757d;margin-bottom:8px}.privacy-notice-content p:last-child{margin-bottom:0}.privacy-notice-content ul{color:#6c757d;margin:8px 0;padding-left:20px}.privacy-notice-content li{margin-bottom:4px}.privacy-notice-content a{color:#3498db;text-decoration:none}.privacy-notice-content a:hover{text-decoration:underline}@media (max-width:480px){.App{padding:8px}.calendar-container{padding:16px}.app-header h1{font-size:28px}.modal-content{margin:10px;padding:20px}.time-checkboxes{gap:6px;max-width:300px;padding:10px}.time-checkbox{gap:4px;min-height:40px;padding:6px 10px}.time-checkbox label{font-size:11px}.time-checkbox input[type=checkbox]{height:14px;width:14px}.footer-content{gap:20px;text-align:center}.footer-content,.footer-section{align-items:center;flex-direction:column}.footer-section{display:flex}.footer-section h4{margin-bottom:8px;text-align:center}.footer-section p{margin-bottom:4px;text-align:center}.settings-btn{font-size:12px;padding:6px 10px}}@media (max-width:380px){.calendar-day{font-size:14px}.modal-buttons{flex-direction:column}.time-checkboxes{gap:4px;max-width:280px;padding:8px}.time-checkbox{gap:3px;min-height:36px;padding:4px 8px}.time-checkbox label{font-size:10px}.time-checkbox input[type=checkbox]{height:12px;width:12px}}@media (display-mode:standalone){.modal-section input[type=date],.modal-section input[type=time]{background-color:#f8f9fa;border:1px solid #d5dbdb}.modal-section input[type=date]:focus,.modal-section input[type=time]:focus{background-color:#fff;border-color:#3498db}}
/*# sourceMappingURL=main.8241ae6d.css.map*/