html,body{overscroll-behavior-x:none}:root{--editor-primary: rgb(148, 55, 255);--editor-selection-bg: rgba(148, 55, 255, .1);--editor-thing-name: #666;--editor-border: #e0e0e0;--editor-container-bg: #fafafc;--editor-viewport-grid: #e0e0e0;--editor-panel-bg: #ffffff;--editor-text-muted: #666;--editor-topbar-bg: #ffffff;--editor-popover-bg: #ffffff;--editor-text-primary: #1f2937;--editor-text-secondary: #4b5563;--editor-hover-bg: #f3f4f6;--editor-spacing: 8px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5;color:#1f2937;background-color:#f3f4f6;margin:0;overscroll-behavior-x:none}#container{position:fixed;height:100vh;width:100vw;display:flex;flex-direction:column;background:var(--editor-container-bg);overflow:hidden}#viewport{flex:1;position:relative;overflow:hidden}.viewport-grid{background-image:radial-gradient(circle at 1px 1px,var(--editor-viewport-grid) 1px,transparent 1px);background-size:var(--grid-size) var(--grid-size);background-position:var(--grid-offset-x) var(--grid-offset-y)}.thing-name{position:absolute;top:-1.5em;left:0;height:1.5em;color:var(--editor-thing-name);font-size:small;cursor:grab;visibility:hidden;-webkit-user-select:none;user-select:none}.thing-status{position:absolute;bottom:-2em;width:256px;height:1.5em;color:red;font-size:small;pointer-events:none;-webkit-user-select:none;user-select:none}.selected{outline:1px solid var(--editor-primary);outline-offset:1px}.dragging{opacity:.8}.editing{outline:1px solid var(--editor-primary);cursor:text!important}.frame-drop-target{outline:1px solid var(--editor-primary)}#container[data-tool=browse-tool] .thing-hidden,#container[data-tool=browse-tool] .thing-hidden .thing-name{visibility:hidden}#container[data-tool=edit-tool] .thing-hidden .thing-content{opacity:.2}#container[data-tool=edit-tool] .selected>.thing-name,#container[data-tool=edit-tool] [id^="ahoy:"]:hover>.thing-name,:has([data-code-field]:focus) .thing-name,#container[data-spring-loaded=true] .thing-name{visibility:visible}#container[data-tool=edit-tool] [id^="ahoy:"]:hover:not(.selected),:has([data-code-field]:focus) [id^="ahoy:"]:not(.selected),#container[data-spring-loaded=true] [id^="ahoy:"]:not(.selected){outline:1px solid var(--editor-border)}#container[data-tool=browse-tool] #canvas button,#container[data-tool=browse-tool] #canvas input[type=checkbox],[type=range]{cursor:pointer}#container[data-tool=edit-tool] #canvas .thing-content,#container[data-tool=edit-tool] #canvas .thing-content *{cursor:default}#system-panel,#inspector-panel{position:fixed;top:0;bottom:0;min-width:10%;z-index:100;padding:var(--editor-spacing);background:var(--editor-panel-bg);border-inline:1px solid var(--editor-border);transition:all .15s ease-out}#inspector-panel{width:25%}#inspector-panel{right:0;transform:translate(100%)}#system-panel{left:0;transform:translate(-100%)}#container[data-tool=edit-tool] #system-panel,#container[data-tool=edit-tool] #inspector-panel,#container[data-spring-loaded=true] #system-panel,#container[data-spring-loaded=true] #inspector-panel{transform:translate(0)}.no-selection{color:var(--editor-text-muted)}#canvas input[type=number]::-webkit-inner-spin-button,#canvas input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}#canvas input[type=number]{-moz-appearance:textfield;appearance:textfield}a,a:hover,a:visited{color:inherit}.editor-top-bar{display:flex;justify-content:space-between;align-items:center;height:50px;padding:0 16px;background-color:var(--editor-topbar-bg);border-bottom:1px solid var(--editor-border);z-index:999}.top-bar-left,.top-bar-right{flex:1;display:flex;align-items:center}.top-bar-center{flex:2;display:flex;justify-content:center;align-items:center}.top-bar-right{justify-content:flex-end}.back-button,.share-button{display:flex;align-items:center;gap:6px;background:none;border:none;padding:6px 10px;border-radius:4px;font-size:14px;color:var(--editor-text-secondary);cursor:pointer;transition:background-color .2s ease}.back-button:hover,.share-button:hover{background-color:var(--editor-hover-bg);color:var(--editor-text-primary)}.document-title{font-size:18px;font-weight:500;color:var(--editor-text-primary);padding:4px 12px;border-radius:4px;cursor:pointer}.document-title:hover{background-color:var(--editor-hover-bg)}.document-title-input{font-size:18px;font-weight:500;color:var(--editor-text-primary);border:1px solid var(--editor-primary);border-radius:4px;padding:4px 8px;width:100%;min-width:200px;outline:none;background:var(--editor-panel-bg)}.share-popover{background-color:var(--editor-popover-bg);border:1px solid var(--editor-border);border-radius:8px;box-shadow:0 4px 12px #0000001a;padding:16px;width:400px;z-index:1000}.share-popover-header{font-size:16px;font-weight:500;color:var(--editor-text-primary);margin-bottom:8px}.share-popover-info{font-size:13px;color:var(--editor-text-secondary);margin-bottom:12px}.share-popover-url{display:flex;margin-bottom:16px}.share-popover-url input{flex:1;border:1px solid var(--editor-border);border-radius:4px 0 0 4px;padding:8px 12px;font-size:13px;color:var(--editor-text-secondary);background:var(--editor-hover-bg)}.copy-url-button{background-color:var(--editor-primary);color:#fff;border:none;border-radius:0 4px 4px 0;padding:8px 12px;cursor:pointer}.share-popover-social{display:flex;gap:8px}.share-popover-social a{display:flex;align-items:center;justify-content:center;gap:6px;text-decoration:none;padding:8px 12px;border-radius:4px;background-color:var(--editor-hover-bg);color:var(--editor-text-secondary);font-size:13px;flex:1}.share-popover-social a:hover{background-color:var(--editor-border);color:var(--editor-text-primary)}#twitter-icon,#bluesky-icon{width:16px;height:16px}#system-panel,#inspector-panel{top:50px;height:calc(100% - 50px)}.inspector-panel-container{height:100%;overflow-x:hidden}.share-urls-container{margin-bottom:16px;display:grid;grid-template-columns:auto 1fr;gap:var(--editor-spacing)}.share-url-container{display:contents}.share-url-label{font-size:small;text-align:right;color:var(--editor-text-muted);white-space:nowrap}.share-url-input{min-width:0;border:1px solid var(--editor-border);border-radius:2px;font-size:small;background-color:var(--editor-container-bg);color:var(--editor-text-muted);cursor:pointer}.category-header{font-size:x-small;color:var(--editor-text-muted);text-transform:uppercase;margin:var(--editor-spacing) 0 calc(var(--editor-spacing) / 2);padding-bottom:calc(var(--editor-spacing) / 4);border-bottom:1px solid var(--editor-border)}.property-group{margin-bottom:var(--editor-spacing);font-size:small}.property-group-row{display:flex;align-items:center;gap:var(--editor-spacing)}.property-group-row label{flex:0 0 45%;margin-bottom:3px;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.property-group-stacked{display:flex;flex-direction:column;gap:calc(var(--editor-spacing) / 2)}.property-group-stacked label{margin-bottom:3px}.property-group input:not([type=checkbox]),.property-group select{width:100%;min-width:0%}.CodeMirror{height:auto;border:1px solid #767676;min-width:0%;border-radius:2px}.formula-toggle{height:16px;padding:0;color:#767676;background:none;border:none;cursor:pointer}.formula-toggle:disabled{opacity:.5;cursor:auto}.formula-input{width:100%;margin-top:1px;box-sizing:border-box;font-family:monospace;font-size:small}.formula-input.hidden{display:none}.property-group :invalid,.invalid{background-color:#ff00001a;outline:1px solid red;border-radius:1px}.resize-handle{position:absolute;width:8px;height:8px;background:var(--editor-primary);border:1px solid white;-webkit-user-select:none;user-select:none}.resize-handle-n,.resize-handle-s{width:100%;height:8px;background:transparent;border:none}.resize-handle-e,.resize-handle-w{height:100%;width:8px;background:transparent;border:none}.resize-handle-n{cursor:ns-resize;top:-5px}.resize-handle-s{cursor:ns-resize;bottom:-5px}.resize-handle-w{cursor:ew-resize;left:-5px;top:0}.resize-handle-e{cursor:ew-resize;right:-5px;top:0}.resize-handle-nw{cursor:nwse-resize;top:-6px;left:-6px}.resize-handle-ne{cursor:nesw-resize;top:-6px;right:-6px}.resize-handle-sw{cursor:nesw-resize;bottom:-6px;left:-6px}.resize-handle-se{cursor:nwse-resize;bottom:-6px;right:-6px}.resize-handle-start,.resize-handle-end{position:absolute;width:8px;height:8px;background:var(--editor-primary);border:1px solid white;border-radius:50%;cursor:move}.resize-handle-start{left:-4px;top:-4px}.selection-box{position:absolute;border:1px solid var(--editor-primary);background:var(--editor-selection-bg);pointer-events:none}.things-category-header{font-size:x-small;color:var(--editor-text-muted);text-transform:uppercase;margin:var(--editor-spacing) 0 calc(var(--editor-spacing) / 2)}.things-category-group{margin-bottom:var(--editor-spacing)}.object-btn{display:block;width:100%;padding:var(--editor-spacing);margin:calc(var(--editor-spacing) / 2) 0;text-align:left;cursor:grab;background:var(--editor-panel-bg);border:1px solid #767676;border-radius:2px;box-shadow:1px 1px var(--editor-viewport-grid)}.object-btn:hover{background:var(--editor-container-bg)}.object-btn:active{cursor:grabbing}#toolbar{position:fixed;left:50%;bottom:20px;transform:translate(-50%);z-index:1000;display:flex;gap:6px;padding:var(--editor-spacing);background:var(--editor-container-bg);border-radius:10px;box-shadow:#00000029 0 0 2px,#0000003d 0 2px 3px}.toolbar-item{width:44px;height:44px;font-size:x-large;border:none;border-radius:8px;background:var(--editor-container-bg);display:flex;justify-content:center;align-items:center}.toolbar-item:hover{background:color-mix(in srgb,var(--editor-container-bg) 95%,black)}.toolbar-item.active{background:var(--editor-primary)}.toolbar-item img{width:22px;height:22px}.toolbar-item.active img{filter:invert(1) brightness(100)}:root{--primary-color: #2563eb;--primary-hover: #1d4ed8;--danger-color: #ef4444;--danger-hover: #dc2626;--text-color: #1f2937;--secondary-text: #4b5563;--border-color: #e5e7eb;--background-color: #ffffff;--card-background: #f9fafb;--gallery-background: #f3f2f1;--hover-color: #f3f4f6;--cancel-color: #9ca3af;--cancel-hover: #6b7280}html,body{height:100%;margin:0;padding:0;overflow-y:auto}body{min-height:100vh;display:flex;flex-direction:column}.document-list-container{margin:0 auto;height:100vh;overflow-y:auto;display:flex;flex-direction:column}.document-list-container *{box-sizing:border-box;margin:0;padding:0}.document-list-container h1,.document-list-container h2{font-family:Londrina Solid,sans-serif}.document-list-container h2{font-weight:300}.document-list-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-color);position:sticky;top:0;background-color:var(--background-color);z-index:10}.document-list-header h1{margin:0;font-size:2rem;color:var(--text-color)}.page-title{display:flex;flex-direction:row;align-items:baseline;gap:.5rem}.document-list-content{display:grid;grid-template-columns:1fr;flex:1;overflow-y:auto}@media (min-width: 768px){.document-list-content{grid-template-columns:1fr 1fr}}.templates-section,.documents-section{padding:1.5rem;background-color:var(--card-background);border-radius:.5rem;box-shadow:0 1px 3px #0000001a;overflow-y:auto}.list-title{margin-top:0;margin-bottom:1rem;color:var(--text-color);position:sticky;top:-1.5rem;background-color:var(--card-background);padding:.5rem 0;z-index:1;display:flex;flex-direction:row;align-items:baseline;gap:10px}.documents-section .list-title{justify-content:space-between}.templates-section,.templates-section .list-title{background-color:var(--gallery-background)}.list-item h2{margin:0;font-size:1.5rem}.templates-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1.5rem;overflow-y:auto}.gallery-item{display:flex;flex-direction:column;background-color:var(--background-color);border:1px solid var(--border-color);border-radius:.25rem;overflow:hidden;cursor:pointer;transition:all .2s ease}.gallery-item:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000000d}.gallery-item .thumbnail{position:relative;width:100%;height:0;padding-bottom:100%;overflow:hidden;background-color:#f3f4f6}.gallery-item .thumbnail img{position:absolute;width:100%;height:100%;object-fit:cover}.gallery-item .thumbnail.no-image{display:flex;align-items:center;justify-content:center;background-color:#e5e7eb}.gallery-item .thumbnail.no-image span{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#9ca3af;font-size:.875rem}.gallery-item .template-title{margin:0;padding:.75rem;font-size:1rem;text-align:center}.gallery-item .template-description{color:var(--secondary-text);margin:0;padding:0 .75rem .75rem;font-size:.75rem;text-align:center}.documents-list{display:flex;flex-direction:column;gap:.75rem;overflow-y:auto}.document-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background-color:var(--background-color);border:1px solid var(--border-color);border-radius:.25rem;cursor:pointer;transition:background-color .2s ease}.document-item:hover{background-color:var(--hover-color)}.document-info{display:flex;flex-direction:column;flex-grow:1}.document-name{font-weight:500;color:var(--text-color)}.document-name-input{width:100%;font-weight:500;color:var(--text-color);border:1px solid var(--border-color);padding:.25rem .5rem;border-radius:.25rem;outline:none;font-family:inherit;font-size:inherit}.document-name-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 1px var(--primary-color)}.document-date{font-size:.75rem;color:var(--secondary-text);margin-top:.25rem}.document-actions{display:flex;gap:.5rem}.document-actions .document-action{background:none;border:none;font-size:.875rem;cursor:pointer;color:var(--secondary-text);padding:.25rem .5rem;border-radius:.25rem;transition:all .2s ease}.document-actions .document-action:hover{background-color:var(--hover-color);color:var(--text-color)}.document-action.delete-action:hover{color:var(--danger-color)}.delete-confirmation{position:absolute;background-color:#fff;border:1px solid var(--border-color);border-radius:.25rem;padding:.75rem;display:flex;flex-direction:column;gap:.5rem;box-shadow:0 4px 6px #0000001a;z-index:100;width:200px;margin-top:5px}.delete-confirmation:before{content:"";position:absolute;top:-8px;left:50%;transform:translate(-50%);border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:8px solid white;z-index:101}.delete-confirmation:after{content:"";position:absolute;top:-9px;left:50%;transform:translate(-50%);border-left:9px solid transparent;border-right:9px solid transparent;border-bottom:9px solid var(--border-color);z-index:100}.delete-confirmation p{margin:0 0 .5rem;font-size:.875rem;color:var(--text-color);text-align:center}.delete-confirmation-buttons{display:flex;gap:.5rem;justify-content:center}.delete-confirmation-cancel{background-color:var(--cancel-color);color:#fff;border:none;padding:.5rem .75rem;border-radius:.25rem;font-size:.875rem;cursor:pointer;transition:background-color .2s ease}.delete-confirmation-cancel:hover{background-color:var(--cancel-hover)}.delete-confirmation-confirm{background-color:var(--danger-color);color:#fff;border:none;padding:.5rem .75rem;border-radius:.25rem;font-size:.875rem;cursor:pointer;transition:background-color .2s ease}.delete-confirmation-confirm:hover{background-color:var(--danger-hover)}.document-action.open-action{color:var(--primary-color);font-weight:500}.empty-state{color:var(--secondary-text);text-align:center;padding:2rem 0}.primary-button{background-color:var(--primary-color);color:#fff;border:none;padding:.5rem 1rem;border-radius:.25rem;font-weight:500;cursor:pointer;transition:background-color .2s ease}.primary-button:hover{background-color:var(--primary-hover)}.error-message{text-align:center;padding:2rem;background-color:var(--card-background);border-radius:.5rem;box-shadow:0 1px 3px #0000001a}.error-message h2{color:var(--danger-color);margin-top:0}.error-message button{background-color:var(--primary-color);color:#fff;border:none;padding:.5rem 1rem;border-radius:.25rem;font-weight:500;cursor:pointer;margin-top:1rem}.error-message button:hover{background-color:var(--primary-hover)}
