:root{--bg: #0a0a0a;--fg: #f4f4f4;--chrome: #161616;--rail-bg: #0f0f0f;--accent: #b8ff4a;--accent-ink: #0a0a0a;--accent-30: rgba(184,255,74,.3);--accent-25: rgba(184,255,74,.25);--accent-12: rgba(184,255,74,.12);--accent-10: rgba(184,255,74,.1);--accent-04: rgba(184,255,74,.04);--fg-80: rgba(255,255,255,.8);--fg-75: rgba(255,255,255,.75);--fg-65: rgba(255,255,255,.65);--fg-55: rgba(255,255,255,.55);--fg-50: rgba(255,255,255,.5);--fg-40: rgba(255,255,255,.4);--fg-15: rgba(255,255,255,.15);--fg-12: rgba(255,255,255,.12);--fg-10: rgba(255,255,255,.1);--fg-08: rgba(255,255,255,.08);--fg-05: rgba(255,255,255,.05);--fg-03: rgba(255,255,255,.03);--fg-025: rgba(255,255,255,.025);--font-sans: "Helvetica Neue", Helvetica, Arial, sans-serif;--font-mono: "SF Mono", "Consolas", "Monaco", ui-monospace, monospace}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.visible{visibility:visible}.fixed{position:fixed}.block{display:block}.flex{display:flex}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.outline{outline-style:solid}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}html,body,#root{margin:0;padding:0;background:var(--chrome);color:var(--fg);font-family:var(--font-sans);font-feature-settings:"kern" 1,"liga" 1;-webkit-font-smoothing:antialiased;min-height:100vh;overflow-x:hidden}*,*:before,*:after{box-sizing:border-box}:focus{outline:none}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.tp-app{display:grid;grid-template-columns:340px 1fr 300px;min-height:100vh;background:var(--chrome)}@media (max-width: 1279px){.tp-app{grid-template-columns:340px 1fr}.tp-rail-right{display:none}}@media (max-width: 899px){.tp-app{grid-template-columns:1fr}}.tp-rail{background:var(--rail-bg);border-right:1px solid var(--fg-10);padding:22px 18px 32px;overflow-y:auto;max-height:100vh;position:sticky;top:0}.tp-rail-right{border-right:0;border-left:1px solid var(--fg-10)}.tp-app-left-closed .tp-rail-left,.tp-app-right-closed .tp-rail-right{display:none}.tp-app-left-closed.tp-app-right-closed{grid-template-columns:1fr}.tp-app-left-closed:not(.tp-app-right-closed){grid-template-columns:1fr 300px}.tp-app-right-closed:not(.tp-app-left-closed){grid-template-columns:340px 1fr}@media (max-width: 1279px){.tp-app-left-closed{grid-template-columns:1fr}}.tp-rail-toggle{position:fixed;top:50%;transform:translateY(-50%);width:28px;height:64px;background:#0f0f0f;border:1px solid var(--fg-15);color:var(--fg-65);font-family:var(--font-mono);font-size:14px;cursor:pointer;z-index:500;padding:0;display:grid;place-items:center}.tp-rail-toggle:hover{color:var(--accent);border-color:var(--accent-30)}.tp-rail-toggle-left{left:0;border-left:0;border-radius:0 4px 4px 0}.tp-rail-toggle-right{right:0;border-right:0;border-radius:4px 0 0 4px}.tp-rail-close{background:transparent;border:1px solid var(--fg-10);color:var(--fg-55);width:24px;height:24px;border-radius:3px;font-size:12px;cursor:pointer;display:grid;place-items:center;padding:0}.tp-rail-close:hover{color:var(--fg);border-color:var(--fg-15)}.tp-rail-title{font-size:11px;font-weight:700;letter-spacing:.25em;text-transform:uppercase;margin:0 0 18px}.tp-rail-title:before{content:"✦ ";color:var(--accent)}.tp-section{margin-bottom:14px;border-top:1px solid var(--fg-10);padding-top:10px}.tp-section:first-of-type{border-top:0;padding-top:0}.tp-section-title{font-size:10px;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--fg-80);margin-bottom:10px}.tp-section-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.tp-section-title-row .tp-section-title{margin-bottom:0}.tp-collapsible .tp-section-head{width:100%;display:flex;align-items:center;gap:8px;background:transparent;border:0;padding:4px 0;cursor:pointer;text-align:left;color:var(--fg-80)}.tp-collapsible .tp-section-head:hover{color:var(--fg)}.tp-collapsible .tp-section-head .tp-section-title{margin:0;flex:1}.tp-collapsible .tp-section-caret{font-size:10px;color:var(--fg-55);width:12px;display:inline-block}.tp-collapsible.is-open .tp-section-caret{color:var(--accent)}.tp-collapsible .tp-section-right{margin-left:auto;cursor:default}.tp-collapsible .tp-section-body{padding-top:10px;animation:tp-slide .14s ease}@keyframes tp-slide{0%{opacity:0;transform:translateY(-2px)}to{opacity:1;transform:translateY(0)}}.tp-hint{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-40);margin:0 0 8px;line-height:1.55}.tp-row{display:flex;flex-direction:column;margin-bottom:12px}.tp-row label{font-size:9px;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--fg-55);margin-bottom:6px}.tp-row input[type=text],.tp-row input[type=number],.tp-row textarea{width:100%;background:#ffffff0a;border:1px solid var(--fg-12);border-radius:4px;color:var(--fg);padding:8px 10px;font-family:var(--font-sans);font-size:12px}.tp-row textarea{resize:vertical;font-family:inherit}.tp-row input:focus,.tp-row textarea:focus{border-color:var(--accent)}.tp-row input[type=range]{width:100%;accent-color:var(--accent)}.tp-toggle-row{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.tp-toggle-row.two{grid-template-columns:repeat(2,1fr)}.tp-seg{background:#ffffff0a;border:1px solid var(--fg-12);color:var(--fg-65);padding:7px 0;font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;border-radius:3px}.tp-seg:hover{color:var(--fg)}.tp-seg.on{background:var(--accent-10);color:var(--accent);border-color:var(--accent-30)}.tp-mini-toggle{font-family:var(--font-mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--fg-40);cursor:pointer;padding:4px 8px;border:1px solid var(--fg-12);border-radius:999px}.tp-mini-toggle.on{color:var(--accent);border-color:var(--accent-30);background:var(--accent-10)}.tp-upload{display:flex;gap:6px}.tp-upload-btn{flex:1;background:#ffffff0a;border:1px solid var(--fg-12);color:var(--fg-65);padding:10px;font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;border-radius:4px;text-align:center;display:inline-block}.tp-upload-btn:hover{color:var(--fg);border-color:var(--fg-15)}.tp-upload-btn-sm{padding:7px 10px;font-size:9px}.tp-upload-clear{background:transparent;border:1px solid var(--fg-12);color:var(--fg-55);padding:7px 12px;font-family:var(--font-mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;border-radius:4px}.tp-add-btn,.tp-add-inline{background:transparent;border:1px dashed var(--fg-15);color:var(--fg-65);padding:8px 10px;font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;border-radius:3px;width:100%}.tp-add-inline{width:auto;padding:4px 10px;font-size:9px}.tp-add-btn:hover,.tp-add-inline:hover{color:var(--fg);border-color:var(--accent-30)}.tp-x{background:transparent;border:1px solid var(--fg-12);color:var(--fg-55);padding:3px 10px;font-family:var(--font-mono);font-size:10px;cursor:pointer;border-radius:3px}.tp-x:hover{color:#ff7a7a;border-color:#ff7a7a55}.tp-palette-edit{display:flex;flex-direction:column;gap:6px}.tp-swatch-edit{display:grid;grid-template-columns:28px 90px 1fr 28px;gap:6px;align-items:center}.tp-swatch-edit input[type=color]{width:28px;height:28px;padding:0;border:1px solid var(--fg-12);border-radius:3px;background:transparent;cursor:pointer}.tp-swatch-hex-input,.tp-swatch-name-input{background:#ffffff0a;border:1px solid var(--fg-12);color:var(--fg);padding:6px 8px;font-family:var(--font-mono);font-size:11px;border-radius:3px}.tp-view-card{border:1px solid var(--fg-10);border-radius:4px;padding:10px;margin-bottom:8px;background:var(--fg-03)}.tp-view-card-head{display:flex;gap:6px;align-items:center;margin-bottom:8px}.tp-view-name{flex:1;background:transparent;border:1px solid var(--fg-10);color:var(--fg);padding:6px 8px;font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;border-radius:3px}.tp-view-card-actions{display:flex;gap:3px}.tp-view-card-actions button{background:transparent;border:1px solid var(--fg-10);color:var(--fg-55);width:24px;height:24px;font-size:11px;cursor:pointer;border-radius:3px}.tp-view-card-actions button:hover:not(:disabled){color:var(--fg);border-color:var(--fg-15)}.tp-view-card-actions button:disabled{opacity:.3;cursor:not-allowed}.tp-view-img-controls{margin-top:10px}.tp-nudge{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}.tp-nudge button{background:#ffffff0a;border:1px solid var(--fg-12);color:var(--fg-65);padding:5px 0;font-family:var(--font-mono);font-size:11px;cursor:pointer;border-radius:3px}.tp-nudge button:empty{visibility:hidden}.tp-export{width:100%;background:var(--accent);color:var(--accent-ink);border:0;padding:14px;font-weight:700;font-size:11px;letter-spacing:.25em;text-transform:uppercase;cursor:pointer;border-radius:4px;margin-top:14px}.tp-export:hover{filter:brightness(1.05)}.tp-export:disabled{opacity:.6;cursor:progress}.tp-reset-btn{width:100%;background:transparent;border:1px solid var(--fg-12);color:var(--fg-55);padding:10px;font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;border-radius:4px}.tp-reset-btn:hover{color:#ff7a7a;border-color:#ff7a7a66}.tp-reset-btn-danger{background:#ff7a7a;color:#0a0a0a;border-color:#ff7a7a;flex:1}.tp-reset-btn-danger:hover{color:#0a0a0a;filter:brightness(1.05)}.tp-reset-confirm{display:flex;flex-direction:column;gap:8px}.tp-view-photo-wrap{touch-action:none}.tp-image-row{display:flex;gap:8px;align-items:stretch;margin-bottom:6px}.tp-thumb{position:relative;border:1px solid var(--fg-12);border-radius:4px;background:#000;overflow:hidden;flex:0 0 auto}.tp-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.tp-thumb-x{position:absolute;top:2px;right:2px;width:18px;height:18px;border:0;border-radius:999px;background:#000000b3;color:var(--fg);font-size:13px;line-height:1;cursor:pointer;display:grid;place-items:center}.tp-thumb-x:hover{background:#f55;color:#fff}.tp-rail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.tp-rail-header .tp-rail-title{margin:0}.tp-undo-bar{display:flex;gap:4px}.tp-undo-bar button{background:transparent;border:1px solid var(--fg-12);color:var(--fg-65);width:28px;height:28px;font-size:14px;cursor:pointer;border-radius:3px}.tp-undo-bar button:hover:not(:disabled){color:var(--fg);border-color:var(--fg-15)}.tp-undo-bar button:disabled{opacity:.3;cursor:not-allowed}.tp-ctx-menu{background:#0f0f0f;border:1px solid var(--fg-15);border-radius:4px;padding:4px;min-width:140px;z-index:9999;box-shadow:0 8px 24px #0006}.tp-ctx-menu button{display:block;width:100%;text-align:left;background:transparent;border:0;color:var(--fg-80);padding:7px 10px;font-family:var(--font-mono);font-size:10px;letter-spacing:.15em;text-transform:uppercase;cursor:pointer;border-radius:3px}.tp-ctx-menu button:hover{background:var(--fg-05);color:var(--fg)}.tp-anchor-hit{position:absolute;z-index:6;cursor:move;border-radius:999px;touch-action:none}.tp-callout-number{color:var(--accent);font-family:var(--font-mono);font-size:14px;letter-spacing:.15em;margin-right:4px}.tp-callout-arrow{color:var(--fg-55)}.tp-tpl-list{display:flex;flex-direction:column;gap:4px}.tp-tpl-row{display:flex;gap:4px;align-items:stretch}.tp-tpl-load{flex:1;text-align:left;background:var(--fg-03);border:1px solid var(--fg-10);border-radius:3px;padding:8px 10px;cursor:pointer;display:flex;flex-direction:column;gap:2px}.tp-tpl-load:hover{border-color:var(--accent-30);background:var(--accent-04)}.tp-tpl-name{font-family:var(--font-sans);font-size:11px;font-weight:600;color:var(--fg);letter-spacing:.01em}.tp-tpl-meta{font-family:var(--font-mono);font-size:9px;letter-spacing:.12em;color:var(--fg-40);text-transform:uppercase}.tp-saved{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--fg-40);margin-top:8px;justify-content:center}.tp-saved-dot{width:6px;height:6px;border-radius:999px;background:var(--accent)}.tp-saved-saving .tp-saved-dot{background:#ffa54a;animation:tp-pulse 1s infinite}@keyframes tp-pulse{0%,to{opacity:1}50%{opacity:.3}}.tp-current-chip{display:flex;align-items:baseline;gap:6px;padding:8px 10px;border:1px solid var(--fg-10);background:var(--fg-03);border-radius:4px;min-width:0}.tp-current-label{font-family:var(--font-mono);font-size:9px;letter-spacing:.2em;color:var(--fg-55);text-transform:uppercase}.tp-current-name{font-size:12px;font-weight:600;color:var(--fg);letter-spacing:.01em;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tp-proj-list{display:flex;flex-direction:column;gap:10px}.tp-proj{border:1px solid var(--fg-10);background:var(--fg-03);border-radius:4px;padding:8px;display:flex;flex-direction:column;gap:6px;transition:border-color .12s}.tp-proj:hover{border-color:var(--fg-15)}.tp-proj.is-current{border-color:var(--accent-30);background:var(--accent-04)}.tp-proj-thumb{position:relative;aspect-ratio:9 / 16;border-radius:3px;overflow:hidden;background:#000;cursor:pointer;border:1px solid var(--fg-10)}.tp-proj-thumb:hover{border-color:var(--accent-30)}.tp-proj-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.tp-proj-thumb span{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;font-family:var(--font-mono);font-size:9px;letter-spacing:.2em;color:var(--fg-40)}.tp-proj-current{position:absolute;top:4px;left:4px;background:var(--accent);color:var(--accent-ink);font-family:var(--font-mono);font-size:8px;letter-spacing:.2em;font-weight:700;padding:2px 6px;border-radius:2px;pointer-events:none}.tp-proj-meta{display:flex;flex-direction:column;gap:2px}.tp-proj-name{font-size:12px;font-weight:600;color:var(--fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tp-proj-date{font-family:var(--font-mono);font-size:9px;letter-spacing:.12em;color:var(--fg-40);text-transform:uppercase}.tp-proj-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}.tp-proj-actions button{background:transparent;border:1px solid var(--fg-12);color:var(--fg-55);padding:5px 0;font-family:var(--font-mono);font-size:9px;letter-spacing:.15em;text-transform:uppercase;cursor:pointer;border-radius:3px}.tp-proj-actions button:hover{color:var(--fg);border-color:var(--fg-15)}.tp-proj-actions button:last-child:hover{color:#ff7a7a;border-color:#ff7a7a55}.tp-upload-clear{cursor:pointer}.tp-upload-clear:hover{color:var(--fg);border-color:var(--fg-15)}.tp-anchor-hit{transition:transform .1s}.tp-anchor-hit:hover{transform:scale(1.2)}.tp-anchor-hit:active{cursor:grabbing}.tp-view-photo-wrap{cursor:grab}.tp-view-photo-wrap:active{cursor:grabbing}.tp-swatch-edit input[type=color]{cursor:pointer}.tp-swatch-edit input[type=color]:hover{border-color:var(--fg-15)}.tp-logo-preview,.tp-chrome-dots span{cursor:default}.tp-callout-bubble{cursor:inherit}.tp-callout.is-selected .tp-callout-bubble:hover{cursor:grab}.tp-mini-toggle:hover{color:var(--fg);border-color:var(--fg-15)}.tp-mini-toggle.on:hover{color:var(--accent);border-color:var(--accent-30)}.tp-view-name{cursor:text}.tp-view-name:hover{border-color:var(--fg-15)}.tp-canvas-rail{position:relative;display:flex;align-items:flex-start;justify-content:center;padding:24px;overflow:auto;background:var(--chrome)}.tp-canvas-outer{position:relative}.tp-canvas-wrap{transform-origin:top left;position:absolute;top:0;left:0}.tp-workspace-zoom{position:fixed;bottom:16px;left:50%;transform:translate(-50%);display:inline-flex;align-items:center;gap:8px;padding:6px 10px;background:#000000c7;border:1px solid var(--fg-15);border-radius:999px;box-shadow:0 4px 18px #00000059;z-index:20;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.tp-workspace-zoom-slider{display:inline-flex;align-items:center;gap:6px}.tp-workspace-zoom-slider input[type=range]{width:140px;accent-color:var(--accent)}.tp-workspace-zoom-btn{font:inherit;font-size:12px;font-weight:700;letter-spacing:.02em;color:var(--fg);background:transparent;border:1px solid var(--fg-15);border-radius:999px;padding:4px 10px;cursor:pointer;white-space:nowrap}.tp-workspace-zoom-btn:hover{border-color:var(--accent-30);color:var(--accent)}.tp-workspace-zoom-reset{min-width:48px;text-align:center}.tp-logo-upload{display:flex;gap:10px;align-items:center}.tp-logo-preview{width:48px;height:48px;border-radius:999px;background:var(--accent);display:grid;place-items:center;overflow:hidden;flex:0 0 auto;border:1px solid var(--accent-30)}.tp-logo-preview img{width:80%;height:80%;-o-object-fit:contain;object-fit:contain}.tp-logo-upload-inner{flex:1;display:flex;flex-direction:column;gap:6px}.tp-post{background:var(--bg);background-image:linear-gradient(var(--fg-025) 1px,transparent 1px),linear-gradient(90deg,var(--fg-025) 1px,transparent 1px);background-size:40px 40px;color:var(--fg);font-family:var(--font-sans);font-feature-settings:"kern" 1,"liga" 1;position:relative;overflow:hidden;display:flex;flex-direction:column;padding:32px;gap:16px}.tp-post-landscape{padding:24px;gap:12px}.tp-post-landscape .tp-chrome{height:56px}.tp-post-portrait{width:1080px;height:1920px}.tp-post-landscape{width:1920px;height:1080px}.tp-chrome{flex:0 0 auto;height:70px;display:flex;align-items:center;justify-content:space-between;padding:0 22px;border:1px solid var(--fg-10);background:var(--fg-03);border-radius:8px}.tp-chrome-brand{display:flex;align-items:center;gap:14px}.tp-chrome-logo{width:44px;height:44px;border-radius:999px;background:var(--accent);display:grid;place-items:center;overflow:hidden;flex:0 0 auto}.tp-chrome-logo img{width:80%;height:80%;-o-object-fit:contain;object-fit:contain}.tp-chrome-handle{font-size:20px;font-weight:700;letter-spacing:.02em;color:var(--fg)}.tp-chrome-handle sup{font-size:11px;font-weight:500;color:var(--fg-55);margin-left:2px;letter-spacing:.1em}.tp-chrome-dots{display:flex;gap:10px;align-items:center}.tp-chrome-dots span{width:12px;height:12px;border-radius:999px;background:var(--fg-10);border:1px solid var(--fg-15)}.tp-chrome-dots span:last-child{background:var(--accent);border-color:var(--accent)}.tp-header{flex:0 0 auto;border:1px solid var(--fg-10);background:var(--fg-03);border-radius:8px;padding:18px 24px;display:grid;grid-template-columns:1fr 1fr;gap:4px 40px}.tp-post-landscape .tp-header{grid-template-columns:1fr 1fr 1fr 1fr;padding:14px 22px;gap:2px 28px}.tp-post-landscape .tp-field{padding:6px 0}.tp-field{display:flex;align-items:baseline;padding:8px 0;border-bottom:1px solid var(--fg-08);gap:14px}.tp-field-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.25em;color:var(--fg-55);text-transform:uppercase;flex:0 0 90px}.tp-field-value{font-family:var(--font-sans);font-size:18px;font-weight:700;letter-spacing:-.01em;color:var(--fg);text-transform:uppercase;margin-left:auto;text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.tp-field{min-width:0}.tp-palette{flex:0 0 auto;border:1px solid var(--fg-10);background:var(--fg-03);border-radius:8px;padding:14px 20px;display:flex;align-items:center;gap:20px}.tp-palette-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.25em;color:var(--fg-55);text-transform:uppercase;flex:0 0 auto}.tp-palette-swatches{display:flex;gap:20px;flex-wrap:wrap;flex:1}.tp-swatch{display:flex;align-items:center;gap:10px}.tp-swatch-chip{width:34px;height:34px;border-radius:4px;border:1px solid var(--fg-15)}.tp-swatch-meta{display:flex;flex-direction:column;line-height:1.15}.tp-swatch-name{font-family:var(--font-sans);font-weight:700;font-size:12px;letter-spacing:.01em;text-transform:uppercase;color:var(--fg)}.tp-swatch-hex{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;color:var(--fg-55)}.tp-views{flex:1 1 auto;display:flex;min-height:0;gap:18px}.tp-views-standard.tp-dir-col{flex-direction:column}.tp-views-standard.tp-dir-row{flex-direction:row}.tp-views-standard>.tp-view-slot{flex:1 1 0;display:flex;flex-direction:column;min-height:0;min-width:0}.tp-views-freeform{gap:0}.tp-views-freeform>.tp-view{flex:1}.tp-view{position:relative;flex:1 1 auto;border:1px solid var(--fg-10);background:var(--fg-03);border-radius:8px;overflow:hidden}.tp-view-label{font-family:var(--font-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--accent);position:absolute;top:14px;left:18px;z-index:5}.tp-view-label:before{content:"→ "}.tp-view-placeholder{position:absolute;top:40px;right:24px;bottom:24px;left:24px;display:grid;place-items:center;border:1px dashed var(--fg-15);border-radius:6px;font-family:var(--font-mono);font-size:11px;letter-spacing:.25em;color:var(--fg-40);text-transform:uppercase}.tp-view-photo-wrap{position:absolute;top:40px;right:24px;bottom:24px;left:24px;display:grid;place-items:center;cursor:crosshair}.tp-view-photo{max-width:100%;max-height:100%;-o-object-fit:contain;object-fit:contain;transform-origin:center center;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none;pointer-events:none}.tp-callout-svg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:6}.tp-anchor-dot{fill:var(--accent);stroke:var(--bg);stroke-width:2}.tp-anchor-ring{fill:none;stroke:var(--accent);stroke-width:1;opacity:.5}.tp-callout{position:absolute;z-index:7;cursor:grab;touch-action:none}.tp-callout:active{cursor:grabbing}.tp-callout.is-selected .tp-callout-bubble{outline:2px solid var(--accent);outline-offset:3px}.tp-callout-bubble{position:relative;border:2px solid var(--accent);background:var(--bg);overflow:hidden;box-shadow:0 0 0 1px var(--bg) inset}.tp-callout-bubble img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block;pointer-events:none}.tp-callout-circle{border-radius:999px}.tp-callout-square,.tp-callout-rect{border-radius:4px}.tp-callout-label{position:absolute;top:50%;transform:translateY(-50%);font-family:var(--font-sans);font-weight:800;font-size:15px;letter-spacing:-.01em;line-height:1.05;color:var(--fg);text-transform:uppercase;white-space:nowrap;pointer-events:none;max-width:360px;paint-order:stroke fill;-webkit-text-stroke:2px #000;text-shadow:-1px -1px 0 #000,1px -1px 0 #000,-1px 1px 0 #000,1px 1px 0 #000}.tp-callout-label-right{left:calc(100% + 14px);text-align:left}.tp-callout-label-left{right:calc(100% + 14px);text-align:right}.tp-callout-label-below{top:calc(100% + 10px);left:50%;transform:translate(-50%);text-align:center}.tp-passcode-shell{min-height:100vh;display:grid;place-items:center;background:var(--bg);padding:24px}.tp-passcode-card{width:100%;max-width:360px;background:#0f0f0f;border:1px solid var(--fg-10);border-radius:6px;padding:36px 28px;display:flex;flex-direction:column;align-items:center;gap:12px}.tp-passcode-card.shake{animation:tp-shake .4s ease}@keyframes tp-shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.tp-passcode-mark{width:56px;height:56px}.tp-passcode-title{font-size:13px;font-weight:700;letter-spacing:.3em;text-transform:uppercase}.tp-passcode-sub{font-family:var(--font-mono);font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--fg-55);margin-bottom:14px}.tp-passcode-card input{width:100%;background:#ffffff0a;border:1px solid var(--fg-12);border-radius:4px;color:var(--fg);padding:12px 14px;font-family:var(--font-mono);font-size:14px;letter-spacing:.3em;text-align:center}.tp-passcode-card input:focus{border-color:var(--accent)}.tp-passcode-card button{width:100%;background:var(--accent);color:var(--accent-ink);border:0;padding:12px;font-weight:700;font-size:11px;letter-spacing:.25em;text-transform:uppercase;cursor:pointer;border-radius:4px;margin-top:4px}
