: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:20px;width:min(920px,100% - 1.6rem);margin:1.2rem auto;padding:.8rem 1rem;box-shadow:0 12px 36px #4e331f14}.app-bar{border-bottom:1px solid var(--line);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.6rem;padding:.2rem .3rem .5rem;display:flex}.app-bar-brand{font-family:var(--font-title);color:var(--ink);letter-spacing:.1em;white-space:nowrap;font-size:1.1rem}.main-tabs{flex-wrap:wrap;gap:.4rem;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}.primary-btn,.ghost-btn{justify-content:center;align-items:center;gap:.35rem;min-height:2.2rem;display:inline-flex}.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:.6rem .2rem .2rem}.panel-compact{gap:.55rem!important}.flip-nav{justify-content:space-between;align-items:center;gap:.4rem;display:flex}.flip-nav-label{font-family:var(--font-title);text-align:center;flex-wrap:wrap;justify-content:center;align-items:center;font-size:1rem;display:flex}.flip-nav-btn{padding:.25rem .55rem!important;font-size:.9rem!important}.note-save-row{align-items:flex-start;gap:.5rem;display:flex}.note-textarea{resize:none;border:1px solid var(--line);color:var(--ink);background:#fffdf8bf;border-radius:12px;flex:1;padding:.5rem .65rem;font-family:inherit;font-size:.9rem;line-height:1.45}.note-save-actions{flex-direction:column;flex-shrink:0;gap:.3rem;display:flex}.fold-bar{border-top:1px dashed #8b654526;flex-wrap:wrap;gap:.4rem;padding-top:.2rem;display:flex}.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,.month-view-toggle{flex-wrap:wrap;gap:.55rem;display:flex}.week-toolbar{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.week-range{color:var(--ink-soft);margin:0;font-size:.9rem}.week-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:.55rem;display:grid}.week-day-card{border:1px solid var(--line);cursor:pointer;background:#fffaf1b8;border-radius:16px;flex-direction:column;justify-content:space-between;min-height:106px;padding:.48rem .4rem;transition:transform .18s,border-color .18s,background-color .18s;display:flex;position:relative}.week-day-card:hover{transform:translateY(-1px)}.week-day-card.has-face{background:#fff7ecdb}.week-day-card.is-selected{background:#faecd6d1;border-color:#be9365c7}.week-day-card:focus-visible{outline-offset:2px;outline:2px solid #be9365e6}.week-face-thumb{aspect-ratio:1;align-self:center;width:100%;max-width:56px}.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}.canvas-book{margin-left:.3rem;padding:.35rem .5rem .35rem .8rem;position:relative}.canvas-book-spine{border-left:1.5px dashed #8b654547;width:6px;position:absolute;top:.3rem;bottom:.3rem;left:0}.canvas-book-spine:before{content:"";background:repeating-linear-gradient(#0000 0 9px,#a07f5e40 10px 10.5px);border-radius:2px;width:10px;position:absolute;top:12px;bottom:12px;left:-5px}.canvas-book-stack{z-index:0;pointer-events:none;background:#f1e7d966;border:1px solid #7e604514;border-radius:4px 16px 16px 4px;position:absolute;inset:2px 2px -2px}.canvas-book-stack+.canvas-book-stack{opacity:.45;background:#ebdfcf59;inset:5px 5px -5px}.canvas-book-leaf{z-index:1;background:linear-gradient(#ffffff80,#fff3),#fff9f1a6;border:1px solid #7e604524;border-radius:4px 14px 14px 4px;transition:transform .28s cubic-bezier(.25,.1,.15,1),opacity .18s;position:relative}.canvas-book-leaf:after{content:"";pointer-events:none;z-index:5;background:linear-gradient(135deg,#b99f8226 0%,#0000 60%);border-radius:0 0 14px;width:16px;height:12px;position:absolute;bottom:0;right:0}.canvas-book-leaf.flip-left{animation:.28s cubic-bezier(.25,.1,.15,1) pageFlipLeft}.canvas-book-leaf.flip-right{animation:.28s cubic-bezier(.25,.1,.15,1) pageFlipRight}@keyframes pageFlipLeft{0%{opacity:1;transform:perspective(600px)rotateY(0)translate(0)}35%{opacity:.6;transform:perspective(600px)rotateY(-5deg)translate(4%)}to{opacity:1;transform:perspective(600px)rotateY(0)translate(0)}}@keyframes pageFlipRight{0%{opacity:1;transform:perspective(600px)rotateY(0)translate(0)}35%{opacity:.6;transform:perspective(600px)rotateY(5deg)translate(-4%)}to{opacity:1;transform:perspective(600px)rotateY(0)translate(0)}}.canvas-book-edge{z-index:4;cursor:pointer;width:16%;position:absolute;top:0;bottom:0}.canvas-book-edge.prev{left:0}.canvas-book-edge.next{right:0}.canvas-book-page-num{color:var(--ink-soft);text-align:center;opacity:.65;margin:.25rem 0 0;font-size:.78rem}.folio-book{margin-left:.3rem;padding:.4rem .5rem .4rem .8rem;position:relative}.folio-book-spine{border-left:1.5px dashed #8b654540;width:5px;position:absolute;top:.2rem;bottom:.2rem;left:0}.folio-book-spine:before{content:"";background:repeating-linear-gradient(#0000 0 8px,#a07f5e38 9px 9.5px);border-radius:2px;width:8px;position:absolute;top:10px;bottom:10px;left:-4px}.folio-leaf{z-index:1;background:linear-gradient(#ffffff7a,#ffffff2e),#fffaf3b3;border:1px solid #7e604524;border-radius:4px 14px 14px 4px;gap:.7rem;min-height:340px;padding:1rem;transition:transform .32s cubic-bezier(.25,.1,.15,1),opacity .2s;display:grid;position:relative}.folio-leaf:after{content:"";pointer-events:none;background:linear-gradient(135deg,#b99f8221 0%,#0000 60%);border-radius:0 0 14px;width:16px;height:12px;position:absolute;bottom:0;right:0}.folio-leaf.flip-left{animation:.32s cubic-bezier(.25,.1,.15,1) folioFlipLeft}.folio-leaf.flip-right{animation:.32s cubic-bezier(.25,.1,.15,1) folioFlipRight}@keyframes folioFlipLeft{0%{opacity:1;transform:perspective(500px)rotateY(0)}40%{opacity:.5;transform:perspective(500px)rotateY(-6deg)translate(3%)}to{opacity:1;transform:perspective(500px)rotateY(0)}}@keyframes folioFlipRight{0%{opacity:1;transform:perspective(500px)rotateY(0)}40%{opacity:.5;transform:perspective(500px)rotateY(6deg)translate(-3%)}to{opacity:1;transform:perspective(500px)rotateY(0)}}.folio-edge{z-index:4;cursor:pointer;width:18%;position:absolute;top:0;bottom:0}.folio-edge.prev{left:0}.folio-edge.next{right:0}.folio-side-by-side{grid-template-columns:1fr 1fr;align-items:start}.folio-big-left{grid-template-columns:1.3fr .7fr;align-items:start}.folio-big-right{grid-template-columns:.7fr 1.3fr;align-items:start}.folio-diagonal{grid-template-rows:auto auto;grid-template-columns:1fr}.folio-diagonal .folio-card-0{justify-self:start;width:65%}.folio-diagonal .folio-card-1{justify-self:end;width:65%;margin-top:.4rem}.folio-card{flex-direction:column;align-items:center;gap:.3rem;padding:.3rem;display:flex;position:relative}.folio-card-0{transform:rotate(-1.5deg)}.folio-card-1{transform:rotate(2deg)}.folio-tape{z-index:5;background:#ebdec68c;border:1px solid #b99c7b33;border-radius:1px;width:42px;height:9px;position:absolute;top:-3px}.folio-card-0 .folio-tape{left:12px;transform:rotate(-7deg)}.folio-card-1 .folio-tape{left:14px;transform:rotate(11deg)}.folio-face{aspect-ratio:1;width:100%;max-width:140px}.folio-text{text-align:center;flex-direction:column;gap:.15rem;display:flex}.folio-title{font-family:var(--font-title);margin:0;font-size:.95rem}.folio-note{color:var(--ink-soft);margin:0;font-size:.83rem;line-height:1.45}.folio-author{color:var(--ink-soft);opacity:.7;margin:0;font-size:.75rem}.folio-foot{justify-content:space-between;align-items:center;gap:.5rem;margin-top:.4rem;display:flex}.folio-page-num{color:var(--ink-soft);opacity:.65;font-size:.8rem}@media (width<=680px){.folio-leaf{min-height:300px;padding:.7rem}.folio-side-by-side,.folio-big-left,.folio-big-right{grid-template-columns:1fr 1fr;gap:.5rem}.folio-big-left .folio-card-0,.folio-big-right .folio-card-1{grid-column:span 1}.folio-face{max-width:120px}.folio-diagonal .folio-card-0,.folio-diagonal .folio-card-1{width:75%}}.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}.heatmap{border:1px solid var(--line);background:#fffbf4b8;border-radius:14px;padding:.65rem .7rem}.heatmap-head{justify-content:center;align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.heatmap-month-label{font-family:var(--font-title);text-align:center;min-width:6rem;font-size:.95rem}.heatmap-month-btn{padding:.28rem .55rem!important;font-size:.8rem!important}.heatmap-grid{flex-direction:column;gap:2px;display:flex}.heatmap-row{grid-template-columns:repeat(7,minmax(0,1fr));gap:2px;display:grid}.heatmap-cell{aspect-ratio:1;border-radius:8px;justify-content:center;align-items:center;font-size:.78rem;display:flex}.heatmap-day-label{color:var(--ink-soft);aspect-ratio:unset;padding-bottom:2px;font-size:.72rem}.heatmap-empty{background:0 0}.heatmap-dot{appearance:none;color:var(--ink-soft);cursor:pointer;background:#e1d4c359;border:1px solid #0000;font-family:inherit;line-height:1;transition:all .15s}.heatmap-dot.has-record{color:var(--ink);background:#ad8c6c52;border-color:#936f4a33;font-weight:600}.heatmap-dot.is-selected{background:var(--accent);border-color:var(--accent-strong);color:var(--ink);transform:scale(1.05);box-shadow:0 0 0 2px #be93654d}.heatmap-dot.is-today{text-underline-offset:2px;text-decoration:underline}.heatmap-dot:hover{transform:scale(1.08)}.heatmap-dot-inner{pointer-events:none}.hanger-book{border:1px solid var(--line);touch-action:pan-y;background:#fffbf4b3;border-radius:16px 16px 16px 4px;flex-direction:column;gap:.7rem;padding:.9rem .9rem .9rem 2.2rem;display:flex;position:relative;overflow:hidden}.hanger-book-spine{border-left:1px dashed #8b65454d;width:0;position:absolute;top:.6rem;bottom:.6rem;left:.5rem}.hanger-book-spine:after{content:"";background:repeating-linear-gradient(#0000 0 14px,#805e3f38 15px 16px);width:4px;position:absolute;inset:0 0 0 -2.5px}.hanger-book-nav{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.hanger-book-date{color:var(--ink-soft);text-align:center;margin:0}.hanger-book-pages{position:relative}.hanger-book-stack{z-index:0;background:#f1e7d98c;border:1px solid #7e60451a;border-radius:4px 14px 14px 4px;position:absolute;inset:4px 3px -3px}.hanger-book-stack+.hanger-book-stack{opacity:.5;inset:7px 6px -6px}.hanger-book-leaf{z-index:1;cursor:pointer;-webkit-user-select:none;user-select:none;background:linear-gradient(#fff9,#ffffff47),#fff9f1c7;border:1px solid #7e604533;border-radius:4px 14px 14px 4px;padding:.85rem;transition:transform .28s cubic-bezier(.25,.1,.15,1),opacity .18s;position:relative}.hanger-book-leaf:after{content:"";pointer-events:none;background:linear-gradient(135deg,#b99f822e 0%,#0000 60%);border-radius:0 0 14px;width:18px;height:14px;position:absolute;bottom:0;right:0}.hanger-book-leaf.flip-left{animation:.28s cubic-bezier(.25,.1,.15,1) flipLeft}.hanger-book-leaf.flip-right{animation:.28s cubic-bezier(.25,.1,.15,1) flipRight}@keyframes flipLeft{0%{opacity:1;transform:translate(0)rotateY(0)}40%{opacity:.7;transform:translate(6%)rotateY(-4deg)}to{opacity:1;transform:translate(0)rotateY(0)}}@keyframes flipRight{0%{opacity:1;transform:translate(0)rotateY(0)}40%{opacity:.7;transform:translate(-6%)rotateY(4deg)}to{opacity:1;transform:translate(0)rotateY(0)}}.hanger-book-leaf .click-zone{z-index:2;width:38%;position:absolute;top:0;bottom:0}.hanger-book-leaf .click-zone.prev{cursor:w-resize;left:0}.hanger-book-leaf .click-zone.next{cursor:e-resize;right:0}.hanger-book-footer{justify-content:space-between;align-items:center;gap:.5rem;margin-top:.35rem;display:flex}.hanger-book-page-num{color:var(--ink-soft);opacity:.7;margin:0;font-size:.8rem}.hanger-book-empty{flex-direction:column;gap:.45rem;display:flex}.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-toast{color:#48673b;text-align:center;background:#adcd9147;border-radius:999px;margin:0 0 .5rem;padding:.45rem .8rem;font-size:.85rem;animation:.3s reveal}.settings-card{border:1px solid var(--line);background:#fffaf1b3;border-radius:14px;flex-direction:column;gap:.5rem;margin-top:.65rem;padding:.75rem .85rem;display:flex}.settings-card:first-of-type{margin-top:0}.settings-card-title{font-family:var(--font-title);margin:0;font-size:1.02rem}.settings-fold-toggle{all:unset;cursor:pointer;font-family:var(--font-title);justify-content:space-between;align-items:center;font-size:1.02rem;display:flex}.fold-arrow{color:var(--ink-soft);font-size:.9rem}.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:180px;color:var(--ink);background:#fffdf8bf;border-radius:999px;flex:1;padding:.45rem .75rem;font-family:inherit}.settings-actions{flex-wrap:wrap;gap:.5rem;display:flex}.sync-bar{flex-direction:column;gap:.25rem;display:flex}.sync-bar-track{background:#d8c8b240;border-radius:999px;height:8px;display:flex;overflow:hidden}.sync-bar-seg{height:100%;transition:width .4s}.sync-bar-seg.synced{background:#8ea9758c}.sync-bar-seg.dirty{background:#d8b48b99}.sync-bar-seg.local{background:#bdae9d66}.sync-bar-legend{color:var(--ink-soft);gap:.8rem;font-size:.75rem;display:flex}.submission-timeline{border-left:1.5px solid #8b654526;flex-direction:column;gap:0;margin-left:.5rem;padding-left:.6rem;display:flex}.submission-item{align-items:flex-start;gap:.55rem;padding:.5rem 0;display:flex;position:relative}.submission-dot{border:1px solid #3a261826;border-radius:999px;width:8px;min-width:8px;height:8px;margin-top:.35rem}.submission-dot.is-synced{background:#8ea975a6}.submission-dot.is-dirty{background:#d8b48ba6}.submission-dot.is-local{background:#b47d658c}.submission-item-body{flex-direction:column;flex:1;gap:.15rem;font-size:.85rem;display:flex}.submission-item-date{color:var(--ink)}.submission-item-comment{color:var(--ink-soft);font-size:.8rem}.submission-thumb{aspect-ratio:1;border-radius:8px;width:40px;min-width:40px}.settings-stats,.settings-auth,.settings-install{display:none}.dialog-mask{z-index:50;background:#22170f5c;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.dialog-card{border:1px solid var(--line);background:#fffbf4f5;border-radius:16px;flex-direction:column;gap:.6rem;width:min(460px,100%);padding:.95rem;display:flex;box-shadow:0 12px 32px #2c1c112e}.dialog-title{font-family:var(--font-title);margin:0;font-size:1.08rem}.dialog-copy{color:var(--ink-soft);margin:0}.dialog-input{min-width:100%}.dialog-error{color:#9e3f2e;margin:0;font-size:.85rem}.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}.featured-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.7rem;display:grid}.featured-card{border:1px solid var(--line);background:linear-gradient(#ffffff80,#ffffff47),#fffaf1cc;border-radius:18px;flex-direction:column;gap:.65rem;padding:.72rem;display:flex}.featured-face{aspect-ratio:1;align-self:center;width:100%;min-width:120px;max-width:150px}.featured-copy{flex-direction:column;gap:.3rem;display:flex}.featured-title,.featured-note,.featured-author{margin:0}.featured-title{font-family:var(--font-title);font-size:1.02rem}.featured-note{color:var(--ink);line-height:1.5}.featured-author{color:var(--ink-soft);font-size:.85rem}.ghost-btn{padding:.48rem .95rem}.primary-btn:hover,.ghost-btn:hover,.mini-chip:hover{transform:translateY(-1px);box-shadow:0 4px 10px #563d2714}.primary-btn:active,.ghost-btn:active,.mini-chip:active{transform:translateY(0)scale(.98);box-shadow:0 1px 5px #563d271a}.primary-btn:focus-visible,.ghost-btn:focus-visible,.mini-chip:focus-visible{outline-offset:2px;outline:2px solid #936f4ad9}.ghost-btn.is-active{background:#adcd9147;border-color:#6b98598c}.primary-btn.is-success,.ghost-btn.is-success{background:#adcd9157;border-color:#6b98599e}.primary-btn.is-loading,.ghost-btn.is-loading{opacity:.92}.btn-spinner{border:2px solid #533d2842;border-top-color:#533d28e6;border-radius:50%;width:.92rem;height:.92rem;animation:.62s linear infinite spin}.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)}}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=680px){.app-shell{border-radius:14px;width:calc(100% - .5rem);margin:.3rem auto;padding:.6rem .7rem}.app-bar{padding:.1rem .1rem .4rem}.app-bar-brand{font-size:.95rem}.tab-chip{padding:.35rem .7rem;font-size:.85rem}.three-canvas{width:min(300px,100%)}.note-save-row{flex-direction:column}.note-save-actions{flex-direction:row;align-self:flex-end}.featured-grid{grid-template-columns:1fr;gap:.6rem}.featured-card{padding:.75rem}.featured-face{min-width:132px;max-width:168px}}@media (width>=681px) and (width<=980px){.featured-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
