@import "https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,400;1,9..144,500&family=Instrument+Sans:wght@400;500;600&family=JetBrains+Mono:wght@300;400&display=swap";:root{--paper:#ede6d6;--paper-grid:#1b1a170b;--paper-edge:#dcd2bc;--wall:#f2ecde;--wall-shadow:#1b1a1714;--wall-edge:#c9bea4;--ink:#1b1a17;--ink-2:#5c544a;--ink-3:#8a8274;--rule:#c9bea4;--rule-strong:#8a8274;--mat:#fbf7ec;--mat-bevel:#e8e0ce;--wood-light:#c89968;--wood-mid:#8c6542;--wood-dark:#4a3728;--wood-white:#f7f3ea;--mark:#b8482e;--ink-blue:#2c4a52;--ease:cubic-bezier(.2, .8, .2, 1);--ease-in:cubic-bezier(.4, 0, 1, 1);--sh-frame:0 1px 2px #1b1a172e, 0 6px 14px -4px #1b1a1738;--sh-frame-hover:0 1px 2px #1b1a1738, 0 14px 24px -6px #1b1a174d;--sh-card:0 1px 2px #1b1a171a, 0 10px 30px -10px #1b1a1740}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--paper);color:var(--ink);-webkit-font-smoothing:antialiased;background-image:linear-gradient(var(--paper-grid) 1px, transparent 1px), linear-gradient(90deg, var(--paper-grid) 1px, transparent 1px);background-size:24px 24px;font-family:Instrument Sans,system-ui,sans-serif;font-size:14px;line-height:1.45}.font-display{font-family:Fraunces,Georgia,serif}.font-mono{font-family:JetBrains Mono,ui-monospace,monospace}.app{grid-template-rows:56px 1fr;height:100%;display:grid}.toolbar{border-bottom:1px solid var(--rule);background:var(--paper);z-index:10;align-items:center;gap:14px;padding:0 20px;font-size:13px;display:flex;position:relative}.toolbar .wordmark{letter-spacing:-.01em;color:var(--ink);-webkit-user-select:none;user-select:none;font-family:Fraunces,serif;font-size:20px;font-style:italic;font-weight:500}.toolbar .wordmark .dot{background:var(--mark);vertical-align:middle;border-radius:50%;width:4px;height:4px;margin:0 6px;display:inline-block}.toolbar .divider{background:var(--rule);width:1px;height:24px}.toolbar .group{align-items:center;gap:6px;display:inline-flex}.toolbar .group-label{letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);font:500 10px/1 Instrument Sans,sans-serif}.toolbar .unit{color:var(--ink-3);font:300 11px JetBrains Mono,monospace}.toolbar input[type=number]{border:none;border-bottom:1px solid var(--rule-strong);width:46px;color:var(--ink);text-align:right;background:0 0;padding:4px;font:300 13px JetBrains Mono,monospace}.toolbar input[type=number]:focus{border-bottom-color:var(--mark);outline:none}.toolbar input[type=range]{width:90px;accent-color:var(--mark)}.toolbar .spacer{flex:1}.toolbar .ghost{color:var(--ink-2);letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:color .12s var(--ease);background:0 0;border:none;padding:8px 10px;font:500 11px/1 Instrument Sans,sans-serif}.toolbar .ghost:hover{color:var(--ink)}.toolbar .ghost.danger:hover{color:var(--mark)}.toolbar .toggle{letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;font:500 10px/1 Instrument Sans,sans-serif;display:inline-flex}.toolbar .toggle input{accent-color:var(--mark)}.workspace{padding:52px 48px 80px;position:relative;overflow:auto}.workspace__hint{color:var(--ink-3);letter-spacing:.01em;pointer-events:none;font:italic 400 12px Fraunces,serif;position:absolute;top:16px;right:32px}.wall-holder{padding:24px 0 0 24px;display:inline-block;position:relative}.wall{background:var(--wall);border:1px solid var(--wall-edge);box-shadow:var(--sh-card);animation:fadeIn .3s var(--ease) both;position:relative}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.ruler{background:var(--paper);color:var(--ink-2);pointer-events:none;position:absolute}.ruler--top{border-bottom:1px solid var(--rule-strong);height:24px;top:0;left:24px}.ruler--left{border-right:1px solid var(--rule-strong);width:24px;top:24px;left:0}.ruler .tick{background:var(--rule-strong);position:absolute}.ruler--top .tick{width:1px;bottom:0}.ruler--left .tick{height:1px;right:0}.ruler .tick--quarter{opacity:.55}.ruler--top .tick--major{height:10px}.ruler--top .tick--half{height:6px}.ruler--top .tick--quarter{height:4px}.ruler--left .tick--major{width:10px}.ruler--left .tick--half{width:6px}.ruler--left .tick--quarter{width:4px}.ruler .label{color:var(--ink-2);font:400 9px/1 JetBrains Mono,monospace;position:absolute}.ruler--top .label{top:4px;transform:translate(3px)}.ruler--left .label{left:3px;transform:translateY(-4px)}.ruler__caret{color:var(--mark);font:400 10px/1 JetBrains Mono,monospace;transition:transform 60ms linear;position:absolute}.ruler--top .ruler__caret{bottom:-1px;transform:translate(-50%)}.ruler--left .ruler__caret{right:-1px;transform:translateY(-50%)}.ruler__corner{background:var(--paper);border-right:1px solid var(--rule-strong);border-bottom:1px solid var(--rule-strong);width:24px;height:24px;color:var(--ink-3);letter-spacing:.1em;justify-content:center;align-items:center;font:300 8px/1 JetBrains Mono,monospace;display:flex;position:absolute;top:0;left:0}.frame{box-shadow:var(--sh-frame);transition:box-shadow .14s var(--ease), transform .14s var(--ease);cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;position:absolute}.frame:hover{box-shadow:var(--sh-frame-hover);transform:translateY(-1px)}.frame.is-dragging{cursor:grabbing;box-shadow:var(--sh-frame-hover);z-index:5;transition:none}.frame.is-selected{z-index:4}.frame.is-selected:after{content:"";border:1.5px dashed var(--mark);pointer-events:none;animation:markIn .12s var(--ease) both;position:absolute;inset:-6px}@keyframes markIn{0%{opacity:0}to{opacity:1}}.frame__wood{background:linear-gradient(180deg, #fff6, #0000000d), var(--wood,var(--wood-white));position:absolute;inset:0;box-shadow:inset 0 0 0 1px #1b1a1724,inset 0 1px #fff9}.frame__mat{background:var(--mat);box-shadow:inset 0 0 0 1px var(--mat-bevel), inset 0 1px 2px #0000000a;position:absolute}.frame__opening{background:var(--mat-bevel);position:absolute;overflow:hidden;box-shadow:inset 0 0 0 1px #0000001f}.frame__opening img{object-fit:cover;transform-origin:50%;pointer-events:none;width:100%;height:100%;display:block}.frame__placeholder{width:100%;height:100%;color:var(--ink-3);letter-spacing:.02em;justify-content:center;align-items:center;font:italic 400 11px/1 Fraunces,serif;display:flex}.frame__nail{pointer-events:none;background:#1a1612;border-radius:50%;width:3px;height:3px;position:absolute;top:-1px;left:50%;transform:translate(-50%);box-shadow:0 1px 2px #0006}.frame__tag{color:var(--mark);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .12s var(--ease);font:300 10px/1 JetBrains Mono,monospace;position:absolute;top:-20px;left:0}.frame.is-dragging .frame__tag,.frame.is-selected .frame__tag{opacity:1}.controls{z-index:20;background:var(--wall);border:1px solid var(--rule);width:272px;box-shadow:var(--sh-card);animation:cardIn .16s var(--ease) both;padding:16px 16px 12px;position:absolute}@keyframes cardIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.controls h3{color:var(--ink);justify-content:space-between;align-items:baseline;margin:0 0 12px;font:italic 500 16px/1.1 Fraunces,serif;display:flex}.controls h3 .sub{color:var(--ink-3);letter-spacing:.04em;font:300 10px JetBrains Mono,monospace}.controls .row{flex-direction:column;gap:5px;margin-bottom:12px;display:flex}.controls .row-inline{flex-direction:row;align-items:center;gap:10px}.controls label.lbl{letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);font:500 10px/1 Instrument Sans,sans-serif}.controls .pills{border:1px solid var(--rule);align-self:flex-start;display:inline-flex}.controls .pills button{color:var(--ink-2);cursor:pointer;transition:background .1s var(--ease);background:0 0;border:none;padding:6px 12px;font:500 12px Instrument Sans,sans-serif}.controls .pills button+button{border-left:1px solid var(--rule)}.controls .pills button.is-active{background:var(--ink);color:var(--paper)}.controls select{border:none;border-bottom:1px solid var(--rule-strong);width:100%;color:var(--ink);appearance:none;background:0 0;background-image:linear-gradient(45deg, transparent 50%, var(--ink-2) 50%), linear-gradient(135deg, var(--ink-2) 50%, transparent 50%);background-position:calc(100% - 8px),calc(100% - 4px);background-repeat:no-repeat;background-size:4px 4px,4px 4px;border-radius:0;padding:6px 4px;font:400 13px Instrument Sans,sans-serif}.controls select:focus{border-bottom-color:var(--mark);outline:none}.controls .drop{border:1px dashed var(--rule-strong);color:var(--ink-2);cursor:pointer;transition:border-color .12s var(--ease), color .12s var(--ease);background:#ffffff40;justify-content:center;align-items:center;padding:14px 10px;font:italic 400 12px Fraunces,serif;display:flex}.controls .drop:hover{border-color:var(--mark);color:var(--mark)}.controls .photo-preview{align-items:center;gap:10px;display:flex}.controls .photo-preview .thumb{border:1px solid var(--rule);flex-shrink:0;width:44px;height:44px;overflow:hidden}.controls .photo-preview .thumb img{object-fit:cover;width:100%;height:100%}.controls .photo-preview .actions{gap:4px;display:flex}.controls .slider-row{letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);grid-template-columns:32px 1fr 40px;align-items:center;gap:8px;font:500 10px Instrument Sans,sans-serif;display:grid}.controls .slider-row input[type=range]{width:100%;accent-color:var(--mark)}.controls .slider-row .val{color:var(--ink-2);text-align:right;font:300 10px JetBrains Mono,monospace}.controls .delete{letter-spacing:.08em;text-transform:uppercase;color:var(--mark);cursor:pointer;background:0 0;border:none;margin-top:4px;padding:6px 0 0;font:500 10px/1 Instrument Sans,sans-serif}.controls .delete:hover{color:#7e2f1c}.controls .mini-ghost{border:1px solid var(--rule);color:var(--ink-2);letter-spacing:.08em;text-transform:uppercase;cursor:pointer;background:0 0;padding:4px 6px;font:500 9px/1 Instrument Sans,sans-serif}.controls .mini-ghost:hover{color:var(--ink);border-color:var(--rule-strong)}.frame.is-entering{opacity:0;animation:frameIn .26s var(--ease) forwards;animation-delay:var(--stagger,0s)}@keyframes frameIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}input[type=file]{display:none}.sync-status{border:1px solid var(--rule);color:var(--ink-2);transition:border-color .2s var(--ease), background .2s var(--ease);cursor:default;-webkit-user-select:none;user-select:none;background:#fffdf673;align-items:center;gap:10px;margin-right:4px;padding:5px 12px 6px;display:inline-flex}.sync-status[data-state=syncing]{border-color:var(--wood-light)}.sync-status[data-state=offline]{border-color:var(--mark);background:#b8482e0d}.sync-status__glyph{color:#6d8a63;width:14px;height:14px;transition:color .22s var(--ease);flex-shrink:0;display:inline-flex}.sync-status[data-state=syncing] .sync-status__glyph{color:var(--wood-light)}.sync-status[data-state=offline] .sync-status__glyph{color:var(--mark)}.sync-glyph--spin{transform-origin:50%;animation:.9s linear infinite syncSpin}@keyframes syncSpin{to{transform:rotate(360deg)}}.sync-status__body{flex-direction:column;gap:2px;line-height:1;display:flex}.sync-status__row{align-items:baseline;gap:5px;min-height:14px;display:inline-flex}.sync-status__hint{color:var(--ink);letter-spacing:.005em;font:italic 500 12px Fraunces,serif}.sync-status__who{color:var(--ink);letter-spacing:0;font:italic 500 13px Fraunces,serif}.sync-status__who--other{color:var(--mark)}.sync-status__sep{color:var(--ink-3);font:300 10px JetBrains Mono,monospace}.sync-status__time{color:var(--ink-3);letter-spacing:.02em;font:300 10px JetBrains Mono,monospace}.sync-status__me{opacity:.85;align-items:baseline;gap:5px;display:inline-flex}.sync-status__me-label{letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);font:500 8px/1 Instrument Sans,sans-serif}.sync-status__me em{color:var(--ink-2);letter-spacing:0;font:italic 500 11px Fraunces,serif}.toast-region{z-index:100;pointer-events:none;flex-direction:column;align-items:flex-end;gap:8px;display:flex;position:fixed;top:18px;right:22px}.toast{background:var(--wall);color:var(--ink);border:1px solid var(--rule);box-shadow:var(--sh-card);letter-spacing:.005em;min-width:180px;max-width:320px;animation:toastIn .26s var(--ease) both;pointer-events:auto;border-left:none;align-items:center;gap:12px;padding:11px 16px 11px 14px;font:italic 500 13px/1.2 Fraunces,serif;display:inline-flex;position:relative}.toast__rule{background:var(--mark);width:3px;position:absolute;top:-1px;bottom:-1px;left:0}.toast--warn .toast__rule{background:var(--wood-mid)}.toast__body{display:inline}.toast__who{color:var(--mark);margin-right:2px;font:italic 600 13px Fraunces,serif}.toast__sep{color:var(--ink-3);letter-spacing:.04em;margin:0 2px;font:300 10px JetBrains Mono,monospace}@keyframes toastIn{0%{opacity:0;transform:translate(6px,-4px)}to{opacity:1;transform:none}}
