.linen-canvas{background-color:var(--color-canvas-bg);background-image:repeating-linear-gradient(0deg,#0000,#0000 2px,#b4aa9b14 2px 3px),repeating-linear-gradient(90deg,#0000,#0000 2px,#b4aa9b0f 2px 3px),repeating-linear-gradient(45deg,#0000,#0000 4px,#c8beaf0a 4px 5px),repeating-linear-gradient(-45deg,#0000,#0000 4px,#c8beaf08 4px 5px)}.linen-canvas-with-texture{background-color:var(--color-canvas-bg);background-blend-mode:multiply;opacity:.97;background-image:url(/linen.png);background-repeat:repeat;background-size:256px 256px}:root{--color-coral:#fa9189;--color-peach:#fcae7c;--color-yellow:#ffe699;--color-lemon:#f9ffb5;--color-mint:#b3f5bc;--color-sky:#d6f6ff;--color-lavender:#e2cbf7;--color-lilac:#d1bdff;--color-eggplant:#483a5c;--color-mauve:#b894b0;--color-steel:#b3cde0;--color-sage-cream:#dcdfd4;--color-sage:#a1bd8f;--color-canvas-bg:#fafaf7;--color-panel-bg:#f5f3ee;--color-border:#e8e4dc;--color-text-primary:#3d3450;--color-text-muted:#9b8fad;--color-text-light:#c4bbcf;--color-white:#fff;--color-overlay:#3d345066;--color-brand-green:#0b3b2e;--color-brand-green-hover:#0d4136;--shadow-panel:0 2px 16px #3d345014;--shadow-card:0 4px 24px #3d34501a;--shadow-dialog:0 8px 48px #3d34502e;--shadow-toast:0 4px 16px #3d345024;--radius-xs:4px;--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--radius-xl:28px;--radius-pill:999px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--ease-soft:cubic-bezier(.4, 0, .2, 1);--ease-out:cubic-bezier(0, 0, .2, 1);--duration-fast:.12s;--duration-base:.22s;--duration-slow:.4s;--duration-xslow:.7s;--z-canvas:1;--z-panel:10;--z-cursor:20;--z-pip:30;--z-prompt:40;--z-dialog:50;--z-toast:60;--z-onboarding:70;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--color-text-primary);background:var(--color-canvas-bg);font-family:Nunito,system-ui,-apple-system,sans-serif}*,:before,:after{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0;padding:0;overflow:hidden}body{background:var(--color-canvas-bg);color:var(--color-text-primary);font-family:Nunito,system-ui,-apple-system,sans-serif}button{cursor:pointer;color:inherit;background:0 0;border:none;padding:0;font-family:inherit}input,textarea{font-family:inherit}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeSlideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes cursorPulse{0%{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.15)}to{opacity:1;transform:scale(1)}}@keyframes pinchRipple{0%{opacity:.8;transform:scale(.8)}to{opacity:0;transform:scale(2.4)}}@keyframes swatchPop{0%{transform:scale(1)}40%{transform:scale(1.18)}70%{transform:scale(.95)}to{transform:scale(1.06)}}@keyframes toastIn{0%{opacity:0;transform:translateY(16px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes toastOut{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(8px)scale(.96)}}@keyframes dialogIn{0%{opacity:0;transform:scale(.94)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes instrumentBounce{0%{transform:translateY(0)}30%{transform:translateY(-4px)}60%{transform:translateY(1px)}to{transform:translateY(0)}}@keyframes demoHandPinch{0%{transform:scale(1)}40%{transform:scale(.82)}70%{transform:scale(1.04)}to{transform:scale(1)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes canvasSweep{0%{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0 0% 0 0)}}@keyframes cardLift{0%{box-shadow:var(--shadow-card);transform:translateY(0)}to{transform:translateY(-4px);box-shadow:0 8px 32px #3d345026}}.plonk-logo{letter-spacing:-.02em;color:var(--color-text-primary);-webkit-user-select:none;user-select:none;align-items:center;font-family:Nunito,sans-serif;font-weight:800;line-height:1;display:inline-flex}.plonk-logo__text,.plonk-logo__o-wrap{display:inline-block;position:relative}.plonk-logo__dot{background:var(--color-coral);opacity:.85;width:8px;height:8px;transition:transform .22s var(--ease-spring);border-radius:50%;position:absolute;top:-6px;left:calc(50% + 2px);transform:translate(-50%)}.plonk-logo:hover .plonk-logo__dot{animation:instrumentBounce .32s var(--ease-spring)}.plonk-logo--default{font-size:28px}.plonk-logo--sm{font-size:20px}.plonk-logo--sm .plonk-logo__dot{width:6px;height:6px;top:-4px}.plonk-logo--mono{color:var(--color-white);font-size:28px}.plonk-logo--mono .plonk-logo__dot{background:var(--color-lavender)}.tool-panel{background:var(--color-panel-bg);border-right:1px solid var(--color-border);border-radius:var(--radius-lg) 0 0 var(--radius-lg);width:108px;height:100%;box-shadow:var(--shadow-panel);padding:var(--space-4) var(--space-3);align-items:center;gap:var(--space-3);z-index:var(--z-panel);flex-direction:column;flex-shrink:0;display:flex;overflow:visible}.tool-panel__swatches{justify-items:start;gap:var(--space-2);grid-template-columns:repeat(2,1fr);width:100%;display:grid}.tool-panel__swatch{background:var(--swatch-hex);cursor:pointer;width:32px;height:32px;transition:transform var(--duration-fast) var(--ease-soft), border-color var(--duration-fast) var(--ease-soft), box-shadow var(--duration-fast) var(--ease-soft);border:2px solid #0000;border-radius:50%;flex-shrink:0;position:relative;box-shadow:inset 0 0 0 1px #3d345014}.tool-panel__swatch:hover{transform:scale(1.08)}.tool-panel__swatch.is-selected{border-color:color-mix(in srgb, var(--swatch-hex) 60%, transparent);box-shadow:0 0 0 3px color-mix(in srgb, var(--swatch-hex) 30%, transparent)}.tool-panel__swatch.is-popping{animation:swatchPop .3s var(--ease-spring)}.tool-panel__divider{background:var(--color-border);width:100%;height:1px;margin:var(--space-2) 0}.tool-panel__tools{gap:var(--space-2);flex-direction:column;align-items:center;display:flex}.tool-panel__tool{border-radius:var(--radius-sm);width:36px;height:36px;color:var(--color-text-primary);cursor:pointer;transition:background var(--duration-fast) var(--ease-soft), color var(--duration-fast) var(--ease-soft);justify-content:center;align-items:center;display:inline-flex;position:relative}.tool-panel__tool:hover{background:#e2cbf74d}.tool-panel__tool.is-selected{color:var(--color-eggplant);background:#e2cbf780}.tool-panel__swatch-tooltip{background:var(--color-text-primary);color:var(--color-white);letter-spacing:.04em;white-space:nowrap;border-radius:var(--radius-sm);opacity:0;pointer-events:none;transition:opacity var(--duration-fast) var(--ease-soft);z-index:calc(var(--z-toast) + 2);box-shadow:var(--shadow-panel);padding:5px 10px;font-size:11px;font-weight:600;position:absolute;top:50%;left:calc(100% + 12px);transform:translateY(-50%)}.tool-panel__swatches .tool-panel__swatch:nth-child(odd) .tool-panel__swatch-tooltip{left:calc(100% + 52px)}.tool-panel__swatch:hover .tool-panel__swatch-tooltip,.tool-panel__tool:hover .tool-panel__swatch-tooltip{opacity:1}.tool-panel__size{width:36px;height:100px;margin-top:var(--space-2);justify-content:center;align-items:center;display:flex;position:relative}.tool-panel__size-input{appearance:none;background:var(--color-border);border-radius:var(--radius-pill);transform-origin:50%;cursor:pointer;background-image:linear-gradient(to right, var(--accent,var(--color-text-primary)) 0%, var(--accent,var(--color-text-primary)) 50%, var(--color-border) 50%);background-repeat:no-repeat;outline:none;width:80px;height:4px;transform:rotate(-90deg)}.tool-panel__size-input::-webkit-slider-thumb{appearance:none;background:var(--color-text-primary);border:2px solid var(--color-white);width:14px;height:14px;box-shadow:var(--shadow-panel);cursor:grab;border-radius:50%}.tool-panel__size-input::-moz-range-thumb{background:var(--color-text-primary);border:2px solid var(--color-white);width:14px;height:14px;box-shadow:var(--shadow-panel);cursor:grab;border-radius:50%}.tool-panel__size-dots{pointer-events:none;flex-direction:column;justify-content:space-between;align-items:center;padding:2px 0;display:flex;position:absolute;inset:0}.tool-panel__size-dots .dot{background:var(--color-text-light);border-radius:50%;width:4px;height:4px}.tool-panel__size-dots .dot--s{width:3px;height:3px}.tool-panel__size-dots .dot--m{width:5px;height:5px}.tool-panel__size-dots .dot--l{width:7px;height:7px}.webcam-pip{top:30vh;right:var(--space-6);border-radius:var(--radius-lg);width:235.591px;height:195.591px;box-shadow:var(--shadow-card);border:2px solid var(--color-border);z-index:var(--z-pip);opacity:.85;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;transition:opacity var(--duration-base) var(--ease-soft), width var(--duration-base) var(--ease-soft), height var(--duration-base) var(--ease-soft);background:#000;position:fixed;bottom:auto;overflow:hidden}.webcam-pip.is-dragging{cursor:grabbing;opacity:1;transition:none;box-shadow:0 12px 32px #3d345038}.webcam-pip:hover{opacity:1}.webcam-pip.is-hidden{opacity:.85;background:var(--color-white);border-color:var(--color-border);width:72px;height:36px}.webcam-pip.is-hidden .webcam-pip__video{display:none}.webcam-pip__video{object-fit:cover;width:100%;height:100%;display:block;transform:scaleX(-1)}.webcam-pip__status{border-radius:var(--radius-pill);color:var(--color-white);-webkit-backdrop-filter:blur(8px);z-index:2;pointer-events:none;-webkit-user-select:none;user-select:none;background:#140e2099;align-items:center;gap:8px;padding:5px 12px;display:inline-flex;position:absolute;top:8px;left:8px}.webcam-pip__status-dot{width:7px;height:7px;transition:background var(--duration-fast) var(--ease-soft);background:#ffffff59;border-radius:50%;flex-shrink:0}.webcam-pip__status.is-tracking .webcam-pip__status-dot{background:var(--color-mint);animation:pipStatusPulse 1.6s var(--ease-soft) infinite;box-shadow:0 0 0 3px #b3f5bc2e}@keyframes pipStatusPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.65;transform:scale(.88)}}.webcam-pip__status-text{letter-spacing:.12em;text-transform:uppercase;white-space:nowrap;font-family:Nunito,sans-serif;font-size:10px;font-weight:700}.hand-skel{pointer-events:none;z-index:1;width:100%;height:100%;position:absolute;inset:0}.hand-skel__lines line{stroke:#fcae7c;stroke-width:1.6px;stroke-linecap:round;opacity:.85;vector-effect:non-scaling-stroke}.hand-skel__dots circle{fill:#fcae7c;opacity:.95}.webcam-pip__toolbar{z-index:2;align-items:center;gap:4px;display:inline-flex;position:absolute;top:6px;right:6px}.webcam-pip__btn{width:28px;height:28px;color:var(--color-text-primary);-webkit-backdrop-filter:blur(4px);transition:background var(--duration-fast) var(--ease-soft), color var(--duration-fast) var(--ease-soft), transform var(--duration-fast) var(--ease-spring);background:#ffffffd9;border-radius:50%;justify-content:center;align-items:center;display:inline-flex}.webcam-pip__btn:hover:not(:disabled){background:var(--color-white);transform:scale(1.06)}.webcam-pip__btn:disabled{opacity:.5;cursor:not-allowed}.webcam-pip__btn svg{width:16px;height:16px}.webcam-pip__btn.is-off{color:#b14a40;background:#fa91892e}.webcam-pip__btn.is-off:hover:not(:disabled){background:#fa91894d}.webcam-pip--off{background:#2a2434;border-color:#ffffff14}.webcam-pip__placeholder{color:#fff6;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.webcam-pip__placeholder svg{width:40px;height:40px}.webcam-pip--error{bottom:calc(56px + var(--space-4));right:var(--space-6);background:var(--color-white);max-width:240px;min-height:85.7953px;color:var(--color-text-muted);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-toast);z-index:calc(var(--z-toast) + 1);align-items:center;font-size:12px;display:flex;position:fixed}.hand-cursor{pointer-events:none;width:40px;height:40px;z-index:var(--z-cursor);will-change:transform;position:absolute;top:0;left:0}.hand-cursor__eraser-ring{pointer-events:none;background:#ffffff2e;border:1.5px solid #3d34508c;border-radius:50%;position:absolute;top:0;left:0;box-shadow:inset 0 0 0 1px #ffffff80}.hand-cursor.is-eraser.is-pinching .hand-cursor__eraser-ring{background:#ffffff59;border-color:#3d3450d9}.hand-cursor__ripple{pointer-events:none;animation:pinchRipple .6s var(--ease-out) forwards;border:2px solid;border-radius:50%;position:absolute;inset:4px}.hand-cursor__hold-ring{opacity:.6;pointer-events:none;animation:holdRingPulse .9s var(--ease-soft) infinite;border:2px solid;border-radius:50%;position:absolute;inset:-4px}@keyframes holdRingPulse{0%{opacity:.7;transform:scale(1)}50%{opacity:.15;transform:scale(1.35)}to{opacity:.7;transform:scale(1)}}.now-playing{bottom:var(--space-4);align-items:center;gap:var(--space-2);-webkit-backdrop-filter:blur(8px);border-radius:var(--radius-pill);padding:var(--space-2) var(--space-4);box-shadow:var(--shadow-panel);animation:fadeSlideUp var(--duration-base) var(--ease-spring);pointer-events:none;z-index:var(--z-cursor);background:#ffffffd9;display:inline-flex;position:absolute;left:50%;transform:translate(-50%)}.now-playing__dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.now-playing__label{letter-spacing:.04em;color:var(--color-text-muted);text-transform:uppercase;font-family:Nunito,sans-serif;font-size:12px;font-weight:600;display:inline-block}.now-playing__label.is-bouncing{animation:instrumentBounce .36s var(--ease-spring)}.text-bubble{min-width:80px;max-width:320px;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);color:var(--bubble-color);cursor:text;will-change:transform;z-index:var(--z-cursor);-webkit-user-select:text;user-select:text;background:0 0;border:1.5px dashed #0000;font-family:Nunito,sans-serif;font-weight:600;line-height:1.4;position:absolute;top:0;left:0}.text-bubble.is-active{border-color:color-mix(in srgb, var(--bubble-color) 60%, transparent);background:#ffffffb3}.text-bubble__editor{white-space:pre-wrap;word-wrap:break-word;text-align:left;direction:ltr;unicode-bidi:normal;outline:none;min-width:60px;min-height:1.2em}.text-bubble__editor:empty:before{content:"Type something…";color:var(--color-text-light);font-weight:500}.text-bubble__delete{background:var(--color-white);width:20px;height:20px;color:var(--color-text-muted);box-shadow:var(--shadow-panel);border:1px solid var(--color-border);border-radius:50%;justify-content:center;align-items:center;display:inline-flex;position:absolute;top:-8px;right:-8px}.text-bubble__delete svg{width:12px;height:12px}.text-bubble__delete:hover{color:#b14a40}.prompt-card{align-items:center;gap:var(--space-4);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-6);box-shadow:var(--shadow-card);margin:var(--space-3) var(--space-4) var(--space-3);animation:fadeSlideDown var(--duration-slow) var(--ease-spring);z-index:2;background:#f8f6f1;border:none;flex-shrink:0;display:flex;position:relative}.prompt-card__icon{border-radius:var(--radius-md);background:var(--color-yellow);width:40px;height:40px;color:var(--color-text-primary);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex;box-shadow:0 1px 2px #3d34500f}.prompt-card__icon svg{color:#b08838;width:22px;height:22px}.prompt-card__body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.prompt-card__label{letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);font-family:Nunito,sans-serif;font-size:11px;font-weight:600}.prompt-card__text{color:var(--color-text-primary);letter-spacing:-.005em;white-space:nowrap;text-overflow:ellipsis;margin:0;font-family:Nunito,sans-serif;font-size:17px;font-weight:700;line-height:1.25;overflow:hidden}.prompt-card__actions{align-items:center;gap:var(--space-2);flex-shrink:0;display:inline-flex}.prompt-card__skip{color:var(--color-text-muted);padding:var(--space-2) var(--space-3);border-radius:var(--radius-pill);transition:color var(--duration-fast) var(--ease-soft), background var(--duration-fast) var(--ease-soft);font-family:Nunito,sans-serif;font-size:13px;font-weight:600}.prompt-card__skip:hover{color:var(--color-text-primary);background:#3d34500d}.prompt-card__start{color:var(--color-white);background:var(--color-brand-green);padding:var(--space-2) var(--space-5);border-radius:var(--radius-pill);transition:background var(--duration-fast) var(--ease-soft), transform var(--duration-fast) var(--ease-spring);font-family:Nunito,sans-serif;font-size:13px;font-weight:700}.prompt-card__start:hover{background:var(--color-brand-green-hover)}.prompt-card__start:active{transform:scale(.97)}.prompt-card__dismiss{width:32px;height:32px;color:var(--color-text-light);transition:background var(--duration-fast) var(--ease-soft), color var(--duration-fast) var(--ease-soft);border-radius:50%;justify-content:center;align-items:center;display:inline-flex}.prompt-card__dismiss svg{width:16px;height:16px}.prompt-card__dismiss:hover{color:var(--color-text-muted);background:#3d34500f}.save-dialog__overlay{background:var(--color-overlay);-webkit-backdrop-filter:blur(4px);z-index:var(--z-dialog);padding:var(--space-5);animation:fadeSlideUp var(--duration-base) var(--ease-soft);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.save-dialog{background:var(--color-white);border-radius:var(--radius-xl);width:400px;max-width:100%;padding:var(--space-8);box-shadow:var(--shadow-dialog);animation:dialogIn .3s var(--ease-spring);gap:var(--space-5);flex-direction:column;display:flex}.save-dialog__title{color:var(--color-text-primary);margin:0;font-family:Nunito,sans-serif;font-size:18px;font-weight:700}.save-dialog__input{width:100%;padding:var(--space-3) var(--space-4);color:var(--color-text-primary);background:var(--color-canvas-bg);border:1.5px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--duration-fast) var(--ease-soft);outline:none;font-family:Nunito,sans-serif;font-size:14px;font-weight:600}.save-dialog__input:focus{border-color:var(--color-lavender)}.save-dialog__input::placeholder{color:var(--color-text-light);font-weight:500}.save-dialog__field{gap:var(--space-2);flex-direction:column;display:flex}.save-dialog__field--row{flex-direction:row;justify-content:space-between;align-items:center}.save-dialog__label{letter-spacing:.04em;text-transform:uppercase;color:var(--color-text-muted);font-family:Nunito,sans-serif;font-size:12px;font-weight:600}.save-dialog__mood{background:var(--color-canvas-bg);border-radius:var(--radius-pill);gap:2px;width:fit-content;padding:4px;display:inline-flex}.save-dialog__mood-btn{color:var(--color-text-muted);padding:var(--space-2) var(--space-5);border-radius:var(--radius-pill);cursor:pointer;transition:background var(--duration-fast) var(--ease-soft), color var(--duration-fast) var(--ease-soft);font-family:Nunito,sans-serif;font-size:13px;font-weight:600}.save-dialog__mood-btn.is-selected{background:var(--color-brand-green);color:var(--color-white)}.save-dialog__mood-btn:disabled{opacity:.6;cursor:not-allowed}.save-dialog__switch{background:var(--color-border);border-radius:var(--radius-pill);cursor:pointer;width:44px;height:26px;transition:background var(--duration-fast) var(--ease-soft);padding:0;position:relative}.save-dialog__switch.is-on{background:var(--color-brand-green)}.save-dialog__switch-knob{background:var(--color-white);width:20px;height:20px;transition:transform var(--duration-fast) var(--ease-spring);border-radius:50%;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0003}.save-dialog__switch.is-on .save-dialog__switch-knob{transform:translate(18px)}.save-dialog__actions{justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-2);display:flex}.save-dialog__spinner{border:2px solid #ffffff4d;border-top-color:var(--color-white);border-radius:50%;width:14px;height:14px;animation:.8s linear infinite spin;display:inline-block}.toast{bottom:var(--space-8);align-items:center;gap:var(--space-2);background:var(--color-white);color:var(--color-text-primary);border-radius:var(--radius-pill);padding:var(--space-3) var(--space-5);box-shadow:var(--shadow-toast);z-index:var(--z-toast);animation:toastIn .3s var(--ease-spring);font-family:Nunito,sans-serif;font-size:13px;font-weight:600;display:inline-flex;position:fixed;left:50%;transform:translate(-50%)}.toast.is-leaving{animation:toastOut .3s var(--ease-soft) forwards}.toast__check{width:20px;height:20px;color:var(--color-mint);justify-content:center;align-items:center;display:inline-flex}.toast__check svg{width:16px;height:16px}.canvas-view{background:var(--color-canvas-bg);flex-direction:column;width:100vw;height:100vh;display:flex}.canvas-view__header{height:52px;padding:0 var(--space-5);background:var(--color-panel-bg);border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.canvas-view__header-btn{border-radius:var(--radius-sm);width:36px;height:36px;color:var(--color-text-primary);transition:background var(--duration-fast) var(--ease-soft);justify-content:center;align-items:center;display:inline-flex}.canvas-view__header-btn:hover{background:var(--color-lavender);background:#e2cbf780}.canvas-view__body{flex:1;min-height:0;display:flex;position:relative}.canvas-view__canvas-column{flex-direction:column;flex:1;min-width:0;min-height:0;display:flex;position:relative}.canvas-view__canvas-area{cursor:default;flex:1;position:relative;overflow:hidden}.canvas-view__canvas-area.is-text-mode{cursor:text}.canvas-view__canvas-area.is-draw-mode{cursor:crosshair}.canvas-view__sweep{background:var(--color-canvas-bg);animation:canvasSweep .7s var(--ease-soft) forwards;pointer-events:none;z-index:var(--z-canvas);position:absolute;inset:0}.canvas-view__loading{color:var(--color-text-muted);pointer-events:none;justify-content:center;align-items:center;font-size:14px;font-weight:500;display:flex;position:absolute;inset:0}.canvas-view__footer{justify-content:flex-end;align-items:center;gap:var(--space-3);height:72px;padding:0 var(--space-5);z-index:1;background:0 0;flex-shrink:0;display:flex;position:relative}.canvas-view__footer-actions{align-items:center;gap:var(--space-3);display:inline-flex}.btn{align-items:center;gap:var(--space-2);letter-spacing:.01em;border-radius:var(--radius-pill);padding:var(--space-3) var(--space-5);cursor:pointer;transition:background var(--duration-fast) var(--ease-soft), color var(--duration-fast) var(--ease-soft), border-color var(--duration-fast) var(--ease-soft), transform var(--duration-fast) var(--ease-soft);border:1px solid #0000;font-family:Nunito,sans-serif;font-size:14px;font-weight:700;line-height:1;display:inline-flex}.btn--primary{background:var(--color-brand-green);color:var(--color-white)}.btn--primary:hover{background:var(--color-brand-green-hover)}.btn--primary:active{transform:scale(.97)}.btn--ghost{color:var(--color-text-primary);background:#f5f0e8;border:1px solid #0000;box-shadow:0 1px 3px #3d34500f}.btn--ghost:hover{background:#ede5d6}.btn--ghost-danger:hover{color:#b14a40;background:#fa918929}.memory-book{background:var(--color-canvas-bg);width:100vw;min-height:100vh;padding:var(--space-12) var(--space-12) var(--space-16);box-sizing:border-box;overflow-y:auto}.memory-book__header{margin:0 auto var(--space-12);max-width:1600px}.memory-book__title-row{align-items:center;gap:var(--space-4);margin-bottom:var(--space-3);display:flex}.memory-book__back{width:40px;height:40px;color:var(--color-text-primary);box-shadow:var(--shadow-panel);transition:transform var(--duration-fast) var(--ease-spring), background var(--duration-fast) var(--ease-soft);background:#ffffffb3;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.memory-book__back:hover{background:var(--color-white);transform:scale(1.06)}.memory-book__title{letter-spacing:-.02em;color:var(--color-text-primary);margin:0;font-family:Playfair Display,Georgia,serif;font-size:clamp(40px,5vw,56px);font-weight:800;line-height:1.05}.memory-book__subtitle{color:var(--color-text-muted);max-width:540px;margin:0;font-family:Nunito,sans-serif;font-size:15px;font-weight:500;line-height:1.5}.memory-book__grid{column-count:4;column-gap:var(--space-6);max-width:1600px;margin:0 auto}@media (width<=1200px){.memory-book__grid{column-count:3}}@media (width<=820px){.memory-book__grid{column-count:2}}@media (width<=520px){.memory-book__grid{column-count:1}}.memory-card{width:100%;margin:0 0 var(--space-6);break-inside:avoid;border-radius:var(--radius-lg);box-shadow:var(--shadow-card);cursor:pointer;transition:transform var(--duration-base) var(--ease-soft), box-shadow var(--duration-base) var(--ease-soft);animation:fadeSlideUp var(--duration-slow) var(--ease-spring) both;background:#f5f0e8;display:block;overflow:hidden}.memory-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px #3d345026}.memory-card:hover .memory-card__play{opacity:1;transform:scale(1.06)}.memory-card__thumb{background:#f5f0e8;width:100%;position:relative}.memory-card__thumb img{width:100%;height:auto;display:block}.memory-card__thumb-fade{pointer-events:none;background:linear-gradient(#f5f0e800 0%,#f5f0e8d9 100%);height:64px;position:absolute;inset:auto 0 0}.memory-card__play{bottom:var(--space-3);right:var(--space-3);background:var(--color-white);width:36px;height:36px;color:var(--color-text-primary);box-shadow:var(--shadow-panel);opacity:.75;transition:opacity var(--duration-fast) var(--ease-soft), transform var(--duration-fast) var(--ease-spring), background var(--duration-fast) var(--ease-soft);border-radius:50%;justify-content:center;align-items:center;display:inline-flex;position:absolute}.memory-card__play svg{width:14px;height:14px}.memory-card__play:hover{background:var(--color-canvas-bg)}.memory-card__meta{padding:var(--space-3) var(--space-5) var(--space-4)}.memory-card__title{color:var(--color-text-primary);letter-spacing:-.005em;margin:0 0 4px;font-family:Playfair Display,Georgia,serif;font-size:18px;font-weight:700;line-height:1.25}.memory-card__prompt{color:var(--color-text-muted);margin:0 0 var(--space-3);font-family:Nunito,sans-serif;font-size:13px;font-style:italic;font-weight:500;line-height:1.4}.memory-card__footer{justify-content:space-between;align-items:center;gap:var(--space-3);margin-top:var(--space-2);display:flex}.memory-card__dots{align-items:center;gap:4px;display:inline-flex}.memory-card__dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;box-shadow:0 0 0 1px #3d34500f}.memory-card__date{color:var(--color-text-light);letter-spacing:.02em;white-space:nowrap;align-items:center;gap:6px;font-family:Nunito,sans-serif;font-size:12px;font-weight:500;display:inline-flex}.memory-card__sep{color:var(--color-text-light);display:inline-block}.memory-book__empty{justify-content:center;align-items:center;gap:var(--space-5);padding:var(--space-16) var(--space-12);text-align:center;flex-direction:column;max-width:480px;margin:0 auto;display:flex}.memory-book__empty-tile{border-radius:var(--radius-lg);border:2px dashed var(--color-border);opacity:.7;width:200px;height:140px}.memory-book__empty-text{color:var(--color-text-muted);margin:0;font-family:Playfair Display,Georgia,serif;font-size:22px;font-weight:700}.playback-view{background:var(--color-overlay);-webkit-backdrop-filter:blur(8px);z-index:var(--z-dialog);padding:var(--space-8);animation:fadeSlideUp var(--duration-base) var(--ease-soft);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.playback-view__close{top:var(--space-5);right:var(--space-5);background:var(--color-white);width:40px;height:40px;color:var(--color-text-primary);box-shadow:var(--shadow-panel);transition:transform var(--duration-fast) var(--ease-spring);border-radius:50%;justify-content:center;align-items:center;display:inline-flex;position:absolute}.playback-view__close:hover{transform:scale(1.06)}.playback-view__content{align-items:center;gap:var(--space-5);flex-direction:column;max-width:80vw;max-height:90vh;display:flex}.playback-view__artwork-wrap{background:var(--color-white);padding:var(--space-3);border-radius:var(--radius-lg);box-shadow:var(--shadow-dialog);display:flex}.playback-view__artwork{border-radius:var(--radius-md);max-width:80vw;max-height:65vh;display:block}.playback-view__meta{text-align:center}.playback-view__title{margin:0 0 var(--space-3);color:var(--color-white);font-size:18px;font-weight:700}.playback-view__tags{gap:var(--space-2);flex-wrap:wrap;justify-content:center;display:flex}.playback-view__tag{padding:var(--space-2) var(--space-4);background:var(--color-white);border-radius:var(--radius-pill);color:var(--color-text-primary);align-items:center;font-size:12px;font-weight:600;display:inline-flex}.playback-view__tag--muted{color:var(--color-text-muted);background:#ffffffd9}.playback-view__tag--mood{background:var(--color-lavender);color:var(--color-text-primary)}.playback-view__controls{gap:var(--space-3);display:flex}.playback-view__play,.playback-view__download{background:var(--color-white);width:48px;height:48px;color:var(--color-text-primary);box-shadow:var(--shadow-panel);transition:transform var(--duration-fast) var(--ease-spring), background var(--duration-fast) var(--ease-soft);border-radius:50%;justify-content:center;align-items:center;display:inline-flex}.playback-view__play:hover,.playback-view__download:hover{background:var(--color-canvas-bg);transform:scale(1.06)}.specs-view{background:var(--color-canvas-bg);color:var(--color-text-primary);padding:var(--space-8);max-width:1100px;height:100vh;margin:0 auto;font-family:Nunito,sans-serif;overflow-y:auto}.specs-view__top{align-items:center;gap:var(--space-3);margin:0 0 var(--space-6);display:flex}.specs-view__back{width:36px;height:36px;color:var(--color-text-primary);box-shadow:var(--shadow-panel);transition:transform var(--duration-fast) var(--ease-spring);background:#ffffffb3;border-radius:50%;justify-content:center;align-items:center;display:inline-flex}.specs-view__back:hover{transform:scale(1.06)}.specs-view h1{margin:0;font-size:24px;font-weight:700}.specs-view section{margin-bottom:var(--space-8)}.specs-view h2{margin:0 0 var(--space-3);color:var(--color-text-primary);font-size:18px;font-weight:700}.specs-view table{border-collapse:collapse;background:var(--color-white);border-radius:var(--radius-md);width:100%;box-shadow:var(--shadow-panel);font-size:13px;overflow:hidden}.specs-view th,.specs-view td{text-align:left;padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-border)}.specs-view th{background:var(--color-panel-bg);text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);font-size:11px;font-weight:700}.specs-view code{background:var(--color-panel-bg);border-radius:4px;padding:1px 5px;font-family:ui-monospace,Menlo,monospace;font-size:12px}.specs-view__swatch{vertical-align:middle;width:18px;height:18px;box-shadow:0 0 0 1px var(--color-border);border-radius:50%;display:inline-block}.specs-view ol{background:var(--color-white);padding:var(--space-4) var(--space-8);border-radius:var(--radius-md);box-shadow:var(--shadow-panel)}.specs-view li{margin:var(--space-1) 0;font-size:14px}.onboarding{-webkit-backdrop-filter:blur(8px);z-index:var(--z-onboarding);padding:var(--space-5);animation:fadeSlideUp var(--duration-slow) var(--ease-soft);background:#3d345099;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.onboarding.is-leaving{animation:fadeSlideOutDown var(--duration-slow) var(--ease-soft) forwards}@keyframes fadeSlideOutDown{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(12px)}}.onboarding__card{border-radius:var(--radius-xl);width:480px;max-width:100%;padding:var(--space-8);text-align:center;color:var(--color-white);box-shadow:var(--shadow-dialog);-webkit-backdrop-filter:blur(20px);background:#ffffff14;border:1px solid #ffffff2e}.onboarding__logo{margin-bottom:var(--space-5);justify-content:center;display:flex}.onboarding__illustration{margin:var(--space-6) 0;justify-content:center;align-items:center;min-height:120px;display:flex}.onboarding__title{letter-spacing:-.01em;margin:0 0 var(--space-2);color:var(--color-white);font-family:Nunito,sans-serif;font-size:22px;font-weight:700}.onboarding__body{color:#fffc;margin:0 0 var(--space-6);font-size:14px;font-weight:500;line-height:1.5}.onboarding__dots{justify-content:center;gap:var(--space-2);margin-bottom:var(--space-6);display:flex}.onboarding__dot{width:6px;height:6px;transition:background var(--duration-fast) var(--ease-soft), transform var(--duration-fast) var(--ease-soft);background:#ffffff4d;border-radius:50%}.onboarding__dot.is-active{background:var(--color-white);transform:scale(1.3)}.onboarding__actions{justify-content:center;align-items:center;gap:var(--space-3);display:flex}.onboarding__skip{color:#fff9;padding:var(--space-2) var(--space-3);transition:color var(--duration-fast) var(--ease-soft);font-family:Nunito,sans-serif;font-size:13px;font-weight:600}.onboarding__skip:hover{color:var(--color-white)}.ob-palette{gap:var(--space-2);flex-wrap:wrap;justify-content:center;max-width:320px;display:flex}.ob-palette__dot{width:28px;height:28px;animation:palettePulse 4s var(--ease-soft) infinite;border-radius:50%;box-shadow:0 0 #fff0}.ob-palette__dot:first-child{animation-delay:0s}.ob-palette__dot:nth-child(2){animation-delay:.4s}.ob-palette__dot:nth-child(3){animation-delay:.8s}.ob-palette__dot:nth-child(4){animation-delay:1.2s}.ob-palette__dot:nth-child(5){animation-delay:1.6s}.ob-palette__dot:nth-child(6){animation-delay:2s}.ob-palette__dot:nth-child(7){animation-delay:2.4s}.ob-palette__dot:nth-child(8){animation-delay:2.8s}@keyframes palettePulse{0%,to{transform:scale(1);box-shadow:0 0 #fff0}10%{transform:scale(1.2);box-shadow:0 0 0 6px #fff3}20%{transform:scale(1);box-shadow:0 0 #fff0}}.ob-pinch{justify-content:center;display:flex}.ob-notes svg text{animation:noteFloat 2.4s var(--ease-soft) infinite}.ob-notes svg text:nth-of-type(2){animation-delay:.4s}.ob-notes svg text:nth-of-type(3){animation-delay:.8s}@keyframes noteFloat{0%{opacity:0;transform:translateY(8px)}30%{opacity:1;transform:translateY(0)}70%{opacity:1;transform:translateY(-4px)}to{opacity:0;transform:translateY(-12px)}}.segnav{background:var(--color-brand-green);border-radius:var(--radius-pill);align-items:center;gap:2px;padding:6px;display:inline-flex;box-shadow:0 2px 8px #0b3b2e38}.segnav__item{align-items:center;gap:var(--space-2);border-radius:var(--radius-pill);color:#ffffffb3;transition:background var(--duration-fast) var(--ease-soft), color var(--duration-fast) var(--ease-soft);cursor:pointer;background:0 0;padding:8px 18px;font-family:Nunito,sans-serif;font-size:13px;font-weight:600;display:inline-flex}.segnav__item:hover{color:var(--color-white);background:#ffffff14}.segnav__item svg{flex-shrink:0;width:18px;height:18px}.segnav__label{white-space:nowrap}.segnav__item.is-active,.segnav__item.is-active:hover{color:var(--color-text-primary);background:#f8f6f1}.app-nav-dock{left:calc(108px + var(--space-5));bottom:var(--space-5);z-index:40;pointer-events:auto;position:fixed}:root{--app-nav-height:60px}
