:root{--background:#fffaf3;--surface:#fff;--surface-soft:#fff1dc;--text:#2f2924;--muted:#766b61;--border:#efe2ce;--primary:#e9a35f;--primary-strong:#b86438;--mint:#dbeee5;--sky:#dcecf7;--rose:#f8deda;--butter:#fff0b8;--shadow:0 18px 48px #7b5b371c;--placeholder:#a8a09a;--focus-ring:#e9a35f80;--focus-glow:0 0 0 3px #e9a35f14;--safe-bottom:env(safe-area-inset-bottom,0px);--bottom-nav-content-height:72px;--bottom-nav-reserved-height:140px}*{box-sizing:border-box}html{overscroll-behavior-x:none;-webkit-text-size-adjust:100%;background:linear-gradient(#fffdf7 0%,#fff9ee 80px,#fffaf3 180px);width:100%;max-width:100%;min-height:100%;overflow-x:hidden}body{overscroll-behavior-x:none;width:100%;max-width:100%;min-height:100%;color:var(--text);background:radial-gradient(circle at 0 0,#ffefb894,#0000 28rem),radial-gradient(circle at 100% 0,#dbeee59e,#0000 24rem),linear-gradient(#fffaf3 0%,#fff7ed 52%,#fffaf3 100%);margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;position:relative;overflow-x:hidden}a{color:inherit;text-decoration:none}button,input,select,textarea{min-width:0;max-width:100%;font:inherit}button{cursor:pointer}input,select,textarea{font-size:16px}.form-field{border:1px solid var(--border);width:100%;min-width:0;max-width:100%;color:var(--text);background:#fff;border-radius:14px;padding:12px 16px;font-size:16px;line-height:1.5;transition:border-color .2s,box-shadow .2s}textarea.form-field{resize:vertical;min-height:120px;line-height:1.6}select.form-field{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M5 7.5L10 12.5L15 7.5' stroke='%2390877d' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 18px center;background-repeat:no-repeat;background-size:20px;padding-right:46px}::placeholder{color:var(--placeholder);font-weight:400}input:focus,textarea:focus,select:focus{border-color:var(--focus-ring);box-shadow:var(--focus-glow);outline:none}select.select-placeholder{color:var(--placeholder);font-weight:400}select.form-field.form-select-native{appearance:auto;height:48px;color:var(--text);-webkit-text-fill-color:var(--text);background-image:none;padding-right:16px}select.form-field.form-select-native.select-placeholder{color:var(--placeholder);-webkit-text-fill-color:var(--placeholder);font-weight:400}.app-shell{width:100%;min-width:0;max-width:430px;min-height:100vh;padding:calc(18px + env(safe-area-inset-top,0px)) 14px 32px;margin:0 auto;overflow-x:hidden}.app-shell>*{width:100%;min-width:0;max-width:100%}.page-stack{flex-direction:column;gap:16px;width:100%;min-width:0;max-width:100%;display:flex;overflow-x:hidden}.page-stack--with-bottom-nav{padding-bottom:var(--bottom-nav-reserved-height)}.soft-card{border:1px solid var(--border);background:#ffffffe6;border-radius:18px;width:100%;min-width:0;max-width:100%;box-shadow:0 12px 30px #7b5b3717}.section-title{word-break:break-word;margin:0;font-size:18px;line-height:1.35}h1,h2,h3,h4{word-break:break-word}.muted{color:var(--muted)}.pill-row{flex-wrap:wrap;gap:8px;min-width:0;display:flex}.pill{border:1px solid var(--border);min-height:34px;color:var(--muted);background:#fffaf5;border-radius:999px;align-items:center;padding:6px 11px;font-size:14px;line-height:1.2;display:inline-flex}.primary-button,.secondary-button,.quiet-button{border:0;border-radius:14px;min-width:0;min-height:46px;padding:0 16px;font-weight:700}.primary-button{color:#fffaf3;background:linear-gradient(#f0b36d 0%,#e79a55 100%);box-shadow:0 10px 22px #b8643833}.primary-button:active{background:var(--primary-strong)}.primary-button:disabled{opacity:.55;cursor:default}.secondary-button{border:1px solid var(--border);color:var(--text);background:#fff}.secondary-button:active{background:#fff1dc73}.secondary-button:disabled{opacity:.5;cursor:default}.selected-button{min-height:46px;color:var(--primary-strong);background:#fff1dc8c;border:1px solid #e9a35f66;border-radius:14px;padding:0 16px;font-weight:700}.selected-button:active{background:#e9a35f33}.selected-button:disabled{opacity:.5;cursor:default}.completed-button{border:1px solid var(--border);min-height:46px;color:var(--muted);cursor:default;background:#f5f2ed80;border-radius:14px;justify-content:center;align-items:center;padding:0 16px;font-weight:700;display:inline-flex}.completed-button:active{background:#f5f2edb3}.quiet-button{color:var(--primary-strong);background:0 0}.quiet-button:active{opacity:.7}.quiet-button:disabled{opacity:.4;cursor:default}.button-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.toast{top:calc(20px + env(safe-area-inset-top,0px));z-index:2000;color:#fffaf3;text-align:center;opacity:0;pointer-events:none;background:#2f2924;border-radius:12px;max-width:min(100% - 32px,340px);padding:12px 24px;font-size:14px;line-height:1.5;transition:opacity .25s,transform .25s;position:fixed;left:50%;transform:translate(-50%)translateY(-8px)}.toast--visible{opacity:1;transform:translate(-50%)translateY(0)}.sheet-overlay{z-index:1000;background:#2f292400;justify-content:center;align-items:flex-end;transition:background .3s;display:flex;position:fixed;inset:0}.sheet-overlay--visible{background:#2f292473}.sheet-card{width:100%;min-width:0;max-width:430px;max-height:85vh;padding:16px 20px calc(18px + var(--safe-bottom));border-radius:20px 20px 0 0;transition:transform .3s cubic-bezier(.32,.72,0,1);overflow-y:auto;transform:translateY(100%)}.sheet-card--visible{transform:translateY(0)}.sheet-handle{background:#d4cdc4;border-radius:3px;width:36px;height:5px;margin:0 auto 18px}.sheet-card__title{text-align:center;margin:0;font-size:18px;line-height:1.35}.sheet-card__desc{color:var(--muted);text-align:center;margin:12px 0 20px;font-size:15px;line-height:1.65}
.page-back-link{min-height:auto;color:var(--primary-strong);align-self:flex-start;padding:0;font-size:15px;font-weight:700}.simple-header{min-width:0;max-width:100%;padding:10px 4px 0}.simple-header h1{margin:0;font-size:26px;line-height:1.2}.simple-header p{color:var(--muted);margin:6px 0 0;font-size:14px;line-height:1.6}.stats-panel{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:12px;display:grid}.stats-panel div{background:var(--surface-soft);border-radius:14px;flex-direction:column;justify-content:center;min-width:0;min-height:56px;padding:10px 12px;display:flex}.stats-panel strong{font-size:20px}.stats-panel span{color:var(--muted);font-size:12px}.page-actions{justify-content:center;padding:4px 0 6px;display:flex}.page-actions__button{justify-content:center;align-items:center;min-width:132px;max-width:100%;display:inline-flex}.child-form{flex-direction:column;gap:16px;width:100%;min-width:0;max-width:100%;padding:18px;display:flex}.child-save-group{flex-direction:column;gap:8px;margin-top:4px;display:flex}.form-submit{width:100%;max-width:100%;margin-top:4px}.save-note{color:var(--primary-strong);text-align:center;background:#fff6dd7a;border-radius:12px;padding:7px 12px;font-size:13px;font-weight:700;line-height:1.45}.save-note--success{color:#7b5a42}.save-note--error{color:#a24f2f;background:#fff5ed;border:1px solid #b8643838}.dialog-overlay{z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#2f292473;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.dialog-card{text-align:center;width:100%;min-width:0;max-width:340px;padding:24px 20px 20px}.dialog-card__title{margin:0;font-size:18px;line-height:1.35}.dialog-card__desc{color:var(--muted);margin:10px 0 16px;font-size:15px;line-height:1.65}.history-header{justify-content:space-between;align-items:center;gap:12px;min-width:0;max-width:100%;padding:18px 4px 0;display:flex}.history-header__title{flex:1;min-width:0}.history-header__title h1{margin:0;font-size:28px;line-height:1.2}.history-header__title p{color:var(--muted);margin:8px 0 0;line-height:1.7}.history-remove-action{min-height:38px;color:var(--muted);background:0 0;border:0;border-radius:12px;padding:0 14px;font-size:13px;font-weight:600}.history-remove-action:active{color:#b86438;background:#f8deda73}@media (max-width:360px){.history-header{gap:8px}}.feedback-form{flex-direction:column;gap:16px;width:100%;min-width:0;max-width:100%;padding:18px;display:flex}.feedback-field{flex-direction:column;gap:10px;min-width:0;display:flex}.feedback-field__label{font-size:15px;font-weight:600}.feedback-success{text-align:center;padding:28px 20px;font-size:15px;line-height:1.65}.feedback-success .secondary-button{width:100%;margin-top:16px}
