.sidebar{background:#fff;border-right:1px solid #00000014;flex-direction:column;gap:0;width:200px;min-width:200px;display:flex;overflow:hidden}@media (width<=768px) and (orientation:portrait){.sidebar{width:100%;min-width:0;height:120px;min-height:120px;padding-bottom:env(safe-area-inset-bottom,0);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff7;border-top:1px solid #0000001a;border-right:none;flex-direction:column;flex-shrink:0;order:10;justify-content:center;overflow:hidden}.sidebar-title,.sidebar-divider,.sidebar-bookmarklet{display:none}.garden-list{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-flow:row;flex:none;align-items:center;gap:8px;width:100%;padding:0 14px;overflow:auto visible}.garden-list::-webkit-scrollbar{display:none}.garden-item{color:#0000008c;background:#0000000a;border-radius:22px;flex-shrink:0;padding:8px 18px;font-size:.85rem}.garden-item.active{color:#2846a0e6;background:#3c64b41f}.garden-delete{display:none}.create-form{flex-direction:row;flex-shrink:0;justify-content:flex-end;align-items:center;gap:0;width:100%;padding:8px 14px 0}.create-form input[type=text],.create-form-dims{display:none}.create-btn{border-radius:22px;padding:7px 18px;font-size:.82rem}}@media (width<=900px) and (orientation:landscape){.sidebar{border-right:1px solid #00000014;flex-direction:column;order:0;width:160px;min-width:160px;height:100%;overflow:hidden}.sidebar-bookmarklet{display:none}}.sidebar-title{letter-spacing:.1em;text-transform:uppercase;color:#0000004d;padding:16px 14px 10px;font-size:.7rem;font-weight:700}.garden-list{flex-direction:column;flex:1;gap:2px;padding:0 8px;display:flex;overflow-y:auto}.garden-item{cursor:pointer;color:#00000080;border-radius:6px;justify-content:space-between;align-items:center;gap:6px;padding:6px 8px;font-size:.8rem;transition:background .12s,color .12s;display:flex}.garden-item:hover{color:#000c;background:#0000000a}.garden-item.active{color:#2846a0e6;background:#3c64b414}.garden-item-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.garden-delete{opacity:0;color:#b4323280;cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:.8rem;line-height:1;transition:opacity .12s,color .12s}.garden-item:hover .garden-delete{opacity:1}.garden-delete:hover{color:#b43232}.sidebar-divider{background:#00000012;height:1px;margin:10px 0}.create-form{flex-direction:column;gap:6px;padding:10px 12px 14px;display:flex}.create-form input[type=text]{color:#1a1a18;background:#f7f6f2;border:1px solid #0000001a;border-radius:5px;outline:none;padding:5px 8px;font-size:.78rem;transition:border-color .15s}.create-form input[type=text]:focus{background:#fff;border-color:#3c64b466}.create-form-dims{color:#00000059;align-items:center;gap:6px;font-size:.7rem;display:flex}.create-form-dims input[type=number]{color:#1a1a18;background:#f7f6f2;border:1px solid #0000001a;border-radius:5px;outline:none;width:44px;padding:4px 6px;font-size:.75rem;transition:border-color .15s}.create-form-dims input[type=number]:focus{border-color:#3c64b466}.sidebar-bookmarklet{color:#2846a0b3;text-align:center;cursor:grab;-webkit-user-select:none;user-select:none;background:#3c64b40f;border:1.5px dashed #3c64b440;border-radius:6px;margin:0 12px;padding:6px 10px;font-size:.72rem;text-decoration:none;transition:background .12s,border-color .12s;display:block}.sidebar-bookmarklet:hover{background:#3c64b41a;border-color:#3c64b466}.create-btn{color:#2846a0d9;cursor:pointer;background:#3c64b412;border:1px solid #3c64b438;border-radius:5px;padding:5px 0;font-size:.75rem;transition:background .13s}.create-btn:hover{background:#3c64b421}.cell-tooltip{z-index:200;pointer-events:auto;background:#fff;border:1px solid #0000001a;border-radius:10px;min-width:120px;padding:12px 14px;animation:.12s ease-out forwards tooltip-in;position:fixed;box-shadow:0 4px 20px #0000001f}.cell-tooltip.pinned{border-color:#5064a04d;box-shadow:0 4px 24px #5064a029}.tt-actions{align-items:center;gap:2px;display:flex;position:absolute;top:8px;right:8px}.tt-pin,.tt-close{cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 3px;line-height:1;transition:background .12s}.tt-pin:hover,.tt-close:hover{background:#0000000f}.tt-pin{opacity:.35;font-size:.75rem}.tt-pin.active{opacity:1}.tt-close{color:#0006;font-size:1rem}@keyframes tooltip-in{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.tt-emoji{margin-bottom:8px;font-size:2rem;line-height:1}.tt-name{color:#1a1a18;align-items:center;gap:4px;margin-bottom:4px;font-size:.82rem;font-weight:600;display:flex}.tt-lock{font-size:.72rem;line-height:1}.tt-text{color:#00000085;white-space:pre-wrap;word-break:break-word;margin-bottom:8px;font-family:Georgia,Times New Roman,serif;font-size:.74rem;font-style:italic;line-height:1.5}.tt-link-wrap{margin-bottom:6px}.tt-link{color:#3a6ea8;text-overflow:ellipsis;white-space:nowrap;font-size:.72rem;text-decoration:none;display:block;overflow:hidden}.tt-link:hover{text-decoration:underline}.tt-og-image{object-fit:cover;background:#f0f0ec;border-radius:6px;width:100%;max-height:80px;margin-top:5px;display:block}.tt-media{aspect-ratio:16/9;background:#f0f0ec;border:none;border-radius:6px;width:100%;margin-top:8px;display:block}.tt-image{object-fit:cover;border-radius:6px;width:100%;max-height:120px;margin-top:8px;display:block}.tt-images-preview{flex-direction:column;gap:6px;margin-top:8px;display:flex}.tt-image--thumb{max-height:90px;margin-top:0}.tt-gallery-btn{color:#3a6ea8;cursor:pointer;text-align:left;background:0 0;border:1px solid #3c64b433;border-radius:5px;padding:4px 8px;font-size:.72rem;transition:background .12s}.tt-gallery-btn:hover{background:#3c64b40f}.conflict-prompt{z-index:300;background:#fff;border:1px solid #0000001a;border-radius:10px;padding:12px 14px;animation:.14s ease-out forwards cp-in;position:fixed;box-shadow:0 4px 24px #00000024}@keyframes cp-in{0%{opacity:0;transform:translateY(6px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.cp-header{align-items:flex-start;gap:10px;margin-bottom:10px;display:flex}.cp-avatar{object-fit:cover;border:2px solid #0000;border-radius:50%;flex-shrink:0;width:28px;height:28px}.cp-avatar--initial{color:#000000a6;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}.cp-message{color:#000000a6;font-size:.78rem;line-height:1.4}.cp-message strong{color:#1a1a18}.cp-actions{gap:8px;display:flex}.cp-btn{cursor:pointer;border:none;border-radius:6px;flex:1;padding:5px 10px;font-size:.75rem;font-weight:600;transition:opacity .12s}.cp-btn:hover{opacity:.82}.cp-btn--primary{color:#fff;background:#3a6ea8}.cp-btn--ghost{color:#0009;background:#0000000f}.gallery-backdrop{z-index:400;-webkit-backdrop-filter:blur(4px);background:#000000b8;position:fixed;inset:0}.gallery-modal{z-index:401;background:#fff;border-radius:14px;flex-direction:column;width:min(860px,95vw);max-height:88dvh;animation:.16s ease-out forwards gallery-in;display:flex;position:fixed;top:50%;left:50%;overflow:hidden;transform:translate(-50%,-50%);box-shadow:0 20px 60px #0000004d}@keyframes gallery-in{0%{opacity:0;transform:translate(-50%,-48%)}to{opacity:1;transform:translate(-50%,-50%)}}@media (width<=600px){.gallery-modal{border-radius:0;width:100vw;height:100dvh;max-height:100dvh;top:0;left:0;transform:none}@keyframes gallery-in{0%{opacity:0;transform:none}to{opacity:1;transform:none}}}.gallery-header{border-bottom:1px solid #00000014;flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.gallery-title{color:#00000073;font-size:.82rem;font-weight:500}.gallery-back{color:#3a6ea8;cursor:pointer;background:0 0;border:none;padding:0;font-size:.78rem;font-weight:500}.gallery-back:hover{opacity:.7}.gallery-close{color:#0006;cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:1.3rem;line-height:1;transition:color .12s}.gallery-close:hover{color:#000c}.gallery-masonry{columns:3;overscroll-behavior:contain;column-gap:8px;padding:16px;overflow-y:auto}@media (width<=500px){.gallery-masonry{columns:2}}.gallery-thumb{cursor:pointer;break-inside:avoid;object-fit:cover;border-radius:8px;width:100%;margin-bottom:8px;transition:opacity .12s,transform .12s;display:block}.gallery-thumb:hover{opacity:.88;transform:scale(1.02)}.gallery-carousel{flex:1;justify-content:center;align-items:center;min-height:300px;padding:20px 56px;display:flex;position:relative;overflow:hidden}.gallery-carousel-img{object-fit:contain;border-radius:8px;max-width:100%;max-height:calc(88dvh - 100px);animation:.2s ease-out carousel-fade}@keyframes carousel-fade{0%{opacity:.4;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.gallery-arrow{cursor:pointer;color:#000000b3;background:#ffffffe6;border:1px solid #0000001a;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;padding:0;font-size:1.4rem;line-height:1;transition:background .12s,box-shadow .12s;display:flex;position:absolute;top:50%;transform:translateY(-50%);box-shadow:0 2px 8px #0000001f}.gallery-arrow:hover{background:#fff;box-shadow:0 4px 12px #0000002e}.gallery-arrow:disabled{opacity:.3;cursor:default}.gallery-arrow--prev{left:12px}.gallery-arrow--next{right:12px}.gallery-counter{color:#0006;pointer-events:none;font-size:.72rem;font-weight:500;position:absolute;bottom:10px;left:50%;transform:translate(-50%)}.mc-overlay{z-index:250;background:#00000052;position:fixed;inset:0}.mc-center{z-index:251;pointer-events:none;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.memory-card{pointer-events:auto;background:#fffef9;border-radius:16px;width:min(360px,100vw - 32px);max-height:calc(100dvh - 48px);overflow:hidden auto;box-shadow:0 8px 32px #00000024,0 2px 8px #0000000f}.mc-mood-strip{flex-shrink:0;width:100%;height:6px}.mc-body{padding:18px 20px 16px;position:relative}.mc-close-btn{color:#0000004d;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:2px 6px;font-size:1.25rem;line-height:1;transition:background .12s,color .12s;position:absolute;top:10px;right:10px}.mc-close-btn:hover{color:#0009;background:#0000000f}.mc-emoji{margin-bottom:10px;font-size:46px;line-height:1;display:block}.mc-name{color:#1a1a18;letter-spacing:-.01em;margin:0 0 10px;padding-right:28px;font-size:16px;font-weight:600}.mc-text{color:#4a4a3f;white-space:pre-wrap;word-break:break-word;margin:0 0 14px;font-family:Georgia,Times New Roman,serif;font-size:14px;font-style:italic;line-height:1.65}.mc-images{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.mc-img-thumb{object-fit:cover;cursor:pointer;background:#0000000f;border-radius:8px;width:72px;height:56px;transition:opacity .12s}.mc-img-thumb:hover{opacity:.82}.mc-more-imgs{color:#00000073;cursor:pointer;background:#0000000f;border:none;border-radius:8px;width:72px;height:56px;font-size:13px;transition:background .12s}.mc-more-imgs:hover{background:#0000001a}.mc-links{flex-direction:column;gap:5px;margin-bottom:14px;display:flex}.mc-link{color:#3a6ea8;text-overflow:ellipsis;white-space:nowrap;font-size:12px;text-decoration:none;overflow:hidden}.mc-link:before{content:"🔗 ";font-size:10px}.mc-link:hover{text-decoration:underline}.mc-footer{border-top:1px solid #f0ece0;justify-content:space-between;align-items:center;margin-top:2px;padding-top:12px;display:flex}.mc-date{color:#9a9880;font-size:11px}.mc-edit-btn{color:#fff;cursor:pointer;background:#1a1a18;border:none;border-radius:8px;padding:5px 14px;font-size:13px;transition:opacity .12s}.mc-edit-btn:hover{opacity:.78}.cell{width:var(--cell-size,36px);height:var(--cell-size,36px);font-size:calc(var(--cell-size,36px) * .55);cursor:pointer;-webkit-user-select:none;user-select:none;background:0 0;border-radius:3px;justify-content:center;align-items:center;transition:box-shadow .16s ease-in;display:flex;position:relative}.cell-border-svg{pointer-events:none;width:100%;height:100%;position:absolute;inset:0;overflow:visible}.cell-border-rect{x:.75px;y:.75px;fill:none;stroke:#50648c47;stroke-width:1.5px;stroke-dasharray:5 3;stroke-dashoffset:0;opacity:0;width:calc(100% - 1.5px);height:calc(100% - 1.5px);transition:opacity .16s ease-in}.cell:hover .cell-border-rect{opacity:1;animation:.4s linear infinite march}@keyframes march{to{stroke-dashoffset:-8px}}.cell:hover{z-index:1;box-shadow:0 0 0 2px #5064a014,0 0 10px 3px #5064a01f}.cell.empty{color:#0000001a;font-size:calc(var(--cell-size,36px) * .2)}.cell.empty:hover{color:#0000004d}.cell.empty:after{content:"";pointer-events:none;opacity:0;transform-origin:50%;background:radial-gradient(circle,#5064a052 0%,#0000 65%);border-radius:50%;position:absolute;inset:0}.cell.empty:hover:after{opacity:1;animation:3s ease-in-out infinite empty-cell-glow}@keyframes empty-cell-glow{0%,to{opacity:.85;transform:scale(.78)}50%{opacity:.45;transform:scale(1.05)}}.cell.empty.cell--editing .cell-emoji,.cell.empty.cell--editing:hover .cell-emoji{opacity:1;animation:none}.cell-emoji--preview{font-size:calc(var(--cell-size,36px) * .55);animation:1.2s ease-in-out infinite ghost-breathe}@keyframes ghost-breathe{0%,to{opacity:.6}50%{opacity:.08}}.cell--editing .cell-emoji--preview{animation:1.2s ease-in-out infinite ghost-breathe}.cell--editing{z-index:1;animation:1.6s ease-in-out infinite editing-ring}@keyframes editing-ring{0%,to{box-shadow:0 0 0 2px #6e5ad240,0 0 8px 2px #6e5ad21a}50%{box-shadow:0 0 0 2px #6e5ad273,0 0 16px 5px #6e5ad233}}.cell--editing .cell-emoji{animation:1.6s ease-in-out infinite emoji-breathe}@keyframes emoji-breathe{0%,to{opacity:.55}50%{opacity:.22}}.cell--editing:hover{animation:1.6s ease-in-out infinite editing-ring-hover}@keyframes editing-ring-hover{0%,to{box-shadow:0 0 0 2px #6e5ad266,0 0 14px 4px #6e5ad233}50%{box-shadow:0 0 0 2px #6e5ad2a6,0 0 24px 8px #6e5ad252}}.cell--editing:hover .cell-emoji{animation:1.6s ease-in-out infinite emoji-breathe-hover}@keyframes emoji-breathe-hover{0%,to{opacity:.7}50%{opacity:.4}}.cell--presence{box-shadow:0 0 0 2px var(--presence-color,#85c1e9), 0 0 8px 2px color-mix(in srgb, var(--presence-color,#85c1e9) 40%, transparent);z-index:1;animation:1.8s ease-in-out infinite presence-pulse}@keyframes presence-pulse{0%,to{box-shadow:0 0 0 2px var(--presence-color,#85c1e9), 0 0 8px 2px color-mix(in srgb, var(--presence-color,#85c1e9) 40%, transparent)}50%{box-shadow:0 0 0 2px var(--presence-color,#85c1e9), 0 0 14px 5px color-mix(in srgb, var(--presence-color,#85c1e9) 55%, transparent)}}.cell-presence-avatar{background:var(--presence-color,#85c1e9);color:#000000a6;pointer-events:none;z-index:2;border:1.5px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;font-size:8px;font-weight:700;display:flex;position:absolute;top:-5px;right:-5px;overflow:hidden}.cell-presence-avatar img{object-fit:cover;width:100%;height:100%}@keyframes cell-float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.app--floating .cell--editing .cell-emoji{animation:cell-float var(--float-dur,3.5s) ease-in-out infinite;animation-delay:var(--float-offset,0s)}.app--floating .cell:not(.empty) .cell-emoji{transition:opacity .35s,filter .35s}.app--floating .grid:has(.cell--editing) .cell:not(.empty):not(.cell--editing) .cell-emoji{opacity:.65;filter:blur(1.5px)}.grid .cell:not(.empty) .cell-emoji{transition:opacity .18s,filter .18s}.grid:has(.cell:not(.empty):hover) .cell:not(.empty):not(:hover):not(.cell--pinned) .cell-emoji{opacity:.75;filter:blur(2px)}.grid .cell:not(.empty):hover .cell-emoji{opacity:1!important;filter:none!important}.cell--mood-bloom{background:#f9c4d061}.cell--mood-sky{background:#b8d4f061}.cell--mood-dusk{background:#d4c4f061}.cell--mood-moss{background:#b8d8b061}.cell--mood-sand{background:#f0e4b861}.cell--mood-mist{background:#dde8e061}.cell-badges{pointer-events:none;gap:2px;display:flex;position:absolute;bottom:3px;right:3px}.cell-badge{opacity:.65;border-radius:50%;width:4px;height:4px}.cell-badge--note{background:#c4823a}.cell-badge--image{background:#4a82b8}.palette-overlay{z-index:100;position:fixed;inset:0}.cell-editor{z-index:101;background:#fff;border:1px solid #0000001a;border-radius:12px;flex-direction:column;gap:10px;width:270px;max-height:480px;padding:12px;display:flex;position:fixed;overflow:hidden;box-shadow:0 4px 24px #0000001f}.editor-emoji-tabs{flex-wrap:wrap;gap:3px;display:flex}.editor-tab{color:#0006;cursor:pointer;background:0 0;border:1px solid #0000001a;border-radius:4px;padding:2px 6px;font-size:.62rem;transition:background .1s,color .1s}.editor-tab:hover,.editor-tab.active{color:#2846a0e6;background:#3c64b414;border-color:#3c64b440}.editor-emoji-grid{flex-wrap:wrap;gap:2px;max-height:130px;display:flex;overflow-y:auto}.editor-emoji-btn{cursor:pointer;border:2px solid #0000;border-radius:5px;justify-content:center;align-items:center;width:30px;height:30px;font-size:1rem;transition:background 90ms,border-color 90ms;display:flex}.editor-emoji-btn:hover{background:#0000000f}.editor-emoji-btn.selected{background:#3c64b412;border-color:#3c64b466}.editor-selected-preview{text-align:center;opacity:.35;min-height:1.6rem;font-size:1.5rem}.editor-selected-preview.has-emoji{opacity:1}.editor-divider{background:#00000012;flex-shrink:0;height:1px}.editor-fields{flex-direction:column;flex:1;gap:5px;display:flex;overflow-y:auto}.editor-field{flex-direction:column;gap:2px;display:flex}.editor-label{color:#00000059;text-transform:uppercase;letter-spacing:.06em;justify-content:space-between;align-items:center;font-size:.62rem;display:flex}.editor-add-link{color:#3a6ea8;cursor:pointer;text-transform:none;letter-spacing:0;background:0 0;border:none;padding:0;font-size:.68rem;font-weight:600}.editor-add-link:hover{opacity:.7}.editor-link-block{flex-direction:column;gap:3px;margin-bottom:4px;display:flex}.editor-link-row{align-items:center;gap:4px;display:flex}.editor-link-row .editor-input{flex:1}.editor-link-name{color:#0000008c;font-style:italic}.editor-remove-link{color:#00000059;cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0 2px;font-size:1rem;line-height:1}.editor-remove-link:hover{color:#000000a6}.editor-input,.editor-textarea{color:#1a1a18;resize:none;background:#f7f6f2;border:1px solid #0000001a;border-radius:5px;outline:none;padding:5px 8px;font-family:inherit;font-size:.78rem;transition:border-color .14s}.editor-input:focus,.editor-textarea:focus{background:#fff;border-color:#3c64b466}.editor-textarea{height:54px;line-height:1.4}.editor-footer{flex-shrink:0;gap:6px;display:flex}.editor-save{color:#2846a0e6;cursor:pointer;background:#3c64b412;border:1px solid #3c64b440;border-radius:6px;flex:1;padding:6px 0;font-size:.75rem;transition:background .12s}.editor-save:hover{background:#3c64b421}.editor-save:disabled{opacity:.35;cursor:not-allowed}.editor-clear{color:#b43232a6;cursor:pointer;background:0 0;border:1px solid #c83c3c33;border-radius:6px;padding:6px 10px;font-size:.75rem;transition:background .12s,color .12s}.editor-clear:hover{color:#b43232e6;background:#c83c3c12}.editor-mood-row{align-items:center;gap:8px;display:flex}.editor-mood-label{color:#00000059;text-transform:uppercase;letter-spacing:.06em;flex-shrink:0;font-size:.62rem}.editor-mood-picker{flex-wrap:wrap;gap:5px;display:flex}.mood-dot{cursor:pointer;border-radius:50%;flex-shrink:0;width:16px;height:16px;padding:0;transition:transform .1s,box-shadow .1s}.mood-dot:hover{transform:scale(1.2)}.mood-dot.active{transform:scale(1.1);box-shadow:0 0 0 2px #fff,0 0 0 3.5px #00000059}.editor-skin-tones{flex-wrap:wrap;gap:3px;display:flex}.skin-tone-btn{cursor:pointer;background:0 0;border:2px solid #0000;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;padding:0;font-size:.9rem;transition:border-color .1s,background .1s;display:flex}.skin-tone-btn:hover{background:#0000000f}.skin-tone-btn.active{background:#3c64b412;border-color:#3c64b466}.editor-drag-hint{color:#0000004d;text-transform:none;letter-spacing:0;margin-left:4px;font-size:.6rem;font-weight:400}.editor-pick-hint{color:#00000059;text-align:center;margin:0;font-size:.65rem}.editor-img-chips{flex-wrap:wrap;gap:5px;margin-bottom:5px;display:flex}.editor-img-chip{cursor:grab;background:#f0f0ec;border-radius:5px;flex-shrink:0;width:48px;height:38px;position:relative;overflow:hidden}.editor-img-chip img{object-fit:cover;width:100%;height:100%}.editor-img-chip-remove{color:#fff;cursor:pointer;background:#00000080;border:none;border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;padding:0;font-size:.6rem;line-height:1;display:flex;position:absolute;top:1px;right:2px}.editor-img-chip-remove:hover{background:#000000bf}.editor-drop-zone{color:#00000059;cursor:pointer;text-align:center;border:1.5px dashed #0000002e;border-radius:8px;outline:none;justify-content:center;align-items:center;min-height:56px;padding:10px 12px;font-size:.72rem;transition:background .12s,border-color .12s,color .12s;display:flex}.editor-drop-zone:focus{border-color:#3c64b44d}.editor-drop-zone.hover{color:#2846a0b3;background:#3c64b40d;border-color:#3c64b459}.editor-drop-zone.uploading{color:#2846a099;background:#3c64b40a;border-color:#3c64b433}.editor-drop-zone.error{color:#b43232cc;background:#c83c3c0a;border-color:#c83c3c4d}.editor-drop-input{color:#0009;text-align:center;cursor:text;background:0 0;border:none;outline:none;width:100%;font-family:inherit;font-size:.72rem}.editor-drop-input::placeholder{color:#00000052}.grid-wrapper{background:0 0;flex:1;justify-content:center;align-items:center;padding:48px;display:flex;overflow:auto}.grid{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100'%3E%3Ccircle cx='50' cy='50' r='9' fill='none' stroke='black' stroke-opacity='0.22' stroke-width='1.4' stroke-dasharray='4.5 3'/%3E%3C/svg%3E");width:max-content;height:max-content;display:grid}.ascii-texture-wrap{pointer-events:none;position:absolute;inset:0;overflow:hidden}.ascii-texture-canvas{width:100%;height:100%;display:block}.grid-border{pointer-events:none;-webkit-user-select:none;user-select:none;flex-direction:column;flex:1;display:flex}.gb-cell{width:var(--border-size);height:var(--border-size);font-size:calc(var(--border-size) * .7);opacity:0;flex-shrink:0;justify-content:center;align-items:center;transition:opacity .3s;display:flex;-webkit-mask-image:radial-gradient(60% 60%,#000 30%,#0000 80%);mask-image:radial-gradient(60% 60%,#000 30%,#0000 80%)}.gb-cell--visible{opacity:.42}.gb-row{background:#0000000b;flex-direction:row;justify-content:center;display:flex;position:relative}.gb-corner{width:var(--border-size);height:var(--border-size);flex-shrink:0}.gb-middle{flex-direction:row;flex:1;display:flex}.gb-col{background:#0000000b;flex-direction:column;flex-shrink:0;display:flex;position:relative}.gb-content{pointer-events:auto;flex:1;display:flex;overflow:hidden}.plant-log{background:#fff;border-left:1px solid #00000014;flex-direction:column;width:176px;min-width:176px;display:flex;overflow:hidden}.plant-log-title{letter-spacing:.1em;text-transform:uppercase;color:#0000004d;border-bottom:1px solid #00000012;flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 12px 8px;font-size:.7rem;font-weight:700;display:flex}.plant-log-close-btn{color:#0000004d;cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:1.1rem;line-height:1;display:none}.plant-log-list{flex:1;padding:6px 0;overflow-y:auto}.plant-log-empty{color:#00000040;padding:20px 14px;font-size:.75rem}.ple{cursor:default;align-items:flex-start;gap:8px;padding:7px 12px;transition:background .12s;display:flex;position:relative}.ple:hover{background:#00000008}.ple-emoji{flex-shrink:0;font-size:1.1rem;line-height:1.2}.ple-info{flex:1;min-width:0}.ple-name{color:#000000b3;text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;overflow:hidden}.ple-time{color:#0000004d;margin-top:1px;font-size:.65rem}.plant-log-tab,.plant-log-backdrop{display:none}.ple-tooltip{z-index:200;pointer-events:none;background:#fff;border:1px solid #0000001a;border-radius:10px;min-width:120px;max-width:220px;padding:12px 14px;font-size:.75rem;animation:.14s ease-out forwards ple-tip-in;position:fixed;box-shadow:0 4px 20px #0000001f}@keyframes ple-tip-in{0%{opacity:0;transform:translate(4px)}to{opacity:1;transform:translate(0)}}.ple-tooltip-emoji{margin-bottom:6px;font-size:1.6rem}.ple-tooltip-name{color:#1a1a18;margin-bottom:4px;font-size:.82rem;font-weight:600}.ple-tooltip-text{color:#00000080;white-space:pre-wrap;word-break:break-word;margin-bottom:5px;line-height:1.4}.ple-tooltip-link{color:#3a6ea8;text-overflow:ellipsis;white-space:nowrap;margin-bottom:5px;text-decoration:none;display:block;overflow:hidden}.ple-tooltip-img{object-fit:cover;border-radius:5px;width:100%;max-height:90px;margin-top:4px}.ple-tooltip-ts{color:#00000040;margin-top:6px;font-size:.65rem}@media (width<=768px){.plant-log{z-index:80;border-left:1px solid #0000001a;width:min(72vw,280px);min-width:0;transition:right .22s;position:fixed;top:0;bottom:64px;right:-100%;box-shadow:-4px 0 20px #0000001a}.plant-log--open{right:0}.plant-log-close-btn{display:block}.plant-log-backdrop{z-index:79;background:#00000026;display:block;position:fixed;inset:0}.plant-log-tab{z-index:78;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);cursor:pointer;background:#fffffff2;border:1px solid #0000001a;border-right:none;border-radius:8px 0 0 8px;flex-direction:column;justify-content:center;align-items:center;gap:3px;width:28px;padding:10px 0;transition:background .12s;display:flex;position:fixed;top:50%;right:0;transform:translateY(-50%);box-shadow:-2px 0 8px #0000000f}.plant-log-tab:hover{background:#fff}.plant-log-tab-icon{font-size:.9rem;line-height:1}.plant-log-tab-count{color:#00000073;font-size:.65rem;font-weight:600;line-height:1}}@media (width<=900px) and (orientation:landscape){.plant-log{width:160px;min-width:160px;max-height:none;box-shadow:none;border-left:1px solid #00000014;transition:none;display:flex;position:relative;top:auto;bottom:auto;right:auto}.plant-log-tab,.plant-log-backdrop,.plant-log-close-btn{display:none}}.garden-view{background:#e8e3d4;flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}@media (width<=768px) and (orientation:portrait){.garden-header{padding:8px 40px 6px 12px}.garden-style-bar{display:none}}@media (width<=900px) and (orientation:landscape){.garden-header{padding:6px 12px}.garden-style-bar{display:none}}.garden-header{background:#fff;border-bottom:1px solid #00000012;flex-direction:column;flex-shrink:0;gap:8px;padding:10px 20px 8px;display:flex}.garden-header-row{align-items:baseline;gap:10px;display:flex}.garden-close-btn{color:#0000004d;cursor:pointer;background:0 0;border:none;flex-shrink:0;margin-left:auto;padding:0 2px;font-size:1.2rem;line-height:1;transition:color .12s}.garden-close-btn:hover{color:#000000b3}.garden-name{color:#1a1a18;letter-spacing:.01em;cursor:text;border-bottom:1px solid #0000;outline:none;font-size:1rem;font-weight:600;transition:border-color .15s}.garden-name:focus{border-color:#3c64b466}.garden-meta{color:#00000059;font-size:.7rem}.garden-style-bar{align-items:center;gap:14px;display:flex}.style-section{align-items:center;gap:5px;display:flex}.style-section--themes{border-left:1px solid #00000014;padding-left:14px}.colour-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;outline:none;width:18px;height:18px;padding:0;transition:transform .12s,border-color .12s}.colour-swatch:hover{transform:scale(1.2)}.colour-swatch--active{border-color:#00000059}.theme-btn{cursor:pointer;opacity:.55;background:0 0;border:1px solid #0000;border-radius:6px;padding:2px 4px;font-size:1rem;line-height:1;transition:opacity .12s,border-color .12s}.theme-btn:hover{opacity:1}.theme-btn--active{opacity:1;background:#0000000a;border-color:#0003}.theme-btn--pro{cursor:not-allowed;position:relative}.theme-btn--pro:after{content:"✦";color:#b8860b;font-size:.45rem;position:absolute;top:1px;right:1px}.garden-body{flex:1;display:flex;overflow:hidden}.garden-empty{color:#0003;flex:1;justify-content:center;align-items:center;font-size:.85rem;display:flex}.garden-quick-add-banner{color:#2846a0d9;background:#3c64b412;border-bottom:1px solid #3c64b426;flex-shrink:0;align-items:center;gap:8px;padding:7px 16px;font-size:.75rem;display:flex}.garden-quick-add-banner span{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.garden-quick-add-dismiss{cursor:pointer;color:#2846a066;background:0 0;border:none;flex-shrink:0;padding:0 2px;font-size:1rem;line-height:1;transition:color .12s}.garden-quick-add-dismiss:hover{color:#2846a0e6}.gc-backdrop{z-index:500;-webkit-backdrop-filter:blur(6px);background:#00000040;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.gc-modal{background:#fff;border-radius:16px;width:min(460px,90vw);padding:36px 40px;animation:.22s cubic-bezier(.34,1.56,.64,1) forwards gc-in;box-shadow:0 24px 64px #00000029}@keyframes gc-in{0%{opacity:0;transform:scale(.93)translateY(12px)}to{opacity:1;transform:scale(1)translateY(0)}}.gc-header{flex-direction:column;align-items:center;gap:8px;margin-bottom:28px;display:flex}.gc-logo{font-size:2.4rem;line-height:1}.gc-title{color:#1a1a18;letter-spacing:.01em;font-size:1.1rem;font-weight:600}.gc-form{flex-direction:column;gap:20px;display:flex}.gc-field{flex-direction:column;gap:8px;display:flex}.gc-label{color:#0000008c;letter-spacing:.01em;font-size:.8rem;font-weight:500}.gc-input{color:#1a1a18;background:#f7f6f2;border:1px solid #0000001a;border-radius:8px;outline:none;width:100%;padding:10px 14px;font-family:inherit;font-size:.9rem;transition:border-color .15s,background .15s}.gc-input:focus{background:#fff;border-color:#3c64b473}.gc-dims{align-items:center;gap:10px;display:flex}.gc-input--dim{text-align:center;width:72px;padding:10px 8px}.gc-times{color:#0000004d;flex-shrink:0;font-size:1rem;font-weight:500}.gc-btn{color:#fff;letter-spacing:.02em;cursor:pointer;background:#1a1a18;border:none;border-radius:10px;margin-top:4px;padding:12px 0;font-size:.88rem;font-weight:600;transition:background .15s,transform .1s}.gc-btn:hover{background:#2d2d2a}.gc-btn:active{transform:scale(.98)}.auth-backdrop{z-index:800;background:#e8e3d4;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.auth-modal{text-align:center;background:#fff;border-radius:18px;flex-direction:column;align-items:center;width:min(420px,90vw);padding:44px 48px;animation:.24s cubic-bezier(.34,1.4,.64,1) forwards auth-in;display:flex;box-shadow:0 24px 64px #0000001f}@keyframes auth-in{0%{opacity:0;transform:translateY(16px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.auth-logo{margin-bottom:12px;font-size:3rem;line-height:1}.auth-title{color:#1a1a18;letter-spacing:.01em;margin-bottom:6px;font-size:1.4rem;font-weight:700}.auth-sub{color:#0000006b;margin-bottom:32px;font-size:.82rem}.auth-actions{flex-direction:column;gap:10px;width:100%;margin-bottom:20px;display:flex}.auth-btn{cursor:pointer;border-radius:10px;justify-content:center;align-items:center;gap:10px;width:100%;padding:12px 20px;font-family:inherit;font-size:.88rem;font-weight:600;transition:background .14s,transform .1s,box-shadow .14s;display:flex}.auth-btn:active{transform:scale(.98)}.auth-btn--google{color:#1a1a18;background:#fff;border:1px solid #00000029;box-shadow:0 1px 4px #00000014}.auth-btn--google:hover{background:#f8f8f8;box-shadow:0 2px 8px #0000001f}.auth-btn--guest{color:#00000073;background:0 0;border:1px solid #0000001a}.auth-btn--guest:hover{color:#000000a6;background:#00000008}.auth-google-icon{flex-shrink:0;width:18px;height:18px}.auth-note{color:#0000004d;font-size:.72rem}.ob-backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:1000;background:#00000059;justify-content:center;align-items:center;animation:.2s ob-fade-in;display:flex;position:fixed;inset:0}@keyframes ob-fade-in{0%{opacity:0}}.ob-card{background:#fff;border-radius:18px;width:min(420px,100vw - 40px);padding:40px 36px 32px;animation:.24s cubic-bezier(.34,1.26,.64,1) ob-slide-up;position:relative;overflow:visible;box-shadow:0 24px 64px #0000002e,0 4px 12px #00000014}@keyframes ob-slide-up{0%{opacity:0;transform:translateY(16px)scale(.97)}}.ob-marquee{pointer-events:none;width:calc(100% + 72px);height:calc(100% + 72px);position:absolute;top:-36px;left:-36px;overflow:visible}.ob-marquee-rect{fill:none;stroke:#3c64b42e;stroke-width:1.5px;stroke-dasharray:14 6;stroke-dashoffset:0;x:1px;y:1px;rx:28px;width:calc(100% - 2px);height:calc(100% - 2px);animation:8s linear infinite ob-march}@keyframes ob-march{to{stroke-dashoffset:-20px}}.ob-skip{color:#0000004d;cursor:pointer;background:0 0;border:none;padding:4px 6px;font-size:.72rem;transition:color .12s;position:absolute;top:16px;right:18px}.ob-skip:hover{color:#0000008c}.ob-emoji{margin-bottom:16px;font-size:2.8rem;line-height:1}.ob-title{color:#1a1a18;letter-spacing:-.01em;margin-bottom:10px;font-size:1.25rem;font-weight:700}.ob-body{color:#00000085;margin-bottom:28px;font-size:.88rem;line-height:1.6}.ob-usecases{flex-direction:column;gap:12px;margin:0 0 28px;padding:0;list-style:none;display:flex}.ob-usecases li{color:#0000008c;align-items:flex-start;gap:10px;font-size:.84rem;line-height:1.55;display:flex}.ob-usecases strong{color:#1a1a18;font-weight:600}.ob-uc-icon{flex-shrink:0;margin-top:1px;font-size:1rem}.ob-seeds{align-items:flex-end;gap:10px;margin-bottom:24px;display:flex}.ob-seed{line-height:1;transition:font-size .22s,opacity .22s,transform .22s}.ob-seed--past{opacity:.28;font-size:.9rem;transform:translateY(0)}.ob-seed--active{opacity:1;font-size:1.25rem;transform:translateY(-4px)}.ob-seed--future{opacity:.13;font-size:.78rem;transform:translateY(0)}.ob-actions{justify-content:flex-end;gap:8px;display:flex}.ob-btn{cursor:pointer;border:none;border-radius:10px;padding:9px 20px;font-size:.82rem;font-weight:500;transition:background .12s,opacity .12s}.ob-btn--back{color:#0006;background:0 0;border:1px solid #0000001a}.ob-btn--back:hover{background:#0000000a}.ob-btn--primary{color:#fff;background:#3c64b4}.ob-btn--primary:hover{background:#3358a0}.profile-page{background:#f7f6f2;flex-direction:column;height:100vh;display:flex;overflow:hidden}.profile-header{background:#fff;border-bottom:1px solid #00000014;flex-shrink:0;align-items:center;gap:12px;padding:12px 20px;display:flex}.profile-avatar{object-fit:cover;background:#e8e6e0;border:none;border-radius:50%;width:38px;height:38px}.profile-avatar--initial{color:#0000008c;justify-content:center;align-items:center;font-size:1rem;font-weight:700;display:flex}.profile-meta{flex-direction:column;gap:1px;display:flex}.profile-username{color:#1a1a18;font-size:.82rem;font-weight:700}.profile-display{color:#00000073;font-size:.75rem}.profile-body{flex:1;display:flex;overflow:hidden}.profile-garden-list{background:#fff;border-right:1px solid #00000014;flex-direction:column;flex-shrink:0;width:200px;padding:12px 0;display:flex;overflow-y:auto}.profile-list-title{letter-spacing:.06em;text-transform:uppercase;color:#00000059;padding:0 14px 8px;font-size:.7rem;font-weight:700}.profile-garden-item{text-align:left;color:#000000b3;cursor:pointer;background:0 0;border:none;border-radius:0;justify-content:space-between;align-items:center;gap:6px;width:100%;padding:8px 14px;font-size:.82rem;transition:background .12s;display:flex}.profile-garden-item:hover{background:#0000000a}.profile-garden-item.active{color:#3a6ea8;background:#3a6ea814;font-weight:600}.profile-home-badge{opacity:.7;font-size:.7rem}.profile-grid-area{flex:1;overflow:auto}.profile-no-garden{color:#0000004d;justify-content:center;align-items:center;height:100%;font-size:.85rem;display:flex}.profile-banner{text-align:center;color:#ffffffbf;background:#1a1a18;flex-shrink:0;padding:10px;font-size:.78rem}.profile-banner-link{color:#82e0aa;font-weight:600;text-decoration:none}.profile-banner-link:hover{text-decoration:underline}.profile-404{flex-direction:column;justify-content:center;align-items:center;gap:12px;height:100%;display:flex}.profile-404-emoji{font-size:3rem}.profile-404-msg{color:#00000073;font-size:.9rem}@media (width<=768px){.profile-body{flex-direction:column}.profile-garden-list{border-top:1px solid #00000014;border-right:none;flex-direction:row;order:2;width:100%;height:72px;padding:0;overflow:auto hidden}.profile-list-title{display:none}.profile-garden-item{white-space:nowrap;border-bottom:3px solid #0000;border-radius:0;flex-shrink:0;height:100%;padding:0 16px}.profile-garden-item.active{background:#3a6ea80f;border-bottom-color:#3a6ea8}.profile-grid-area{flex:1;order:1}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;font-family:system-ui,-apple-system,sans-serif;font-size:14px}html,body,#root{color:#1a1a18;background:#e8e3d4;height:100%}.app{height:100%;display:flex;overflow:hidden}@media (width<=768px) and (orientation:portrait){.app{flex-direction:column}.float-dev-toggle,.ob-dev-toggle{display:none}}@media (width<=900px) and (orientation:landscape){.app{flex-direction:row}.float-dev-toggle,.ob-dev-toggle{display:none}}.float-dev-toggle{z-index:900;letter-spacing:.04em;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#00000059;cursor:pointer;background:#ffffffd9;border:1px solid #0000001f;border-radius:20px;padding:4px 10px;font-size:.68rem;font-weight:600;transition:background .12s,color .12s,border-color .12s;position:fixed;bottom:12px;right:14px}.float-dev-toggle:hover{color:#0009;background:#fff}.float-dev-toggle--on{color:#2a7a46;background:#eef8f0;border-color:#288c504d}.ob-dev-toggle{z-index:900;letter-spacing:.04em;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#00000059;cursor:pointer;background:#ffffffd9;border:1px solid #0000001f;border-radius:20px;padding:4px 10px;font-size:.68rem;font-weight:600;transition:background .12s,color .12s,border-color .12s;position:fixed;top:12px;right:14px}.ob-dev-toggle:hover{color:#0009;background:#fff}.ob-dev-toggle--on{color:#3c64b4;background:#eef3ff;border-color:#3c64b44d}
