:root{--paper:#f7f1e7;--paper-deep:#ebddcb;--ink:#2f2218;--ink-soft:#6b5748;--line:#d8c8b2;--accent:#d8b48b;--accent-strong:#be9365;--ok:#8ea975;--warn:#b47d65;--font-body:"Palatino Linotype", "Noto Serif SC", "Source Han Serif SC", serif;--font-title:"STKaiti", "KaiTi", "Noto Serif SC", serif}*,:before,:after{box-sizing:border-box}body{min-height:100svh;color:var(--ink);font-family:var(--font-body);background:radial-gradient(circle at 8% 8%, #fffdf9 0%, transparent 28%), radial-gradient(circle at 92% 90%, #f3e5d2 0%, transparent 26%), linear-gradient(180deg, var(--paper) 0%, #f4ebde 55%, #efe1cf 100%);margin:0;line-height:1.55}#root{min-height:100svh}.app-shell{border:1px solid var(--line);background:linear-gradient(#ffffff8c,#ffffff4d),repeating-linear-gradient(#0000 0 27px,#5239270f 28px);border-radius:24px;width:min(920px,100% - 2rem);margin:2.4rem auto;padding:1.4rem;box-shadow:0 12px 36px #4e331f14}.app-header{padding:.7rem .5rem 1rem;animation:.5s reveal}.app-mark{color:var(--ink-soft);letter-spacing:.15em;margin:0;font-size:.9rem}.app-title{font-family:var(--font-title);margin:.45rem 0 .2rem;font-size:clamp(1.75rem,4.6vw,2.5rem);font-weight:600;line-height:1.2}.app-subtitle{color:var(--ink-soft);margin:0;font-size:1rem}.main-tabs{border-bottom:1px solid var(--line);flex-wrap:wrap;gap:.55rem;padding:.2rem .4rem .9rem;display:flex}.tab-chip,.mini-chip,.primary-btn,.ghost-btn{appearance:none;border:1px solid var(--line);color:var(--ink);cursor:pointer;background:#fff8ecb8;border-radius:999px;font-family:inherit;transition:all .22s}.tab-chip{padding:.45rem .95rem;font-size:.95rem}.tab-chip:hover{transform:translateY(-1px)}.tab-chip.is-active{background:var(--accent);border-color:var(--accent-strong)}.main-content{padding:1rem .35rem .2rem}.panel{flex-direction:column;gap:1rem;animation:.42s reveal;display:flex}.panel-head h2{font-family:var(--font-title);margin:0;font-size:clamp(1.4rem,4vw,1.9rem)}.panel-head p{color:var(--ink-soft);margin:.25rem 0 0}.month-toolbar{flex-wrap:wrap;gap:.55rem;display:flex}.block{border:1px solid var(--line);background:#fffbf4b3;border-radius:16px;padding:.85rem}.mode-switch{gap:.5rem;display:flex}.onboarding-card{background:linear-gradient(#fff6e7cc,#fff7eba6),#fffbf4b3;flex-direction:column;gap:.55rem;display:flex}.onboarding-title{font-family:var(--font-title);margin:0;font-size:1.05rem}.onboarding-copy{color:var(--ink-soft);margin:0}.onboarding-actions{flex-wrap:wrap;gap:.5rem;display:flex}.three-editor{flex-direction:column;gap:.65rem;margin-top:.45rem;display:flex}.three-canvas{aspect-ratio:1;touch-action:none;background:radial-gradient(circle at 20% 20%,#ffffffb8,#0000 45%),#fdf6ecbd;border:1px dashed #83624259;border-radius:18px;align-self:center;width:min(420px,100%)}.three-draw-line{fill:none;stroke:#3d2919;stroke-width:3.8px;stroke-linecap:round;stroke-linejoin:round}.three-draw-line.draft{stroke:#3d291973}.three-guide-line{fill:none;stroke:#543b2652;stroke-width:1.1px;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:1.6 1.2}.handle-anchor{fill:#4b76534d;stroke:#366040cc;stroke-width:.45px;cursor:pointer}.three-actions{flex-wrap:wrap;gap:.5rem;display:flex}.role-row,.semantic-row{flex-wrap:wrap;align-items:center;gap:.45rem;display:flex}.role-title{color:var(--ink-soft);margin-right:.15rem;font-size:.85rem}.mini-chip{padding:.35rem .8rem;font-size:.88rem}.mini-chip.is-active{background:#d8b48b73}.editor-stage{flex-direction:column;justify-content:flex-start;min-height:260px;display:flex}.block-title{margin:0;font-size:1.05rem}.block-note{color:var(--ink-soft);margin:.25rem 0 0}.template-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.5rem;margin-top:.6rem;display:grid}.template-card{border:1px solid var(--line);cursor:pointer;background:#fffbf3b8;border-radius:12px;flex-direction:column;align-items:center;gap:.35rem;padding:.45rem;display:flex}.template-face{aspect-ratio:1;width:74px}.template-title{color:var(--ink-soft);font-size:.8rem}.parametric-editor{flex-direction:column;gap:.65rem;margin-top:.45rem;display:flex}.preset-row{flex-wrap:wrap;gap:.4rem;display:flex}.preset-chip{appearance:none;border:1px solid var(--line);color:var(--ink);cursor:pointer;background:#fff8ecb8;border-radius:999px;padding:.32rem .76rem;font-family:inherit;font-size:.85rem}.preset-chip.is-active{background:#d8b48b6b;border-color:#be9365b3}.face-canvas{aspect-ratio:1;touch-action:none;background:radial-gradient(circle at 20% 20%,#ffffffb3,#0000 45%),#fdf6ecb3;border:1px dashed #83624259;border-radius:18px;align-self:center;width:min(420px,100%)}.face-bg{fill:#fffbf3b8;stroke:#73553a33;stroke-width:.5px}.line-shape{fill:none;stroke-linecap:round;stroke-linejoin:round;transition:opacity .18s,filter .18s}.line-hit{fill:none;stroke:#0000;stroke-width:11px;cursor:grab}.part-active .line-shape{filter:drop-shadow(0 0 1px #49322040)}.handle-point{fill:#3a261840;stroke:#3a2618bf;stroke-width:.45px;cursor:nwse-resize}.handle-curve{fill:#be93654d;stroke:#875f3ad9;stroke-width:.45px;cursor:ns-resize}.handle-extra{fill:#7d5c4042;stroke:#563d27c7;stroke-width:.45px;cursor:pointer}.editor-hint,.editor-state{color:var(--ink-soft);margin:0;font-size:.86rem}.freehand-editor{flex-direction:column;gap:.65rem;margin-top:.45rem;display:flex}.freehand-canvas{aspect-ratio:1;touch-action:none;cursor:crosshair;background:radial-gradient(circle at 20% 20%,#ffffffad,#0000 45%),#fdf6ecb8;border:1px dashed #83624259;border-radius:18px;align-self:center;width:min(420px,100%)}.freehand-bg{fill:#0000}.freehand-line{fill:none;stroke:#3d2919;stroke-linecap:round;stroke-linejoin:round}.freehand-line.draft{stroke:#3d291980}.freehand-actions{flex-wrap:wrap;gap:.5rem;display:flex}.note-box{flex-direction:column;gap:.45rem;display:flex}.date-picker-row{flex-wrap:wrap;align-items:center;gap:.55rem;display:flex}.date-picker-row span{color:var(--ink-soft)}.date-picker-row input[type=date]{border:1px solid var(--line);color:var(--ink);background:#fffdf8bf;border-radius:999px;padding:.4rem .75rem;font-family:inherit}.note-box textarea{resize:vertical;border:1px solid var(--line);width:100%;color:var(--ink);background:#fffdf8bf;border-radius:14px;padding:.7rem .75rem;font-family:inherit}.primary-btn{background:#8ea97538;border-color:#708a588c;width:fit-content;padding:.52rem 1rem}.saved-hint{color:var(--ok);margin:0}.calendar-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:.55rem;display:grid}.day-card{border:1px solid var(--line);cursor:pointer;background:#fffaf1b3;border-radius:14px;flex-direction:column;justify-content:space-between;min-height:72px;padding:.4rem;transition:transform .18s,border-color .18s,background-color .18s;display:flex;position:relative}.day-card:hover{transform:translateY(-1px)}.day-card.has-face{background:#fff7ecdb}.day-card.is-selected{background:#faecd6d1;border-color:#be9365c7}.day-card:focus-visible{outline-offset:2px;outline:2px solid #be9365e6}.day-label{color:var(--ink-soft);font-size:.8rem}.face-dot{text-align:center;color:#6b5748cc;font-size:1.3rem;line-height:1}.month-face-thumb{aspect-ratio:1;align-self:center;width:100%;max-width:44px}.sync-dot{border:1px solid #3a261833;border-radius:999px;width:8px;height:8px;position:absolute;top:.45rem;right:.4rem}.mood-face-bg{fill:#fffaf2cc;stroke:#73553a24;stroke-width:.8px}.mood-face-line{fill:none;stroke:#4a3222;stroke-linecap:round;stroke-linejoin:round}.mood-face-mouth{stroke:#3a2618}.month-detail{border:1px solid var(--line);background:#fffbf4b3;border-radius:16px;padding:.9rem}.month-detail-title{font-family:var(--font-title);margin:0;font-size:1.1rem}.month-detail-body{align-items:center;gap:.9rem;margin-top:.65rem;display:flex}.month-face-large{aspect-ratio:1;width:104px;min-width:104px}.month-detail-copy{flex-direction:column;gap:.45rem;display:flex}.month-detail-note,.month-detail-meta{margin:0}.month-detail-meta{color:var(--ink-soft);font-size:.85rem}.sync-pill{border:1px solid #0000;border-radius:999px;width:fit-content;margin:0;padding:.15rem .55rem;font-size:.82rem}.sync-pill.is-local,.sync-dot.is-local{color:#7f5e49;background:#d4ae8c47;border-color:#a4785573}.sync-pill.is-dirty,.sync-dot.is-dirty{color:#8d5b2f;background:#edca9259;border-color:#b37d3f85}.sync-pill.is-synced,.sync-dot.is-synced{color:#48673b;background:#adcd9157;border-color:#6b98598c}.empty-tip{color:var(--ink-soft);margin:0}.settings-list{border:1px solid var(--line);border-radius:16px;margin:0;padding:0;list-style:none;overflow:hidden}.settings-list li{background:#fffaf1b3;padding:.75rem .85rem}.settings-list li+li{border-top:1px solid var(--line)}.settings-stats{border:1px solid var(--line);background:#fffaf1b3;border-radius:16px;padding:.8rem .9rem}.settings-auth,.settings-install{border:1px solid var(--line);background:#fffaf1b3;border-radius:16px;flex-direction:column;gap:.5rem;padding:.8rem .9rem;display:flex}.settings-auth-state{margin:0}.settings-note{color:var(--ink-soft);margin:0;font-size:.85rem}.settings-auth-signin{flex-wrap:wrap;gap:.5rem;display:flex}.settings-input{border:1px solid var(--line);min-width:220px;color:var(--ink);background:#fffdf8bf;border-radius:999px;flex:1;padding:.5rem .8rem;font-family:inherit}.settings-stats-title{font-family:var(--font-title);margin:0 0 .35rem}.settings-stats p{margin:.2rem 0}.settings-actions{flex-wrap:wrap;gap:.55rem;display:flex}.consent-row{color:var(--ink-soft);align-items:center;gap:.45rem;font-size:.9rem;display:flex}.submission-list{flex-direction:column;gap:.6rem;display:flex}.submission-card{border:1px solid var(--line);background:#fffdf8b8;border-radius:14px;gap:.65rem;padding:.55rem;display:flex}.submission-face{aspect-ratio:1;width:74px;min-width:74px}.submission-copy{flex-direction:column;gap:.35rem;display:flex}.submission-title{margin:0;font-size:.9rem}.ghost-btn{padding:.48rem .95rem}.ghost-btn.is-active{background:#adcd9147;border-color:#6b98598c}.ghost-btn.warn{background:#b47d6529;border-color:#b47d65bf}button:disabled,textarea:disabled{cursor:not-allowed;opacity:.75}@keyframes reveal{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (width<=680px){.app-shell{border-radius:18px;width:calc(100% - 1rem);margin:.6rem auto;padding:.9rem}.calendar-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.day-card{min-height:64px}.month-detail-body{flex-direction:column;align-items:flex-start}.month-face-large{width:88px;min-width:88px}}
