.button{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s;background-color:var(--tg-theme-button-color, #2481cc);color:var(--tg-theme-button-text-color, #ffffff)}.button:hover{opacity:.9}.button:active{opacity:.8}.button:disabled{opacity:.5;cursor:not-allowed}.button.secondary{background-color:var(--tg-theme-secondary-bg-color, #f1f1f1);color:var(--tg-theme-text-color, #000000)}.button.danger{background-color:#ef4444;color:#fff}.button.full-width{width:100%}.local-dev-banner{background-color:#fff3cd;border-bottom:1px solid #ffc107;padding:12px 16px;position:sticky;top:0;z-index:1000}.banner-content{display:flex;align-items:center;gap:12px;max-width:1200px;margin:0 auto}.banner-icon{font-size:24px;flex-shrink:0}.banner-text{flex:1}.banner-text strong{display:block;margin-bottom:4px;color:#856404}.banner-text p{margin:4px 0;font-size:14px;color:#856404}.user-id-control{display:flex;gap:8px;margin-top:8px;align-items:center}.user-id-input{padding:6px 12px;border:1px solid #ccc;border-radius:4px;font-size:14px;width:150px}.banner-close{background:none;border:none;font-size:24px;cursor:pointer;color:#856404;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.banner-close:hover{opacity:.7}.sidebar-toggle{position:fixed;top:16px;left:16px;z-index:1000;background-color:var(--tg-theme-button-color, #3390ec);color:#fff;border:none;border-radius:8px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px #0003;transition:all .2s}.sidebar-toggle:hover{background-color:var(--tg-theme-button-color, #2a7bc4);transform:scale(1.05)}.sidebar-toggle-icon{font-size:24px;font-weight:700}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:999;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.sidebar{position:fixed;top:0;left:0;height:100vh;width:280px;background-color:var(--tg-theme-bg-color, #ffffff);box-shadow:2px 0 8px #0000001a;z-index:1000;transform:translate(-100%);transition:transform .3s ease;display:flex;flex-direction:column}.sidebar.sidebar-open{transform:translate(0)}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--tg-theme-secondary-bg-color, #f1f1f1)}.sidebar-header h2{margin:0;font-size:20px;font-weight:600;color:var(--tg-theme-text-color, #000)}.sidebar-close{background:none;border:none;font-size:32px;color:var(--tg-theme-text-color, #000);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.sidebar-close:hover{background-color:var(--tg-theme-secondary-bg-color, #f1f1f1)}.sidebar-nav{flex:1;overflow-y:auto;padding:8px 0}.sidebar-item{width:100%;display:flex;align-items:center;gap:12px;padding:16px 20px;background:none;border:none;text-align:left;cursor:pointer;color:var(--tg-theme-text-color, #000);transition:background-color .2s;font-size:16px}.sidebar-item:hover{background-color:var(--tg-theme-secondary-bg-color, #f1f1f1)}.sidebar-item.active{background-color:var(--tg-theme-button-color, #3390ec);color:#fff}.sidebar-item-icon{font-size:20px;flex-shrink:0}.sidebar-item-label{flex:1;word-wrap:break-word}@media (max-width: 480px){.sidebar{width:260px}.sidebar-item-label{font-size:14px}}.layout{display:flex;flex-direction:column;height:100dvh;min-height:100dvh;overflow:hidden;overscroll-behavior:none;--app-top-bar-height: 52px}.layout.with-nav{padding-bottom:calc(70px + env(safe-area-inset-bottom,0px))}.main-content{flex:1;padding:16px;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding-top:calc(var(--app-top-bar-height) + env(safe-area-inset-top,0px) + 8px);scroll-padding-bottom:96px}.top-bar{position:fixed;top:0;left:0;right:0;z-index:1001;display:grid;grid-template-columns:48px 1fr 48px;align-items:center;gap:4px;min-height:calc(var(--app-top-bar-height) + env(safe-area-inset-top,0px));padding:env(safe-area-inset-top,0px) 10px 0;background:color-mix(in srgb,var(--tg-theme-bg-color, #fff) 90%,transparent);backdrop-filter:blur(16px) saturate(160%);-webkit-backdrop-filter:blur(16px) saturate(160%);border-bottom:1px solid color-mix(in srgb,var(--tg-theme-hint-color, #ccc) 14%,transparent);box-shadow:0 4px 24px #0000000a}.top-bar-title{margin:0;min-width:0;font-size:17px;font-weight:600;letter-spacing:-.02em;line-height:1.2;text-align:center;color:var(--tg-theme-text-color, #1a1a1e);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.top-bar-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:none;border-radius:12px;background:transparent;color:var(--tg-theme-link-color, #2481cc);cursor:pointer;transition:background .15s ease,transform .12s ease;-webkit-tap-highlight-color:transparent}.top-bar-btn--leading{justify-self:start}.top-bar-btn--trailing{justify-self:end}.top-bar-btn:active{background:color-mix(in srgb,var(--tg-theme-text-color, #000) 6%,transparent);transform:scale(.96)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;align-items:center;gap:8px;min-height:calc(62px + env(safe-area-inset-bottom,0px));padding:6px 12px env(safe-area-inset-bottom,0px);background:color-mix(in srgb,var(--tg-theme-bg-color, #fff) 92%,transparent);backdrop-filter:blur(16px) saturate(160%);-webkit-backdrop-filter:blur(16px) saturate(160%);border-top:1px solid color-mix(in srgb,var(--tg-theme-hint-color, #ccc) 14%,transparent);box-shadow:0 -4px 24px #0000000a;z-index:100}.layout.form-field-focused.with-nav{padding-bottom:0}.layout.form-field-focused .main-content{padding-bottom:24px;scroll-padding-bottom:24px}.layout.form-field-focused .bottom-nav{transform:translateY(110%);pointer-events:none}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;max-width:120px;padding:8px 12px;border:none;border-radius:14px;background:none;cursor:pointer;color:var(--tg-theme-hint-color, #8e8e93);transition:color .15s ease,background .15s ease;-webkit-tap-highlight-color:transparent}.nav-item.active{color:var(--tg-theme-link-color, #2481cc);background:color-mix(in srgb,var(--tg-theme-link-color, #2481cc) 10%,transparent)}.nav-item:active{transform:scale(.98)}.nav-icon{font-size:22px;line-height:1}.nav-label{font-size:11px;font-weight:600;letter-spacing:-.01em}.input-group{margin-bottom:16px}.input-label{display:block;margin-bottom:6px;font-size:14px;font-weight:500;color:var(--tg-theme-text-color, #000000)}.input{width:100%;padding:12px;border:1px solid var(--tg-theme-secondary-bg-color, #e0e0e0);border-radius:8px;font-size:16px;background-color:var(--tg-theme-bg-color, #ffffff);color:var(--tg-theme-text-color, #000000);transition:border-color .2s}.input:focus{outline:none;border-color:var(--tg-theme-button-color, #2481cc)}.input::placeholder{color:var(--tg-theme-hint-color, #999999)}.input[type=number]{-moz-appearance:textfield}.input[type=number]::-webkit-outer-spin-button,.input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.select{width:100%;padding:12px;border:1px solid var(--tg-theme-secondary-bg-color, #e0e0e0);border-radius:8px;font-size:16px;background-color:var(--tg-theme-bg-color, #ffffff);color:var(--tg-theme-text-color, #000000);cursor:pointer}.select:focus{outline:none;border-color:var(--tg-theme-button-color, #2481cc)}.textarea{width:100%;padding:12px;border:1px solid var(--tg-theme-secondary-bg-color, #e0e0e0);border-radius:8px;font-size:16px;font-family:inherit;background-color:var(--tg-theme-bg-color, #ffffff);color:var(--tg-theme-text-color, #000000);resize:vertical;min-height:80px}.textarea:focus{outline:none;border-color:var(--tg-theme-button-color, #2481cc)}.textarea::placeholder{color:var(--tg-theme-hint-color, #999999)}.status-bar{background-color:var(--tg-theme-secondary-bg-color, #f1f1f1);border-radius:12px;padding:16px;margin:16px 0;box-shadow:0 2px 8px #0000001a}.status-bar-header{margin-bottom:12px}.status-bar-header h3{font-size:16px;font-weight:600;margin:0;color:var(--tg-theme-text-color, #000);text-align:center}.status-bar-options{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.status-option{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12px 8px;background-color:var(--tg-theme-bg-color, #fff);border:2px solid var(--tg-theme-hint-color, #e0e0e0);border-radius:8px;cursor:pointer;transition:all .2s;min-height:70px}.status-option:hover{border-color:var(--tg-theme-button-color, #3390ec);background-color:var(--tg-theme-secondary-bg-color, #f8f8f8);transform:translateY(-2px)}.status-option.selected{border-color:var(--tg-theme-button-color, #3390ec);background-color:var(--tg-theme-button-color, #3390ec);color:#fff}.status-option.selected .status-emoji{filter:brightness(0) invert(1)}.status-emoji{font-size:24px;margin-bottom:4px;display:block}.status-label{font-size:12px;font-weight:500;text-align:center;color:var(--tg-theme-text-color, #000)}.status-option.selected .status-label{color:#fff}@media (max-width: 480px){.status-bar-options{grid-template-columns:repeat(2,1fr)}.status-option{min-height:80px}.status-emoji{font-size:28px}.status-label{font-size:13px}}.home-page{max-width:600px;margin:0 auto;padding:20px}.home-loading{text-align:center;padding:40px;font-size:18px}.home-header{margin-bottom:24px}.greeting-section{display:flex;flex-direction:column;align-items:center;gap:16px}.greeting{font-size:28px;font-weight:600;margin:0;text-align:center;color:var(--tg-theme-text-color, #000)}.profile-picture-container{display:flex;justify-content:center;margin-top:8px}.home-profile-picture{width:100px;height:100px;border-radius:50%;object-fit:cover;border:3px solid var(--tg-theme-button-color, #3390ec);box-shadow:0 2px 8px #0000001a}.home-profile-picture-placeholder{width:100px;height:100px;border-radius:50%;background-color:var(--tg-theme-secondary-bg-color, #f1f1f1);border:3px solid var(--tg-theme-button-color, #3390ec);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001a}.placeholder-icon{font-size:48px;color:var(--tg-theme-hint-color, #999)}.mood-section{margin-bottom:32px;display:flex;flex-direction:column;align-items:center;gap:16px}.emotional-state-badge{display:inline-flex;align-items:center;gap:8px;background-color:var(--tg-theme-button-color, #3390ec);color:#fff;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:500}.emotional-state-badge.editable{cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.emotional-state-badge.editable:hover{background-color:var(--tg-theme-button-color-hover, #1a73b8);transform:scale(1.05)}.emotional-state-badge.editable:active{transform:scale(.98)}.edit-icon{font-size:12px;opacity:.8;margin-left:4px}.emotional-state-emoji{font-size:18px}.emotional-state-text{text-transform:capitalize}.features-section{display:flex;flex-direction:column;gap:16px}.feature-card{display:flex;align-items:center;gap:16px;background-color:var(--tg-theme-secondary-bg-color, #f1f1f1);border-radius:12px;padding:20px;cursor:pointer;transition:all .2s ease;border:2px solid transparent}.feature-card:hover{background-color:var(--tg-theme-bg-color, #fff);border-color:var(--tg-theme-button-color, #3390ec);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.feature-card:active{transform:translateY(0)}.feature-icon{font-size:32px;flex-shrink:0}.feature-content{flex:1;display:flex;flex-direction:column;gap:4px}.feature-title{font-size:18px;font-weight:600;margin:0;color:var(--tg-theme-text-color, #000)}.feature-description{font-size:14px;margin:0;color:var(--tg-theme-hint-color, #999)}.feature-arrow{font-size:20px;color:var(--tg-theme-button-color, #3390ec);flex-shrink:0}.profile-switcher{margin-bottom:16px;margin-top:16px}.profile-switcher label{display:block;margin-bottom:8px;font-size:14px;font-weight:500}.profile-info-section{margin-bottom:32px}.profile-card{background-color:var(--tg-theme-secondary-bg-color, #f1f1f1);border-radius:12px;padding:20px;margin-bottom:24px}.profile-card h2{font-size:20px;margin-bottom:16px}.profile-info{margin-bottom:16px}.profile-info p{margin-bottom:8px;font-size:16px}.profile-info strong{margin-right:8px}.profile-form{margin-top:16px}.button-group{margin-top:24px;display:flex;flex-direction:column;gap:12px}.other-profiles{margin-top:24px}.other-profiles h3{font-size:18px;margin-bottom:12px}.profile-brief-card{background-color:var(--tg-theme-secondary-bg-color, #f1f1f1);border-radius:8px;padding:12px;margin-bottom:8px;cursor:pointer;transition:background-color .2s}.profile-brief-card:hover{background-color:var(--tg-theme-hint-color, #e0e0e0)}.profile-brief-card p{margin:4px 0;font-size:14px}.profile-picture-upload{margin-bottom:20px}.profile-picture-upload label{display:block;margin-bottom:8px;font-size:14px;font-weight:500;color:var(--tg-theme-text-color, #000)}.profile-picture-preview{display:flex;flex-direction:column;align-items:center}.profile-picture-preview img{width:120px;height:120px;border-radius:50%;object-fit:cover;border:3px solid var(--tg-theme-button-color, #3390ec);margin-bottom:8px;box-shadow:0 2px 8px #0000001a}.profile-picture-placeholder{display:flex;justify-content:center}.profile-picture-upload-button{display:flex;flex-direction:column;align-items:center;justify-content:center;width:120px;height:120px;border-radius:50%;border:2px dashed var(--tg-theme-hint-color, #999);background-color:var(--tg-theme-secondary-bg-color, #f1f1f1);cursor:pointer;transition:all .2s;gap:8px;padding:20px;box-sizing:border-box}.profile-picture-upload-button:hover{border-color:var(--tg-theme-button-color, #3390ec);background-color:var(--tg-theme-bg-color, #fff)}.profile-picture-upload-button span:first-child{font-size:32px}.profile-picture-upload-button span:last-child{font-size:12px;color:var(--tg-theme-text-color, #000);text-align:center}.profile-edit-header{margin-bottom:24px;display:flex;flex-direction:column;align-items:center}.profile-picture-edit-container{display:flex;justify-content:center;margin-bottom:24px}.profile-picture-edit-preview{display:flex;flex-direction:column;align-items:center;gap:12px}.profile-picture-edit-actions{display:flex;flex-direction:column;align-items:center;gap:8px}.profile-picture-edit-placeholder{display:flex;justify-content:center}.profile-edit-section{margin-top:0}.profile-edit-fields{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.profile-picture-change-button{display:inline-block;padding:8px 16px;background-color:var(--tg-theme-button-color, #3390ec);color:#fff;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:background-color .2s;text-align:center}.profile-picture-change-button:hover{background-color:var(--tg-theme-button-color-hover, #1a73b8)}.documentation-page{max-width:600px;margin:0 auto}.documentation-page h1{font-size:24px;font-weight:600;margin-bottom:16px}.documentation-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.tab{flex:1;min-width:80px;display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;border:1px solid var(--tg-theme-secondary-bg-color, #e0e0e0);border-radius:8px;background-color:var(--tg-theme-bg-color, #ffffff);color:var(--tg-theme-text-color, #000000);cursor:pointer;transition:all .2s}.tab.active{background-color:var(--tg-theme-button-color, #2481cc);color:var(--tg-theme-button-text-color, #ffffff);border-color:var(--tg-theme-button-color, #2481cc)}.tab-icon{font-size:20px}.tab-label{font-size:12px;font-weight:500}.folder-filter,.documents-list{margin-bottom:16px}.document-card{background-color:var(--tg-theme-secondary-bg-color, #f1f1f1);border-radius:12px;padding:16px;margin-bottom:12px}.document-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.document-header h3{font-size:18px;font-weight:600;margin:0}.document-description{margin:8px 0;font-size:14px;color:var(--tg-theme-hint-color, #666666)}.document-folder,.document-date{margin:4px 0;font-size:12px;color:var(--tg-theme-hint-color, #999999)}.document-form{margin-top:16px}.document-form h2{font-size:20px;margin-bottom:16px}.date-field-optional{margin-left:6px;font-size:12px;font-weight:400;color:var(--tg-theme-hint-color, #888)}.date-field-box{position:relative;display:flex;align-items:center;gap:10px;min-height:48px;padding:0 12px 0 14px;border:1px solid var(--tg-theme-secondary-bg-color, #e0e0e0);border-radius:12px;background:var(--tg-theme-bg-color, #fff);transition:border-color .2s,box-shadow .2s}.date-field-box:focus-within{border-color:var(--tg-theme-button-color, #2481cc);box-shadow:0 0 0 3px #2481cc1f}.date-field-box--filled{border-color:#2481cc59}.date-field-icon{flex-shrink:0;display:flex;color:var(--tg-theme-button-color, #2481cc);opacity:.85}.date-field-text{position:relative;z-index:1;flex:1;font-size:16px;line-height:1.2;color:var(--tg-theme-text-color, #000);pointer-events:none;-webkit-user-select:none;user-select:none}.date-field-text--placeholder{color:var(--tg-theme-hint-color, #999)}.date-field-native{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;width:100%;height:100%;margin:0;padding:0;opacity:0;cursor:pointer;border:none;background:transparent;color:transparent;-webkit-appearance:none;-moz-appearance:none;appearance:none}.date-field-clear{position:relative;z-index:2;flex-shrink:0;width:28px;height:28px;padding:0;border:none;border-radius:50%;background:var(--tg-theme-secondary-bg-color, #eee);color:var(--tg-theme-hint-color, #666);font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.date-field-clear:active{opacity:.7}.medications-page{max-width:600px;margin:0 auto}.medications-page h1{font-size:24px;font-weight:600;margin-bottom:16px}.medications-filter{margin-bottom:16px;padding:12px;background-color:var(--tg-theme-secondary-bg-color, #f1f1f1);border-radius:8px}.medications-filter label{display:flex;align-items:center;gap:8px;font-size:14px;cursor:pointer}.medications-filter input[type=checkbox]{width:18px;height:18px;cursor:pointer}.medications-list{margin-bottom:16px}.empty-state{text-align:center;padding:40px;color:var(--tg-theme-hint-color, #999999)}.medication-card{background-color:var(--tg-theme-secondary-bg-color, #f1f1f1);border-radius:12px;padding:16px;margin-bottom:12px}.medication-card.inactive{opacity:.6}.medication-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.medication-header h3{font-size:18px;font-weight:600;margin:0}.status-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.status-badge.active{background-color:#10b981;color:#fff}.status-badge.inactive{background-color:#6b7280;color:#fff}.medication-card p{margin:8px 0;font-size:14px}.medication-card strong{margin-right:8px}.medication-notes{margin-top:12px;padding:12px;background-color:#0000000d;border-radius:6px;font-style:italic;color:var(--tg-theme-hint-color, #666666)}.medication-actions{display:flex;gap:8px;margin-top:12px;align-items:stretch}.medication-actions .button{flex:1;min-height:44px;padding:10px 8px;font-size:14px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center}.medication-form{margin-top:16px}.medication-form h2{font-size:20px;margin-bottom:16px}.medication-form .input-group{margin-bottom:14px}.medication-form .med-field-control,.medication-form .input.med-field-control,.medication-form .select.med-field-control{min-height:48px;padding:12px 14px;border-radius:12px;font-size:16px;box-sizing:border-box}.medication-form input[type=time].med-field-control{-webkit-appearance:none;-moz-appearance:none;appearance:none}.medication-date-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}.medication-date-row .input-group{margin-bottom:0}.medication-reminder-fields{display:flex;flex-direction:column;gap:12px;margin-top:4px}.medication-reminder-times{display:flex;flex-direction:column;gap:8px}.medication-time-row{display:flex;align-items:flex-end;gap:8px}.medication-time-row .input-group{flex:1;margin-bottom:0}.medication-time-remove{flex-shrink:0;width:40px;height:48px;border:1px solid var(--tg-theme-secondary-bg-color, #e0e0e0);border-radius:10px;background:var(--tg-theme-bg-color, #fff);color:var(--tg-theme-hint-color, #666);font-size:22px;line-height:1;cursor:pointer}.medication-time-hint{margin:0;font-size:12px;line-height:1.4;color:var(--tg-theme-hint-color, #888)}.medication-reminder-row{display:grid;grid-template-columns:1fr;gap:10px;align-items:start}.medication-reminder-row .input-group{margin-bottom:0;min-width:0}.medication-interval-wrap .input-group{margin-bottom:0;max-width:160px}.medications-hint{font-size:13px;color:var(--tg-theme-hint-color, #888);line-height:1.45;margin-bottom:16px}.medications-hint code{font-size:12px;background:#0000000f;padding:2px 6px;border-radius:4px}.medication-reminders{color:var(--tg-theme-text-color, #000);font-size:14px}.medication-reminder-section{margin:16px 0;padding:14px;background:var(--tg-theme-secondary-bg-color, #f5f5f5);border-radius:14px}.medication-form .button-group{display:flex;flex-direction:column;gap:10px;margin-top:8px}.medication-form .button-group button{min-height:48px}.medication-checkbox-label{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:500;margin-bottom:12px;cursor:pointer}.medication-checkbox-label input{width:18px;height:18px}.medication-timezone-note{margin:8px 0 0;font-size:13px;line-height:1.4;color:var(--tg-theme-hint-color, #666)}.medication-weekdays{display:flex;flex-wrap:wrap;gap:8px}.medication-weekday-chip{flex:1;min-width:40px;min-height:40px;padding:8px 4px;border:1px solid var(--tg-theme-secondary-bg-color, #e0e0e0);border-radius:10px;background:var(--tg-theme-bg-color, #fff);color:var(--tg-theme-text-color, #000);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.medication-weekday-chip--active{background:var(--tg-theme-button-color, #2481cc);border-color:var(--tg-theme-button-color, #2481cc);color:var(--tg-theme-button-text-color, #fff)}.medication-next-reminder{font-size:13px;color:var(--tg-theme-hint-color, #666)}@media (max-width: 380px){.medication-date-row,.medication-reminder-row{grid-template-columns:1fr}}.wellbeing-page{max-width:600px;margin:0 auto;padding:20px}.wellbeing-page h1{font-size:24px;font-weight:600;margin-bottom:16px;color:var(--tg-theme-text-color, #000)}.calendar-container{background-color:var(--tg-theme-secondary-bg-color, #f1f1f1);border-radius:12px;padding:16px;margin-bottom:24px}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.calendar-header h2{font-size:18px;font-weight:600}.month-nav{background:none;border:none;font-size:20px;cursor:pointer;color:var(--tg-theme-button-color, #2481cc);padding:4px 12px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-weekday{text-align:center;font-size:12px;font-weight:600;padding:8px 4px;color:var(--tg-theme-hint-color, #999999)}.calendar-day{aspect-ratio:1;border:1px solid var(--tg-theme-secondary-bg-color, #e0e0e0);background-color:var(--tg-theme-bg-color, #ffffff);border-radius:6px;cursor:pointer;font-size:14px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;transition:all .2s;padding:4px}.calendar-day:hover{background-color:var(--tg-theme-secondary-bg-color, #f1f1f1)}.calendar-day.selected{background-color:var(--tg-theme-button-color, #2481cc);color:var(--tg-theme-button-text-color, #ffffff);border-color:var(--tg-theme-button-color, #2481cc)}.calendar-day.has-entries{border-color:#10b981;border-width:2px}.complaint-indicator{position:absolute;bottom:2px;right:2px;width:6px;height:6px;background-color:#10b981;border-radius:50%}.emotional-state-indicator{position:absolute;top:2px;right:2px;font-size:12px;line-height:1}.calendar-day.has-emotional-state{border-color:#3390ec;border-width:2px}.emotional-state-card{background-color:var(--tg-theme-secondary-bg-color, #f1f1f1);border-radius:12px;padding:16px;margin-bottom:12px}.emotional-state-header{display:flex;align-items:center;gap:12px}.emotional-state-emoji-large{font-size:32px;line-height:1}.emotional-state-value{margin:4px 0 0;font-size:14px;text-transform:capitalize;color:var(--tg-theme-hint-color, #999999)}.calendar-day.empty{border:none;background:none;cursor:default}.selected-date-info{margin-bottom:24px}.selected-date-info h3{font-size:18px;font-weight:600;margin-bottom:12px}.empty-state{text-align:center;padding:20px;color:var(--tg-theme-hint-color, #999999)}.complaint-card{background-color:var(--tg-theme-secondary-bg-color, #f1f1f1);border-radius:12px;padding:16px;margin-bottom:12px}.complaint-description{font-size:16px;margin-bottom:12px;font-weight:500}.complaint-card p{margin:8px 0;font-size:14px}.complaint-card strong{margin-right:8px}.complaint-form{margin-top:0;display:flex;flex-direction:column;gap:16px}.complaint-form h2{font-size:20px;margin-bottom:16px;color:var(--tg-theme-text-color, #000)}.loading{text-align:center;padding:40px;font-size:18px}.entry-type-chooser{margin-top:16px;background-color:var(--tg-theme-secondary-bg-color, #f1f1f1);border-radius:12px;padding:16px}.entry-type-chooser h2{font-size:20px;margin:0 0 8px;color:var(--tg-theme-text-color, #000)}.entry-type-hint{margin:0 0 12px;font-size:14px;color:var(--tg-theme-hint-color, #999)}.health-monitoring-page{max-width:600px;margin:0 auto;padding:20px}.health-monitoring-page h1{font-size:24px;font-weight:600;margin-bottom:8px;color:var(--tg-theme-text-color, #000)}.health-monitoring-form{display:flex;flex-direction:column;gap:16px}.mood-stress-tracker-page{max-width:600px;margin:0 auto;padding:20px}.mood-stress-tracker-page h1{font-size:24px;font-weight:600;margin-bottom:8px;color:var(--tg-theme-text-color, #000)}.mood-stress-form{display:flex;flex-direction:column;gap:16px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.button-group{margin-top:8px;display:flex;flex-direction:column;gap:10px}@media (max-width: 480px){.form-row{grid-template-columns:1fr}}.source-autocomplete-hint{font-size:13px;color:var(--tg-theme-hint-color, #888);margin:0 0 10px;line-height:1.4}.source-autocomplete-field{position:relative}.source-autocomplete-list{position:absolute;left:0;right:0;top:100%;z-index:20;max-height:220px;overflow-y:auto;margin:4px 0 0;padding:4px 0;list-style:none;background:var(--tg-theme-bg-color, #fff);border:1px solid var(--tg-theme-hint-color, #ddd);border-radius:8px;box-shadow:0 4px 12px #0000001f}.source-autocomplete-option{display:block;width:100%;text-align:left;padding:10px 12px;border:none;background:transparent;font-size:15px;color:var(--tg-theme-text-color, #000);cursor:pointer;font-family:inherit}.source-autocomplete-option:hover,.source-autocomplete-option:focus-visible{background:var(--tg-theme-secondary-bg-color, #f0f0f0)}.source-autocomplete-option.selected{font-weight:600}.source-autocomplete-meta{font-size:12px;color:var(--tg-theme-hint-color, #999);margin:8px 0 0}.allergy-control-page{max-width:600px;margin:0 auto;padding:20px}.allergy-control-page h1{font-size:24px;font-weight:600;margin-bottom:8px;color:var(--tg-theme-text-color, #000)}.allergy-toolbar{margin-bottom:8px}.allergy-back-link{border:none;background:transparent;padding:0;color:var(--tg-theme-link-color, #3390ec);cursor:pointer;font:inherit;font-size:14px;text-align:left}.allergy-back-link:hover{text-decoration:underline}.allergy-section-title{font-size:18px;font-weight:600;margin:24px 0 12px;color:var(--tg-theme-text-color, #000)}.allergy-section-title:first-of-type{margin-top:0}.allergy-topic-card{background-color:var(--tg-theme-secondary-bg-color, #f1f1f1);border:2px solid transparent;border-radius:12px;margin-bottom:16px;overflow:hidden;transition:border-color .2s ease,box-shadow .2s ease}.allergy-topic-card:hover{border-color:var(--tg-theme-button-color, #3390ec);box-shadow:0 4px 12px #00000014}.allergy-topic-header{display:flex;align-items:center;gap:16px;width:100%;padding:20px;border:none;background:transparent;color:inherit;cursor:pointer;font:inherit;text-align:left}.allergy-topic-icon{font-size:32px;flex-shrink:0;line-height:1}.allergy-topic-content{flex:1;display:flex;flex-direction:column;gap:4px}.allergy-topic-title{font-size:18px;font-weight:600;color:var(--tg-theme-text-color, #000)}.allergy-topic-description{font-size:14px;line-height:1.35;color:var(--tg-theme-hint-color, #999)}.allergy-topic-arrow{font-size:20px;color:var(--tg-theme-button-color, #3390ec);flex-shrink:0}.allergy-topic-body{padding:0 20px 20px;display:flex;flex-direction:column;gap:12px}.allergy-topic-body .allergies-list{padding:0;margin-top:0}.allergy-topic-body .empty-state{padding:12px 0 0}.drug-intolerance-section{margin-top:32px;padding-top:24px;border-top:1px solid var(--tg-theme-hint-color, #e0e0e0)}.drug-intolerance-hint{font-size:14px;color:var(--tg-theme-hint-color, #999);margin-bottom:16px;line-height:1.4}.drug-intolerance-add-btn{margin-top:8px}.drug-intolerance-form{display:flex;flex-direction:column;gap:16px;padding:0}.drug-intolerance-empty{padding:24px 16px}.drug-intolerance-list{margin-bottom:12px}.cross-allergen-results{padding-bottom:4px}.cross-allergen-summary{margin:0;padding:0 20px 16px;font-size:14px;line-height:1.4;color:var(--tg-theme-hint-color, #999)}.cross-allergen-summary.standalone{padding:0 0 16px}.cross-allergen-list{padding-bottom:16px}.cross-allergen-list.standalone{padding:0 0 16px}.cross-allergen-card h3{word-break:break-word}.allergy-control-loading{text-align:center;padding:40px;font-size:18px}.empty-state{text-align:center;padding:4px 20px 20px;color:var(--tg-theme-hint-color, #999)}.allergies-list{display:flex;flex-direction:column;gap:12px;padding:0 20px 20px;margin:0;list-style:none}.allergy-card{background-color:var(--tg-theme-bg-color, #fff);border-radius:12px;padding:16px}.allergy-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.allergy-header h3{margin:0;font-size:18px;font-weight:600;color:var(--tg-theme-text-color, #000)}.allergy-severity{margin:8px 0;font-size:14px;color:var(--tg-theme-hint-color, #999);text-transform:capitalize}.allergy-notes{margin:8px 0 0;font-size:14px;color:var(--tg-theme-text-color, #000)}.allergy-form{display:flex;flex-direction:column;gap:16px}.allergy-add-btn{margin-bottom:20px}.allergy-wizard{margin-top:8px}.allergy-wizard-steps{display:flex;flex-wrap:wrap;align-items:center;gap:6px;font-size:12px;color:var(--tg-theme-hint-color, #999);margin-bottom:20px}.allergy-wizard-steps .active{color:var(--tg-theme-button-color, #3390ec);font-weight:600}.allergy-wizard-steps .done{color:var(--tg-theme-hint-color, #888)}.allergy-wizard-steps .sep{opacity:.6}.allergy-step-title{font-size:18px;font-weight:600;margin:0 0 8px;color:var(--tg-theme-text-color, #000)}.allergy-step-hint{font-size:13px;color:var(--tg-theme-hint-color, #888);margin:0 0 16px}.allergy-category-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:8px}@media (min-width: 480px){.allergy-category-grid{grid-template-columns:repeat(2,1fr)}}.allergy-category-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:4px;padding:16px 12px;border-radius:16px;border:2px solid rgba(0,0,0,.08);background:var(--tg-theme-secondary-bg-color, #f5f5f5);cursor:pointer;font:inherit;color:var(--tg-theme-text-color, #000);transition:border-color .2s,box-shadow .2s;-webkit-tap-highlight-color:transparent}.allergy-category-card:hover{border-color:var(--tg-theme-button-color, #3390ec)}.allergy-category-card.selected{border-color:var(--tg-theme-button-color, #3390ec);box-shadow:0 0 0 2px #3390ec40;background:var(--tg-theme-bg-color, #fff)}.allergy-category-icon{font-size:32px;line-height:1}.allergy-category-label{font-size:15px;font-weight:600}.allergy-category-label-ru{font-size:12px;color:var(--tg-theme-hint-color, #888)}.allergy-category-desc{font-size:11px;color:var(--tg-theme-hint-color, #999);line-height:1.3}.allergy-symptom-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:8px}.allergy-symptom-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-height:96px;padding:10px 6px;border-radius:16px;width:100%;border:2px solid rgba(0,0,0,.08);background:linear-gradient(160deg,#faf8ff,#f0edff);cursor:pointer;font:inherit;color:var(--tg-theme-text-color, #222);transition:border-color .2s,transform .15s,box-shadow .2s;-webkit-tap-highlight-color:transparent}.allergy-symptom-cell:hover{border-color:#8b5cf673}.allergy-symptom-cell.selected{border-color:var(--tg-theme-button-color, #3390ec);background:linear-gradient(160deg,#e8f4ff,#dceeff);box-shadow:0 2px 10px #3390ec33;transform:scale(1.02)}.allergy-symptom-emoji{font-size:26px;line-height:1}.allergy-symptom-ru{font-size:12px;font-weight:600;text-transform:lowercase;line-height:1.2;text-align:center}.allergy-symptom-en{font-size:10px;color:var(--tg-theme-hint-color, #888);line-height:1.2;text-align:center}.allergy-category-line{margin:4px 0 0;font-size:13px;color:var(--tg-theme-hint-color, #888)}.allergy-symptoms-line{margin:8px 0 0;font-size:13px;line-height:1.4;color:var(--tg-theme-text-color, #333)}.allergy-step-details .form-group{margin-bottom:4px}.aq-page{max-width:640px;margin:0 auto;padding:16px 20px 32px}.aq-loading{text-align:center;padding:40px}.aq-toolbar{margin-bottom:8px}.aq-back-link{font-size:14px;color:var(--tg-theme-link-color, #3390ec);text-decoration:none}.aq-back-link:hover{text-decoration:underline}.aq-page h1{font-size:22px;font-weight:600;margin:0 0 8px;color:var(--tg-theme-text-color, #000)}.aq-lead{font-size:14px;color:var(--tg-theme-hint-color, #888);margin:0 0 16px;line-height:1.45}.aq-report-card{display:flex;flex-direction:column;gap:12px;padding:14px;margin-bottom:16px;border-radius:12px;background:var(--tg-theme-secondary-bg-color, #f4f4f4)}.aq-report-title{margin:0 0 4px;font-size:16px;font-weight:600;color:var(--tg-theme-text-color, #000)}.aq-report-text{margin:0;font-size:13px;line-height:1.4;color:var(--tg-theme-hint-color, #888)}.aq-muted{color:var(--tg-theme-hint-color, #888)}.aq-entry-date-card{margin-bottom:16px;padding:14px;border-radius:12px;background:var(--tg-theme-secondary-bg-color, #f4f4f4)}.aq-entry-date-card .input-group{margin-bottom:8px}.aq-entry-date-hint{margin:0;font-size:13px;line-height:1.4;color:var(--tg-theme-hint-color, #888)}.aq-entry-date-warn{margin:10px 0 0;font-size:13px;line-height:1.4;color:#b45309;font-weight:500}.aq-step-badge{display:inline-block;font-size:13px;font-weight:500;padding:6px 12px;border-radius:999px;background:var(--tg-theme-secondary-bg-color, #f0f0f0);color:var(--tg-theme-hint-color, #666);margin-bottom:20px}.aq-section{margin-bottom:8px}.aq-section-title{font-size:18px;font-weight:600;margin:0 0 8px;color:var(--tg-theme-text-color, #000)}.aq-csms-sub{font-size:15px;font-weight:500;margin:0 0 8px;color:var(--tg-theme-text-color, #333)}.aq-instructions{font-size:14px;line-height:1.5;color:var(--tg-theme-text-color, #222);margin:0 0 16px}.aq-vas-block{padding:12px 0}.aq-vas-label{display:block;font-size:14px;font-weight:500;margin-bottom:12px}.aq-vas-row{display:flex;align-items:center;gap:10px}.aq-vas-end{font-size:13px;color:var(--tg-theme-hint-color, #888);min-width:24px}.aq-vas-slider{flex:1;height:8px;accent-color:var(--tg-theme-button-color, #e53935)}.aq-vas-output{display:block;text-align:center;font-size:28px;font-weight:700;margin-top:12px;color:var(--tg-theme-button-color, #e53935)}.aq-csms-list{display:flex;flex-direction:column;gap:20px}.aq-csms-q{margin:0 0 8px;font-size:14px;line-height:1.4}.aq-yesno{display:flex;gap:20px;flex-wrap:wrap}.aq-yesno-opt{display:inline-flex;align-items:center;gap:8px;font-size:15px;cursor:pointer}.aq-yesno-opt input{width:18px;height:18px;accent-color:var(--tg-theme-button-color, #3390ec)}.aq-table-wrap{overflow-x:auto;margin:0 -4px;-webkit-overflow-scrolling:touch}.aq-symptom-table{width:100%;min-width:520px;border-collapse:collapse;font-size:13px}.aq-symptom-table th,.aq-symptom-table td{border:1px solid var(--tg-theme-hint-color, #ddd);padding:8px 6px;text-align:center;vertical-align:middle}.aq-th-symptom,.aq-symptom-name{text-align:left!important;font-weight:500}.aq-symptom-name{font-weight:400}.aq-cat-row td{background:var(--tg-theme-secondary-bg-color, #ececec);font-weight:600;text-align:left;font-size:13px}.aq-th-sev.aq-col-none{background:#6495ed26}.aq-th-sev.aq-col-mild{background:#81c78459}.aq-th-sev.aq-col-mod{background:#ffd54f73}.aq-th-sev.aq-col-sev{background:#ef9a9a73}.aq-td-radio.aq-col-none{background:#6495ed0f}.aq-td-radio.aq-col-mild{background:#81c7841f}.aq-td-radio.aq-col-mod{background:#ffd54f26}.aq-td-radio.aq-col-sev{background:#ef9a9a26}.aq-td-radio input{width:18px;height:18px;cursor:pointer;accent-color:var(--tg-theme-button-color, #333)}.aq-fieldset{border:none;padding:0;margin:0 0 20px}.aq-legend{font-size:15px;font-weight:600;margin-bottom:10px;padding:0}.aq-radio-list{display:flex;flex-direction:column;gap:10px}.aq-radio-line{display:flex;align-items:center;gap:10px;font-size:14px;cursor:pointer}.aq-radio-line input{width:18px;height:18px;accent-color:var(--tg-theme-button-color, #3390ec)}.aq-nav{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px;margin-bottom:32px}.aq-nav button{flex:1;min-width:120px}.aq-history{border-top:1px solid var(--tg-theme-hint-color, #e0e0e0);padding-top:20px}.aq-history-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.aq-history-table{width:100%;min-width:520px;border-collapse:collapse;font-size:13px}.aq-history-table th,.aq-history-table td{border:1px solid var(--tg-theme-hint-color, #ddd);padding:8px;text-align:left;vertical-align:middle}.aq-history-table th{background:var(--tg-theme-secondary-bg-color, #f4f4f4);font-weight:600;color:var(--tg-theme-text-color, #000)}.aq-history-saved{font-size:12px;color:var(--tg-theme-hint-color, #999);font-weight:400}.aq-history-del{border:none;background:transparent;font-size:22px;line-height:1;cursor:pointer;color:var(--tg-theme-hint-color, #999);padding:4px 8px}.cycle-timeline-strip-wrap{margin:16px 0 8px}.cycle-timeline-strip{display:flex;justify-content:center;align-items:flex-end;gap:6px;padding:8px 4px 4px}.cycle-timeline-day{display:flex;flex-direction:column;align-items:center;gap:6px;min-width:36px}.cycle-timeline-pointer{width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid var(--tg-theme-text-color, #000)}.cycle-timeline-letter{font-size:13px;font-weight:500;color:var(--tg-theme-hint-color, #888);line-height:1}.cycle-timeline-capsule{position:relative;width:28px;height:48px;border-radius:14px;background:var(--tg-theme-secondary-bg-color, #e8e8ed);display:flex;align-items:center;justify-content:center}.cycle-timeline-capsule--selected{background:color-mix(in srgb,var(--tg-theme-secondary-bg-color, #e8e8ed) 70%,#fff);box-shadow:0 0 0 1px color-mix(in srgb,var(--tg-theme-hint-color, #999) 30%,transparent)}.cycle-timeline-capsule--fertility{background:repeating-linear-gradient(-45deg,#5ac8fa,#5ac8fa 3px,#7dd3fc 3px,#7dd3fc 6px)}.cycle-timeline-period{width:18px;height:18px;border-radius:50%;background:#ff6b6b;flex-shrink:0}.cycle-timeline-period--selected{width:20px;height:20px}.cycle-timeline-predicted{width:18px;height:18px;border-radius:50%;background:repeating-linear-gradient(-45deg,#ff7878f2,#ff7878f2 2px,#ffb4b4f2 2px,#ffb4b4f2 4px);flex-shrink:0}.cycle-timeline-diary{position:absolute;bottom:6px;left:50%;transform:translate(-50%);width:6px;height:6px;border-radius:50%;background:#af52de}.cycle-timeline-caption{margin:10px 0 0;text-align:center;font-size:11px;font-weight:600;letter-spacing:.04em;color:#ff6b6b}.cycle-timeline-caption--fertility{color:#5ac8fa}.cycle-timeline-legend-icon{flex-shrink:0}.cycle-timeline-capsule--legend{width:32px;height:56px}.cycle-diary-strip-wrap{position:relative;margin:0 -8px;padding:12px 0 4px;min-height:88px}.cycle-diary-strip-fade{position:absolute;top:12px;bottom:8px;width:28px;z-index:3;pointer-events:none}.cycle-diary-strip-fade--left{left:0;background:linear-gradient(to right,var(--cd-elevated, #f5f5f8) 0%,transparent 100%)}.cycle-diary-strip-fade--right{right:0;background:linear-gradient(to left,var(--cd-elevated, #f5f5f8) 0%,transparent 100%)}.cycle-diary-strip-pointer{position:absolute;top:0;left:50%;transform:translate(-50%);width:8px;height:8px;border-radius:2px;background:var(--cd-text, #1a1a1e);z-index:4;pointer-events:none}.cycle-diary-strip-scroll{display:flex;gap:10px;overflow-x:auto;overflow-y:hidden;padding:8px max(24px,calc(50% - 24px));scroll-snap-type:x mandatory;overscroll-behavior-x:contain;touch-action:pan-x;-webkit-overflow-scrolling:touch;scrollbar-width:none}.cycle-diary-strip-scroll::-webkit-scrollbar{display:none}.cycle-diary-strip-day{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:8px;min-width:44px;padding:0;border:none;background:none;cursor:pointer;scroll-snap-align:center;-webkit-tap-highlight-color:transparent}.cycle-diary-strip-weekday{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--cd-muted, #8e8e93);transition:color .12s ease}.cycle-diary-capsule{width:36px;min-height:52px;border-radius:18px;transition:box-shadow .15s ease,background .15s ease}.cycle-diary-capsule--selected{box-shadow:0 2px 10px #00000014}.cycle-diary-strip-day--selected .cycle-diary-strip-weekday{color:var(--cd-text, #1a1a1e)}.cycle-diary-day-num{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--cd-text, #1a1a1e);color:var(--cd-surface, #fff);font-size:13px;font-weight:700;line-height:1}.cycle-diary-strip-wrap .cycle-timeline-capsule{background:color-mix(in srgb,var(--cd-muted, #8e8e93) 18%,var(--cd-surface, #fff))}.cycle-diary-strip-wrap .cycle-timeline-capsule--selected{background:var(--cd-surface, #fff)}.cycle-diary-strip-wrap .cycle-timeline-period{background:linear-gradient(145deg,#ff6b8a,#ff4757);box-shadow:0 2px 8px #ff475759}.cycle-diary-strip-wrap .cycle-timeline-diary{background:var(--cd-data, #9b6dff);width:7px;height:7px;bottom:5px}.period-sheet-root{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;display:flex;align-items:flex-end;justify-content:center;overflow:hidden;overscroll-behavior:none;touch-action:none}.period-sheet-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;border:none;background:#00000073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:pointer;animation:diary-sheet-backdrop-in .28s ease-out}@keyframes diary-sheet-backdrop-in{0%{opacity:0}to{opacity:1}}.period-sheet-panel{position:relative;display:flex;flex-direction:column;width:100%;max-width:480px;max-height:min(92vh,720px);overflow:hidden;padding:8px 0 0;border-radius:20px 20px 0 0;background:var(--tg-theme-bg-color, #fff);box-shadow:0 -8px 40px #0000001f;animation:period-sheet-in .28s ease-out;touch-action:none}.diary-sheet-scroll{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;overscroll-behavior-y:contain;overscroll-behavior-x:none;-webkit-overflow-scrolling:touch;touch-action:pan-y;padding:0 20px 8px}.diary-sheet-footer{flex-shrink:0;padding:12px 20px calc(16px + env(safe-area-inset-bottom,0px));border-top:1px solid color-mix(in srgb,var(--tg-theme-hint-color, #ccc) 16%,transparent);background:var(--tg-theme-bg-color, #fff)}.diary-sheet-footer-hint{margin:0 0 10px;text-align:center;font-size:13px;color:var(--tg-theme-hint-color, #8e8e93)}.diary-sheet-save-btn.button.secondary{min-height:52px;border-radius:14px;font-size:17px;font-weight:600;color:var(--tg-theme-link-color, #2481cc);background:var(--tg-theme-secondary-bg-color, #f2f2f7)}.diary-sheet-save-btn.button.secondary:disabled{opacity:.45}@keyframes period-sheet-in{0%{transform:translateY(100%)}to{transform:translateY(0)}}.period-sheet-handle{width:36px;height:4px;margin:4px auto 16px;border-radius:2px;background:var(--tg-theme-hint-color, #c7c7cc);opacity:.6}.period-sheet-date{margin:0 0 20px;text-align:center;font-size:22px;font-weight:700;letter-spacing:-.02em;color:var(--tg-theme-text-color, #1a1a1e)}.period-sheet-card{border-radius:16px;overflow:hidden;background:var(--tg-theme-secondary-bg-color, #f5f5f8);box-shadow:0 2px 12px #0000000f}.period-sheet-banner{padding:12px 16px;font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;text-align:center;color:#fff;background:linear-gradient(135deg,#ff6b35,#ff4757)}.period-sheet-subhead{margin:0;padding:14px 16px 6px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--tg-theme-hint-color, #8e8e93);background:var(--tg-theme-bg-color, #fff);border-top:1px solid color-mix(in srgb,var(--tg-theme-hint-color, #ccc) 18%,transparent)}.period-sheet-group{background:var(--tg-theme-bg-color, #fff)}.period-sheet-group--flow{border-radius:0 0 16px 16px}.period-sheet-row{display:flex;align-items:center;justify-content:space-between;width:100%;padding:16px 18px;border:none;border-bottom:1px solid color-mix(in srgb,var(--tg-theme-hint-color, #ccc) 14%,transparent);background:transparent;font-size:17px;color:var(--tg-theme-text-color, #1a1a1e);cursor:pointer;text-align:left;transition:background .12s ease,transform .1s ease;-webkit-tap-highlight-color:transparent}.period-sheet-row:active{background:color-mix(in srgb,var(--tg-theme-text-color, #000) 4%,transparent);transform:scale(.995)}.period-sheet-row--last{border-bottom:none}.period-sheet-radio{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;border:2px solid var(--tg-theme-hint-color, #c7c7cc);transition:border-color .15s ease,background .15s ease}.period-sheet-radio--on{border-color:var(--tg-theme-button-color, #5b7cfa)}.period-sheet-radio-dot{width:12px;height:12px;border-radius:50%;background:var(--tg-theme-button-color, #5b7cfa)}.period-sheet-step{margin:20px 0 12px;text-align:center;font-size:13px;color:var(--tg-theme-hint-color, #8e8e93)}.period-sheet-root--closing .period-sheet-backdrop{animation:diary-sheet-backdrop-out .24s ease-in forwards}.period-sheet-panel--closing{animation:diary-sheet-panel-out .26s ease-in forwards}@keyframes diary-sheet-backdrop-out{0%{opacity:1}to{opacity:0}}@keyframes diary-sheet-panel-out{0%{transform:translateY(0)}to{transform:translateY(100%)}}.diary-sheet-clear{display:block;width:100%;margin:10px 0 0;padding:10px 8px;border:none;background:none;font-size:15px;color:var(--tg-theme-hint-color, #8e8e93);cursor:pointer;text-align:center;transition:opacity .15s ease}.diary-sheet-clear:active:not(:disabled){opacity:.65}.diary-sheet-clear:disabled{opacity:.4;cursor:not-allowed}.period-sheet-handle{display:block;width:36px;height:4px;margin:4px auto 16px;padding:12px 24px;border:none;border-radius:999px;background-clip:content-box;background-color:var(--tg-theme-hint-color, #c7c7cc);opacity:.6;cursor:pointer}.period-sheet-handle:disabled{cursor:not-allowed}body.diary-sheet-open .bottom-nav{transform:translateY(110%);pointer-events:none}body.diary-sheet-open .top-bar{opacity:0;pointer-events:none}.period-sheet-banner--symptoms{background:linear-gradient(135deg,#7c5cff,#5b3fd4)}.symptoms-sheet-card--scroll{max-height:none}.symptoms-sheet-card--scroll .symptoms-sheet-list{max-height:none;overflow:visible}.symptoms-sheet-list{background:var(--tg-theme-bg-color, #fff);overscroll-behavior:contain}.symptoms-sheet-row{font-size:16px}.symptoms-sheet-check{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;border:2px solid var(--tg-theme-hint-color, #c7c7cc);color:#fff;transition:border-color .15s ease,background .15s ease}.symptoms-sheet-check--on{border-color:#7c5cff;background:#7c5cff}.symptoms-sheet-nav{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px;margin:12px 0 4px}.symptoms-sheet-nav-btn{border:none;background:none;padding:8px 4px;font-size:15px;font-weight:500;color:var(--tg-theme-link-color, #5b7cfa);cursor:pointer}.symptoms-sheet-nav-btn:last-child{text-align:right}.symptoms-sheet-step{margin:0}.period-sheet-banner--sexual{background:linear-gradient(135deg,#7c5cff,#5b3fd4)}.sexual-activity-clear{display:block;width:100%;margin:8px 0 0;padding:8px;border:none;background:none;font-size:15px;color:var(--tg-theme-hint-color, #8e8e93);cursor:pointer;text-align:center}.sexual-activity-clear:active{opacity:.7}.period-sheet-banner--spotting{display:flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,#7c5cff,#5b3fd4)}.spotting-sheet-info{display:flex;align-items:center;justify-content:center;width:20px;height:20px;margin-left:4px;padding:0;border:1.5px solid rgba(255,255,255,.85);border-radius:50%;background:transparent;font-size:12px;font-weight:700;font-style:italic;font-family:Georgia,Times New Roman,serif;line-height:1;color:#fff;cursor:pointer}.spotting-sheet-info:active{opacity:.75}.spotting-sheet-clear{display:block;width:100%;margin:8px 0 0;padding:8px;border:none;background:none;font-size:15px;color:var(--tg-theme-hint-color, #8e8e93);cursor:pointer;text-align:center}.spotting-sheet-clear:active{opacity:.7}.cycle-diary-page{--cd-period: #ff5c7a;--cd-period-soft: rgba(255, 92, 122, .12);--cd-data: #9b6dff;--cd-data-soft: rgba(155, 109, 255, .12);--cd-accent: var(--tg-theme-button-color, #5b7cfa);--cd-surface: var(--tg-theme-bg-color, #fff);--cd-elevated: var(--tg-theme-secondary-bg-color, #f5f5f8);--cd-text: var(--tg-theme-text-color, #1a1a1e);--cd-muted: var(--tg-theme-hint-color, #8e8e93);--cd-radius: 16px;--cd-shadow: 0 4px 24px rgba(0, 0, 0, .06);max-width:480px;margin:0 auto;padding:0 20px 40px;min-height:calc(100vh - 80px);overflow-x:hidden}.cycle-diary-nav{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px;padding:12px 0 8px}.cycle-diary-nav-title{margin:0;font-size:16px;font-weight:600;letter-spacing:-.02em;text-align:center;color:var(--cd-text)}.cycle-diary-nav-btn{display:inline-flex;align-items:center;gap:2px;font-size:15px;font-weight:500;color:var(--cd-accent);text-decoration:none;background:none;border:none;padding:8px 0;cursor:pointer}.cycle-diary-nav-btn--end{justify-self:end}.cycle-diary-nav-icon{font-size:22px;line-height:1;margin-right:2px}.cycle-diary-nav-btn:disabled{opacity:.4;cursor:not-allowed}.cycle-diary-hero{margin:8px -4px 28px;padding:20px 12px 16px;border-radius:20px;background:linear-gradient(165deg,color-mix(in srgb,var(--cd-accent) 8%,var(--cd-surface)) 0%,var(--cd-elevated) 100%);box-shadow:var(--cd-shadow);contain:layout style}.cycle-diary-headline{margin:0 0 16px;padding:0 8px;min-height:2.4em;text-align:center;font-size:26px;font-weight:700;letter-spacing:-.03em;line-height:1.2;color:var(--cd-text);transition:opacity .18s ease}.cycle-diary-future-hint{margin:-12px 0 20px;padding:12px 14px;border-radius:12px;font-size:14px;line-height:1.4;text-align:center;color:var(--cd-muted);background:color-mix(in srgb,var(--cd-muted) 10%,var(--cd-surface))}.cycle-diary-records{contain:layout style}.cycle-diary-section{margin-top:8px}.cycle-diary-section--compact{margin-top:28px}.cycle-diary-section h2{margin:0 0 16px;font-size:20px;font-weight:700;letter-spacing:-.02em;color:var(--cd-text)}.cycle-diary-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.cycle-diary-section-header h2{margin:0}.cycle-diary-text-btn{border:none;background:none;padding:6px 12px;font-size:15px;font-weight:500;color:var(--cd-accent);border-radius:20px;cursor:pointer;transition:background .15s ease}.cycle-diary-text-btn:active{background:color-mix(in srgb,var(--cd-accent) 12%,transparent)}.cycle-diary-block{margin-bottom:20px}.cycle-diary-label{margin:0 0 8px 4px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.cycle-diary-label--period{color:var(--cd-period)}.cycle-diary-label--data{color:var(--cd-data)}.cycle-diary-card{border-radius:var(--cd-radius);overflow:hidden;box-shadow:0 1px 3px #0000000a}.cycle-diary-card--period{background:var(--cd-period-soft);border:1px solid color-mix(in srgb,var(--cd-period) 18%,transparent)}.cycle-diary-card--data{background:var(--cd-data-soft);border:1px solid color-mix(in srgb,var(--cd-data) 18%,transparent)}.cycle-diary-card--neutral{background:var(--cd-surface);border:1px solid color-mix(in srgb,var(--cd-muted) 20%,transparent);box-shadow:var(--cd-shadow)}.cycle-diary-row{display:flex;align-items:center;justify-content:space-between;width:100%;padding:16px 18px;border:none;border-bottom:1px solid color-mix(in srgb,var(--cd-muted) 12%,transparent);background:transparent;cursor:pointer;text-align:left;transition:background .15s ease}.cycle-diary-row:active:not(:disabled){background:color-mix(in srgb,var(--cd-text) 4%,transparent)}.cycle-diary-row--last{border-bottom:none}.cycle-diary-row--active .cycle-diary-row-label{font-weight:600}.cycle-diary-row-label,.cycle-diary-action{transition:color .12s ease,background .12s ease,opacity .12s ease}.cycle-diary-row:disabled{opacity:.45;cursor:not-allowed}.cycle-diary-row-label{font-size:17px;letter-spacing:-.01em;color:var(--cd-text)}.cycle-diary-row-text{display:flex;flex-direction:column;align-items:flex-start;gap:2px;min-width:0}.cycle-diary-row-subtitle{font-size:13px;font-weight:500}.cycle-diary-row-subtitle--period{color:var(--cd-period)}.cycle-diary-row-subtitle--data{color:var(--cd-data)}.cycle-diary-row-subtitle--neutral{color:var(--cd-accent)}.cycle-diary-row-hint{font-size:13px;color:var(--cd-muted)}.cycle-diary-row-badge{flex-shrink:0;padding:6px 12px;border-radius:999px;font-size:13px;font-weight:600;letter-spacing:-.01em;transition:background .15s ease,color .15s ease,transform .12s ease}.cycle-diary-row-badge--period{color:var(--cd-period);background:color-mix(in srgb,var(--cd-period) 14%,transparent)}.cycle-diary-row-badge--data{color:var(--cd-data);background:color-mix(in srgb,var(--cd-data) 14%,transparent)}.cycle-diary-row-badge--neutral{color:var(--cd-accent);background:color-mix(in srgb,var(--cd-accent) 12%,transparent)}.cycle-diary-row-badge--on.cycle-diary-row-badge--period{color:#fff;background:var(--cd-period)}.cycle-diary-row-badge--on.cycle-diary-row-badge--data{color:#fff;background:var(--cd-data)}.cycle-diary-row:active:not(:disabled) .cycle-diary-row-badge{transform:scale(.96)}.cycle-diary-row-label--accent{color:var(--cd-accent);font-weight:500}.cycle-diary-chevron{font-size:24px;font-weight:300;line-height:1;color:var(--cd-muted)}.cycle-calendar-page{--cc-period: #ff5c7a;--cc-data: #9b6dff;--cc-fertility: #5ac8fa;--cc-surface: var(--tg-theme-bg-color, #fff);--cc-elevated: var(--tg-theme-secondary-bg-color, #f5f5f8);--cc-text: var(--tg-theme-text-color, #1a1a1e);--cc-muted: var(--tg-theme-hint-color, #8e8e93);--cc-accent: var(--tg-theme-link-color, #2481cc);max-width:480px;margin:0 auto;padding:0 4px 32px}.cycle-calendar-header{margin-bottom:16px}.cycle-calendar-nav-row{display:grid;grid-template-columns:44px 1fr 44px;align-items:center;gap:8px}.cycle-calendar-month{margin:0;text-align:center;font-size:22px;font-weight:700;letter-spacing:-.03em;color:var(--cc-text)}.cycle-calendar-nav-btn{width:40px;height:40px;border:none;border-radius:12px;background:var(--cc-elevated);color:var(--cc-accent);font-size:24px;line-height:1;cursor:pointer}.cycle-calendar-nav-btn:active{transform:scale(.96)}.cycle-calendar-today-btn{display:block;margin:10px auto 0;padding:6px 14px;border:none;border-radius:999px;background:color-mix(in srgb,var(--cc-accent) 12%,transparent);color:var(--cc-accent);font-size:14px;font-weight:600;cursor:pointer}.cycle-calendar-today-btn:disabled{opacity:.4;cursor:not-allowed}.cycle-calendar-card{padding:14px 12px 16px;border-radius:20px;background:linear-gradient(165deg,color-mix(in srgb,var(--cc-accent) 6%,var(--cc-surface)) 0%,var(--cc-elevated) 100%);box-shadow:0 4px 24px #0000000f}.cycle-calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px}.cycle-calendar-weekdays span{text-align:center;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--cc-muted)}.cycle-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.cycle-calendar-pad{aspect-ratio:.82}.cycle-calendar-day{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:space-between;aspect-ratio:.82;min-height:52px;padding:6px 2px 4px;border:none;border-radius:14px;background:color-mix(in srgb,var(--cc-muted) 10%,var(--cc-surface));cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .12s ease,box-shadow .12s ease}.cycle-calendar-day:active{transform:scale(.96)}.cycle-calendar-day--selected{box-shadow:0 0 0 2px var(--cc-accent);background:var(--cc-surface)}.cycle-calendar-day--today .cycle-calendar-day-num{color:var(--cc-accent);font-weight:800}.cycle-calendar-day--period{background:linear-gradient(145deg,#ff6b8a,#ff4757)}.cycle-calendar-day--period .cycle-calendar-day-num{color:#fff}.cycle-calendar-day--predicted{background:repeating-linear-gradient(-45deg,rgba(255,120,120,calc(.35 * var(--predicted-opacity, 1))),rgba(255,120,120,calc(.35 * var(--predicted-opacity, 1))) 2px,rgba(255,180,180,calc(.35 * var(--predicted-opacity, 1))) 2px,rgba(255,180,180,calc(.35 * var(--predicted-opacity, 1))) 4px)}.cycle-calendar-day--fertility:not(.cycle-calendar-day--period){background:repeating-linear-gradient(-45deg,#5ac8fa59,#5ac8fa59 3px,#7dd3fc59 3px,#7dd3fc59 6px)}.cycle-calendar-day-num{font-size:15px;font-weight:600;line-height:1;color:var(--cc-text)}.cycle-calendar-dots{display:flex;flex-wrap:wrap;justify-content:center;gap:3px;min-height:8px;padding-bottom:2px}.cycle-calendar-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.cycle-calendar-dot--period{background:#fff;box-shadow:0 0 0 1px #ff475766}.cycle-calendar-day--period .cycle-calendar-dot--period{background:#fff}.cycle-calendar-dot--symptoms{background:var(--cc-data)}.cycle-calendar-dot--sexual{background:#5b7cfa}.cycle-calendar-dot--spotting{background:#ff9500}.cycle-calendar-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:12px 16px;margin:16px 4px}.cycle-calendar-legend-item{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:var(--cc-muted)}.cycle-calendar-legend-swatch{width:14px;height:14px;border-radius:4px}.cycle-calendar-legend-swatch--period{background:linear-gradient(145deg,#ff6b8a,#ff4757)}.cycle-calendar-legend-swatch--predicted{background:repeating-linear-gradient(-45deg,#ff7878cc,#ff7878cc 2px,#ffb4b4cc 2px,#ffb4b4cc 4px)}.cycle-calendar-legend-swatch--fertility{background:repeating-linear-gradient(-45deg,#5ac8fa,#5ac8fa 3px,#7dd3fc 3px,#7dd3fc 6px)}.cycle-calendar-detail{padding:18px 16px;border-radius:18px;background:var(--cc-surface);border:1px solid color-mix(in srgb,var(--cc-muted) 14%,transparent);box-shadow:0 2px 16px #0000000a}.cycle-calendar-detail-date{margin:0 0 10px;font-size:18px;font-weight:700;letter-spacing:-.02em;color:var(--cc-text)}.cycle-calendar-detail-list{margin:0 0 14px;padding-left:18px;color:var(--cc-text);font-size:14px;line-height:1.5}.cycle-calendar-detail-empty{margin:0 0 14px;font-size:14px;color:var(--cc-muted);line-height:1.45}.cycle-calendar-detail-actions{display:flex;flex-direction:column;gap:8px}.cycle-calendar-action{width:100%;padding:14px 16px;border:none;border-radius:14px;background:var(--cc-elevated);color:var(--cc-text);font-size:16px;font-weight:600;cursor:pointer}.cycle-calendar-action--primary{background:color-mix(in srgb,var(--cc-accent) 14%,var(--cc-surface));color:var(--cc-accent)}.cycle-calendar-action:disabled{opacity:.45;cursor:not-allowed}.cycle-calendar-action:active:not(:disabled){transform:scale(.99)}.month-calendar{margin:12px 0 20px;padding:12px;border-radius:14px;background:var(--tg-theme-bg-color, #fff);border:1px solid var(--tg-theme-secondary-bg-color, #e8e8e8)}.month-calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.month-calendar-title{font-size:17px;font-weight:600;color:var(--tg-theme-text-color, #000)}.month-calendar-nav{width:36px;height:36px;border:none;border-radius:50%;background:var(--tg-theme-secondary-bg-color, #f0f0f0);color:var(--tg-theme-button-color, #2481cc);font-size:22px;line-height:1;cursor:pointer}.month-calendar-nav:disabled{opacity:.35;cursor:not-allowed}.month-calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px}.month-calendar-weekday{text-align:center;font-size:12px;font-weight:500;color:var(--tg-theme-hint-color, #888)}.month-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.month-calendar-empty{aspect-ratio:1}.month-calendar-day{aspect-ratio:1;border:none;border-radius:50%;background:transparent;font-size:15px;color:var(--tg-theme-text-color, #000);cursor:pointer}.month-calendar-day--selected{background:var(--tg-theme-button-color, #2481cc);color:var(--tg-theme-button-text-color, #fff);font-weight:600}.month-calendar-day--disabled{color:var(--tg-theme-hint-color, #ccc);cursor:not-allowed}.month-calendar-day:not(.month-calendar-day--disabled):not(.month-calendar-day--selected):active{background:var(--tg-theme-secondary-bg-color, #eee)}.wheel-picker{position:relative;height:220px;margin:8px 0 16px;overflow:hidden}.wheel-picker-highlight{position:absolute;left:16px;right:16px;top:50%;transform:translateY(-50%);height:44px;border-radius:10px;background:color-mix(in srgb,var(--tg-theme-secondary-bg-color, #eee) 35%,transparent);border-top:1px solid color-mix(in srgb,var(--tg-theme-hint-color, #999) 25%,transparent);border-bottom:1px solid color-mix(in srgb,var(--tg-theme-hint-color, #999) 25%,transparent);pointer-events:none;z-index:0}.wheel-picker-list{position:relative;z-index:1;height:100%;overflow-y:auto;scroll-snap-type:y mandatory;padding:88px 0;-webkit-overflow-scrolling:touch}.wheel-picker-item{display:block;width:100%;padding:10px 16px;border:none;background:transparent;font-size:20px;color:var(--tg-theme-hint-color, #999);scroll-snap-align:center;scroll-snap-stop:always;cursor:grab;transition:color .12s ease,font-weight .12s ease,opacity .12s ease;-webkit-tap-highlight-color:transparent}.wheel-picker-list:active .wheel-picker-item{cursor:grabbing}.wheel-picker-item--active{color:var(--tg-theme-text-color, #000);font-weight:600}.cycle-timeline-tutorial{flex:1}.cycle-timeline-tutorial-date{margin:0 0 4px;text-align:center;font-size:17px;font-weight:600;color:var(--tg-theme-text-color, #000)}.cycle-timeline-tutorial-legend{display:flex;gap:16px;align-items:flex-start;margin:28px 8px 16px;padding:0 4px}.cycle-timeline-tutorial-copy{flex:1;min-width:0}.cycle-timeline-tutorial-legend-title{margin:0 0 6px;font-size:17px;font-weight:600;color:var(--tg-theme-text-color, #000)}.cycle-timeline-tutorial-legend-text{margin:0;font-size:15px;line-height:1.45;color:var(--tg-theme-text-color, #333)}.cycle-timeline-tutorial-disclaimer{margin:0 16px 12px;font-size:13px;line-height:1.45;text-align:center;color:var(--tg-theme-hint-color, #888)}.cycle-timeline-tutorial-progress{margin:8px 0 0;text-align:center;font-size:13px;color:var(--tg-theme-hint-color, #888)}.wh-onboarding{max-width:480px;margin:0 auto;min-height:calc(100vh - 120px);display:flex;flex-direction:column;padding:8px 16px 24px}.wh-onboarding-header{display:flex;justify-content:space-between;align-items:center;min-height:44px;margin-bottom:12px}.wh-onboarding-link{border:none;background:none;padding:8px 4px;font-size:16px;color:var(--tg-theme-link-color, #2481cc);cursor:pointer}.wh-onboarding-link:disabled{opacity:.5;cursor:not-allowed}.wh-onboarding-step{flex:1}.wh-onboarding-title{margin:0 0 8px;font-size:22px;font-weight:700;line-height:1.25;text-align:center;color:var(--tg-theme-text-color, #000)}.wh-onboarding-hint{margin:0;font-size:13px;line-height:1.45;text-align:center;color:var(--tg-theme-hint-color, #888)}.wh-factor-list{display:flex;flex-direction:column;gap:0;margin:20px 0 16px;border-top:1px solid var(--tg-theme-secondary-bg-color, #eee)}.wh-factor-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 4px;border-bottom:1px solid var(--tg-theme-secondary-bg-color, #eee);font-size:16px;color:var(--tg-theme-text-color, #000);cursor:pointer}.wh-factor-row input{width:22px;height:22px;flex-shrink:0;accent-color:var(--tg-theme-button-color, #2481cc)}.wh-onboarding-footer{margin-top:auto;padding-top:20px;display:flex;flex-direction:column;gap:12px;align-items:center}.wh-onboarding-skip{border:none;background:none;padding:8px 16px;font-size:16px;font-weight:500;color:var(--tg-theme-link-color, #2481cc);cursor:pointer}.wh-onboarding-skip:disabled{opacity:.5;cursor:not-allowed}.wh-factor-cards{display:flex;flex-direction:column;gap:12px;margin:20px 0 16px}.wh-factor-card{border-radius:12px;background:var(--tg-theme-secondary-bg-color, #f4f4f5);overflow:hidden}.wh-factor-card--active{outline:1px solid var(--tg-theme-button-color, #2481cc)}.wh-factor-card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;font-size:16px;font-weight:500;color:var(--tg-theme-text-color, #000);cursor:pointer}.wh-factor-card-header input{width:22px;height:22px;flex-shrink:0;accent-color:var(--tg-theme-button-color, #2481cc)}.wh-factor-start-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px 14px;border-top:1px solid rgba(0,0,0,.06);font-size:15px}.wh-factor-start-label{color:var(--tg-theme-hint-color, #888)}.wh-factor-start-date{position:relative;display:inline-flex;align-items:center;min-width:120px;min-height:32px;cursor:pointer}.wh-factor-start-display{position:relative;z-index:1;color:var(--tg-theme-link-color, #2481cc);font-weight:500;pointer-events:none}.wh-factor-start-date input[type=date]{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;width:100%;height:100%;margin:0;padding:0;border:none;opacity:0;background:transparent;color:transparent;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.wh-contraceptive-entry{border-top:1px solid rgba(0,0,0,.06);padding-bottom:4px}.wh-contraceptive-type-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px 0}.wh-contraceptive-select{border:none;background:transparent;font-size:15px;font-weight:500;color:var(--tg-theme-link-color, #2481cc);text-align:right;max-width:60%;cursor:pointer}.wh-add-contraceptive{display:block;width:100%;border:none;background:none;padding:12px 16px 14px;font-size:15px;font-weight:500;color:var(--tg-theme-link-color, #2481cc);text-align:left;cursor:pointer}.wh-settings-list{display:flex;flex-direction:column;gap:12px;margin:20px 0 16px}.wh-toggle-card{border-radius:12px;background:var(--tg-theme-secondary-bg-color, #f4f4f5);padding:14px 16px}.wh-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.wh-toggle-title{font-size:16px;font-weight:500;color:var(--tg-theme-text-color, #000)}.wh-toggle-description{margin:8px 0 0;font-size:13px;line-height:1.45;color:var(--tg-theme-hint-color, #888)}.wh-toggle-switch{position:relative;display:inline-block;width:51px;height:31px;flex-shrink:0}.wh-toggle-switch input{opacity:0;width:0;height:0}.wh-toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:31px;background:#ccc;transition:background .2s;cursor:pointer}.wh-toggle-slider:before{content:"";position:absolute;height:27px;width:27px;left:2px;bottom:2px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 3px #0003}.wh-toggle-switch input:checked+.wh-toggle-slider{background:#34c759}.wh-toggle-switch input:checked+.wh-toggle-slider:before{transform:translate(20px)}.womens-health-page{max-width:600px;margin:0 auto;padding:20px}.womens-health-page h1{font-size:24px;font-weight:600;margin-bottom:8px;color:var(--tg-theme-text-color, #000)}.womens-health-loading{text-align:center;padding:40px;font-size:18px}.empty-state{text-align:center;padding:40px;color:var(--tg-theme-hint-color, #999)}.records-list{display:flex;flex-direction:column;gap:12px}.record-card{background-color:var(--tg-theme-secondary-bg-color, #f1f1f1);border-radius:12px;padding:16px}.record-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.record-header h3{margin:0;font-size:18px;font-weight:600;color:var(--tg-theme-text-color, #000)}.delete-button{background:none;border:none;font-size:24px;color:var(--tg-theme-hint-color, #999);cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s}.delete-button:hover{background-color:var(--tg-theme-bg-color, #fff);color:var(--tg-theme-button-color, #3390ec)}.record-date{margin:8px 0;font-size:14px;color:var(--tg-theme-hint-color, #999)}.record-notes{margin:8px 0 0;font-size:14px;color:var(--tg-theme-text-color, #000)}.record-form{display:flex;flex-direction:column;gap:16px}.input-select{width:100%;padding:12px;border:1px solid var(--tg-theme-hint-color, #e0e0e0);border-radius:8px;font-size:16px;font-family:inherit;background-color:var(--tg-theme-bg-color, #fff);color:var(--tg-theme-text-color, #000);box-sizing:border-box;cursor:pointer}.input-select:focus{outline:none;border-color:var(--tg-theme-button-color, #3390ec)}.button-group{margin-top:8px;display:flex;flex-direction:column;gap:12px}.wh-summary-card{margin-top:8px;padding:14px;border-radius:12px;background:var(--tg-theme-secondary-bg-color, #f4f4f4);font-size:14px;line-height:1.5}.wh-summary-card h3{margin:0 0 8px;font-size:15px}.wh-summary-card p{margin:4px 0;color:var(--tg-theme-text-color, #000)}.wh-summary-muted{color:var(--tg-theme-hint-color, #888)}.womens-health-hub{max-width:480px;margin:0 auto}.wh-section-tabs{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin:0 16px 12px;padding:4px;border-radius:14px;background:var(--tg-theme-secondary-bg-color, #f2f2f7)}.wh-section-tab{padding:10px 12px;border:none;border-radius:11px;background:transparent;font-size:15px;font-weight:600;letter-spacing:-.01em;color:var(--tg-theme-hint-color, #8e8e93);cursor:pointer;transition:background .15s ease,color .15s ease,box-shadow .15s ease}.wh-section-tab--active{background:var(--tg-theme-bg-color, #fff);color:var(--tg-theme-text-color, #1a1a1e);box-shadow:0 2px 8px #0000000f}.wh-section-tab:active{transform:scale(.98)}.health-tips-page{max-width:600px;margin:0 auto;padding:20px 20px 100px}.health-tips-header{margin-bottom:32px}.health-tips-page h1{font-size:28px;font-weight:600;margin-bottom:8px;color:var(--tg-theme-text-color, #000)}.page-description{font-size:14px;color:var(--tg-theme-hint-color, #999);margin-bottom:0}.health-tips-admin-link{color:var(--tg-theme-link-color, var(--tg-theme-button-color, #3390ec));text-decoration:underline;text-underline-offset:2px}.health-tips-status,.health-tips-error{font-size:14px;margin-bottom:12px}.health-tips-error{color:#c62828}.showcase-container{display:flex;flex-direction:column;gap:16px;margin-bottom:40px}.category-showcase{background-color:var(--tg-theme-bg-color, #ffffff);border-radius:16px;overflow:hidden;box-shadow:0 2px 8px #00000014;transition:box-shadow .2s}.category-showcase:hover{box-shadow:0 4px 12px #0000001f}.category-header{display:flex;align-items:center;justify-content:space-between;padding:20px;cursor:pointer;background-color:var(--tg-theme-secondary-bg-color, #f8f9fa);border-left:4px solid;transition:background-color .2s}.category-header:hover{background-color:var(--tg-theme-secondary-bg-color, #f1f1f1)}.category-header-content{display:flex;align-items:center;gap:16px;flex:1}.category-icon-large{font-size:40px;line-height:1}.category-info{display:flex;flex-direction:column;gap:4px}.category-title{margin:0;font-size:20px;font-weight:600;color:var(--tg-theme-text-color, #000)}.category-tip-count{font-size:12px;color:var(--tg-theme-hint-color, #999);font-weight:400}.expand-icon{font-size:16px;color:var(--tg-theme-hint-color, #999);transition:transform .2s}.tips-showcase{padding:16px 20px 20px;display:flex;flex-direction:column;gap:12px;background-color:var(--tg-theme-bg-color, #ffffff)}.tip-card-showcase{display:flex;gap:12px;padding:16px;background-color:var(--tg-theme-secondary-bg-color, #f8f9fa);border-radius:12px;transition:transform .2s,box-shadow .2s}.tip-card-showcase:hover{transform:translateY(-2px);box-shadow:0 2px 8px #0000001a}.tip-preview-toggle{display:block;width:100%;margin:0;padding:0;border:none;background:none;cursor:pointer;text-align:left;font:inherit;color:inherit;-webkit-tap-highlight-color:transparent}.tip-preview-toggle:focus-visible{outline:2px solid var(--tg-theme-button-color, #3390ec);outline-offset:2px;border-radius:8px}.tip-preview-plain{margin:0;font-size:14px;line-height:1.6;color:var(--tg-theme-hint-color, #666)}.tip-preview-cta{display:inline-block;margin-top:8px;font-size:13px;font-weight:500;color:var(--tg-theme-link-color, var(--tg-theme-button-color, #3390ec))}.tip-icon{font-size:24px;line-height:1;flex-shrink:0}.tip-content-wrapper{flex:1;display:flex;flex-direction:column;gap:6px}.tip-title{margin:0;font-size:16px;font-weight:600;color:var(--tg-theme-text-color, #000)}.tip-content{font-size:14px;line-height:1.6;color:var(--tg-theme-hint-color, #666)}.tip-content-markdown>:first-child{margin-top:0}.tip-content-markdown>:last-child{margin-bottom:0}.tip-content-markdown p{margin:0 0 .65em}.tip-content-markdown p:last-child{margin-bottom:0}.tip-content-markdown ul,.tip-content-markdown ol{margin:0 0 .65em;padding-left:1.25rem}.tip-content-markdown li{margin-bottom:.35em}.tip-content-markdown strong{color:var(--tg-theme-text-color, #333);font-weight:600}.tip-content-markdown a{color:var(--tg-theme-link-color, var(--tg-theme-button-color, #3390ec));text-decoration:underline;text-underline-offset:2px}.tip-content-markdown code{font-size:.92em;padding:.1em .35em;border-radius:4px;background:#0000000f}.tip-content-markdown pre{margin:0 0 .65em;padding:10px 12px;border-radius:8px;overflow-x:auto;font-size:13px;line-height:1.45;background:var(--tg-theme-secondary-bg-color, #f0f0f0)}.tip-content-markdown pre code{padding:0;background:none}.tip-content-markdown blockquote{margin:0 0 .65em;padding-left:12px;border-left:3px solid var(--tg-theme-hint-color, #ccc);color:var(--tg-theme-hint-color, #666)}.future-topics-section{margin-top:40px;padding-top:32px;border-top:2px solid var(--tg-theme-secondary-bg-color, #f1f1f1)}.future-topics-title{font-size:22px;font-weight:600;margin:0 0 8px;color:var(--tg-theme-text-color, #000)}.future-topics-description{font-size:14px;color:var(--tg-theme-hint-color, #999);margin:0 0 24px}.future-topics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.future-topic-card{background-color:var(--tg-theme-secondary-bg-color, #f8f9fa);border-radius:12px;padding:16px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;position:relative;opacity:.8;transition:opacity .2s,transform .2s}.future-topic-card:hover{opacity:1;transform:translateY(-2px)}.future-topic-icon{font-size:32px;line-height:1}.future-topic-title{margin:0;font-size:14px;font-weight:600;color:var(--tg-theme-text-color, #000)}.future-topic-description{margin:0;font-size:12px;color:var(--tg-theme-hint-color, #999);line-height:1.4}.coming-soon-badge{position:absolute;top:8px;right:8px;background-color:var(--tg-theme-button-color, #3390ec);color:#fff;font-size:10px;font-weight:600;padding:4px 8px;border-radius:12px;text-transform:uppercase;letter-spacing:.5px}@media (max-width: 480px){.future-topics-grid{grid-template-columns:1fr}.category-header{padding:16px}.category-icon-large{font-size:32px}.category-title{font-size:18px}}.health-tip-reader-page{min-height:60vh;max-width:640px;margin:0 auto;padding:20px 20px 100px}.health-tip-reader-status{font-size:15px;color:var(--tg-theme-hint-color, #999)}.health-tip-reader-error{font-size:15px;color:#c62828;margin-bottom:16px}.health-tip-reader-article{max-width:640px;margin:0 auto;padding:16px 20px 100px;background:var(--tg-theme-bg-color, #fff);min-height:100%}.health-tip-reader-header{margin-bottom:24px}.health-tip-reader-category{display:flex;align-items:center;gap:8px;margin:0 0 12px;font-size:13px;font-weight:500;color:var(--tg-theme-hint-color, #888);text-transform:uppercase;letter-spacing:.04em}.health-tip-reader-cat-icon{font-size:18px;line-height:1}.health-tip-reader-title{margin:0;font-size:24px;font-weight:600;line-height:1.35;color:var(--tg-theme-text-color, #000)}.health-tip-reader-title-icon{margin-right:8px;font-size:28px;vertical-align:-4px}.health-tip-reader-body{font-size:17px;line-height:1.65;color:var(--tg-theme-text-color, #222)}.health-tip-reader-body.tip-content-markdown p{margin:0 0 1em}.health-tip-reader-body.tip-content-markdown p:last-child{margin-bottom:0}.health-tip-reader-body.tip-content-markdown ul,.health-tip-reader-body.tip-content-markdown ol{margin:0 0 1em;padding-left:1.35rem}.health-tip-reader-body.tip-content-markdown li{margin-bottom:.4em}.health-tip-reader-body.tip-content-markdown strong{color:var(--tg-theme-text-color, #000);font-weight:600}.health-tip-reader-body.tip-content-markdown a{color:var(--tg-theme-link-color, var(--tg-theme-button-color, #3390ec));text-decoration:underline;text-underline-offset:3px}.health-tip-reader-body.tip-content-markdown code{font-size:.92em;padding:.12em .4em;border-radius:4px;background:#0000000f}.health-tip-reader-body.tip-content-markdown pre{margin:0 0 1em;padding:14px 16px;border-radius:10px;overflow-x:auto;font-size:14px;line-height:1.5;background:var(--tg-theme-secondary-bg-color, #f0f0f0)}.health-tip-reader-body.tip-content-markdown pre code{padding:0;background:none}.health-tip-reader-body.tip-content-markdown blockquote{margin:0 0 1em;padding-left:14px;border-left:3px solid var(--tg-theme-hint-color, #ccc);color:var(--tg-theme-hint-color, #666)}.health-tip-reader-external-hint{font-size:14px;color:var(--tg-theme-hint-color, #888);margin:0 0 16px;line-height:1.45}.health-tip-reader-external-actions{margin:20px 0 8px}.health-tip-reader-open-external{display:inline-block;width:100%;box-sizing:border-box;padding:14px 18px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;background:var(--tg-theme-button-color, #3390ec);color:var(--tg-theme-button-text-color, #fff);-webkit-tap-highlight-color:transparent}.health-tip-reader-open-external:active{opacity:.92}.health-tip-reader-footer{margin-top:36px;padding-top:20px;border-top:1px solid rgba(0,0,0,.08)}.health-tip-reader-back-link{font-size:15px;font-weight:500;color:var(--tg-theme-link-color, var(--tg-theme-button-color, #3390ec));text-decoration:none}.health-tip-reader-back-link:active{opacity:.85}.health-tips-admin-page{max-width:720px;margin:0 auto;padding:20px 20px 100px}.health-tips-admin-page h1{font-size:22px;font-weight:600;margin:0;color:var(--tg-theme-text-color, #000)}.health-tips-admin-toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px}.health-tips-admin-toolbar-actions{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.health-tips-admin-card{background:var(--tg-theme-secondary-bg-color, #f8f9fa);border-radius:16px;padding:24px;max-width:420px;margin:40px auto}.health-tips-admin-intro{font-size:14px;color:var(--tg-theme-hint-color, #666);line-height:1.5;margin-bottom:16px}.health-tips-admin-intro code{font-size:12px;background:#0000000f;padding:2px 6px;border-radius:4px}.health-tips-admin-input{width:100%;box-sizing:border-box;padding:12px 14px;border-radius:10px;border:1px solid rgba(0,0,0,.12);font-size:16px;margin-bottom:12px;background:var(--tg-theme-bg-color, #fff);color:var(--tg-theme-text-color, #000)}.health-tips-admin-btn{padding:10px 16px;border-radius:10px;border:none;font-size:14px;font-weight:500;cursor:pointer;background:var(--tg-theme-secondary-bg-color, #e8e8e8);color:var(--tg-theme-text-color, #000)}.health-tips-admin-btn:disabled{opacity:.6;cursor:not-allowed}.health-tips-admin-btn.primary{background:var(--tg-theme-button-color, #3390ec);color:var(--tg-theme-button-text-color, #fff)}.health-tips-admin-btn.danger{background:#f4433626;color:#c62828}.health-tips-admin-btn.sm{padding:6px 12px;font-size:13px}.health-tips-admin-back{margin-top:20px;font-size:14px}.health-tips-admin-back a,.health-tips-admin-link-out{color:var(--tg-theme-link-color, var(--tg-theme-button-color, #3390ec));text-decoration:none}.health-tips-admin-error{color:#c62828;font-size:14px;margin:8px 0}.health-tips-admin-info{color:var(--tg-theme-hint-color, #666);font-size:14px;margin:8px 0}.health-tips-admin-muted{color:var(--tg-theme-hint-color, #999);font-size:14px}.health-tips-admin-section{margin-bottom:28px;padding:16px;background:var(--tg-theme-secondary-bg-color, #f8f9fa);border-radius:12px}.health-tips-admin-section h2{font-size:18px;margin:0 0 12px}.health-tips-admin-section h3{font-size:15px;margin:0 0 10px}.health-tips-admin-form{display:flex;flex-direction:column;gap:10px}.health-tips-admin-form label{display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--tg-theme-hint-color, #666)}.health-tips-admin-form input,.health-tips-admin-form textarea{padding:10px 12px;border-radius:8px;border:1px solid rgba(0,0,0,.12);font-size:14px;font-family:inherit;background:var(--tg-theme-bg-color, #fff);color:var(--tg-theme-text-color, #000)}.health-tips-admin-form.tip-create{margin-top:16px;padding-top:16px;border-top:1px solid rgba(0,0,0,.08)}.health-tips-admin-cat-head{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:12px}.health-tips-admin-slug{font-weight:400;font-size:14px;color:var(--tg-theme-hint-color, #999)}.health-tips-admin-tip-list{list-style:none;margin:0;padding:0}.health-tips-admin-tip-item{margin-bottom:12px;padding:12px;background:var(--tg-theme-bg-color, #fff);border-radius:10px;border:1px solid rgba(0,0,0,.06)}.tip-row-readonly{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.tip-mode-badge{font-size:11px;font-weight:600;color:var(--tg-theme-hint-color, #999);white-space:nowrap}.tip-preview{margin:6px 0 0;font-size:12px;color:var(--tg-theme-hint-color, #888);white-space:pre-wrap;font-family:inherit;line-height:1.4}.tip-row-actions{display:flex;flex-shrink:0;gap:6px}.tip-row-edit label{display:flex;flex-direction:column;gap:4px;font-size:13px;margin-bottom:8px;color:var(--tg-theme-hint-color, #666)}.tip-row-edit input,.tip-row-edit textarea{padding:8px 10px;border-radius:8px;border:1px solid rgba(0,0,0,.12);font-size:14px;width:100%;box-sizing:border-box;font-family:inherit;background:var(--tg-theme-bg-color, #fff);color:var(--tg-theme-text-color, #000)}.category-block{border-left:4px solid var(--tg-theme-button-color, #3390ec)}.activity-tracking-page{max-width:600px;margin:0 auto;padding:20px}.activity-tracking-page h1{font-size:24px;font-weight:600;margin-bottom:8px;color:var(--tg-theme-text-color, #000)}.page-description{font-size:14px;color:var(--tg-theme-hint-color, #999);margin-bottom:24px}.activity-form{display:flex;flex-direction:column;gap:24px}.form-section{display:flex;flex-direction:column;gap:16px;padding:20px;background-color:var(--tg-theme-secondary-bg-color, #f1f1f1);border-radius:12px}.section-title{font-size:18px;font-weight:600;margin:0 0 8px;color:var(--tg-theme-text-color, #000)}.nutrition-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.form-group{display:flex;flex-direction:column}.input-label{display:block;margin-bottom:8px;font-size:14px;font-weight:500;color:var(--tg-theme-text-color, #000)}.input-textarea{width:100%;padding:12px;border:1px solid var(--tg-theme-hint-color, #e0e0e0);border-radius:8px;font-size:16px;font-family:inherit;background-color:var(--tg-theme-bg-color, #fff);color:var(--tg-theme-text-color, #000);resize:vertical;box-sizing:border-box}.input-textarea:focus{outline:none;border-color:var(--tg-theme-button-color, #3390ec)}.button-group{margin-top:8px}@media (max-width: 480px){.nutrition-grid{grid-template-columns:1fr}}.no-tg-page{max-width:640px;margin:0 auto;padding:20px;color:var(--tg-theme-text-color, #000)}.no-tg-page h1{font-size:22px;font-weight:700;margin:0 0 10px}.no-tg-text{margin:0 0 16px;font-size:14px;line-height:1.5;color:var(--tg-theme-hint-color, #777)}.no-tg-card{background:var(--tg-theme-secondary-bg-color, #f4f4f4);border-radius:12px;padding:14px 16px}.no-tg-subtitle{margin:0 0 8px;font-weight:600}.no-tg-list{margin:0;padding-left:18px;color:var(--tg-theme-text-color, #000);font-size:14px;line-height:1.5}.no-tg-hint{margin:12px 0 0;font-size:13px;color:var(--tg-theme-hint-color, #777);line-height:1.4}.no-tg-actions{margin-top:16px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-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-color:var(--tg-theme-bg-color, #ffffff);color:var(--tg-theme-text-color, #000000)}html,body,#root{min-height:100%;height:100%;overflow:hidden;overscroll-behavior:none;touch-action:pan-y}#root{min-height:100dvh}:root{--tg-theme-bg-color: #ffffff;--tg-theme-text-color: #000000;--tg-theme-hint-color: #999999;--tg-theme-link-color: #2481cc;--tg-theme-button-color: #2481cc;--tg-theme-button-text-color: #ffffff;--tg-theme-secondary-bg-color: #f1f1f1}
