*,:before,:after,::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border:0 solid #e5e7eb}:before,:after{--tw-content:""}html,:host{-webkit-text-size-adjust:100%;tab-size:4;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;font-family:Noto Sans JP,system-ui,sans-serif;line-height:1.5}body{line-height:inherit;margin:0}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-feature-settings:inherit;font-variation-settings:inherit;font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:#0000;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{margin:0;padding:0;list-style:none}dialog{padding:0}input::-moz-placeholder{opacity:1;color:#9ca3af}textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.i-lucide-arrow-left{width:1em;height:1em;-webkit-mask-image:var(--svg);-webkit-mask-image:var(--svg);mask-image:var(--svg);--svg:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' width='24' height='24'%3E%3Cpath fill='none' stroke='black' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m12 19l-7-7l7-7m7 7H5'/%3E%3C/svg%3E");background-color:currentColor;display:inline-block;-webkit-mask-size:100% 100%;mask-size:100% 100%;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.i-lucide-check{width:1em;height:1em;-webkit-mask-image:var(--svg);-webkit-mask-image:var(--svg);mask-image:var(--svg);--svg:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' width='24' height='24'%3E%3Cpath fill='none' stroke='black' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");background-color:currentColor;display:inline-block;-webkit-mask-size:100% 100%;mask-size:100% 100%;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.i-lucide-chevron-left{width:1em;height:1em;-webkit-mask-image:var(--svg);-webkit-mask-image:var(--svg);mask-image:var(--svg);--svg:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' width='24' height='24'%3E%3Cpath fill='none' stroke='black' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m15 18l-6-6l6-6'/%3E%3C/svg%3E");background-color:currentColor;display:inline-block;-webkit-mask-size:100% 100%;mask-size:100% 100%;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.i-lucide-chevron-right{width:1em;height:1em;-webkit-mask-image:var(--svg);-webkit-mask-image:var(--svg);mask-image:var(--svg);--svg:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' width='24' height='24'%3E%3Cpath fill='none' stroke='black' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m9 18l6-6l-6-6'/%3E%3C/svg%3E");background-color:currentColor;display:inline-block;-webkit-mask-size:100% 100%;mask-size:100% 100%;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.i-lucide-pencil{width:1em;height:1em;-webkit-mask-image:var(--svg);-webkit-mask-image:var(--svg);mask-image:var(--svg);--svg:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' width='24' height='24'%3E%3Cpath fill='none' stroke='black' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M21.174 6.812a1 1 0 0 0-3.986-3.987L3.842 16.174a2 2 0 0 0-.5.83l-1.321 4.352a.5.5 0 0 0 .623.622l4.353-1.32a2 2 0 0 0 .83-.497zM15 5l4 4'/%3E%3C/svg%3E");background-color:currentColor;display:inline-block;-webkit-mask-size:100% 100%;mask-size:100% 100%;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.i-lucide-plus{width:1em;height:1em;-webkit-mask-image:var(--svg);-webkit-mask-image:var(--svg);mask-image:var(--svg);--svg:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' width='24' height='24'%3E%3Cpath fill='none' stroke='black' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M5 12h14m-7-7v14'/%3E%3C/svg%3E");background-color:currentColor;display:inline-block;-webkit-mask-size:100% 100%;mask-size:100% 100%;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.i-lucide-refresh-cw{width:1em;height:1em;-webkit-mask-image:var(--svg);-webkit-mask-image:var(--svg);mask-image:var(--svg);--svg:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' width='24' height='24'%3E%3Cg fill='none' stroke='black' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'%3E%3Cpath d='M3 12a9 9 0 0 1 9-9a9.75 9.75 0 0 1 6.74 2.74L21 8'/%3E%3Cpath d='M21 3v5h-5m5 4a9 9 0 0 1-9 9a9.75 9.75 0 0 1-6.74-2.74L3 16'/%3E%3Cpath d='M8 16H3v5'/%3E%3C/g%3E%3C/svg%3E");background-color:currentColor;display:inline-block;-webkit-mask-size:100% 100%;mask-size:100% 100%;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.i-lucide-trash-2{width:1em;height:1em;-webkit-mask-image:var(--svg);-webkit-mask-image:var(--svg);mask-image:var(--svg);--svg:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' width='24' height='24'%3E%3Cpath fill='none' stroke='black' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M10 11v6m4-6v6m5-11v14a2 2 0 0 1-2 2H7a2 2 0 0 1-2-2V6M3 6h18M8 6V4a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2v2'/%3E%3C/svg%3E");background-color:currentColor;display:inline-block;-webkit-mask-size:100% 100%;mask-size:100% 100%;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.i-lucide-x{width:1em;height:1em;-webkit-mask-image:var(--svg);-webkit-mask-image:var(--svg);mask-image:var(--svg);--svg:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' width='24' height='24'%3E%3Cpath fill='none' stroke='black' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M18 6L6 18M6 6l12 12'/%3E%3C/svg%3E");background-color:currentColor;display:inline-block;-webkit-mask-size:100% 100%;mask-size:100% 100%;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.visible{visibility:visible}.relative{position:relative}.block{display:block}.flex{display:flex}.table{display:table}.hidden{display:none}.transform{transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.flex-wrap{flex-wrap:wrap}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{--font-main:"Noto Sans JP", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-english:"Outfit", var(--font-main);--color-text-main:var(--ink);--color-text-sub:var(--ink-soft);--color-white:var(--surface);--color-shadow:#373d491f;--color-border:var(--line);--transition-fast:.16s ease;--transition-normal:.24s cubic-bezier(.2, .8, .2, 1)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html{background:var(--app-bg)}body{min-height:100vh;color:var(--ink);background:var(--preg-bg-grad);font-family:var(--font-main);transition:background var(--transition-normal), color var(--transition-normal);justify-content:center;align-items:flex-start;display:flex}button,input,select,textarea{font:inherit}button,a{touch-action:manipulation}body.route-pending #app{visibility:hidden}.app-launch-splash{z-index:1000;background:var(--base);opacity:1;visibility:visible;pointer-events:none;width:min(100%,480px);height:100dvh;margin-inline:auto;transition:opacity .42s,visibility .42s;position:fixed;inset:0;overflow:hidden}.app-launch-splash img{-o-object-fit:cover;object-fit:cover;width:100%;height:100%;display:block}body:not(.route-pending) .app-launch-splash{opacity:0;visibility:hidden}.is-hidden,[hidden]{display:none!important}body.site-page{background:linear-gradient(#fffdf9d1,#fffdf9fa),linear-gradient(145deg,#f6faf8 0%,#fff8f1 58%,#eef4fb 100%);display:block}.site-shell{width:100%;min-height:100vh}.site-nav,.portal-hero,.page-heading,.article-list,.admin-panel,.cms-auth,.cms-layout,.cms-posts,.cms-editor{width:min(1120px,100% - 32px);margin:0 auto}.site-nav{border-bottom:1px solid #2f313714;justify-content:space-between;align-items:center;gap:20px;min-height:72px;display:flex}.site-brand{color:var(--ink);font-family:var(--font-english);font-size:1.08rem;font-weight:800;text-decoration:none}.site-links{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.site-links a,.site-links button{min-height:38px;color:var(--ink-soft);cursor:pointer;transition:color var(--transition-fast), background var(--transition-fast), border var(--transition-fast);background:0 0;border:1px solid #0000;border-radius:8px;align-items:center;padding:0 12px;font-size:.92rem;font-weight:800;text-decoration:none;display:inline-flex}.portal-hero{align-content:center;min-height:calc(100vh - 72px);padding:84px 0 120px;display:grid;position:relative}.portal-hero:after{content:"";aspect-ratio:1;opacity:.18;pointer-events:none;background:linear-gradient(145deg,#fff6,#fff0);width:min(360px,42vw);position:absolute;top:52%;right:0;transform:translateY(-50%)}.site-kicker{color:var(--child-primary-hover);font-family:var(--font-english);letter-spacing:0;text-transform:uppercase;margin-bottom:14px;font-size:.78rem;font-weight:800}.portal-hero h1,.page-heading h1,.article-detail h1{max-width:820px;color:var(--ink);letter-spacing:0;font-size:clamp(2.25rem,6vw,4.55rem);line-height:1.08}.portal-hero p:not(.site-kicker),.page-heading p:not(.site-kicker),.article-excerpt,.article-date,.article-body,.admin-panel p{max-width:660px;color:var(--ink-soft);font-size:1.02rem;line-height:1.9}.site-actions{flex-wrap:wrap;gap:12px;margin-top:28px;display:flex}.primary-link,.secondary-link,.cms-submit,.cms-reset{min-height:44px;transition:transform var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast), border var(--transition-fast), color var(--transition-fast);border-radius:8px;justify-content:center;align-items:center;padding:0 18px;font-weight:800;text-decoration:none;display:inline-flex}.primary-link,.cms-submit{color:#fff;background:var(--ink);cursor:pointer;border:0;box-shadow:0 12px 22px #2f31372e}.primary-link:hover,.cms-submit:hover{background:#1f2228;transform:translateY(-1px)}.secondary-link,.cms-reset{border:1px solid var(--line);color:var(--ink);background:rgba(var(--surface-rgb), .8)}.secondary-link:hover,.cms-reset:hover{border-color:var(--preg-primary);color:var(--preg-primary-hover)}.content-page{background:#fffdf9}.page-heading{padding:58px 0 34px}.article-list{gap:18px;padding-bottom:84px;display:grid}.article-list article,.admin-panel,.cms-auth,.cms-editor,.cms-posts{background:rgba(var(--surface-rgb), .88);border:1px solid var(--line);max-width:760px;box-shadow:var(--shadow-soft);border-radius:8px;padding:26px}.article-list span{color:var(--child-primary-hover);font-size:.78rem;font-weight:800}.article-list h2,.admin-panel h2,.cms-toolbar h2{color:var(--ink);letter-spacing:0;margin:8px 0;font-size:1.45rem;line-height:1.35}.article-list p{color:var(--ink-soft);line-height:1.8}.article-card{gap:10px;display:grid}.article-card h2 a{color:inherit;text-decoration:none}.article-card h2 a:hover{color:var(--preg-primary-hover)}.category-filter,.pagination{flex-wrap:wrap;gap:8px;margin-top:24px;display:flex}.category-filter a,.pagination a,.category-link{border:1px solid var(--line);min-height:36px;color:var(--ink-soft);background:var(--surface);border-radius:8px;align-items:center;padding:0 12px;font-size:.9rem;font-weight:800;text-decoration:none;display:inline-flex}.category-filter a:hover,.category-filter a.active,.pagination a:hover,.pagination a.active,.category-link:hover{color:var(--child-primary-hover);background:var(--child-primary-light);border-color:#5ca79573}.article-detail{width:min(840px,100% - 32px);margin:0 auto;padding:62px 0 92px}.article-detail h1{margin:18px 0 12px}.article-body{border-top:1px solid var(--line);gap:14px;margin-top:18px;padding-top:20px;display:grid}.empty-state{color:var(--ink-soft)}.admin-page{background:var(--app-bg)}.admin-heading .site-kicker{color:var(--preg-primary-hover)}.cms-auth,.cms-editor,.cms-posts{gap:16px;margin-bottom:80px;display:grid}.cms-auth h1,.cms-auth h2{color:var(--ink);letter-spacing:0;line-height:1.15}.cms-auth p,.cms-user,.cms-message{color:var(--ink-soft);line-height:1.7}.cms-image-preview{aspect-ratio:16/9;border:1px solid var(--line);-o-object-fit:cover;object-fit:cover;border-radius:12px;width:min(320px,100%);margin-top:8px}.cms-message{min-height:24px;font-weight:800}.cms-login-actions,.cms-toolbar-actions{flex-wrap:wrap;gap:10px;display:flex}.cms-login-actions button,.cms-login-actions a{cursor:pointer;border:0}.cms-login-actions .google-login{background:#276ef1}.cms-login-actions .line-login{background:#06c755}.cms-layout{grid-template-columns:minmax(0,1fr) minmax(320px,.8fr);align-items:start;gap:24px;padding-bottom:80px;display:grid}.cms-editor,.cms-posts{max-width:none}.cms-editor label{color:var(--ink-soft);gap:7px;font-size:.88rem;font-weight:800;display:grid}.cms-toolbar{justify-content:space-between;align-items:center;gap:12px;display:flex}.cms-fields{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.cms-post-list{gap:12px;margin-top:6px;display:grid}.cms-group{border:1px solid var(--line);background:rgba(var(--surface-rgb,255, 255, 255), .4);border-radius:12px;gap:2px;padding:10px 14px 14px;display:grid}.cms-group-head{align-items:baseline;gap:10px;padding-bottom:4px;display:flex}.cms-group-head h3{color:var(--main-deep,var(--ink));margin:0;font-size:1.08rem}.cms-group-count{color:var(--soft-text,var(--ink));font-size:.8rem;font-weight:700}.cms-group .cms-post-row:first-of-type{border-top:none}.cms-post-row{border-top:1px solid var(--line);grid-template-columns:minmax(0,1fr) auto;gap:14px;padding:16px 0;display:grid}.cms-post-row:first-child{border-top:0}.cms-post-row h3{color:var(--ink);letter-spacing:0;margin:8px 0 4px;font-size:1rem;line-height:1.35}.cms-post-row p{color:var(--ink-soft);font-size:.88rem;line-height:1.6}.cms-status{border-radius:999px;align-items:center;min-height:24px;padding:0 10px;font-size:.75rem;font-weight:800;display:inline-flex}.cms-status.published{color:#276f60;background:#e5f6f0}.cms-status.draft{color:#7c5d16;background:#fff2cd}.cms-row-actions{flex-wrap:wrap;place-content:flex-start flex-end;gap:8px;display:flex}.cms-status-select select{border:1px solid var(--line);background:var(--surface);min-height:36px;color:var(--ink);cursor:pointer;border-radius:8px;padding:0 8px;font-weight:700}.admin-import-button{cursor:pointer;position:relative}.admin-import-button input[disabled]{cursor:progress}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.cms-row-actions button{border:1px solid var(--line);background:var(--surface);min-height:36px;color:var(--ink);cursor:pointer;border-radius:8px;padding:0 11px;font-weight:800}.cms-row-actions button:hover{border-color:var(--preg-primary);color:var(--preg-primary-hover)}.cms-row-actions .admin-icon-btn{border:1px solid var(--line);width:38px;height:38px;min-height:38px;color:var(--ink);background:var(--surface);cursor:pointer;border-radius:8px;place-items:center;padding:0;transition:border-color .16s,color .16s,background .16s;display:inline-grid}.cms-row-actions .admin-icon-btn>span{width:18px;height:18px}.cms-row-actions .admin-icon-btn:hover{border-color:var(--preg-primary);color:var(--preg-primary-hover);background:#fff8f4}.cms-row-actions .admin-icon-btn.danger{color:#b13e45;border-color:#c441483d}.cms-row-actions .admin-icon-btn.danger:hover{color:#fff;background:#c44148;border-color:#c44148}#app{background:linear-gradient(180deg, #ffffffb3, #ffffffdb), var(--preg-bg-grad);border-left:1px solid #fffc;border-right:1px solid #2f313714;flex-direction:column;width:100%;max-width:480px;min-height:100vh;display:flex;position:relative;overflow:hidden;box-shadow:0 26px 80px #2f31372e}#app:before{content:"";pointer-events:none;background:linear-gradient(135deg,#ee76642e,#5ca7951f);height:180px;position:absolute;inset:0 0 auto}.user-selector-bar{z-index:110;color:#ffffffeb;background:#2f3137f5;justify-content:space-between;align-items:center;gap:10px;min-height:48px;padding:8px 14px;font-size:.75rem;display:flex;position:relative}.user-indicator{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-weight:700;overflow:hidden}.user-indicator span{color:#ffd6cc;font-weight:800}body.childcare-active .user-indicator span{color:#bfe7dc}.user-toggles{flex-wrap:wrap;justify-content:flex-end;gap:5px;display:flex}.user-toggle-btn{color:#ffffffdb;background:rgba(var(--surface-rgb), .08);cursor:pointer;min-height:28px;transition:background var(--transition-fast), color var(--transition-fast), transform var(--transition-fast);border:1px solid #ffffff24;border-radius:8px;padding:0 8px;font-size:.7rem;font-weight:800}.user-toggle-btn.secondary{background:rgba(var(--surface-rgb), .12)}.user-toggle-btn.danger{color:#fff;background:#c44148d1}.user-toggle-btn:hover,.user-toggle-btn.active{color:#fff;background:var(--preg-primary)}body.childcare-active .user-toggle-btn:hover,body.childcare-active .user-toggle-btn.active{background:var(--child-primary)}.app-auth-required .app-header,.app-auth-required .app-main,.app-auth-required .app-footer,.app-registration-required .app-header,.app-registration-required .app-main,.app-registration-required .app-footer{display:none}.app-auth-screen{width:100%;min-height:100dvh;padding:calc(env(safe-area-inset-top) + 18px) 18px calc(env(safe-area-inset-bottom) + 18px);background:linear-gradient(180deg, #fbfaf7db, #fbfaf7f5), var(--preg-bg-grad);place-items:center;display:grid}.app-login-panel{width:min(100%,440px)}.app-login-panel .login-required-card h1{color:var(--main-deep);letter-spacing:0;margin:10px 0 12px;font-size:1.8rem;line-height:1.25}.app-registration-panel{width:min(100%,460px)}.app-registration-panel .registration-card h1{color:var(--main-deep);letter-spacing:0;font-size:1.7rem;line-height:1.25}.login-required-panel,.registration-panel{z-index:1;text-align:center;flex:1;place-items:center;padding:28px;display:grid;position:relative}.login-required-card,.registration-card{border:1px solid var(--line);background:rgba(var(--surface-rgb), .88);width:100%;box-shadow:var(--shadow);border-radius:8px;gap:14px;padding:26px 22px;display:grid}.registration-progress{justify-content:space-between;align-items:center;gap:12px;display:flex}.registration-progress-dots{align-items:center;gap:6px;display:inline-flex}.registration-progress-dot{background:var(--line-strong);border-radius:999px;width:22px;height:6px;transition:background .2s,width .2s}.registration-progress-dot.active{background:var(--preg-primary)}.registration-progress-dot.current{background:var(--preg-primary-hover);width:30px}.registration-progress-label{color:var(--ink-soft);font-size:.74rem;font-weight:800}.registration-back-link{color:var(--ink-soft);background:0 0;border:0;justify-self:center;margin-top:2px;font-weight:800}.registration-back-link:hover{color:var(--ink)}.registration-card input.ng-invalid.ng-touched,.settings-edit-form input.ng-invalid.ng-touched,.settings-add-child-form input.ng-invalid.ng-touched{border-color:#c44148;box-shadow:0 0 0 3px #c441481f}.login-required-card h2,.registration-card h2{color:var(--ink);letter-spacing:0;font-size:1.35rem;line-height:1.25}.login-required-card p,.registration-card p{color:var(--ink-soft);line-height:1.7}.login-actions{gap:10px;display:grid}.login-provider-btn{color:#fff;cursor:pointer;min-height:48px;transition:transform var(--transition-fast), box-shadow var(--transition-fast), filter var(--transition-fast);border:0;border-radius:8px;padding:0 18px;font-weight:800}.login-provider-btn:hover{box-shadow:var(--shadow-soft);filter:brightness(.96);transform:translateY(-1px)}.login-provider-btn.google-login{background:#276ef1}.registration-card{text-align:left}.registration-card h2,.registration-card p{text-align:center}.registration-card label{color:var(--ink-soft);gap:6px;font-size:.85rem;font-weight:800;display:grid}.registration-message{min-height:22px;font-weight:800;color:var(--preg-primary-hover)!important}.app-header{z-index:100;background:rgba(var(--surface-rgb), .76);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-bottom:1px solid #2f313714;justify-content:space-between;align-items:center;gap:12px;min-height:84px;padding:18px 20px 14px;display:flex;position:sticky;top:0}.logo{grid-template-columns:36px minmax(0,1fr);align-items:center;gap:10px;min-width:0;display:grid}.logo-icon{background:var(--surface);width:36px;height:36px;box-shadow:var(--shadow-soft);border-radius:8px;place-items:center;font-size:1.2rem;display:grid}.logo-text{color:var(--ink);letter-spacing:0;font-size:1.22rem;font-weight:800;line-height:1}.mode-selector{border:1px solid var(--line);background:rgba(var(--surface-rgb), .7);border-radius:8px;grid-template-columns:1fr 1fr;gap:4px;min-width:154px;padding:4px;display:grid;box-shadow:inset 0 1px #ffffffe6}.mode-btn{min-height:34px;color:var(--ink-soft);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);background:0 0;border:0;border-radius:6px;font-size:.84rem;font-weight:700}.mode-btn.active{color:#fff;background:var(--preg-primary);box-shadow:0 8px 18px #ee766438}body.childcare-active .mode-btn.active{background:var(--child-primary);box-shadow:0 8px 18px #5ca79538}.app-main{z-index:1;flex:1;padding:18px 18px 96px;position:relative}.mode-view{opacity:0;display:none;transform:translateY(8px)}.mode-view.active{animation:.26s forwards slideUpFade;display:block}.app-section-view{opacity:0;display:none;transform:translateY(8px)}.app-section-view.active{animation:.26s forwards slideUpFade;display:block}.card{background:rgba(var(--surface-rgb), .86);box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);transition:transform var(--transition-fast), box-shadow var(--transition-fast), border var(--transition-fast);border:1px solid #2f313714;border-radius:8px;margin-bottom:16px;padding:20px}.card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.card-title{color:var(--ink);letter-spacing:0;align-items:center;gap:7px;margin-bottom:14px;font-size:.98rem;font-weight:700;line-height:1.3;display:flex}.card-title-row{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.chart-controls{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.card-title-row .card-title{margin-bottom:0}.compact-select{border:1px solid var(--line);max-width:112px;min-height:38px;color:var(--ink);background:var(--surface);border-radius:12px;padding:0 10px;font-size:.82rem;font-weight:800}.card-title:before{content:"";background:var(--preg-primary);border-radius:999px;width:8px;height:8px;box-shadow:0 0 0 5px #ee76641f}body.childcare-active .card-title:before{background:var(--child-primary);box-shadow:0 0 0 5px #5ca7951f}.countdown-card{text-align:center;background:linear-gradient(#ffffffeb,#fff5f0e6),linear-gradient(135deg,#ee76641f,#f2b85b24);justify-items:center;display:grid}.countdown-display{margin:8px 0 4px}.days-left{color:var(--preg-primary-hover);font-family:var(--font-english);font-size:4rem;font-weight:800;line-height:.95}.days-unit{color:var(--ink-soft);margin-left:4px;font-size:1.1rem;font-weight:700}.gestation-info{align-items:center;gap:8px;margin:6px 0 4px;display:inline-flex}.gestation-week{color:var(--preg-primary-hover);font-size:1.02rem;font-weight:900}.gestation-trimester{color:var(--preg-primary-hover);background:var(--preg-primary-light);border-radius:999px;padding:2px 10px;font-size:.74rem;font-weight:800}.progress-info{color:var(--ink-soft);margin-bottom:12px;font-size:.9rem;line-height:1.7}.preg-log-recorded-note{color:#9a6a1f;background:#fff5e4;border-radius:10px;margin-top:6px;padding:7px 10px;font-size:.74rem;font-weight:700;line-height:1.5;display:block}.preg-history-card{gap:12px;display:grid}.preg-log-list{gap:10px;margin:0;padding:0;list-style:none;display:grid}.preg-log-item{border:1px solid var(--line);background:var(--surface);border-radius:14px;grid-template-columns:36px minmax(0,1fr) auto;align-items:center;gap:11px;padding:11px 12px;transition:opacity .16s;display:grid}.preg-log-item.deleting{opacity:.5}.preg-log-rating{text-align:center;font-size:1.5rem;line-height:1}.preg-log-body{gap:2px;min-width:0;display:grid}.preg-log-head{align-items:baseline;gap:8px;display:flex}.preg-log-head strong{color:var(--ink);font-size:.9rem}.preg-log-weight{color:var(--preg-primary-hover);font-size:.8rem;font-weight:800}.preg-log-body p{color:var(--ink-soft);word-break:break-word;font-size:.82rem;line-height:1.5}.preg-log-body small{color:var(--muted);font-size:.72rem;font-weight:700}.progress-bar-container{background:#ee76641f;border-radius:999px;width:100%;height:9px;overflow:hidden}.progress-bar{border-radius:inherit;background:linear-gradient(90deg, var(--preg-primary), var(--preg-accent));height:100%;transition:width .8s}.birth-trigger-btn,.submit-btn{color:#fff;background:var(--preg-primary-hover);cursor:pointer;min-height:46px;transition:transform var(--transition-fast), background var(--transition-fast), box-shadow var(--transition-fast);border:0;border-radius:8px;font-weight:700;box-shadow:0 12px 22px #ee76643d}.birth-trigger-btn{margin-top:16px;padding:0 18px}.birth-trigger-btn:hover,.submit-btn:hover{background:var(--preg-primary-hover);filter:brightness(.94);transform:translateY(-1px)}.submit-btn{width:100%;padding:0 16px;font-size:1rem}body.childcare-active .submit-btn{background:var(--child-primary-hover);box-shadow:0 12px 22px #5ca7953d}body.childcare-active .submit-btn:hover{background:var(--child-primary-hover);filter:brightness(.94)}.form-group{margin-bottom:15px}.form-group label,label{color:var(--ink-soft)}.form-group label{margin-bottom:7px;font-size:.84rem;font-weight:700;display:block}input[type=number],input[type=text],input[type=date],input[type=file],select,textarea{border:1px solid var(--line);width:100%;color:var(--ink);background:rgba(var(--surface-rgb), .86);transition:border var(--transition-fast), background var(--transition-fast), box-shadow var(--transition-fast);border-radius:8px;padding:12px 14px;font-size:.95rem}textarea{resize:vertical}input:focus,select:focus,textarea:focus{background:var(--surface);border-color:#ee766494;outline:0;box-shadow:0 0 0 4px #ee76641f}body.childcare-active input:focus,body.childcare-active select:focus,body.childcare-active textarea:focus{border-color:#5ca79594;box-shadow:0 0 0 4px #5ca7951f}.rating-selector{grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;margin:8px 0;display:grid}.rating-btn{aspect-ratio:1;border:1px solid var(--line);background:rgba(var(--surface-rgb), .76);cursor:pointer;transition:transform var(--transition-fast), background var(--transition-fast), border var(--transition-fast), box-shadow var(--transition-fast);border-radius:8px;font-size:1.45rem}.rating-btn:hover{background:var(--surface);transform:translateY(-1px)}.rating-btn.active{background:var(--preg-primary-light);border-color:#ee766473;box-shadow:0 8px 18px #ee766429}.checklist{gap:10px;list-style:none;display:grid}.checklist li{border:1px solid var(--milk-line);background:rgba(var(--surface-rgb), .82);border-radius:16px;align-items:stretch;display:flex;overflow:hidden}.checklist-item{flex:1;min-width:0}.checklist-delete{flex:none;align-self:center;margin-right:10px}.checklist-card{gap:18px;display:grid}.checklist-heading-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.checklist-add-form{gap:8px;display:flex}.checklist-add-form input{border:1px solid var(--milk-line);min-width:0;min-height:44px;color:var(--ink);background:var(--surface);border-radius:12px;flex:1;padding:0 12px}.checklist-add-form .mini-action-btn{flex:none}.checklist-heading{justify-content:space-between;align-items:flex-start;gap:14px;display:flex}.checklist-heading>div{gap:5px;display:grid}.checklist-heading p{color:var(--soft-text);font-size:.78rem;font-weight:700;line-height:1.6}.checklist-count{min-width:62px;min-height:34px;color:var(--main-deep);background:var(--main-soft);font-family:var(--font-english);border-radius:999px;justify-content:center;align-items:center;padding:0 12px;font-size:.84rem;font-weight:900;display:inline-flex}.checklist-progress{background:var(--main-soft);border-radius:16px;gap:8px;padding:13px 14px;display:grid}.checklist-progress-copy{color:var(--main-deep);justify-content:space-between;align-items:center;gap:12px;font-size:.78rem;font-weight:800;display:flex}.checklist-progress-copy strong{font-family:var(--font-english);font-size:.9rem}.checklist-progress-track{background:rgba(var(--surface-rgb), .78);border-radius:999px;height:8px;overflow:hidden}.checklist-progress-track span{border-radius:inherit;background:linear-gradient(90deg, var(--main), var(--preg-accent));height:100%;transition:width .3s;display:block}.checklist-item{cursor:pointer;grid-template-columns:28px minmax(0,1fr);align-items:center;gap:12px;min-height:68px;padding:12px 14px;display:grid}.checklist-item input{opacity:0;width:1px;height:1px;position:absolute}.checklist-check{background:var(--surface);width:28px;height:28px;transition:border-color var(--transition-fast), background var(--transition-fast), transform var(--transition-fast);border:2px solid #cfc8c0;border-radius:9px;place-items:center;display:grid}.checklist-check:after{content:"";opacity:0;width:9px;height:5px;transition:opacity var(--transition-fast), transform var(--transition-fast);border-bottom:2px solid #fff;border-left:2px solid #fff;transform:translateY(-1px)rotate(-45deg)scale(.7)}.checklist-item input:checked+.checklist-check{border-color:var(--main);background:var(--main)}.checklist-item input:checked+.checklist-check:after{opacity:1;transform:translateY(-1px)rotate(-45deg)scale(1)}.checklist-item input:focus-visible+.checklist-check{box-shadow:0 0 0 4px var(--main-ring)}.checklist-item-copy{gap:3px;min-width:0;display:grid}.checklist-item-copy strong{color:var(--charcoal);font-size:.9rem;line-height:1.5}.checklist-item-copy small{color:var(--soft-text);font-size:.7rem;font-weight:700}.checklist li.completed{border-color:color-mix(in srgb, var(--main) 26%, var(--milk-line));background:var(--main-soft)}.checklist li.saving{opacity:.62}.checklist li.saving .checklist-item{cursor:wait}.checklist-loading{gap:10px;padding:14px;display:grid}.checklist-loading span{border-radius:999px;height:12px;display:block}.checklist-loading span:nth-child(2){width:82%}.checklist-loading span:nth-child(3){width:64%}.checklist-empty{color:var(--soft-text);text-align:center;gap:4px;padding:22px 16px;display:grid}.checklist-empty strong{color:var(--charcoal);font-size:.9rem}.checklist-empty span{font-size:.76rem}.checkbox-container{min-width:0;color:var(--ink);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;padding-left:32px;font-size:.95rem;display:flex;position:relative}.checkbox-container input{opacity:0;width:0;height:0;position:absolute}.checkmark{border:1.5px solid var(--line-strong);background:var(--surface);width:21px;height:21px;transition:background var(--transition-fast), border var(--transition-fast);border-radius:6px;position:absolute;top:1px;left:0}.checkmark:after{content:"";border:2px solid #fff;border-width:0 2px 2px 0;width:5px;height:10px;display:none;position:absolute;top:3px;left:7px;transform:rotate(45deg)}.checkbox-container input:checked~.checkmark:after{display:block}.checkbox-container input:checked~.item-text{color:var(--muted);text-decoration:line-through}.badge{white-space:nowrap;border-radius:999px;align-items:center;min-height:26px;padding:0 9px;font-size:.74rem;font-weight:700;display:inline-flex}.baby-age{color:var(--child-primary-hover);font-size:1.05rem;font-weight:700;line-height:1.6}.quick-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.quick-btn{border:1px solid var(--line);background:rgba(var(--surface-rgb), .78);cursor:pointer;min-height:108px;transition:transform var(--transition-fast), border var(--transition-fast), background var(--transition-fast), box-shadow var(--transition-fast);border-radius:8px;place-items:center;gap:7px;padding:14px 10px;display:grid}.quick-btn:hover{background:var(--child-primary-light);border-color:#5ca79573;transform:translateY(-1px);box-shadow:0 10px 22px #5ca7951f}.quick-icon{font-size:2rem;line-height:1}.quick-label{color:var(--ink);text-align:center;font-size:.84rem;font-weight:700;line-height:1.25}.timeline{flex-direction:column;gap:12px;display:flex;position:relative}.timeline-item{grid-template-columns:44px 36px minmax(0,1fr);align-items:center;gap:10px;display:grid}.timeline-time{color:var(--muted);font-family:var(--font-english);font-size:.8rem;font-weight:800}.timeline-badge{z-index:1;width:36px;height:36px;box-shadow:var(--shadow-soft);border-radius:8px;place-items:center;display:grid;position:relative}.type-milk{background-color:#fff0ec}.type-sleep{background-color:#edf2ff}.type-diaper{background-color:#edf8f4}.type-temperature{background-color:#fff5d8}.type-memo{background-color:#f3efff}.timeline-content{background:rgba(var(--surface-rgb), .74);border:1px solid #2f313712;border-radius:8px;min-width:0;padding:11px 13px}.timeline-title{color:var(--ink);font-size:.9rem;font-weight:700;line-height:1.4}.timeline-meta{color:var(--muted);margin-top:4px;font-size:.75rem}.loading-placeholder{color:var(--ink-soft);text-align:center;padding:18px;font-size:.9rem}.summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.summary-item{border:1px solid var(--line);background:rgba(var(--surface-rgb), .72);text-align:left;cursor:pointer;border-radius:8px;align-content:center;gap:4px;min-height:96px;padding:12px;display:grid}.summary-item.selected{border-color:var(--main);background:#eef5ecf2;box-shadow:0 0 0 3px #6b8e751f}.summary-item span,.chart-row small,.settings-list dt{color:var(--ink-soft);font-size:.76rem;font-weight:800}.summary-item strong{color:var(--ink);font-family:var(--font-english);font-size:1.4rem;line-height:1.1}.summary-item small{color:var(--muted);font-size:.72rem;line-height:1.4}.chart-list{gap:14px;display:grid}.chart-row{cursor:pointer;border:1px solid #0000;border-radius:12px;gap:6px;padding:8px;display:grid}.chart-row-wrap{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;display:grid}.chart-row-header{color:var(--ink);justify-content:space-between;align-items:center;gap:10px;font-size:.88rem;font-weight:800;display:flex}.chart-track{background:#6b8e751f;border-radius:999px;height:11px;overflow:hidden}.chart-fill{border-radius:inherit;background:linear-gradient(90deg, var(--main), var(--apricot));height:100%;transition:width .24s}.daily-total-row{border:1px solid var(--line);background:rgba(var(--surface-rgb), .72);border-radius:16px;gap:10px;padding:12px;display:grid}.daily-total-row strong{color:var(--ink);font-size:.92rem}.daily-total-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.daily-total-grid span{color:var(--ink-soft);background:#6b8e7514;border-radius:12px;gap:2px;padding:9px;font-size:.72rem;font-weight:800;display:grid}.daily-total-grid b{color:var(--ink);font-size:.92rem}.metric-chart{scroll-margin-top:calc(76px + env(safe-area-inset-top));gap:12px;display:grid}.metric-chart.selected{border-color:var(--main);box-shadow:0 0 0 3px #6b8e751f,0 10px 22px #4a6b5214}.metric-chart-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.metric-chart-header strong{color:var(--ink)}.metric-chart-header span,.metric-chart-stats{color:var(--ink-soft);font-size:.78rem;font-weight:800}.metric-line-chart{width:100%;min-height:150px;color:var(--main);overflow:visible}.metric-line-chart circle{fill:#fff;stroke:currentColor;stroke-width:3px}.metric-grid-line{stroke:#4a6b5229;stroke-width:1px;stroke-dasharray:3 4}.metric-axis-label,.metric-axis-date{fill:var(--soft-text);font-size:9px;font-weight:700}.metric-axis-date{font-size:8px}.metric-chart-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.metric-chart-stats span{text-align:center;background:#6b8e751a;border-radius:8px;gap:2px;padding:7px 8px;display:grid}.metric-chart-stats strong{color:var(--main-deep);font-size:.82rem}.weekly-range-nav{border:1px solid var(--milk-line);background:rgba(var(--surface-rgb), .82);border-radius:16px;grid-template-columns:44px minmax(0,1fr) 44px;align-items:center;gap:8px;width:100%;min-height:46px;padding:4px;display:grid}.weekly-range-nav strong{color:var(--main-deep);text-align:center;font-size:.88rem}.weekly-range-nav button{width:38px;height:38px;color:var(--main-deep);background:var(--main-soft);cursor:pointer;border:0;border-radius:12px;place-items:center;font-size:1.65rem;line-height:1;display:grid}.weekly-range-nav button:disabled{color:var(--muted);cursor:default;opacity:.5;background:#6b8e750f}.graph-controls.weekly-mode .graph-date-control{display:none}.weekly-chart{--weekly-plot-height:430px;border:1px solid var(--milk-line);background:rgba(var(--surface-rgb), .84);touch-action:pan-y;-webkit-user-select:none;user-select:none;will-change:transform;border-radius:18px;min-width:0;padding:14px 10px 12px;display:grid;position:relative;overflow:hidden;box-shadow:inset 0 1px #ffffffeb}.weekly-chart.animating{transition:transform .21s cubic-bezier(.22,.72,.2,1)}.weekly-chart.dragging{cursor:grabbing;transition:none}.weekly-chart-heading{grid-column:1/-1;justify-content:space-between;align-items:end;gap:12px;min-width:0;margin-bottom:13px;padding:0 5px;display:flex}.weekly-chart-heading>div{gap:2px;min-width:0;display:grid}.weekly-chart-heading span,.weekly-chart-heading small{color:var(--soft-text);font-size:.66rem;font-weight:800}.weekly-chart-heading strong{color:var(--main-deep);font-size:.98rem;line-height:1.25}.weekly-chart-heading small{text-align:right;max-width:145px;line-height:1.35}.weekly-chart-plot{grid-template-columns:repeat(7,minmax(0,1fr));min-width:0;display:grid}.weekly-chart-column{grid-template-rows:var(--weekly-plot-height) auto auto;border-left:1px solid #6b8e7514;justify-items:center;min-width:0;display:grid;position:relative}.weekly-day-marker{z-index:3;background:0 0;border-radius:999px;width:18px;height:3px;position:absolute;top:0;left:50%;transform:translate(-50%)}.weekly-day-marker.today{background:var(--main);box-shadow:0 2px 7px var(--main-shadow)}.weekly-chart-column:nth-child(2n){background:#6b8e750b}.weekly-chart-column:first-child{border-left:0}.weekly-chart-column>strong{color:var(--ink);font-family:var(--font-english);white-space:nowrap;margin-top:9px;font-size:.72rem;line-height:1.2}.weekly-chart-column>span{color:var(--soft-text);white-space:nowrap;margin-top:3px;font-size:.64rem;font-weight:800}.weekly-time-chart{grid-template-columns:27px minmax(0,1fr);padding-left:5px}.weekly-time-axis{height:var(--weekly-plot-height);color:var(--main-deep);font-family:var(--font-english);margin-top:0;font-size:.64rem;font-weight:800;position:relative}.weekly-time-axis span{text-shadow:0 1px #fff;padding-right:1px;position:absolute;right:5px;transform:translateY(-50%)}.weekly-time-column{width:100%;height:var(--weekly-plot-height);position:relative}.weekly-time-column:before{content:"";pointer-events:none;background:repeating-linear-gradient(#6b8e7509 0 6.25%,#0000 6.25% 12.5%),repeating-linear-gradient(#6b8e7533 0 1px,#0000 1px 12.5%);border-top:1px solid #6b8e7538;border-bottom:1px solid #6b8e7538;position:absolute;inset:14px 0}.weekly-time-point{z-index:1;background:var(--main);cursor:pointer;border:1px solid #fffffff0;border-radius:50%;place-items:center;width:24px;height:24px;min-height:0;padding:0;transition:transform .14s,box-shadow .14s;display:grid;position:absolute;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 2px #ffffffad,0 3px 8px #2f313733}.weekly-time-point>span{filter:saturate(.9);font-size:.72rem;line-height:1}.weekly-time-point:hover,.weekly-time-point:focus-visible{z-index:4;outline:0;transform:translate(-50%,-50%)scale(1.28)}.weekly-time-point.sleep-duration{opacity:.88;border-radius:7px;width:17px;min-height:18px;transform:translate(-50%)}.weekly-time-point.sleep-duration>span{font-size:.62rem}.weekly-time-point.sleep-duration.continues-from-previous{border-top:0;border-top-left-radius:0;border-top-right-radius:0}.weekly-time-point.sleep-duration.continues-to-next{border-bottom:0;border-bottom-right-radius:0;border-bottom-left-radius:0}.weekly-time-point.sleep-duration:hover,.weekly-time-point.sleep-duration:focus-visible{transform:translate(-50%)scaleX(1.18)}.weekly-time-point.type-milk,.weekly-amount-segment.type-milk{background:#e9a35d}.weekly-time-point.type-sleep,.weekly-amount-segment.type-sleep{background:#75a9c3}.weekly-time-point.type-diaper,.weekly-amount-segment.type-diaper{background:#79a487}.weekly-time-point.type-diaper.subtype-pee,.weekly-amount-segment.type-diaper.subtype-pee{background:#64a9c7}.weekly-time-point.type-diaper.subtype-poop,.weekly-amount-segment.type-diaper.subtype-poop{background:#b58a62}.weekly-time-point.type-temperature,.weekly-amount-segment.type-temperature{background:#d76f72}.weekly-time-point.type-memo,.weekly-amount-segment.type-memo{background:#9183b5}.weekly-time-point.subtype-baby_food,.weekly-amount-segment.subtype-baby_food{background:#d18b4f}.weekly-total-label{min-height:24px;color:var(--main-deep);font-family:var(--font-english);white-space:nowrap;align-self:end;place-items:center;max-width:100%;padding:0 2px;font-size:clamp(.56rem,2vw,.68rem);font-weight:900;display:grid}.weekly-chart-legend{grid-column:1/-1;justify-content:flex-end;gap:12px;margin:-5px 4px 10px;display:flex}.weekly-chart-legend span{color:var(--soft-text);align-items:center;gap:5px;font-size:.68rem;font-weight:800;display:inline-flex}.weekly-chart-legend i{background:#79a487;border-radius:3px;width:10px;height:10px}.weekly-chart-legend .pee i{background:#64a9c7}.weekly-chart-legend .poop i{background:#b58a62}.weekly-amount-chart .weekly-chart-column{grid-template-rows:25px var(--weekly-plot-height) auto auto}.weekly-amount-column{width:calc(100% - 8px);height:var(--weekly-plot-height);background:repeating-linear-gradient(#6b8e751f 0 1px,#0000 1px 20%);border:1px solid #6b8e751a;border-radius:12px 12px 5px 5px;flex-direction:column-reverse;place-self:end center;gap:2px;padding:3px;display:flex}.weekly-amount-segment{color:#fff;background:var(--main);border:1px solid #ffffffb8;border-radius:7px;place-items:center;min-height:2px;transition:filter .15s,transform .15s;display:grid;overflow:hidden;box-shadow:inset 0 1px #fff3}.weekly-amount-segment:hover{z-index:2;filter:saturate(1.08)brightness(1.03);transform:scaleX(1.06)}.weekly-amount-segment span{font-family:var(--font-english);text-overflow:clip;white-space:nowrap;max-width:100%;padding:2px;font-size:clamp(.5rem,1.8vw,.6rem);font-weight:900;line-height:1;overflow:hidden}.weekly-unsupported{background:radial-gradient(circle at 12% 18%,#e8a3821f,#0000 35%),#ffffffc7;border:1px dashed #6b8e7557;border-radius:18px;grid-template-columns:94px minmax(0,1fr);align-items:center;gap:16px;min-height:190px;padding:20px;display:grid}.weekly-unsupported img{-o-object-fit:contain;object-fit:contain;width:94px;height:82px}.weekly-unsupported div{gap:7px;display:grid}.weekly-unsupported strong{color:var(--main-deep);font-size:.94rem;line-height:1.45}.weekly-unsupported span{color:var(--soft-text);font-size:.78rem;font-weight:700;line-height:1.6}.graph-empty-state{border:1px dashed color-mix(in srgb, var(--main) 38%, white);background:radial-gradient(circle at 12% 18%, color-mix(in srgb, var(--main) 12%, transparent), transparent 34%), linear-gradient(145deg, #fffffff0, color-mix(in srgb, var(--main-soft) 42%, white));border-radius:20px;grid-template-columns:112px minmax(0,1fr);align-items:center;gap:22px;min-height:230px;padding:24px;display:grid}.weekly-empty-state{touch-action:pan-y;-webkit-user-select:none;user-select:none;will-change:transform}.weekly-empty-state.animating{transition:transform .21s cubic-bezier(.22,.72,.2,1)}.weekly-empty-state.dragging{cursor:grabbing;transition:none}.graph-empty-state>img{-o-object-fit:contain;object-fit:contain;width:112px;height:98px}.graph-empty-content{justify-items:start;gap:8px;min-width:0;display:grid}.graph-empty-label{min-height:26px;color:var(--main-deep);background:color-mix(in srgb, var(--main) 12%, white);border-radius:999px;align-items:center;padding:0 10px;font-size:.68rem;font-weight:900;display:inline-flex}.graph-empty-content>strong{color:var(--ink);font-size:1rem;line-height:1.45}.graph-empty-content>p{color:var(--soft-text);margin:0;font-size:.78rem;font-weight:700;line-height:1.65}.graph-empty-actions{flex-wrap:wrap;gap:8px;margin-top:4px;display:flex}.metric-chart-empty{border:1px dashed color-mix(in srgb, var(--main) 28%, white);background:color-mix(in srgb, var(--main-soft) 38%, white);border-radius:14px;grid-template-columns:44px minmax(0,1fr);align-items:center;gap:12px;min-height:112px;margin:10px 0;padding:14px;display:grid}.metric-chart-empty-icon{width:42px;height:42px;color:var(--main-deep);background:var(--surface);border-radius:50%;place-items:center;font-size:1.25rem;font-weight:500;display:grid;box-shadow:0 5px 14px #4a6b521a}.metric-chart-empty>div{gap:4px;display:grid}.metric-chart-empty strong{color:var(--main-deep);font-size:.82rem}.metric-chart-empty div span{color:var(--soft-text);font-size:.72rem;font-weight:700;line-height:1.5}@media (width<=390px){.weekly-chart{--weekly-plot-height:380px;padding-right:6px}.weekly-chart-heading small{display:none}.weekly-time-point{width:21px;height:21px}.weekly-time-point>span{font-size:.64rem}.weekly-chart-column>strong{font-size:.66rem}.weekly-chart-column>span,.weekly-amount-segment span{font-size:.58rem}.weekly-unsupported{grid-template-columns:72px minmax(0,1fr);min-height:160px;padding:16px}.weekly-unsupported img{width:72px;height:64px}.graph-empty-state{text-align:center;grid-template-columns:1fr;justify-items:center;gap:8px;min-height:250px;padding:20px 16px}.graph-empty-state>img{width:92px;height:78px}.graph-empty-content{justify-items:center}.graph-empty-actions{width:100%;display:grid}.graph-empty-actions .mini-action-btn{width:100%}}.pregnancy-trend{gap:12px;display:grid}.pregnancy-condition-chart{border:1px solid var(--line);background:rgba(var(--surface-rgb), .72);border-radius:16px;padding:12px}.pregnancy-log-list{gap:8px;display:grid}.pregnancy-log-row{border:1px solid var(--line);background:rgba(var(--surface-rgb), .72);cursor:pointer;border-radius:14px;grid-template-columns:minmax(120px,1fr) auto auto auto;align-items:center;gap:8px;padding:10px;display:grid}.pregnancy-log-main{gap:5px;min-width:0;display:grid}.pregnancy-log-main strong{color:var(--ink);font-size:.88rem}.condition-dots{gap:3px;display:inline-flex}.condition-dot{background:#6b8e7529;border-radius:999px;width:9px;height:9px}.condition-dot.active{background:var(--main)}.condition-chip,.pregnancy-log-weight{color:var(--ink-soft);white-space:nowrap;background:#6b8e751a;border-radius:999px;padding:4px 8px;font-size:.72rem;font-weight:800}.pregnancy-log-weight{color:var(--ink)}@media (width<=520px){.pregnancy-log-row{grid-template-columns:minmax(0,1fr) auto}.pregnancy-log-row .log-delete-btn{justify-self:end}}.day-timeline{border:1px solid var(--line);background:rgba(var(--surface-rgb), .72);cursor:default;border-radius:16px;gap:8px;padding:12px;display:grid}.logs-list-heading{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.day-nav{align-items:center;gap:6px;display:inline-flex}.day-nav-btn{border:1px solid var(--milk-line);width:40px;min-width:40px;height:40px;min-height:40px;color:var(--main-deep);background:var(--surface);cursor:pointer;border-radius:12px;place-items:center;transition:border-color .16s,background .16s,opacity .16s;display:inline-grid}.day-nav-btn>span{width:18px;height:18px}.day-nav-btn:hover:not(:disabled){border-color:var(--main);background:var(--main-soft)}.day-nav-btn:disabled{opacity:.4;cursor:not-allowed}.day-nav-label{min-width:8.5em;color:var(--ink);text-align:center;font-size:.9rem;font-weight:800}.day-nav-today{border:1px solid var(--main);min-height:36px;color:var(--main-deep);background:var(--main-soft);cursor:pointer;border-radius:999px;margin-bottom:12px;padding:0 16px;font-size:.82rem;font-weight:800}.day-timeline-header,.day-timeline-scale{justify-content:space-between;align-items:center;gap:8px;display:flex}.day-timeline-header strong{color:var(--ink);font-size:.92rem}.day-timeline-header span,.day-timeline-scale,.day-timeline-chips{color:var(--ink-soft);font-size:.72rem;font-weight:800}.day-timeline-track{background:linear-gradient(90deg,#0000 calc(25% - 1px),#6b8e7529 calc(25% - 1px) calc(25% + 1px),#0000 calc(25% + 1px)),linear-gradient(90deg,#0000 calc(50% - 1px),#6b8e752e calc(50% - 1px) calc(50% + 1px),#0000 calc(50% + 1px)),linear-gradient(90deg,#0000 calc(75% - 1px),#6b8e7529 calc(75% - 1px) calc(75% + 1px),#0000 calc(75% + 1px)),#6b8e751a;border-radius:999px;height:38px;position:relative}.day-timeline-dot{color:#fff;background:var(--main);border:2px solid #fff;border-radius:999px;place-items:center;width:28px;height:28px;font-size:.68rem;font-weight:800;line-height:1;display:grid;position:absolute;top:50%;transform:translate(-50%,-50%);box-shadow:0 6px 14px #4a6b5233}.day-timeline-dot.type-milk{background:var(--apricot)}.day-timeline-dot.type-sleep{background:var(--baby-blue)}.day-timeline-dot.type-diaper{background:var(--main)}.day-timeline-dot.type-temperature{background:#c44148}.day-timeline-dot.type-memo{background:#8a7fb7}.day-timeline-dot.subtype-weight{background:#7b6fb0}.day-timeline-dot.subtype-height{background:#5f8fb5}.day-timeline-dot.subtype-medicine{background:#9a5d9f}.day-timeline-dot.subtype-baby_food{background:#c0833f}.day-timeline-sleep{color:#fff;background:var(--baby-blue);border:2px solid #fff;border-radius:999px;place-items:center;min-width:32px;height:28px;font-size:.82rem;font-weight:800;line-height:1;display:grid;position:absolute;top:50%;transform:translateY(-50%);box-shadow:0 6px 14px #4a6b5229}.day-timeline-sleep.ongoing{background:#4f86a6;border-color:#e9f7ff;animation:1.8s ease-in-out infinite sleep-running-glow}.quick-btn.sleep-active{color:#315f78;background:#edf8fd;border-color:#73a9c5}.quick-status{color:#47758c;margin-top:2px;font-size:.72rem;font-weight:700;display:block}.sleep-running-banner{background:#f2fbfe;border:1px solid #b9ddea;border-radius:8px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;margin-top:14px;padding:12px 14px;display:grid}.status-character{-o-object-fit:contain;object-fit:contain;width:52px;height:44px}.sleep-running-banner div{gap:2px;min-width:0;display:grid}.sleep-running-banner strong{color:#315f78}.sleep-running-banner span{color:#57717e;font-size:.82rem}.sleep-running-banner button{background:var(--surface);color:#315f78;border:1px solid #5f95ae;border-radius:7px;min-height:40px;padding:0 16px;font-weight:800}.sleep-running-pulse{background:#4f91b0;border-radius:50%;width:10px;height:10px;animation:1.8s ease-in-out infinite sleep-running-pulse;box-shadow:0 0 0 5px #4f91b024}.sleep-record-error{color:#b33f48;margin:10px 0 0;font-size:.82rem;font-weight:700}.character-empty-state{border:1px dashed var(--milk-line);background:rgba(var(--surface-rgb), .68);border-radius:8px;grid-template-columns:92px minmax(0,1fr);align-items:center;gap:14px;min-height:118px;padding:14px;display:grid}.character-empty-state.compact{min-height:92px}@keyframes character-float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.character-empty-state img{-o-object-fit:contain;object-fit:contain;width:92px;height:78px;animation:3.2s ease-in-out infinite character-float}.character-empty-state div{gap:4px;display:grid}.character-empty-state strong{color:var(--main-deep);line-height:1.4}.character-empty-state span{color:var(--soft-text);font-size:.8rem;font-weight:700;line-height:1.55}.first-food-next.completed{grid-template-columns:72px minmax(0,1fr);align-items:center}.first-food-next.completed>div{gap:4px;display:grid}.inline-character{-o-object-fit:contain;object-fit:contain;width:72px;height:64px}@keyframes sleep-running-pulse{50%{box-shadow:0 0 0 8px #4f91b00d}}@keyframes sleep-running-glow{50%{filter:brightness(1.12)}}.day-timeline-chips{flex-wrap:wrap;gap:6px;display:flex}.day-timeline-chips span{background:#6b8e751a;border-radius:999px;align-items:center;gap:6px;padding:3px 8px;display:inline-flex}.logs-list-card .day-timeline{border-color:var(--milk-line);background:rgba(var(--surface-rgb), .84)}.logs-list-card .day-timeline-track{margin-inline:3px}.logs-list-card .day-timeline-chips:empty{display:none}.day-timeline.selected,.chart-row.selected{border-color:var(--main);background:#eef5eceb;box-shadow:0 0 0 3px #6b8e751f}.settings-list{grid-template-columns:minmax(92px,auto) minmax(0,1fr);gap:10px 14px;display:grid}.settings-list dd{min-width:0;color:var(--ink);overflow-wrap:anywhere;font-size:.9rem;font-weight:800}.settings-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:16px;display:grid}.settings-edit-form,.family-share-box{gap:12px;margin-top:16px;display:grid}.invite-result{gap:8px;display:grid}.invite-result p{color:var(--ink-soft);font-size:.82rem;font-weight:800;line-height:1.55}.invite-link-input{border:1px solid var(--line);width:100%;min-height:44px;color:var(--ink);background:var(--surface);border-radius:8px;padding:0 10px;font-size:.82rem;font-weight:700}.qr-reader{gap:8px;display:grid}.qr-reader[hidden]{display:none}.qr-reader video{aspect-ratio:4/3;border:1px solid var(--line);-o-object-fit:cover;object-fit:cover;background:#111;border-radius:8px;width:100%}.log-delete-btn{color:#a63339;cursor:pointer;background:#c4414814;border:1px solid #c441482e;border-radius:999px;min-height:30px;padding:0 10px;font-size:.72rem;font-weight:800}.log-delete-btn:hover{color:#fff;background:#c44148}.timeline-content{position:relative}.timeline-delete-btn{position:absolute;top:8px;right:8px}.timeline-delete-btn+.timeline-title{padding-right:52px}.secondary-action{color:var(--main-deep);background:var(--surface);border:1px solid var(--line);box-shadow:none}.secondary-action:hover{color:#fff;background:var(--main)}.logout-action{color:#fff;background:var(--main-deep);border:1px solid var(--main-deep);box-shadow:0 10px 22px #4a6b522e}.logout-action:hover{color:#fff;background:var(--main);border-color:var(--main)}.danger-action,.danger-action:hover{background:#c44148;box-shadow:0 12px 24px #c441482e}.modal{z-index:200;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#1f222875;justify-content:center;align-items:flex-end;padding:18px;display:none;position:fixed;inset:0}.modal.active{animation:.18s ease-out fadeIn;display:flex}.modal-content{border:1px solid var(--line);background:var(--surface);border-radius:8px;width:min(100%,420px);padding:22px;animation:.22s ease-out slideUp;box-shadow:0 24px 70px #1f222847}.modal-header{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;padding-bottom:12px;display:flex}.modal-header h3{color:var(--ink);font-size:1.1rem;font-weight:700;line-height:1.35}.modal-close{border:1px solid var(--line);background:var(--surface);width:36px;height:36px;color:var(--ink-soft);cursor:pointer;border-radius:8px;place-items:center;font-size:1.55rem;line-height:1;display:grid}.modal-close:hover{color:var(--ink)}.modal-close>span{width:19px;height:19px}.confirm-dialog{z-index:260}.confirm-dialog-content{text-align:center;gap:16px;display:grid}.confirm-dialog-visual{background:radial-gradient(circle at 24% 18%,#e8a3822e,#0000 36%),radial-gradient(circle at 82% 10%,#b0c4de38,#0000 34%),#fbfaf7;border-radius:24px;justify-self:center;place-items:center;width:128px;height:88px;display:grid}.confirm-dialog-visual img{-o-object-fit:contain;object-fit:contain;width:112px;height:78px}.confirm-dialog-body{gap:8px;display:grid}.confirm-dialog-body h3{color:var(--main-deep);font-size:1.18rem;font-weight:800;line-height:1.4}.confirm-dialog-body p{color:var(--soft-text);font-size:.95rem;line-height:1.75}.confirm-dialog-actions{grid-template-columns:1fr 1fr;gap:10px;display:grid}.confirm-dialog-actions.single-action{grid-template-columns:minmax(160px,220px);justify-content:center}.birth-status-dialog-content{width:min(100%,460px)}.birth-status-form{gap:12px;display:grid}.birth-status-actions{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.birth-revert-btn{color:#fff;cursor:pointer;border:0;border-radius:16px;min-height:48px;padding:0 14px;font-weight:700}.confirm-cancel-btn,.confirm-ok-btn{cursor:pointer;border-radius:16px;min-height:48px;padding:0 14px;font-weight:700}.confirm-cancel-btn{border:1px solid var(--milk-line);color:var(--main-deep);background:var(--surface)}.confirm-ok-btn{color:#fff;background:var(--main);border:0;box-shadow:0 12px 24px #4a6b5233}.confirm-ok-btn.danger{background:#c45f55;box-shadow:0 12px 24px #c45f5533}.confirm-cancel-btn:hover{border-color:var(--main);background:var(--child-primary-light)}.confirm-ok-btn:hover{filter:brightness(.96)}.app-footer{z-index:80;background:rgba(var(--surface-rgb), .9);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-top:1px solid #2f313714;justify-content:space-between;align-items:center;gap:12px;height:72px;padding:0 18px;display:flex;position:absolute;bottom:0;left:0;right:0}.sync-status{min-width:0;color:var(--ink-soft);align-items:center;gap:8px;font-size:.78rem;font-weight:800;display:flex}.sync-status span:last-child{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.sync-dot{background-color:var(--child-primary);border-radius:50%;flex:none;width:9px;height:9px}.blinking{animation:1.5s infinite blink}.submit-btn:active,.quick-btn:active,.birth-trigger-btn:active,.rating-btn:active,.mode-btn:active,.user-toggle-btn:active,.api-btn:active{transform:scale(.98)}@keyframes blink{0%,to{opacity:.32}50%{opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUpFade{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (width>=760px){.modal{align-items:center}}@media (width<=760px){body.site-page{background:linear-gradient(#fffdf9e6,#fffdf9fa),linear-gradient(145deg,#f6faf8 0%,#fff8f1 58%,#eef4fb 100%)}.portal-hero:after{display:none}.portal-hero{min-height:calc(100vh - 72px);padding:54px 0 88px}.site-nav{flex-direction:column;align-items:flex-start;min-height:auto;padding:16px 0}.site-links{justify-content:flex-start}.cms-layout,.cms-fields,.cms-post-row{grid-template-columns:1fr}.cms-row-actions{justify-content:flex-start}}@media (width<=480px){#app{max-width:none;box-shadow:none;border-left:0;border-right:0}.user-selector-bar{flex-direction:column;align-items:flex-start}.user-toggles{justify-content:flex-start;width:100%}.app-header{flex-direction:column;align-items:flex-start}.mode-selector{width:100%}.app-main{padding-inline:14px}.card{padding:18px}.days-left{font-size:3.5rem}.timeline-item{grid-template-columns:42px 34px minmax(0,1fr);gap:8px}.timeline-badge{width:34px;height:34px}.app-footer{padding-inline:14px}}:root{--base:#fbfaf7;--main:#6b8e75;--main-deep:#4a6b52;--main-soft:#eef5ec;--main-ring:#6b8e7524;--main-shadow:#4a6b5238;--apricot:#e8a382;--baby-blue:#b0c4de;--charcoal:#333;--soft-text:#6f716d;--milk-line:#e8e2d8;--cream:#fffdf8;--tap-size:44px;--ink:var(--charcoal);--ink-soft:var(--soft-text);--muted:#74766d;--paper:var(--base);--surface:#fff;--surface-rgb:255, 255, 255;--surface-soft:#f6f4ed;--surface-warm:#fff4ee;--app-bg:#f6f7f2;--line:var(--milk-line);--line-strong:#d9d2c5;--shadow:0 18px 46px #4a6b5224;--shadow-soft:0 10px 28px #4a6b521a;--preg-primary:#d97991;--preg-primary-light:#fff0f4;--preg-primary-hover:#ad526a;--preg-accent:#e7a5b6;--preg-bg-grad:radial-gradient(circle at 16% 6%, #e7a5b64d, transparent 32%), radial-gradient(circle at 94% 2%, #ffdae452, transparent 34%), linear-gradient(180deg, #fffafb 0%, #f9eff2 100%);--child-primary:var(--main);--child-primary-light:#eef5ec;--child-primary-hover:var(--main-deep);--child-accent:var(--baby-blue);--child-bg-grad:radial-gradient(circle at 18% 5%, #b0c4de42, transparent 34%), radial-gradient(circle at 92% 4%, #e8a38238, transparent 34%), linear-gradient(180deg, #fbfaf7 0%, #edf4ec 100%)}body.pregnancy-active{--main:var(--preg-primary);--main-deep:var(--preg-primary-hover);--main-soft:var(--preg-primary-light);--main-ring:#d9799129;--main-shadow:#ad526a38;--shadow:0 18px 46px #ad526a24;--shadow-soft:0 10px 28px #ad526a1a}body.childcare-active{--main:#6b8e75;--main-deep:#4a6b52;--main-soft:#eef5ec;--main-ring:#6b8e7524;--main-shadow:#4a6b5238}html[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--charcoal:#e8e6e0;--soft-text:#b0b1a9;--milk-line:#363c44;--cream:#1f242b;--base:#161a1f;--apricot:#e0a784;--baby-blue:#8fa9c6;--muted:#9a9c94;--surface:#232830;--surface-rgb:35, 40, 48;--surface-soft:#2b323a;--surface-warm:#2f2722;--app-bg:#121519;--line-strong:#474e57;--shadow:0 18px 46px #0000008c;--shadow-soft:0 12px 28px #00000073;--preg-primary:#e58fa5;--preg-primary-light:#3a2a30;--preg-primary-hover:#f0aabb;--preg-accent:#c98399;--preg-bg-grad:radial-gradient(circle at 16% 6%, #d9799124, transparent 32%), radial-gradient(circle at 94% 2%, #d9799114, transparent 34%), linear-gradient(180deg, #181216 0%, #14171c 100%);--child-primary:#8fb89b;--child-primary-light:#243029;--child-primary-hover:#abceb6;--child-accent:#8fa9c6;--child-bg-grad:radial-gradient(circle at 18% 5%, #8fb89b1f, transparent 34%), radial-gradient(circle at 92% 4%, #8fa9c61a, transparent 34%), linear-gradient(180deg, #121519 0%, #141b16 100%)}html[data-theme=dark] body.childcare-active{--main:#8fb89b;--main-deep:#abceb6;--main-soft:#243029;--main-shadow:#00000080}html[data-theme=dark] body.pregnancy-active{--main-shadow:#00000080;--shadow:0 18px 46px #0000008c;--shadow-soft:0 12px 28px #00000073}html[data-theme=dark] body.site-page{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--charcoal:#333;--soft-text:#6f716d;--milk-line:#e8e2d8;--cream:#fffdf8;--base:#fbfaf7;--apricot:#e8a382;--baby-blue:#b0c4de;--muted:#74766d;--surface:#fff;--surface-rgb:255, 255, 255;--surface-soft:#f6f4ed;--surface-warm:#fff4ee;--app-bg:#f6f7f2;--line-strong:#d9d2c5;--shadow:0 18px 46px #4a6b5224;--shadow-soft:0 10px 28px #4a6b521a;--preg-primary:#d97991;--preg-primary-light:#fff0f4;--preg-primary-hover:#ad526a;--preg-accent:#e7a5b6;--child-primary-light:#eef5ec}html[data-theme=dark] body:not(.site-page) .app-header{background:#14171cd1;border-bottom-color:#ffffff14}html[data-theme=dark] body:not(.site-page) .app-footer{background:#14171ceb;border-top-color:#ffffff14}html[data-theme=dark] body:not(.site-page) .card{border-color:#ffffff12}body{color:var(--charcoal);background:var(--preg-bg-grad);font-feature-settings:"palt" 1;letter-spacing:.01em;font-family:Noto Sans JP,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.75}a,button{min-height:var(--tap-size)}mame-app-root,mame-admin-root,mame-app-shell,mame-admin-shell,mame-app-login,mame-app-registration,mame-app-pregnancy,mame-app-childcare,mame-app-graph,mame-app-first-food,mame-app-achievements,mame-app-ranking,mame-app-settings,mame-admin-home,mame-admin-blog-list,mame-admin-blog-editor,mame-admin-blog-categories,mame-admin-rankings,mame-admin-ranking-categories,mame-admin-ranking-items,mame-admin-users,mame-admin-login,mame-admin-not-found{width:100%;display:block}.site-nav{width:min(1040px,100% - 28px);min-height:64px;padding:12px 0}.site-brand{color:var(--main-deep);letter-spacing:0;align-items:center;gap:9px;font-size:1.14rem;display:inline-flex}.site-brand:before{content:none}.site-brand img{border-radius:12px;width:34px;height:34px;box-shadow:0 8px 18px #4a6b5224}.site-links a,.site-links button{min-height:40px;color:var(--main-deep);border-radius:999px;padding:0 14px;font-weight:700}.site-links a:hover,.site-links a[aria-current=page],.site-links button:hover{color:#fff;background:var(--main);border-color:var(--main)}.portal-hero{align-content:start;gap:26px;width:min(1040px,100% - 28px);min-height:calc(100svh - 64px);padding:clamp(36px,8vh,76px) 0 36px;display:grid}.portal-hero:after{display:none}.portal-copy{gap:14px;display:grid}.portal-visual{background:linear-gradient(#ffffffd6,#fbfaf7a3),radial-gradient(circle at 18% 18%,#e8a38238,#0000 34%),radial-gradient(circle at 88% 8%,#b0c4de38,#0000 32%);border:1px solid #e8e2d8e6;border-radius:28px;justify-self:center;width:min(100%,360px);margin:-4px auto 0;padding:18px 18px 6px;position:relative;box-shadow:0 22px 56px #4a6b5224}.portal-visual:after{content:"夫婦で共有";min-height:34px;color:var(--main-deep);background:rgba(var(--surface-rgb), .9);border-radius:999px;align-items:center;padding:0 12px;font-size:.78rem;font-weight:700;display:inline-flex;position:absolute;bottom:14px;right:16px;box-shadow:0 10px 24px #4a6b521f}.portal-visual img{filter:drop-shadow(0 12px 18px #4a6b521f);width:100%;display:block}.portal-hero-screens{width:min(100%,430px);height:420px;padding:20px;display:block;overflow:hidden}.portal-hero-screens:after{z-index:4}.portal-hero-screens .portal-hero-screen{-o-object-fit:cover;object-fit:cover;-o-object-position:top;object-position:top;filter:none;border:6px solid #fffffff5;border-radius:25px;width:58%;position:absolute;top:24px;box-shadow:0 20px 42px #2f313733}.portal-hero-screen.pregnancy{height:345px;left:22px;transform:rotate(-3deg)}.portal-hero-screen.childcare{z-index:2;height:350px;top:50px;right:20px;transform:rotate(3deg)}.site-kicker{color:var(--main);letter-spacing:0;font-size:.78rem}.portal-hero h1,.page-heading h1,.article-detail h1{color:var(--charcoal);font-family:Noto Sans JP,system-ui,sans-serif;font-weight:800;line-height:1.28}.portal-hero h1{max-width:720px;font-size:clamp(2.15rem,11vw,4.4rem)}.portal-hero p:not(.site-kicker),.page-heading p:not(.site-kicker),.article-excerpt,.article-date,.article-body,.admin-panel p{color:var(--soft-text);font-size:1rem;font-weight:500;line-height:1.9}.portal-cta,.site-actions{gap:12px;margin-top:0;display:grid}.site-footer{border-top:1px solid var(--milk-line);width:min(1120px,100% - 28px);margin:0 auto;padding:28px 0 44px}.site-footer nav{flex-wrap:wrap;gap:10px 18px;display:flex}.site-footer a{color:var(--soft-text);font-size:.86rem;font-weight:700;text-decoration:none}.site-footer a:hover,.site-footer a[aria-current=page]{color:var(--main-deep)}.portal-cta{align-self:end;width:100%;max-width:430px}.portal-cta small{color:var(--soft-text);text-align:center;font-size:.76rem;font-weight:700}.portal-web-badges{flex-wrap:wrap;gap:8px;display:flex}.portal-web-badges span{min-height:32px;color:var(--main-deep);background:rgba(var(--surface-rgb), .76);border:1px solid #6b8e7538;border-radius:999px;align-items:center;padding:0 11px;font-size:.76rem;font-weight:800;display:inline-flex}.primary-link,.secondary-link,.cms-submit,.cms-reset{border-radius:18px;min-height:56px;padding:0 20px;font-weight:700}.primary-link,.cms-submit{background:var(--main);box-shadow:0 14px 28px #4a6b5238}.primary-link:hover,.cms-submit:hover{background:var(--main-deep)}.secondary-link,.cms-reset{border-color:var(--milk-line);color:var(--main-deep);background:rgba(var(--surface-rgb), .82)}.secondary-link:hover,.cms-reset:hover{color:var(--main-deep);border-color:var(--main);background:var(--child-primary-light)}.hero-start-link,.blog-start-link{justify-content:center;width:100%;font-size:1rem}.portal-cta .primary-link,.portal-hero .site-actions .primary-link{color:#fff;border-color:var(--main);background:var(--main);box-shadow:0 14px 28px #4a6b523d}.portal-cta .primary-link:hover,.portal-hero .site-actions .primary-link:hover{color:#fff;border-color:var(--main-deep);background:var(--main-deep)}.blog-start-link{background:var(--surface)}.portal-feature-grid{gap:12px;display:grid}.portal-feature-grid article{-moz-column-gap:14px;border:1px solid var(--milk-line);background:rgba(var(--surface-rgb), .76);box-shadow:var(--shadow-soft);border-radius:20px;grid-template-columns:72px minmax(0,1fr);align-items:center;column-gap:14px;padding:18px;display:grid}.portal-feature-grid article>img{-o-object-fit:contain;object-fit:contain;background:var(--base);border-radius:20px;grid-row:span 3;width:72px;height:72px}.portal-feature-grid span{color:var(--apricot);font-family:var(--font-english);font-weight:800}.portal-feature-grid h2{color:var(--main-deep);margin:6px 0;font-size:1.05rem;line-height:1.45}.portal-feature-grid p{color:var(--soft-text);line-height:1.8}.portal-lp-section,.portal-final-cta{width:min(1040px,100% - 28px);margin:0 auto}.portal-lp-section{padding:clamp(64px,9vw,104px) 0}.portal-app-section{border-top:1px solid var(--milk-line);align-items:center;gap:36px;display:grid}.portal-lp-copy,.portal-section-heading{gap:16px;display:grid}.portal-lp-copy h2,.portal-section-heading h2,.portal-final-cta h2{color:var(--charcoal);font-size:clamp(1.8rem,5vw,2.8rem);line-height:1.4}.portal-lp-copy>p:not(.site-kicker),.portal-section-heading>p,.portal-final-cta p:not(.site-kicker){color:var(--soft-text);line-height:1.9}.portal-benefit-list{gap:10px;margin:2px 0 8px;padding:0;list-style:none;display:grid}.portal-use-grid{gap:10px;display:grid}.portal-use-grid article{-moz-column-gap:10px;border:1px solid var(--milk-line);background:rgba(var(--surface-rgb), .72);border-radius:16px;grid-template-columns:auto minmax(0,1fr);column-gap:10px;padding:14px;display:grid}.portal-use-grid article>span{color:var(--main);font-family:var(--font-english);grid-row:span 2;font-size:.76rem;font-weight:900}.portal-use-grid strong{color:var(--charcoal);font-size:.92rem}.portal-use-grid p{color:var(--soft-text);font-size:.82rem;line-height:1.7}.portal-benefit-list li{color:var(--charcoal);padding-left:28px;font-weight:700;line-height:1.7;position:relative}.portal-benefit-list li:before{content:"";background:var(--main);border-radius:50%;width:18px;height:18px;position:absolute;top:.35em;left:0;box-shadow:inset 0 0 0 5px #edf3eb}.portal-lp-copy .site-actions,.portal-final-cta .site-actions{margin-top:8px}.portal-lp-copy .primary-link,.portal-final-cta .primary-link{color:#fff;border-color:var(--main)}.portal-app-preview{border:1px solid var(--milk-line);background:rgba(var(--surface-rgb), .82);border-radius:30px;min-width:0;margin:0;padding:12px 12px 18px;box-shadow:0 24px 56px #4a6b5224}.portal-app-preview img{-o-object-fit:cover;object-fit:cover;-o-object-position:top;object-position:top;border-radius:22px;width:100%;max-height:610px;display:block}.portal-app-preview figcaption{color:var(--soft-text);padding:14px 8px 0;font-size:.78rem;font-weight:700;line-height:1.7}.portal-screen-section{border-top:1px solid var(--milk-line);gap:30px;display:grid}.portal-screen-grid{overscroll-behavior-inline:contain;scroll-snap-type:inline mandatory;scrollbar-width:thin;grid-auto-columns:min(76vw,310px);grid-auto-flow:column;gap:14px;margin-inline:-14px;padding:2px 14px 18px;display:grid;overflow-x:auto}.portal-screen-grid figure{scroll-snap-align:center;border:1px solid var(--milk-line);background:rgba(var(--surface-rgb), .84);min-width:0;box-shadow:var(--shadow-soft);border-radius:24px;margin:0;padding:10px 10px 18px}.portal-screen-grid img{aspect-ratio:9/14;-o-object-fit:cover;object-fit:cover;-o-object-position:top;object-position:top;border-radius:17px;width:100%;display:block}.portal-screen-grid figcaption{gap:4px;padding:14px 6px 0;display:grid}.portal-screen-grid strong{color:var(--main-deep);font-size:.9rem}.portal-screen-grid span{color:var(--soft-text);font-size:.76rem;font-weight:700;line-height:1.6}.portal-articles-section{border-top:1px solid var(--milk-line);gap:32px;display:grid}.portal-section-heading>div{gap:12px;display:grid}.portal-article-grid{gap:16px;display:grid}.portal-article-card{border:1px solid var(--milk-line);color:inherit;background:rgba(var(--surface-rgb), .82);box-shadow:var(--shadow-soft);border-radius:24px;gap:12px;padding:14px 14px 20px;text-decoration:none;transition:transform .2s,border-color .2s,box-shadow .2s;display:grid}.portal-article-card:hover{border-color:var(--main);transform:translateY(-4px);box-shadow:0 18px 40px #4a6b5224}.portal-article-thumb{aspect-ratio:16/10;background:linear-gradient(135deg,#eef3ec,#f6f1ea);border-radius:16px;place-items:center;display:grid}.portal-article-thumb.cat-pregnancy{background:linear-gradient(135deg,#fde7ee,#fff1f4)}.portal-article-thumb.cat-birth-prep{background:linear-gradient(135deg,#fdeede,#fff6ec)}.portal-article-thumb.cat-childcare{background:linear-gradient(135deg,#e7f1ea,#eef6f1)}.portal-article-thumb img{width:auto;height:70%;max-height:96px}.portal-article-category{width:fit-content;color:var(--main-deep);background:#edf3eb;border-radius:999px;padding:5px 10px;font-size:.76rem;font-weight:800}.portal-article-card h3{color:var(--charcoal);font-size:1.1rem;line-height:1.55}.portal-article-card p{color:var(--soft-text);font-size:.9rem;line-height:1.8}.portal-section-actions{justify-content:center}.portal-final-cta{color:var(--charcoal);background:radial-gradient(circle at 85% 12%,#ffffffb3,#0000 34%),#edf3eb;border-radius:28px;gap:24px;margin-bottom:clamp(64px,9vw,104px);padding:clamp(28px,6vw,52px);display:grid}.portal-final-cta>div:first-child{gap:12px;display:grid}.page-heading{width:min(920px,100% - 28px);padding:36px 0 18px}.blog-heading{padding-bottom:12px}.article-list,.article-detail{width:min(920px,100% - 28px)}.article-meta{color:var(--ink-soft);flex-wrap:wrap;align-items:center;gap:6px 14px;margin:4px 0 14px;font-size:.82rem;font-weight:700;display:flex}.article-meta .article-updated{color:var(--main-deep)}.article-meta .article-readtime:before{content:"⏱ "}.article-share{border-top:1px solid var(--line);flex-wrap:wrap;align-items:center;gap:8px;margin:28px 0;padding-top:18px;display:flex}.article-share-label{color:var(--ink-soft);margin-right:2px;font-size:.82rem;font-weight:800}.article-share-btn{color:#fff;border-radius:999px;align-items:center;min-height:38px;padding:0 16px;font-size:.84rem;font-weight:800;text-decoration:none;transition:opacity .16s;display:inline-flex}.article-share-btn.x{background:#000}.article-share-btn.line{background:#06c755}.article-share-btn:hover{opacity:.88}.article-related{border-top:1px solid var(--line);margin:32px 0 8px;padding-top:22px}.article-related h2{color:var(--charcoal);margin-bottom:14px;font-size:1.16rem}.article-related-grid{gap:12px;display:grid}@media (width>=720px){.article-related-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.article-related-card{border:1px solid var(--milk-line);background:rgba(var(--surface-rgb), .82);border-radius:16px;align-content:start;gap:6px;padding:14px 16px;text-decoration:none;transition:transform .2s,border-color .2s;display:grid}.article-related-card:hover{border-color:var(--main);transform:translateY(-3px)}.article-related-category{color:var(--main-deep);font-size:.74rem;font-weight:800}.article-related-card strong{color:var(--charcoal);font-size:.96rem;line-height:1.5}.article-related-card small{-webkit-line-clamp:2;color:var(--soft-text);-webkit-box-orient:vertical;font-size:.8rem;line-height:1.6;display:-webkit-box;overflow:hidden}.post-thumb{aspect-ratio:16/9;background:linear-gradient(135deg,#eef2f6,#f5f1ea);place-items:center;display:grid;overflow:hidden}.post-thumb img{width:46%;max-width:116px;height:auto}.post-thumb-photo{background:var(--surface-soft)}.post-thumb-photo img,.article-hero-photo img{-o-object-fit:cover;object-fit:cover;width:100%;max-width:none;height:100%;max-height:none}.post-thumb.cat-pregnancy,.article-hero.cat-pregnancy{background:linear-gradient(135deg,#fde7ee,#fff1f4)}.post-thumb.cat-birth-prep,.article-hero.cat-birth-prep{background:linear-gradient(135deg,#fdeede,#fff6ec)}.post-thumb.cat-childcare,.article-hero.cat-childcare{background:linear-gradient(135deg,#e7f1ea,#eef6f1)}.article-hero{aspect-ratio:3;background:linear-gradient(135deg,#eef2f6,#f5f1ea);border-radius:20px;place-items:center;margin-bottom:18px;display:grid;overflow:hidden}.article-hero img{width:auto;height:66%;max-height:132px}@media (width<=560px){.article-hero{aspect-ratio:5/2}}.article-card-thumb-link{border-radius:20px 20px 0 0;margin:-20px -20px 0;display:block;overflow:hidden}.article-related-card .post-thumb{border-radius:16px 16px 0 0;margin:-14px -16px 0}.article-list{gap:14px;padding-bottom:88px}.article-list article,.admin-panel,.cms-auth,.cms-editor,.cms-posts,.card,.login-required-card,.registration-card,.modal-content{border-color:var(--milk-line);background:rgba(var(--surface-rgb), .86);border-radius:20px}.article-list article,.cms-auth,.cms-editor,.cms-posts{padding:20px}.article-list h2,.admin-panel h2,.cms-toolbar h2{color:var(--charcoal);font-size:1.24rem}.article-list span{color:var(--main-deep)}.category-filter,.pagination{overscroll-behavior-x:contain;scrollbar-width:none;flex-wrap:nowrap;gap:10px;margin:20px -14px 0;padding:0 14px 6px;display:flex;overflow-x:auto}.category-filter::-webkit-scrollbar{display:none}.pagination::-webkit-scrollbar{display:none}.category-filter a,.pagination a,.category-link{min-height:44px;color:var(--main-deep);background:var(--surface);border-radius:999px;flex:none;padding:0 16px;font-weight:700}.category-filter a:hover,.category-filter a.active,.pagination a:hover,.pagination a.active,.category-link:hover{color:#fff;border-color:var(--main);background:var(--main)}.pagination-edge.disabled{min-height:44px;color:var(--muted);background:var(--surface-soft);opacity:.6;border-radius:999px;align-items:center;padding:0 16px;font-weight:700;display:inline-flex}.pagination-gap{color:var(--ink-soft);align-items:center;padding:0 4px;font-weight:800;display:inline-flex}.article-detail{padding:36px 0 96px}.article-body{color:var(--charcoal);font-size:1.02rem;font-weight:500;line-height:1.95}.article-toc{border:1px solid var(--line);background:var(--surface-soft);border-radius:14px;margin:0 0 24px;padding:14px 18px}.article-toc-title{color:var(--main-deep);margin-bottom:6px;font-size:.86rem;font-weight:800}.article-toc ol{gap:5px;margin:0;padding-left:1.3em;display:grid}.article-toc a{color:var(--ink-soft);font-weight:700;text-decoration:none}.article-toc a:hover{color:var(--main-deep);text-decoration:underline}.article-body h2[id],.article-body h3[id]{scroll-margin-top:16px}.article-body a:not(.affiliate-link){color:var(--main-deep);text-underline-offset:2px;font-weight:700;text-decoration:underline}.article-body blockquote{border-left:4px solid var(--main);background:var(--surface-soft);color:var(--ink-soft);border-radius:0 12px 12px 0;margin:20px 0;padding:12px 16px;font-style:italic;line-height:1.85}.article-body h2,.article-body h3{color:var(--main-deep);margin-top:28px;line-height:1.45}.article-body h2{border-left:5px solid var(--apricot);padding-left:13px;font-size:1.35rem}.article-body h3{border-bottom:6px solid #b0c4de73;font-size:1.14rem;display:inline-block}.article-body ul,.article-body ol{margin:16px 0;padding-left:1.4em}.article-body li{margin:6px 0}.ad-placement{border:1px solid var(--milk-line);background:rgba(var(--surface-rgb), .72);border-radius:16px;align-content:start;gap:8px;width:100%;min-height:120px;margin:10px 0;padding:12px;display:grid;overflow:hidden}.ad-label,.affiliate-disclosure{color:var(--soft-text);letter-spacing:.08em;font-size:.68rem;font-weight:700}.affiliate-box{border:1px solid var(--milk-line);background:#fffaefcc;border-radius:18px;gap:12px;margin:28px 0;padding:18px;display:grid}.affiliate-box p{color:var(--soft-text);margin:0;font-size:.86rem;line-height:1.7}.affiliate-link{color:#fff;background:var(--main);border-radius:999px;justify-content:center;align-items:center;width:fit-content;min-height:44px;padding:0 18px;font-size:.88rem;font-weight:800;display:inline-flex}.affiliate-link:hover{color:#fff;background:var(--main-deep)}#app{background:linear-gradient(180deg, #fbfaf7d1, #fbfaf7f0), var(--preg-bg-grad);max-width:480px}.app-header{background:#fbfaf7e0;border-bottom-color:#6b8e7524;min-height:78px}.logo-icon,.quick-btn,.rating-btn,.mode-selector,input[type=number],input[type=text],input[type=date],input[type=file],select,textarea,.api-btn,.modal-close,.cms-row-actions button{border-radius:16px}.logo-icon{overflow:hidden}.logo-icon img{-o-object-fit:cover;object-fit:cover;width:100%;height:100%;display:block}.logo-text{color:var(--main-deep);font-weight:800}.mode-selector{border-color:var(--milk-line);background:var(--surface)}.header-actions{align-items:center;gap:8px;display:flex}.mode-btn{border-radius:12px}.mode-btn.active,body.childcare-active .mode-btn.active{background:var(--main);box-shadow:0 10px 22px var(--main-shadow)}.hamburger-btn{border:1px solid var(--milk-line);background:var(--surface);cursor:pointer;border-radius:16px;place-content:center;gap:4px;width:44px;height:44px;min-height:44px;display:grid;box-shadow:0 10px 20px #4a6b5214}.hamburger-btn span{background:var(--main-deep);border-radius:999px;width:18px;height:2px;display:block}.hamburger-btn.active,.hamburger-btn:hover{border-color:var(--main);background:var(--main-soft)}.card{box-shadow:var(--shadow-soft);padding:20px}.card-title{color:var(--main-deep);font-size:1rem}.card-title:before,body.childcare-active .card-title:before{background:var(--main);box-shadow:0 0 0 6px var(--main-ring)}.countdown-card{background:linear-gradient(#ffffffeb,#fff4eee6),linear-gradient(135deg,#e8a3822e,#6b8e751f)}.days-left{color:var(--main-deep)}.progress-bar{background:linear-gradient(90deg, var(--main), var(--apricot))}.birth-trigger-btn,.submit-btn,body.childcare-active .submit-btn{background:var(--main-deep);box-shadow:0 12px 24px var(--main-shadow);border-radius:18px}.birth-trigger-btn:hover,.submit-btn:hover,body.childcare-active .submit-btn:hover{background:var(--main-deep);filter:brightness(.94)}input:focus,select:focus,textarea:focus,body.childcare-active input:focus,body.childcare-active select:focus,body.childcare-active textarea:focus{border-color:var(--main);box-shadow:0 0 0 4px var(--main-ring)}.rating-btn.active{background:#fff2ea;border-color:#e8a382ad}.checkbox-container input:checked~.checkmark{border-color:var(--main);background:var(--main)}.category-badge{color:var(--main-deep);background:var(--main-soft)}.baby-info-card{background:linear-gradient(#fffffff0,#eef5eceb),linear-gradient(135deg,#6b8e7524,#b0c4de2e)}.baby-age{color:var(--main-deep)}.quick-record-card{margin-top:18px}.quick-grid,.quick-record-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:9px;margin-inline:0;padding-bottom:0;display:grid;overflow:visible}.quick-btn{border-color:var(--milk-line);background:var(--surface);min-width:0;min-height:82px;box-shadow:0 10px 20px #4a6b5214}.quick-btn:hover{border-color:var(--main);background:var(--child-primary-light)}.quick-icon{background:var(--surface-warm);border-radius:999px;place-items:center;width:38px;height:38px;display:grid}.quick-label{font-size:.74rem;line-height:1.2}.logs-list-card,.quick-record-card{gap:14px;display:grid}.timeline{gap:10px}.timeline-item{grid-template-columns:42px minmax(0,1fr);align-items:start}.timeline-item:has(>.timeline-delete-btn){grid-template-columns:42px minmax(0,1fr) auto auto}.timeline-icon{z-index:1;background:var(--surface-warm);border:1px solid #6b8e7529;border-radius:999px;place-items:center;width:42px;height:42px;font-size:1.18rem;line-height:1;display:grid;position:relative;box-shadow:0 8px 18px #4a6b5214}.timeline-header{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.timeline-header strong{min-width:0;color:var(--charcoal);font-size:.9rem;line-height:1.45}.timeline-header span{color:var(--soft-text);white-space:nowrap;flex:none;font-size:.74rem;font-weight:800}.timeline-content p{color:var(--soft-text);margin:6px 0 0;font-size:.84rem;line-height:1.55}.timeline-content small{color:var(--soft-text);margin-top:5px;font-size:.72rem;font-weight:700;display:block}.timeline-delete-btn{color:#a63339;cursor:pointer;background:#c4414814;border:1px solid #c441482e;border-radius:999px;align-self:center;min-height:34px;padding:0 10px;font-size:.72rem;font-weight:800;position:static}.timeline-delete-btn:hover{color:#fff;background:#c44148}.summary-card,.graph-card{gap:14px;display:grid}.summary-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.summary-item{border-radius:16px;min-height:84px;padding:10px}.summary-item strong{font-size:1.22rem}.graph-controls{border:1px solid var(--milk-line);background:rgba(var(--surface-rgb), .72);border-radius:18px;grid-template-columns:1fr;gap:10px;padding:10px;display:grid}.graph-share-actions{border-top:1px solid color-mix(in srgb, var(--main) 16%, transparent);justify-content:flex-end;align-items:center;margin-top:14px;padding-top:12px;display:flex}.weekly-share-actions{grid-column:1/-1;margin-inline:4px}.graph-share-button{color:#fff;background:linear-gradient(135deg, var(--main), var(--main-deep));min-height:40px;box-shadow:0 7px 18px var(--main-shadow);white-space:nowrap;cursor:pointer;border:0;border-radius:13px;justify-content:center;align-items:center;gap:6px;padding:0 15px;font-size:.76rem;font-weight:900;display:inline-flex}.graph-share-button span{font-size:1rem}.graph-share-button:disabled{cursor:wait;opacity:.64}@media (width<=390px){.graph-share-actions .graph-share-button{width:100%}}.graph-control-group{gap:7px;min-width:0;display:grid}.graph-control-group>span{color:var(--soft-text);font-size:.74rem;font-weight:800}.graph-segment{scrollbar-width:none;grid-auto-columns:minmax(62px,1fr);grid-auto-flow:column;gap:6px;display:grid;overflow-x:auto}.graph-segment::-webkit-scrollbar{display:none}.graph-segment button{border:1px solid var(--milk-line);min-height:38px;color:var(--soft-text);background:var(--surface);white-space:nowrap;cursor:pointer;border-radius:13px;padding:0 10px;font-size:.78rem;font-weight:900}.graph-segment button.active,.graph-segment button:hover{color:var(--main-deep);border-color:var(--main);background:var(--child-primary-light)}.graph-filter-segment{scroll-snap-type:x mandatory;scroll-behavior:smooth;grid-auto-columns:max-content;justify-content:start;overflow-x:auto}.graph-filter-segment button{scroll-snap-align:start;min-width:68px}.graph-date-range{grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:end;gap:8px;display:grid}.graph-date-range label{min-width:0;color:var(--soft-text);gap:5px;font-size:.7rem;font-weight:800;display:grid}.graph-date-range input{border:1px solid var(--milk-line);width:100%;min-height:42px;color:var(--charcoal);background:var(--surface);border-radius:10px;padding:0 9px;font-size:.8rem;font-weight:800}.graph-date-separator{color:var(--soft-text);padding-bottom:11px;font-weight:800}.graph-controls label{min-width:0;color:var(--soft-text);gap:5px;font-size:.74rem;font-weight:800;display:grid}.graph-controls select{width:100%;min-height:42px;color:var(--charcoal);background:var(--surface);border-radius:14px;padding-inline:10px;font-size:.86rem;font-weight:800}.graph-card .chart-list,.metric-modal-list{gap:10px;display:grid}.metric-chart-list{gap:12px;display:grid}.graph-day-timeline-list{gap:10px;display:grid}.graph-day-timeline-list .day-timeline{border-color:var(--milk-line);background:rgba(var(--surface-rgb), .84)}.graph-day-timeline-list .day-timeline-track{margin-inline:3px}.graph-day-timeline-list .day-timeline-chips:empty{display:none}.metric-chart{border:1px solid var(--milk-line);background:var(--surface);border-radius:18px;padding:14px;box-shadow:0 10px 22px #4a6b520f}.metric-chart>small{color:var(--soft-text);font-size:.76rem;font-weight:800;line-height:1.45}.metric-line-chart{min-height:128px}.metric-line-area{fill:none;stroke:#6b8e7524;stroke-width:10px;stroke-linecap:round;stroke-linejoin:round}.metric-line-path{fill:none;stroke:currentColor;stroke-width:4px;stroke-linecap:round;stroke-linejoin:round}.graph-card .timeline-item,.metric-modal-list .timeline-item{grid-template-columns:38px minmax(0,1fr);gap:8px}.graph-card .timeline-item:has(>.timeline-delete-btn){grid-template-columns:38px minmax(0,1fr) auto auto}.graph-card .timeline-icon,.metric-modal-list .timeline-icon{width:38px;height:38px;font-size:1.08rem}.graph-card .timeline-content,.metric-modal-list .timeline-content{padding:10px 11px}.graph-card .timeline-delete-btn{min-height:32px;padding-inline:9px}.timeline-edit-btn{border:1px solid var(--main);min-height:32px;color:var(--main-deep);background:var(--surface);cursor:pointer;border-radius:8px;align-self:center;padding:0 10px;font-size:.74rem;font-weight:800}.timeline-edit-btn:hover{background:var(--child-primary-light)}.icon-action-btn{border:1px solid var(--milk-line);width:40px;min-width:40px;height:40px;min-height:40px;color:var(--main-deep);background:var(--surface);cursor:pointer;border-radius:8px;align-self:center;place-items:center;padding:0;transition:border-color .16s,color .16s,background .16s;display:inline-grid}.icon-action-btn>span{width:18px;height:18px}.icon-action-btn:hover{border-color:var(--main);color:var(--main-deep);background:var(--child-primary-light)}.icon-action-btn.danger{color:#b13e45;border-color:#c441483d}.icon-action-btn.danger:hover{color:#fff;background:#c44148;border-color:#c44148}.more-menu-card{gap:12px;display:grid}.more-menu-list{gap:10px;display:grid}.more-menu-item{border:1px solid var(--milk-line);min-height:72px;color:var(--charcoal);background:var(--surface);text-align:left;cursor:pointer;border-radius:18px;justify-items:start;gap:4px;padding:14px 16px;text-decoration:none;display:grid}.more-menu-item span{color:var(--main-deep);font-size:.98rem;font-weight:800}.more-menu-item small{color:var(--soft-text);font-size:.78rem;font-weight:700;line-height:1.45}.more-menu-item:hover{border-color:var(--main);background:var(--child-primary-light)}.more-menu-link{width:100%}.more-menu-link>span{align-items:center;gap:7px;display:inline-flex}.more-menu-link .more-menu-external{color:var(--soft-text);font-size:.8rem;font-weight:900}.app-version-row{min-height:46px;color:var(--soft-text);justify-content:space-between;align-items:center;gap:12px;padding:10px 14px 2px;font-size:.72rem;font-weight:800;display:flex}.app-version-row small{font-family:var(--font-english);letter-spacing:.04em}.mini-action-btn{border:1px solid var(--milk-line);min-height:36px;color:var(--main-deep);background:var(--surface);cursor:pointer;border-radius:999px;padding:0 14px;font-size:.78rem;font-weight:800}.mini-action-btn:hover{border-color:var(--main);background:var(--child-primary-light)}.mini-action-btn:disabled{color:var(--ink-soft);background:rgba(var(--surface-rgb), .54);cursor:not-allowed;opacity:.65}.icon-label-btn{justify-content:center;align-items:center;gap:6px;display:inline-flex}.icon-label-btn>span{width:16px;height:16px}.timeline-pager{justify-content:space-between;align-items:center;gap:10px;padding-top:4px;display:flex}.timeline-pager span{color:var(--ink-soft);white-space:nowrap;font-size:.78rem;font-weight:800}.graph-load-more{border:1px solid var(--milk-line);width:100%;min-height:44px;color:var(--main-deep);background:var(--surface);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:8px;font-weight:800;display:inline-flex}.graph-load-more small{color:var(--soft-text);font-size:.7rem}.first-food-card{gap:12px;display:grid}.first-food-progress-container{align-items:center;gap:16px;margin-bottom:20px;display:flex}.first-food-progress-value{color:var(--main-deep);font-size:1.15rem;font-weight:800;display:block}.first-food-progress-caption{color:var(--soft-text);font-size:.82rem;font-weight:700}.first-food-guide{border:1px solid var(--line);background:var(--surface-soft);color:var(--ink-soft);border-radius:12px;margin:-6px 0 4px;padding:10px 12px;font-size:.78rem;font-weight:700;line-height:1.6}.first-food-guide strong{color:var(--main-deep)}.first-food-check-icon{animation:.25s cubic-bezier(.175,.885,.32,1.275) both check-scale;display:inline-block}.achievement-card{gap:16px;display:grid}.achievement-lead{color:var(--soft-text);margin-top:5px;font-size:.78rem;font-weight:700}.achievement-note{color:var(--soft-text);background:var(--main-soft);border:1px solid #6b8e752e;border-radius:14px;padding:11px 13px;font-size:.74rem;font-weight:700;line-height:1.65}.achievement-progress{align-items:center;gap:16px;display:flex}.achievement-progress>div:last-child{gap:3px;display:grid}.achievement-progress>div:last-child strong{color:var(--main-deep);font-size:1.05rem}.achievement-progress>div:last-child span{color:var(--soft-text);font-size:.78rem;font-weight:700}.achievement-list{gap:8px;display:grid}.achievement-item{border:1px solid var(--milk-line);width:100%;color:inherit;background:rgba(var(--surface-rgb), .78);transition:border-color var(--transition-fast), background var(--transition-fast), opacity var(--transition-fast);border-radius:16px;display:grid}.achievement-item:hover{border-color:var(--main)}.achievement-item.saving{opacity:.6}.achievement-main{border-radius:inherit;width:100%;color:inherit;font:inherit;text-align:left;cursor:pointer;background:0 0;border:0;grid-template-columns:38px minmax(0,1fr);align-items:center;gap:11px;padding:11px 12px;display:grid}.achievement-main:hover:not(:disabled){background:var(--main-soft)}.achievement-main:disabled{cursor:default}.achievement-check{width:38px;height:38px;color:var(--soft-text);background:var(--surface-soft);border-radius:999px;place-items:center;font-size:.7rem;font-weight:900;display:grid}.achievement-item.done .achievement-check{color:#fff;background:var(--main)}.achievement-copy{gap:5px;min-width:0;display:grid}.achievement-copy>span:first-child{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.achievement-copy strong{color:var(--charcoal);font-size:.9rem}.achievement-item.done .achievement-copy strong{color:var(--main-deep)}.achievement-copy em{color:var(--main-deep);background:var(--main-soft);border-radius:999px;padding:2px 7px;font-size:.65rem;font-style:normal;font-weight:800}.achievement-copy small{color:var(--soft-text);font-size:.75rem;font-weight:700;line-height:1.55}.achievement-copy .achievement-date{color:var(--main-deep);font-weight:900}.achievement-actions{border-top:1px solid var(--milk-line);justify-content:flex-end;gap:8px;padding:9px 12px;display:flex}.achievement-actions button{border:1px solid var(--milk-line);min-height:34px;color:var(--main-deep);background:var(--surface);cursor:pointer;border-radius:10px;padding:0 11px;font-size:.72rem;font-weight:800}.achievement-actions button.danger{color:#a63339;border-color:#c4414847}.achievement-date-editor{border-top:1px solid var(--milk-line);background:var(--main-soft);gap:10px;padding:12px;display:grid}.achievement-date-editor label{color:var(--main-deep);gap:5px;font-size:.72rem;font-weight:800;display:grid}.achievement-date-editor input{border:1px solid var(--milk-line);min-height:42px;color:var(--charcoal);background:var(--surface);border-radius:11px;padding:0 10px}.achievement-date-editor>div{justify-content:flex-end;gap:8px;display:flex}.achievement-date-editor .achievement-save{color:#fff;border-color:var(--main);background:var(--main)}.first-food-checker{gap:12px;display:grid}.first-food-progress,.first-food-next{border:1px solid var(--milk-line);background:var(--surface);border-radius:18px;gap:4px;padding:14px;display:grid}.first-food-progress{-moz-column-gap:12px;grid-template-columns:auto minmax(0,1fr);align-items:center;column-gap:12px}.first-food-progress strong{color:#fff;background:var(--main);border-radius:16px;place-items:center;min-width:68px;min-height:52px;font-size:1.08rem;display:grid}.first-food-progress span,.first-food-next span,.first-food-next small,.first-food-item small{color:var(--soft-text);font-size:.78rem;font-weight:700;line-height:1.45}.first-food-next strong{color:var(--main-deep);font-size:1.12rem;line-height:1.35}.first-food-next.completed{background:var(--child-primary-light)}.first-food-list{gap:8px;display:grid}.first-food-tools{gap:9px;display:grid}.first-food-search{color:var(--soft-text);gap:6px;font-size:.76rem;font-weight:800;display:grid}.first-food-search input{border:1px solid var(--milk-line);width:100%;min-height:44px;color:var(--charcoal);background:var(--surface);border-radius:14px;padding:0 12px}.first-food-categories{scrollbar-width:none;gap:7px;padding-bottom:2px;display:flex;overflow-x:auto}.first-food-categories::-webkit-scrollbar{display:none}.first-food-categories button{border:1px solid var(--milk-line);min-height:34px;color:var(--soft-text);background:var(--surface);border-radius:999px;flex:none;padding:0 12px;font-size:.74rem;font-weight:800}.first-food-categories button.active{color:#fff;border-color:var(--main);background:var(--main)}.first-food-tools>small{color:var(--soft-text);font-size:.72rem;font-weight:800}.first-food-item{-moz-column-gap:10px;border:1px solid var(--milk-line);background:rgba(var(--surface-rgb), .72);border-radius:16px;grid-template-columns:36px minmax(0,1fr);align-items:center;column-gap:10px;padding:10px 12px;display:grid}button.first-food-item{width:100%;color:inherit;font:inherit;text-align:left;cursor:pointer}button.first-food-item:hover{border-color:var(--main);background:#f7fbf6}.first-food-item>span{width:36px;height:36px;color:var(--soft-text);background:var(--surface-soft);border-radius:999px;grid-row:span 2;place-items:center;font-size:.72rem;font-weight:800;display:grid}.first-food-item.done>span{color:#fff;background:var(--main)}.first-food-item strong{min-width:0;color:var(--charcoal);font-size:.9rem;line-height:1.35}.first-food-item-copy{gap:5px;min-width:0;display:grid}.first-food-item-copy>div{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.first-food-item-copy em{color:var(--main-deep);background:var(--child-primary-light);border-radius:999px;padding:2px 7px;font-size:.66rem;font-style:normal;font-weight:800}.first-food-item-copy em.allergy{color:#a94b45;background:#c4414817}.first-food-item-copy .first-food-recorded{color:var(--main-deep);font-weight:900}.timeline-content{border-radius:16px}.timeline-badge{border-radius:999px}.timeline-detail{color:var(--color-text-main);margin-top:4px;font-size:.85rem;font-style:italic;line-height:1.55}.app-footer{height:auto;padding:10px 14px max(10px, env(safe-area-inset-bottom));background:#fbfaf7f5;flex-direction:column;justify-content:center;align-items:stretch;gap:8px}.record-fab{right:16px;bottom:calc(96px + env(safe-area-inset-bottom));z-index:70;color:#fff;background:var(--main-deep);min-height:52px;box-shadow:0 14px 30px var(--main-shadow,#4a6b524d);cursor:pointer;transition:transform var(--transition-fast), box-shadow var(--transition-fast);border:0;border-radius:999px;align-items:center;gap:6px;padding:0 20px 0 17px;font-size:.92rem;font-weight:800;animation:.2s cubic-bezier(.2,.8,.2,1) fab-pop;display:inline-flex;position:fixed}.record-fab:hover{box-shadow:0 18px 34px var(--main-shadow,#4a6b5257);transform:translateY(-1px)}.record-fab:active{transform:scale(.97)}.record-fab-icon{place-items:center;width:22px;height:22px;display:inline-grid}.record-fab-icon svg{fill:none;stroke:currentColor;stroke-width:2.4px;stroke-linecap:round;width:22px;height:22px}.record-fab-label{line-height:1}@media (width>=481px){.record-fab{right:calc(50% - 224px)}}@keyframes fab-pop{0%{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}.sync-status{justify-content:center;min-height:20px;font-size:.72rem}.bottom-nav{border:1px solid var(--milk-line);background:var(--surface);border-radius:24px;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;min-height:60px;padding:8px;display:grid;box-shadow:0 12px 26px #4a6b5224}.bottom-nav-btn{min-height:46px;color:var(--soft-text);cursor:pointer;background:0 0;border:0;border-radius:18px;place-items:center;gap:2px;font-size:.7rem;font-weight:700;display:grid}.bottom-nav-btn.active,.bottom-nav-btn:hover{color:var(--main-deep);background:var(--child-primary-light)}.bottom-nav-icon{font-size:1.2rem;line-height:1}#app{height:100vh;max-height:100vh;overflow:hidden}.app-header{flex:none;position:sticky;top:0}.app-main{overscroll-behavior:contain;min-height:0;overflow-y:auto}.app-footer{flex:none;position:sticky;bottom:0}.settings-mode-switch{border:1px solid var(--milk-line);background:var(--surface);border-radius:18px;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:6px;display:grid}.settings-mode-switch .mode-btn{min-height:44px}.settings-theme-switch{grid-template-columns:repeat(3,minmax(0,1fr))}.settings-theme-note{color:var(--soft-text);margin-bottom:10px;font-size:.8rem;font-weight:700;line-height:1.6}.settings-child-switch{color:var(--soft-text);gap:7px;font-size:.78rem;font-weight:800;display:grid}.settings-child-switch select{border:1px solid var(--milk-line);width:100%;min-height:46px;color:var(--charcoal);background:var(--surface);border-radius:16px;padding:0 12px;font-size:.92rem;font-weight:800}.settings-add-child-form{border:1px dashed var(--main);background:#eef5ec9e;border-radius:18px;gap:12px;padding:14px;display:grid}.settings-add-child-form .form-group{margin-bottom:0}.settings-child-status{gap:7px;display:grid}.settings-child-status>span{color:var(--soft-text);font-size:.78rem;font-weight:800}.settings-demo-card{background:#eef5eca8;border-style:dashed}.settings-demo-card>div{gap:5px;display:grid}.settings-demo-card p{color:var(--soft-text);margin:0;font-size:.8rem;font-weight:700;line-height:1.55}.ranking-card{gap:16px;display:grid}.ranking-subtitle{color:var(--soft-text);margin-top:4px;font-size:.78rem;line-height:1.4}.ranking-tabs{scrollbar-width:none;gap:8px;padding-bottom:2px;display:flex;overflow-x:auto}.ranking-tabs::-webkit-scrollbar{display:none}.ranking-tab{border:1px solid var(--milk-line);min-width:106px;min-height:48px;color:var(--soft-text);background:var(--surface);text-align:left;cursor:pointer;border-radius:16px;flex:none;align-content:center;gap:2px;padding:7px 12px;font-size:.78rem;font-weight:800;display:grid}.ranking-tab span,.ranking-tab small{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.ranking-tab small{color:inherit;opacity:.72;font-size:.68rem}.ranking-tab.active,.ranking-tab:hover{color:var(--main-deep);border-color:var(--main);background:var(--child-primary-light)}.ranking-category-list{gap:10px;display:grid}.ranking-category-card{border:1px solid var(--milk-line);min-height:92px;color:var(--charcoal);background:var(--surface);text-align:left;cursor:pointer;transition:border-color var(--transition-fast), background var(--transition-fast), transform var(--transition-fast);border-radius:18px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:4px 12px;padding:14px;display:grid;box-shadow:0 10px 20px #4a6b520f}.ranking-category-card:hover{border-color:var(--main);background:var(--child-primary-light);transform:translateY(-1px)}.ranking-category-label{min-width:0;color:var(--main-deep);font-size:.98rem;font-weight:900;line-height:1.35}.ranking-category-card strong{color:var(--main-deep);white-space:nowrap;grid-row:span 2;justify-self:end;font-size:1.12rem;font-weight:900}.ranking-category-card small,.ranking-category-card em,.ranking-message{color:var(--soft-text);font-size:.76rem;font-weight:800;line-height:1.45}.ranking-category-card em{width:fit-content;color:var(--main-deep);background:var(--child-primary-light);border-radius:999px;grid-column:1/-1;padding:3px 8px;font-style:normal}.ranking-detail-header{grid-template-columns:auto minmax(0,1fr);align-items:center;gap:10px;display:grid}.ranking-detail-header span{min-width:0;color:var(--main-deep);text-overflow:ellipsis;white-space:nowrap;font-size:.95rem;font-weight:900;overflow:hidden}.ranking-back-btn{min-height:34px;padding-inline:12px}.ranking-summary{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.ranking-summary>div{background:#fbfcf7;border:1px solid #6b8e752e;border-radius:16px;align-content:center;gap:3px;min-height:58px;padding:10px;display:grid}.ranking-summary-label{color:var(--soft-text);font-size:.68rem;font-weight:800}.ranking-summary strong{min-width:0;color:var(--charcoal);text-overflow:ellipsis;white-space:nowrap;font-size:.9rem;font-weight:900;overflow:hidden}.ranking-list{gap:12px;display:grid}.ranking-item{border:1px solid var(--milk-line);background:var(--surface);border-radius:20px;grid-template-columns:46px minmax(0,1fr);align-items:start;gap:12px;padding:14px;display:grid}.ranking-item.top{background:#fffaf5;border-color:#c45f5557}.ranking-item.voted{background:var(--child-primary-light);border-color:#6b8e7580}.ranking-rank{color:#fff;background:var(--main);border-radius:16px;place-items:center;width:46px;height:46px;font-size:.82rem;font-weight:900;display:grid}.ranking-item.top .ranking-rank{background:#c45f55}.ranking-main{gap:8px;min-width:0;display:grid}.ranking-item-header{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.ranking-item-header>div{gap:4px;min-width:0;display:grid}.ranking-item-header strong{min-width:0;color:var(--charcoal);font-size:.98rem;line-height:1.35}.ranking-vote-count,.ranking-updated{color:var(--soft-text);font-size:.76rem;font-weight:800}.ranking-voted-label{width:fit-content;color:var(--main-deep);background:var(--surface);border-radius:999px;padding:3px 8px;font-size:.68rem;font-weight:900}.ranking-main p{color:var(--soft-text);font-size:.78rem;line-height:1.45}.ranking-meter-row{grid-template-columns:minmax(0,1fr) 38px;align-items:center;gap:8px;display:grid}.ranking-meter-row>span{color:var(--soft-text);text-align:right;font-size:.72rem;font-weight:900}.ranking-meter{background:#f1eee6;border-radius:999px;height:8px;overflow:hidden}.ranking-meter span{border-radius:inherit;background:linear-gradient(90deg, var(--main), var(--apricot));height:100%;transition:width .22s;display:block}.ranking-vote-btn{color:#fff;background:var(--main);cursor:pointer;border:0;border-radius:14px;grid-column:2;width:100%;min-height:42px;padding:0 12px;font-size:.78rem;font-weight:800}.ranking-vote-btn:disabled{opacity:.6}.ranking-item.voted .ranking-vote-btn{color:var(--main-deep);background:var(--surface)}.ranking-vote-btn.is-voted{opacity:1;cursor:pointer;color:var(--main-deep);background:var(--main-soft);border:1px solid var(--main)}.ranking-vote-hint{color:var(--ink-soft);margin:2px 0 0;font-size:.74rem;font-weight:700;line-height:1.5}.ranking-updated{text-align:right}.ranking-message{color:#a94b45;text-align:center;margin:0}.cms-auth,.cms-editor,.cms-posts{border-radius:20px;width:min(920px,100% - 28px)}.cms-editor{padding:18px}.ranking-admin-layout{grid-template-columns:minmax(280px,360px) minmax(0,1fr);align-items:start}.ranking-admin-form{align-content:start}.checkbox-label{min-height:44px;color:var(--charcoal);align-items:center;gap:8px;font-weight:800;display:inline-flex}.checkbox-label input{width:18px;height:18px}.cms-editor label,.registration-card label{gap:8px}.cms-fields,.cms-post-row{grid-template-columns:1fr}.cms-post-row{border:1px solid var(--milk-line);background:var(--surface);border-radius:18px;padding:16px}.cms-row-actions{justify-content:stretch}.cms-row-actions a:not(.admin-icon-btn),.cms-row-actions button:not(.admin-icon-btn){flex:120px;justify-content:center}.cms-row-actions .admin-icon-btn{flex:0 0 38px}@media (width>=720px){.portal-hero{grid-template-columns:minmax(0,1fr) minmax(320px,.45fr);align-items:center}.portal-copy{grid-column:1}.portal-visual{grid-area:1/2/span 2;align-self:center}.portal-cta{grid-area:2/1}.portal-feature-grid{grid-column:1/-1;grid-template-columns:repeat(3,minmax(0,1fr))}.portal-app-section{grid-template-columns:minmax(0,.9fr) minmax(320px,1.1fr);gap:clamp(48px,8vw,92px)}.portal-screen-grid{grid-template-columns:repeat(3,minmax(0,1fr));grid-auto-flow:row;gap:18px;margin-inline:0;padding:2px 0 18px;overflow:visible}.portal-screen-grid figure:nth-child(4),.portal-screen-grid figure:nth-child(5){transform:translate(50%)}.portal-article-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.portal-section-heading{grid-template-columns:minmax(0,1.3fr) minmax(280px,.7fr);align-items:end}.portal-final-cta{grid-template-columns:minmax(0,1fr) auto;align-items:center}.site-actions{display:flex}.article-list{grid-template-columns:repeat(2,minmax(0,1fr))}.category-filter,.pagination{margin-inline:0;padding-inline:0}.cms-fields{grid-template-columns:repeat(2,minmax(0,1fr))}.cms-post-row{grid-template-columns:minmax(0,1fr) auto}}@media (width<=480px){.site-nav,.portal-hero,.portal-lp-section,.portal-final-cta,.page-heading,.article-list,.article-detail,.cms-auth,.cms-editor,.cms-posts{width:calc(100% - 28px)}.portal-hero{min-height:calc(100svh - 64px)}.portal-hero-screens{height:360px}.portal-hero-screens .portal-hero-screen{width:61%}.portal-hero-screen.pregnancy{height:305px}.portal-hero-screen.childcare{height:310px}.portal-cta{z-index:4;position:sticky;bottom:14px}.app-header{flex-direction:row;align-items:center}.mode-selector{width:auto}.quick-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width<=860px){.admin-shell .site-nav{align-items:stretch;gap:12px;width:min(920px,100% - 28px)}.admin-shell .site-links{grid-template-columns:repeat(2,minmax(0,1fr));justify-content:stretch;width:100%;display:grid}.admin-shell .site-links a,.admin-shell .site-links button{text-align:center;justify-content:center;min-width:0;padding-inline:10px}.ranking-admin-layout,.cms-layout{grid-template-columns:minmax(0,1fr)}.cms-toolbar{flex-direction:column;align-items:stretch}.cms-toolbar-actions,.page-heading .site-actions,.cms-editor .site-actions{grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.cms-toolbar-actions a,.cms-toolbar-actions button,.page-heading .site-actions a,.page-heading .site-actions button,.cms-editor .site-actions a,.cms-editor .site-actions button{justify-content:center;width:100%}}@media (width<=560px){.admin-shell .site-links,.cms-toolbar-actions,.page-heading .site-actions,.cms-editor .site-actions,.cms-fields{grid-template-columns:1fr}.admin-heading{padding-top:28px}.cms-post-row{gap:12px}.cms-row-actions{grid-template-columns:1fr;display:grid}.cms-row-actions a:not(.admin-icon-btn),.cms-row-actions button:not(.admin-icon-btn){width:100%;min-height:44px}.cms-row-actions:has(.admin-icon-btn){grid-template-columns:none;justify-content:flex-start;display:flex}.cms-row-actions .admin-icon-btn{flex-basis:44px;width:44px;height:44px;min-height:44px}.confirm-dialog-content{width:calc(100% - 28px)}}body.site-page{background:linear-gradient(#fbfaf7f0,#fbfaf7fc),radial-gradient(circle at 12% 0,#e8a3822e,#0000 34%),linear-gradient(145deg,#fbfaf7 0%,#f4f1e9 52%,#edf4ec 100%)}.site-nav{z-index:30;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#fbfaf7e0;border-bottom:1px solid #6b8e7524;min-height:72px;position:sticky;top:0}.site-links{align-items:center}body.site-page .site-nav .site-links .site-app-link{border-color:var(--main);box-shadow:0 10px 22px #4a6b522e;color:#fff!important;background:var(--main,#6b8e75)!important}body.site-page .site-nav .site-links .site-app-link:hover,body.site-page .site-nav .site-links .site-app-link[aria-current=page]{border-color:var(--main-deep);color:#fff!important;background:var(--main-deep,#4a6b52)!important}.portal-hero{min-height:auto;padding-top:clamp(34px,7vh,72px)}.portal-visual{border-radius:22px}.portal-visual:after{content:"家族で共有"}.portal-feature-grid article{border-radius:18px}.article-list article{transition:border-color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast)}.article-list article:hover{border-color:#6b8e7557;transform:translateY(-2px);box-shadow:0 18px 42px #4a6b5221}.article-detail{max-width:840px}.contact-form{background:rgba(var(--surface-rgb), .76);border:1px solid #6b8e7538;border-radius:20px;gap:18px;margin:26px 0;padding:clamp(20px,4vw,32px);display:grid;box-shadow:0 18px 44px #4a6b5217}.contact-response-notice{background:#eef5efc7;border:1px solid #6b8e754d;border-radius:16px;gap:7px;margin:20px 0 4px;padding:16px 18px;display:grid}.contact-response-notice strong{color:var(--main-deep);font-size:.92rem}.contact-response-notice p{color:var(--soft-text);margin:0;font-size:.82rem;line-height:1.75}.contact-form-field{gap:8px;display:grid}.contact-form-field label{color:var(--charcoal);font-size:.9rem;font-weight:800}.contact-form-field label span{color:#a94b45;margin-left:6px;font-size:.72rem}.contact-form-field label small{color:var(--muted);margin-left:6px;font-weight:600}.contact-form-field input,.contact-form-field select,.contact-form-field textarea{border:1px solid var(--milk-line);background:var(--surface);width:100%;color:var(--charcoal);border-radius:12px}.contact-form-field textarea{resize:vertical;min-height:180px}.contact-form-field>small,.contact-mail-fallback{color:var(--muted);font-size:.78rem;line-height:1.7}.contact-form-consent{color:var(--soft-text);align-items:flex-start;gap:10px;font-size:.82rem;line-height:1.7;display:flex}.contact-form-consent input{width:18px;height:18px;accent-color:var(--main);flex:none;margin-top:4px}.contact-submit{cursor:pointer;border:0}.contact-submit:disabled{cursor:wait;opacity:.62}.contact-form-status{border-radius:14px;outline:none;min-height:0;padding:14px 16px;font-size:.84rem;font-weight:700;line-height:1.6;display:none;margin:0!important}.contact-form-status.success{color:var(--main-deep);background:#e8f5ebe6;border:1px solid #4a825847;gap:3px;display:grid}.contact-form-status.error{color:#a94b45;background:#ffefedeb;border:1px solid #a94b4540;display:block}.contact-form-status strong{font-size:.92rem}.contact-form-status strong span{color:#fff;background:var(--main);border-radius:50%;place-items:center;width:22px;height:22px;margin-right:4px;line-height:1;display:inline-grid}.contact-form[aria-busy=true]{cursor:wait}.contact-form[aria-busy=true] .contact-form-field,.contact-form[aria-busy=true] .contact-form-consent{opacity:.72}.contact-form-trap{width:1px;height:1px;position:absolute;left:-10000px;overflow:hidden}.site-footer{grid-template-columns:minmax(220px,1fr) auto;align-items:start;gap:24px;margin-top:12px;padding:30px 0 46px;display:grid}.site-footer-brand{gap:8px;display:grid}.site-footer-brand p{max-width:360px;color:var(--soft-text);font-size:.86rem;font-weight:700;line-height:1.7}.site-footer nav{justify-content:flex-end}#app{height:100dvh;min-height:100dvh;max-height:100dvh}.app-header{min-height:calc(62px + env(safe-area-inset-top));padding:calc(env(safe-area-inset-top) + 10px) 16px 10px;flex-direction:row;align-items:center;overflow:hidden}.app-brand-copy{gap:3px;min-width:0;display:grid}.app-header-tagline{color:var(--soft-text);text-overflow:ellipsis;white-space:nowrap;font-size:.68rem;font-weight:700;line-height:1.2;overflow:hidden}.app-header .header-actions{flex:none;min-width:0;margin-left:auto}.app-header .sync-indicator{min-width:0;max-width:170px;color:var(--soft-text);justify-content:flex-end;align-items:center;gap:6px;font-size:.68rem;font-weight:800;display:flex}.app-header .sync-indicator.error{color:#a94b45}.app-header .sync-indicator.error .sync-dot{background:#c45f55}.app-header .sync-label{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.logo{grid-template-columns:34px minmax(0,1fr);gap:9px;max-width:min(100%,230px)}.logo-icon{flex:none;width:34px;height:34px}.logo-text{text-overflow:ellipsis;white-space:nowrap;font-size:1.06rem;line-height:1.2;overflow:hidden}.hamburger-btn{flex:none;width:42px;height:42px;min-height:42px}.app-main{padding:14px 14px 118px}.login-required-panel{padding:max(22px, env(safe-area-inset-top)) 20px max(22px, env(safe-area-inset-bottom));background:radial-gradient(circle at 50% 6%,#e8a38238,#0000 32%),linear-gradient(#fbfaf757,#fbfaf700)}.login-required-card{text-align:center;background:linear-gradient(#fffffff0,#fbfaf7e6),linear-gradient(135deg,#e8a38229,#6b8e751a);border-radius:22px;justify-items:center;gap:12px;max-width:380px;padding:24px 22px}.login-card-kicker{color:var(--main);font-family:var(--font-english);text-transform:uppercase;font-size:.74rem;font-weight:800}.login-card-character{filter:drop-shadow(0 12px 18px #4a6b521f);width:min(190px,58vw);margin:-2px auto 0;display:block}.login-required-card h2{color:var(--main-deep);font-size:clamp(1.55rem,7vw,2rem);line-height:1.24}.login-required-card p{max-width:310px;font-size:.9rem;line-height:1.75}.login-actions{width:100%;margin-top:4px}.external-browser-guide{text-align:left;background:#fff7f4;border:1px solid #a94b453d;border-radius:16px;gap:12px;width:100%;margin-top:4px;padding:16px;display:grid}.external-browser-guide strong{color:#8f403b;font-size:.98rem}.external-browser-guide p,.external-browser-guide ol{color:var(--soft-text);margin:0;font-size:.82rem;line-height:1.7}.external-browser-guide ol{padding-left:1.35rem}.external-browser-guide .mini-action-btn{justify-content:center;width:100%}.login-provider-btn{border-radius:18px;justify-content:center;align-items:center;min-height:54px;text-decoration:none;display:flex;box-shadow:0 12px 24px #4a6b521f}.login-provider-btn.google-login{color:var(--charcoal);background:var(--surface);border:1px solid var(--milk-line)}.login-provider-btn.line-login{background:#06c755}.login-card-note{color:var(--muted)!important;font-size:.76rem!important;line-height:1.6!important}.registration-step-form,.registration-choice{gap:14px;display:grid}.registration-option-group{border:0;gap:8px;margin:0;padding:0;display:grid}.registration-option-group legend{color:var(--charcoal);margin-bottom:4px;font-size:.9rem;font-weight:800}.registration-radio{border:1px solid var(--milk-line);background:var(--surface);cursor:pointer;border-radius:14px;align-items:center;gap:10px;min-height:54px;padding:10px 12px;display:flex}.registration-radio:has(input:checked){border-color:var(--main);background:var(--child-primary-light);box-shadow:0 0 0 2px #6b8e751f}.registration-radio input{width:18px;height:18px;accent-color:var(--main)}.registration-radio span{gap:2px;display:grid}.registration-radio strong{color:var(--charcoal);font-size:.9rem}.registration-radio small{color:var(--soft-text);font-size:.76rem}.registration-choice{text-align:center}.registration-choice-btn{border:1px solid var(--milk-line);min-height:76px;color:var(--charcoal);background:var(--surface);text-align:left;cursor:pointer;transition:border var(--transition-fast), background var(--transition-fast), transform var(--transition-fast);border-radius:18px;justify-items:start;gap:4px;padding:15px 16px;display:grid}.registration-choice-btn strong{color:var(--main-deep);font-size:.98rem;line-height:1.35}.registration-choice-btn span{color:var(--soft-text);font-size:.78rem;font-weight:700;line-height:1.45}.registration-choice-btn:hover{border-color:var(--main);background:var(--child-primary-light);transform:translateY(-1px)}.registration-actions,.invite-actions{grid-template-columns:minmax(0,.42fr) minmax(0,1fr);gap:10px;display:grid}.invite-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.invite-qr-code{aspect-ratio:1;border:1px solid var(--milk-line);background:var(--surface);border-radius:18px;justify-self:center;width:min(210px,70vw);padding:10px;box-shadow:0 10px 22px #4a6b521a}.qr-reader-panel{gap:10px;display:grid}.qr-reader-stage{display:grid;position:relative}.qr-reader-video{aspect-ratio:1;border:1px solid var(--milk-line);-o-object-fit:cover;object-fit:cover;background:#111;border-radius:18px;width:100%}.qr-reader-frame{aspect-ratio:1;pointer-events:none;width:62%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.qr-reader-frame span{border:3px solid #ffffffeb;width:26px;height:26px;position:absolute}.qr-reader-frame span:first-child{border-bottom:0;border-right:0;border-top-left-radius:8px;top:0;left:0}.qr-reader-frame span:nth-child(2){border-bottom:0;border-left:0;border-top-right-radius:8px;top:0;right:0}.qr-reader-frame span:nth-child(3){border-top:0;border-right:0;border-bottom-left-radius:8px;bottom:0;left:0}.qr-reader-frame span:nth-child(4){border-top:0;border-left:0;border-bottom-right-radius:8px;bottom:0;right:0}.qr-reader-hint{color:#fff;white-space:nowrap;background:#1111119e;border-radius:999px;margin:0;padding:5px 12px;font-size:.74rem;font-weight:700;position:absolute;bottom:12px;left:50%;transform:translate(-50%)}.registration-field-help{color:var(--ink-soft);margin-top:4px;font-size:.72rem;font-weight:600;line-height:1.5;display:block}.line-share-link{color:#fff;background:#06c755;border:1px solid #06c755;justify-content:center;align-items:center;min-height:36px;text-decoration:none;display:inline-flex}.line-share-link:hover{color:#fff;background:#05b64d;border-color:#05b64d}.invite-actions .mini-action-btn,.settings-actions .submit-btn,.ranking-vote-btn,.app-confirm-primary,.login-provider-btn,.submit-btn{border-style:solid;border-width:1px}.submit-btn{border-color:var(--main)}.logout-action{color:var(--main-deep);border-color:var(--milk-line);background:var(--surface);box-shadow:none}.danger-action{background:#c44148;border-color:#c44148}.ranking-vote-btn,.ranking-item.voted .ranking-vote-btn{border-color:var(--main)}.app-confirm-dialog{text-align:center;justify-items:center;width:min(100%,360px)}.app-confirm-character{-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 8px 14px #4a6b521f);width:112px;height:86px;margin:-8px 0 -4px}.app-confirm-icon{width:44px;height:44px;color:var(--main-deep);background:var(--child-primary-light);border-radius:999px;place-items:center;font-size:1.1rem;font-weight:900;display:grid}.app-confirm-icon.danger{color:#a63339;background:#c441481a}.app-confirm-copy{gap:6px;display:grid}.app-confirm-copy h3{color:var(--charcoal);font-size:1.08rem;line-height:1.35}.app-confirm-copy p{color:var(--soft-text);font-size:.88rem;font-weight:700;line-height:1.65}.app-confirm-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;width:100%;display:grid}.app-confirm-primary{color:#fff;border-color:var(--main);background:var(--main)}.app-confirm-primary.danger{background:#c44148;border-color:#c44148}body{justify-content:center}#app{--app-edge:14px;--app-gap:14px;--card-pad:18px;--section-gap:14px;flex:none;width:min(100%,480px);margin-inline:auto}.app-main{align-content:start;gap:var(--section-gap);display:grid}.mode-view,.app-section-view{min-width:0}.mode-view.active,.app-section-view.active{gap:var(--section-gap);display:grid}.card{padding:var(--card-pad);gap:14px;display:grid}.card-title,.card-title-row{margin-bottom:0}.card-title-row{align-items:start;gap:10px}.quick-record-card,.logs-list-card,.summary-card,.graph-card,.more-menu-card,.first-food-card,.ranking-card,.settings-card{gap:14px}.quick-record-grid,.summary-grid,.ranking-category-tabs,.ranking-summary-grid,.first-food-list,.more-menu-list,.timeline,.chart-list,.metric-modal-list,.settings-form,.settings-list{gap:10px}.loading-placeholder{border-radius:16px;padding:16px}.timeline-content{padding:11px 12px}.timeline-pager{margin-top:2px;padding-top:8px}.modal-content{gap:14px;padding:20px;display:grid}.modal-header{margin-bottom:0}.app-auth-screen{padding:calc(env(safe-area-inset-top) + 20px) 18px calc(env(safe-area-inset-bottom) + 20px)}.login-required-card,.registration-card{gap:14px;padding:24px 22px}.site-nav,.page-heading,.article-list,.article-detail,.admin-panel,.cms-auth,.cms-layout,.cms-posts,.cms-editor{width:min(1040px,100% - 28px)}.page-heading,.admin-heading{padding-top:34px;padding-bottom:18px}.article-list,.cms-layout{padding-bottom:72px}.cms-auth,.cms-editor,.cms-posts,.admin-panel{padding:22px}.cms-layout,.ranking-admin-layout{gap:18px}@media (width<=760px){.site-nav{flex-direction:row;align-items:center;gap:12px;min-height:64px;padding:10px 0}.site-brand{white-space:nowrap;min-width:0}.site-links{flex-wrap:nowrap;flex:none;gap:6px}.site-links a,.site-links button{min-height:38px;padding:0 11px;font-size:.84rem}.portal-hero{min-height:auto;padding:28px 0}.portal-hero h1{font-size:clamp(2rem,10vw,3.1rem)}.portal-cta{position:static}.site-footer{grid-template-columns:1fr;gap:18px;padding-bottom:34px}.site-footer nav{justify-content:flex-start}}@media (width<=480px){body{align-items:stretch}.app-header{min-height:calc(58px + env(safe-area-inset-top));padding:calc(env(safe-area-inset-top) + 8px) 12px 8px;gap:8px}.app-header .logo{flex:auto;max-width:none}.header-actions{margin-left:auto}.app-header .sync-indicator{max-width:98px}.app-main{padding:12px 12px 112px}#app{--app-gap:12px;--card-pad:16px;--section-gap:12px}.card,.quick-record-card,.logs-list-card,.summary-card,.graph-card,.more-menu-card,.first-food-card,.ranking-card,.settings-card{gap:12px}.page-heading,.admin-heading{padding-top:24px;padding-bottom:14px}.cms-auth,.cms-editor,.cms-posts,.admin-panel{padding:18px}.app-footer{height:auto;min-height:92px}.bottom-nav{border-radius:20px;min-height:58px;padding:7px}.bottom-nav-btn{border-radius:15px;min-height:46px}}@media (width<=360px){.character-empty-state{grid-template-columns:68px minmax(0,1fr);gap:10px;padding:12px}.character-empty-state img{width:68px;height:60px}.status-character{width:44px}.summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.graph-controls{grid-template-columns:1fr}.app-header .sync-label{display:none}.app-header .sync-indicator{justify-content:center;width:18px}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.loading-placeholder{color:#0000;background:linear-gradient(90deg,#6b8e750f 25%,#6b8e7524 50%,#6b8e750f 75%) 0 0/200% 100%;animation:1.8s ease-in-out infinite shimmer}.bottom-nav-btn.active:after{content:"";background:var(--main);border-radius:50%;width:5px;height:5px;transition:transform .24s,opacity .24s;box-shadow:0 0 0 3px #6b8e752e}.bottom-nav-btn:not(.active):after{content:"";background:0 0;border-radius:50%;width:5px;height:5px}.bottom-nav-icon{transition:transform .2s}.bottom-nav-btn.active .bottom-nav-icon{transform:scale(1.12)}@keyframes toast-slide-in{0%{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%)}}@keyframes toast-slide-out{0%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,20px)}}.toast-container{bottom:calc(108px + env(safe-area-inset-bottom));z-index:300;pointer-events:none;justify-items:center;gap:8px;width:min(100% - 28px,420px);display:grid;position:fixed;left:50%;transform:translate(-50%)}.toast{border:1px solid var(--milk-line);width:100%;min-height:46px;color:var(--charcoal);background:rgba(var(--surface-rgb), .97);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);pointer-events:auto;border-radius:16px;align-items:center;gap:10px;padding:10px 18px;font-size:.84rem;font-weight:700;line-height:1.45;animation:.28s cubic-bezier(.2,.8,.2,1) toast-slide-in;display:inline-flex;box-shadow:0 14px 36px #4a6b5233}.toast-character{-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 4px 8px #4a6b521f);flex:none;width:42px;height:36px}.toast.leaving{animation:.2s ease-in forwards toast-slide-out}.toast-icon{color:#fff;background:var(--main);border-radius:50%;flex:none;place-items:center;width:22px;height:22px;font-size:.68rem;font-weight:900;display:grid}.toast-icon.error{background:#c44148}.timeline{position:relative}.timeline:before{content:"";pointer-events:none;background:linear-gradient(#6b8e7533,#6b8e750a);border-radius:999px;width:2px;position:absolute;top:28px;bottom:28px;left:20px}.logs-list-card .timeline:before{left:20px}.graph-card .timeline:before{left:18px}.timeline-pager~.timeline:before,.timeline:empty:before{display:none}.modal.closing{animation:.18s ease-in forwards fadeOut}.modal.closing .modal-content{animation:.18s ease-in forwards slideDown}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideDown{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(14px)}}input:focus-visible,select:focus-visible,textarea:focus-visible{border-color:var(--main);outline:0;box-shadow:0 0 0 2px #6b8e753d,0 0 0 5px #6b8e7514}button:focus-visible,a:focus-visible,[role=button]:focus-visible,[tabindex]:focus-visible,summary:focus-visible{outline:3px solid var(--main);outline-offset:2px;border-radius:6px}.icon-action-btn.danger:focus-visible,.timeline-delete-btn:focus-visible{outline-color:#c44148}.form-group input[aria-invalid=true],.form-group select[aria-invalid=true],.form-group textarea[aria-invalid=true]{border-color:#c44148;box-shadow:0 0 0 3px #c441481f}.milk-presets{flex-wrap:wrap;gap:8px;margin-top:6px;display:flex}.milk-preset-btn{border:1px solid var(--milk-line);min-width:58px;min-height:44px;color:var(--main-deep);background:var(--surface);cursor:pointer;transition:border-color var(--transition-fast), background var(--transition-fast), color var(--transition-fast);border-radius:12px;padding:0 10px;font-size:.82rem;font-weight:800}.milk-preset-btn:hover,.milk-preset-btn.active{color:#fff;border-color:var(--main);background:var(--main)}@keyframes record-pulse{0%{transform:scale(1)}30%{transform:scale(.94)}60%{transform:scale(1.04)}to{transform:scale(1)}}.quick-btn.recording{animation:.32s ease-out record-pulse}.progress-ring{place-items:center;width:68px;min-width:68px;height:68px;display:grid;position:relative}.progress-ring svg{width:100%;height:100%;position:absolute;inset:0;transform:rotate(-90deg)}.progress-ring-bg{fill:none;stroke:#6b8e751f;stroke-width:5px}.progress-ring-fill{fill:none;stroke:var(--main);stroke-width:5px;stroke-linecap:round;transition:stroke-dashoffset .6s cubic-bezier(.2,.8,.2,1)}.progress-ring strong{color:var(--main-deep);z-index:1;font-size:.86rem;font-weight:900}.settings-status-correction{border:1px solid color-mix(in srgb, var(--main) 24%, white);background:color-mix(in srgb, var(--main-soft) 38%, white);border-radius:14px;justify-content:space-between;align-items:center;gap:14px;padding:13px 14px;display:flex}.settings-status-correction>div{gap:3px;min-width:0;display:grid}.settings-status-correction strong{color:var(--main-deep);font-size:.8rem}.settings-status-correction span{color:var(--soft-text);font-size:.7rem;font-weight:700;line-height:1.5}@media (width<=430px){.settings-status-correction{flex-direction:column;align-items:stretch}.settings-status-correction .mini-action-btn{width:100%}}.settings-share{border-top:1px dashed var(--milk-line);gap:12px;padding-top:14px;display:grid}.invite-result{gap:12px}.account-session-actions{border-top:1px solid var(--milk-line);padding-top:16px;display:grid}.account-action-row{border:1px solid var(--milk-line);width:100%;min-height:72px;color:var(--charcoal);background:var(--surface);text-align:left;cursor:pointer;transition:border-color var(--transition-fast), background var(--transition-fast), transform var(--transition-fast);border-radius:16px;grid-template-columns:42px minmax(0,1fr) auto;align-items:center;gap:12px;padding:12px 14px;display:grid}.account-action-row:hover:not(:disabled){border-color:var(--main);background:#f5f9f3;transform:translateY(-1px)}.account-action-row:disabled,.account-withdraw-btn:disabled{cursor:wait;opacity:.62}.account-action-icon{width:42px;height:42px;color:var(--main-deep);background:var(--child-primary-light);border-radius:13px;place-items:center;display:grid}.account-action-icon svg{fill:none;stroke:currentColor;stroke-width:1.8px;stroke-linecap:round;stroke-linejoin:round;width:22px;height:22px}.account-action-copy{gap:3px;min-width:0;display:grid}.account-action-copy strong{color:var(--charcoal);font-size:.92rem;font-weight:800}.account-action-copy small{color:var(--soft-text);font-size:.74rem;font-weight:700;line-height:1.5}.account-action-chevron{color:var(--soft-text);font-size:1.45rem;line-height:1}.account-danger-zone{background:#c4414809;border:1px solid #c4414833;border-radius:16px;gap:14px;margin-top:18px;padding:15px;display:grid}.account-danger-heading{align-items:flex-start;gap:10px;display:flex}.account-danger-icon{color:#a63339;background:#c441481a;border-radius:999px;flex:none;place-items:center;width:28px;height:28px;font-size:.82rem;font-weight:900;display:grid}.account-danger-heading div{gap:3px;display:grid}.account-danger-heading h3{color:#8f3035;font-size:.88rem;font-weight:800}.account-danger-heading p{color:var(--soft-text);font-size:.75rem;font-weight:700;line-height:1.5}.account-withdraw-btn{color:#a63339;background:var(--surface);cursor:pointer;min-height:42px;transition:color var(--transition-fast), border-color var(--transition-fast), background var(--transition-fast);border:1px solid #c4414861;border-radius:12px;padding:0 14px;font-size:.8rem;font-weight:800}.account-withdraw-btn:hover:not(:disabled){color:#fff;background:#c44148;border-color:#c44148}.admin-page{min-width:320px;color:var(--charcoal);background:radial-gradient(circle at 8% 0,#6b8e751a,#0000 28%),#f4f6f2}.admin-shell{min-height:100vh}.admin-header{z-index:100;background:rgba(var(--surface-rgb), .94);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid #4a6b5221;position:sticky;top:0;box-shadow:0 6px 22px #2f31370d}.admin-header-inner{justify-content:space-between;align-items:center;gap:16px;width:min(1040px,100% - 32px);min-height:64px;margin-inline:auto;display:flex}.admin-brand{min-height:48px;color:var(--charcoal);align-items:center;gap:10px;text-decoration:none;display:inline-flex}.admin-brand-mark,.admin-login-mark{color:#fff;background:linear-gradient(145deg, var(--main), var(--main-deep));width:38px;height:38px;font-family:var(--font-english);border-radius:12px;place-items:center;font-weight:900;display:grid;box-shadow:0 8px 20px #4a6b5233}.admin-brand>span:last-child{gap:0;display:grid}.admin-brand strong{font-size:.94rem;line-height:1.25}.admin-brand small{color:var(--soft-text);font-size:.68rem;font-weight:700;line-height:1.25}.admin-logout{border:1px solid var(--milk-line);min-height:38px;color:var(--soft-text);background:var(--surface);cursor:pointer;border-radius:10px;padding:0 13px;font-size:.76rem;font-weight:800}.admin-logout:hover:not(:disabled){color:#a63339;background:#c441480a;border-color:#c4414859}.admin-logout:disabled{cursor:wait;opacity:.6}.admin-nav{overscroll-behavior-x:contain;scrollbar-width:none;gap:4px;width:min(1040px,100% - 32px);margin-inline:auto;display:flex;overflow-x:auto}.admin-nav::-webkit-scrollbar{display:none}.admin-nav a{min-width:max-content;min-height:44px;color:var(--soft-text);align-items:center;gap:7px;padding:0 14px;font-size:.8rem;font-weight:800;text-decoration:none;display:inline-flex;position:relative}.admin-nav a:after{content:"";background:0 0;border-radius:999px 999px 0 0;height:3px;position:absolute;bottom:0;left:12px;right:12px}.admin-nav a:hover,.admin-nav a.active{color:var(--main-deep);background:#6b8e750f}.admin-nav a.active:after{background:var(--main)}.admin-content{width:100%;display:block}.admin-heading{padding-top:34px}.admin-heading h1{color:var(--charcoal);letter-spacing:-.02em;font-size:clamp(1.55rem,4vw,2.25rem)}.admin-heading>p:not(.site-kicker){max-width:680px;color:var(--soft-text)}.admin-page .cms-auth,.admin-page .cms-editor,.admin-page .cms-posts{box-shadow:0 12px 36px #2f31370f}.admin-page .cms-toolbar{border-bottom:1px solid var(--milk-line);padding-bottom:12px}.admin-page .cms-post-list{gap:10px;margin-top:0}.admin-page .cms-post-row{transition:border-color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast)}.admin-page .cms-post-row:hover{border-color:#6b8e7557;transform:translateY(-1px);box-shadow:0 8px 24px #2f31370f}.admin-page .cms-post-row>div:first-child{min-width:0}.admin-page .cms-post-row p{overflow-wrap:anywhere}.admin-page .admin-form{gap:16px;display:grid}.admin-page .admin-form input:not([type=checkbox]):not([type=file]),.admin-page .admin-form select,.admin-page .admin-form textarea{border:1px solid var(--milk-line);width:100%;color:var(--charcoal);background:var(--surface);font:inherit;transition:border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);border-radius:12px;padding:11px 12px;line-height:1.5}.admin-page .admin-form textarea{resize:vertical}.admin-page .admin-form input[readonly]{color:var(--soft-text);background:#f2f3ef}.admin-page .admin-form input:focus,.admin-page .admin-form select:focus,.admin-page .admin-form textarea:focus{border-color:var(--main);outline:0;box-shadow:0 0 0 3px #6b8e7521}.admin-page .admin-form input.ng-invalid.ng-touched,.admin-page .admin-form select.ng-invalid.ng-touched,.admin-page .admin-form textarea.ng-invalid.ng-touched{background:#c4414806;border-color:#c44148}.admin-page .primary-link:disabled,.admin-page .secondary-link:disabled{cursor:wait;opacity:.58}.admin-page .empty-state{border:1px dashed var(--milk-line);min-height:96px;color:var(--soft-text);text-align:center;background:#f7f8f4b8;border-radius:14px;place-items:center;padding:18px;display:grid}.admin-dashboard{box-shadow:none!important;background:0 0!important;padding:0!important}.admin-dashboard-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.admin-dashboard-card{align-content:space-between;min-height:190px;margin:0}.admin-dashboard-card .cms-row-actions{align-self:end}.admin-login-shell{place-items:center;min-height:100vh;padding:24px 0;display:grid}.admin-login-panel{text-align:center;justify-items:center;width:min(440px,100% - 28px);margin:0;padding:30px}.admin-login-mark{border-radius:16px;width:52px;height:52px;font-size:1.2rem}.admin-login-panel .cms-login-actions,.admin-login-panel .cms-login-actions a{width:100%}.admin-login-panel .cms-login-actions a{justify-content:center}.app-header-back{border:1px solid var(--milk-line);width:42px;height:42px;color:var(--main-deep);background:rgba(var(--surface-rgb), .9);cursor:pointer;transition:border-color var(--transition-fast), background var(--transition-fast), transform var(--transition-fast);border-radius:14px;flex:none;place-items:center;padding:0;display:grid}.app-header-back:hover{border-color:var(--main);background:var(--main-soft)}.app-header-back:active{transform:scale(.95)}.app-header-back svg{fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;width:21px;height:21px}.app-header:has(.app-header-back) .logo-icon{display:none}.app-header:has(.app-header-back) .logo{grid-template-columns:minmax(0,1fr)}.bottom-nav{isolation:isolate;border-color:var(--main-ring);background:rgba(var(--surface-rgb), .96);box-shadow:0 14px 34px var(--main-shadow), inset 0 1px 0 #ffffffe6;padding:7px;position:relative}.bottom-nav-btn{min-height:54px;transition:color var(--transition-fast), background var(--transition-fast), transform var(--transition-fast);border-radius:17px;gap:4px;padding:5px 6px;position:relative}.bottom-nav-btn:hover{background:var(--main-soft)}.bottom-nav-btn:active{transform:scale(.96)}.bottom-nav-icon{width:30px;height:27px;color:var(--soft-text);transition:color var(--transition-fast), background var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);border-radius:10px;place-items:center;display:grid}.bottom-nav-icon svg{fill:none;stroke:currentColor;stroke-width:1.8px;stroke-linecap:round;stroke-linejoin:round;width:21px;height:21px}.bottom-nav-label{font-size:.7rem;font-weight:800;line-height:1}.bottom-nav-btn.active{color:var(--main-deep);background:var(--main-soft)}.bottom-nav-btn.active .bottom-nav-icon{color:#fff;background:var(--main);box-shadow:0 7px 16px var(--main-shadow);transform:translateY(-2px)}.bottom-nav-btn.active:after,.bottom-nav-btn:not(.active):after{display:none}body.childcare-active .bottom-nav-btn.active .bottom-nav-icon{background:var(--main)}@media (width<=760px){.admin-dashboard-grid{grid-template-columns:1fr}.admin-dashboard-card{min-height:auto}}@media (width<=560px){.admin-header-inner,.admin-nav{width:calc(100% - 24px)}.admin-header-inner{min-height:58px}.admin-brand-mark{width:34px;height:34px}.admin-brand small{display:none}.admin-nav a{padding-inline:12px}.admin-page .cms-auth,.admin-page .cms-editor,.admin-page .cms-posts{padding:16px}.admin-page .cms-post-row:hover{transform:none}.app-footer{height:96px;padding:8px 12px max(10px, env(safe-area-inset-bottom));background:linear-gradient(#fbfaf700,#fbfaf7f0 22%,#fbfaf7 54%);border-top:0}}.card:hover{will-change:transform}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-6px)}40%,80%{transform:translate(6px)}}.shake{animation:.3s ease-in-out shake}@keyframes check-pop{0%{transform:scale(1)}50%{transform:scale(1.03)}to{transform:scale(1)}}.checklist li{transition:opacity .24s,transform .24s,border-color .24s,background .24s}.checklist li.completed{animation:.25s ease-out check-pop}.checklist li.completed .checklist-item-copy strong{color:var(--soft-text);text-decoration:line-through;transition:color .24s,-webkit-text-decoration .24s,text-decoration .24s}.chart-tooltip{color:#fff;white-space:nowrap;pointer-events:none;z-index:10;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#2f3137f2;border:1px solid #ffffff1f;border-radius:8px;padding:5px 9px;font-size:.76rem;font-weight:800;transition:opacity .15s,transform .15s;position:absolute;transform:translate(-50%,-100%)translateY(-6px);box-shadow:0 6px 16px #2f313729}.chart-tooltip:after{content:"";border:4px solid #0000;border-top-color:#2f3137f2;border-bottom:0 solid #2f3137f2;width:0;display:block;position:absolute;bottom:-4px;left:50%;transform:translate(-50%)}.metric-chart-point{fill:var(--main);stroke:#fff;stroke-width:1.5px;transition:r .12s,fill .12s}.metric-chart-point:hover,.metric-chart-point.active{r:6px;fill:var(--main-deep)}@keyframes check-scale{0%{opacity:0;transform:scale(0)}70%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.pwa-update-modal{align-items:center}.pwa-update-dialog{text-align:center;border-radius:22px;gap:18px;padding:26px 22px 20px;display:grid}.pwa-update-hero{justify-items:center;gap:8px;display:grid}.pwa-update-icon{color:#fff;background:var(--main-deep);width:56px;height:56px;box-shadow:0 10px 24px var(--main-shadow);border-radius:18px;place-items:center;margin-bottom:4px;font-size:1.9rem;font-weight:900;display:grid}.pwa-update-hero h2{color:var(--ink);font-size:1.12rem;font-weight:900}.pwa-update-hero p{color:var(--ink-soft);font-size:.82rem;font-weight:700;line-height:1.6}.pwa-update-actions{gap:6px;display:grid}.pwa-update-primary{border-radius:15px;width:100%;min-height:50px;font-size:.94rem;font-weight:900}.pwa-update-later{min-height:40px;color:var(--ink-soft);cursor:pointer;background:0 0;border:0;font-size:.82rem;font-weight:800}.pwa-update-later:hover{color:var(--ink)}.pwa-update-later:disabled{opacity:.5;cursor:not-allowed}.more-menu-item:disabled{cursor:wait;opacity:.68}.pwa-install-banner{border:1px solid var(--milk-line);background:rgba(var(--surface-rgb), .84);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:12px;align-items:center;gap:12px;margin:10px 14px 0;padding:10px 14px;animation:.24s ease-out slideUp;display:flex;box-shadow:0 4px 12px #4a6b520f}.pwa-install-icon{font-size:1.5rem}.pwa-install-text{flex:1;gap:2px;min-width:0;display:grid}.pwa-install-text strong{color:var(--ink);font-size:.88rem;font-weight:800}.pwa-install-text span{color:var(--ink-soft);white-space:nowrap;text-overflow:ellipsis;font-size:.76rem;font-weight:700;line-height:1.35;overflow:hidden}.pwa-install-actions{align-items:center;gap:8px;display:flex}.pwa-install-close{width:28px;height:28px;color:var(--ink-soft);cursor:pointer;background:0 0;border:0;place-items:center;font-size:1.25rem;display:grid}.pwa-install-close:hover{color:var(--ink)}.pwa-intro-modal{z-index:1200;padding:max(16px, env(safe-area-inset-top)) 16px max(16px, env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#23272b80;align-items:center}.pwa-intro-dialog{background:var(--surface);text-align:left;scrollbar-width:none;border:1px solid #fffc;border-radius:28px;gap:0;width:min(100%,420px);max-height:min(92dvh,740px);padding:0;position:relative;overflow-y:auto;box-shadow:0 28px 90px #1f22284d}.pwa-intro-dialog::-webkit-scrollbar{display:none}.pwa-intro-close{z-index:2;background:rgba(var(--surface-rgb), .76);width:38px;height:38px;color:var(--ink);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;border:1px solid #ffffffb8;border-radius:50%;place-items:center;font-size:1.35rem;line-height:1;display:grid;position:absolute;top:14px;right:14px;box-shadow:0 6px 18px #2f313714}.pwa-intro-close:hover{background:var(--surface);transform:scale(1.04)}.pwa-intro-hero{background:radial-gradient(circle at 8% 8%, color-mix(in srgb, var(--main) 24%, transparent), transparent 34%), radial-gradient(circle at 92% 18%, color-mix(in srgb, var(--main) 18%, transparent), transparent 32%), linear-gradient(145deg, color-mix(in srgb, var(--main-soft) 78%, white), #fff 76%);text-align:center;padding:24px 24px 22px;position:relative;overflow:hidden}.pwa-intro-hero:after{border:20px solid color-mix(in srgb, var(--main) 8%, transparent);content:"";border-radius:50%;width:130px;height:130px;position:absolute;bottom:-48px;right:-34px}.pwa-intro-visual{z-index:1;justify-content:center;align-items:flex-end;min-height:92px;margin-bottom:6px;display:flex;position:relative}.pwa-intro-app-icon{z-index:2;background:var(--surface);width:72px;height:72px;box-shadow:0 13px 28px var(--main-shadow);border:4px solid #fff;border-radius:19px;place-items:center;margin-right:-10px;display:grid;position:relative;overflow:hidden;transform:rotate(-5deg)}.pwa-intro-app-icon img{-o-object-fit:cover;object-fit:cover;width:100%;height:100%}.pwa-intro-add-mark{z-index:3;background:var(--main);color:#fff;width:27px;height:27px;box-shadow:0 5px 14px var(--main-shadow);border:3px solid #fff;border-radius:50%;place-items:center;margin:0 -13px 12px 0;font-size:1rem;font-weight:900;line-height:1;display:grid;position:relative}.pwa-intro-character{z-index:1;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 9px 13px #2f31371f);width:126px;height:86px;margin-left:-5px;display:block;position:relative}.pwa-intro-copy{z-index:1;text-align:center;position:relative}.pwa-intro-eyebrow{background:color-mix(in srgb, var(--main) 12%, white);min-height:27px;color:var(--main-deep);letter-spacing:.1em;border-radius:999px;align-items:center;padding:3px 11px;font-size:.7rem;font-weight:900;display:inline-flex}.pwa-intro-copy h2{color:var(--ink);letter-spacing:.02em;margin:8px 0 7px;font-size:clamp(1.38rem,5.5vw,1.72rem);font-weight:900;line-height:1.36}.pwa-intro-copy p,.pwa-intro-note{color:var(--ink-soft);margin:0;font-size:.84rem;font-weight:650;line-height:1.65}.pwa-intro-benefits{grid-template-columns:repeat(3,1fr);gap:8px;margin:0;padding:18px 18px 0;list-style:none;display:grid}.pwa-intro-benefits li{border:1px solid color-mix(in srgb, var(--main) 13%, var(--milk-line));background:color-mix(in srgb, var(--main-soft) 42%, white);min-width:0;color:var(--ink);text-align:center;border-radius:16px;place-items:center;gap:3px;padding:12px 5px 11px;display:grid}.pwa-intro-benefits span{background:color-mix(in srgb, var(--main) 13%, white);width:27px;height:20px;color:var(--main-deep);letter-spacing:.05em;border-radius:999px;place-items:center;font-size:.62rem;font-weight:900;display:grid}.pwa-intro-benefits strong{white-space:nowrap;font-size:.78rem;font-weight:900}.pwa-intro-benefits small{max-width:100%;color:var(--ink-soft);text-overflow:ellipsis;white-space:nowrap;font-size:.64rem;font-weight:700;overflow:hidden}.pwa-ios-guide,.pwa-intro-note{border:1px solid color-mix(in srgb, var(--main) 14%, var(--milk-line));background:var(--surface-soft);border-radius:17px;margin:14px 18px 0;padding:14px 15px}.pwa-guide-heading{align-items:center;gap:8px;display:flex}.pwa-guide-heading>span{background:var(--ink);color:#fff;border-radius:999px;padding:3px 8px;font-size:.62rem;font-weight:900}.pwa-guide-heading>strong{color:var(--ink);font-size:.82rem}.pwa-ios-guide ol{gap:8px;margin:12px 0 0;padding:0;list-style:none;display:grid}.pwa-ios-guide li{align-items:center;gap:9px;display:flex}.pwa-ios-guide li>span{background:var(--surface);width:24px;height:24px;color:var(--main-deep);border-radius:50%;flex:0 0 24px;place-items:center;font-size:.68rem;font-weight:900;display:grid;box-shadow:0 3px 8px #2f313714}.pwa-ios-guide p{color:var(--ink-soft);margin:0;font-size:.76rem;font-weight:700;line-height:1.4}.pwa-ios-guide p strong{color:var(--ink);font-weight:900}.pwa-intro-actions{gap:5px;margin-top:16px;padding:0 18px 17px;display:grid}.pwa-intro-actions button{width:100%;min-height:48px}.pwa-intro-primary{box-shadow:0 10px 24px var(--main-shadow);border-radius:15px;justify-content:center;align-items:center;gap:7px;margin:0;font-size:.9rem;font-weight:900;display:flex}.pwa-intro-primary span{font-size:1.15rem;line-height:1}.pwa-intro-later{color:var(--ink-soft);cursor:pointer;background:0 0;border:0;font-size:.78rem;font-weight:800}.pwa-intro-later:hover{color:var(--ink)}@media (width<=360px){.pwa-intro-hero{padding-inline:18px}.pwa-intro-benefits{gap:6px;padding-inline:12px}.pwa-intro-benefits li{padding-inline:3px}.pwa-ios-guide,.pwa-intro-note{margin-inline:12px}.pwa-intro-actions{padding-inline:12px}}html:has(mame-app-shell #app){overscroll-behavior:none;height:100%;overflow:hidden}body:has(mame-app-shell #app){overscroll-behavior:none;width:100%;height:100dvh;min-height:0;position:fixed;inset:0;overflow:hidden}
