@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/fef07dbb0973bf53-s.12tyk43_3sh9u.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/8a480f0b521d4e75-s.0jzbimsg8vl84.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/53b9e256198e5412-s.0-wfv7uh4i7h9.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7178b3e590c64307-s.0nx0ww8fni_q3.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/caa3a2e1cccd8315-s.p.09~u27dqhyhd6.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Fallback;src:local(Arial);ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.0%;size-adjust:104.76%}.geist_a71539c9-module__T19VSG__className{font-family:Geist,Geist Fallback;font-style:normal}.geist_a71539c9-module__T19VSG__variable{--font-geist-sans:"Geist", "Geist Fallback"}
@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5ce348bf30bf5439-s.0ee55_hj9qcer.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/4fa387ec64143e14-s.0.qu-9752pffj.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/6306c77e7c8268e4-s.0mao5jbfbduzp.woff2)format("woff2");unicode-range:U+2000-2001,U+2004-2008,U+200A,U+23B8-23BD,U+2500-259F}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7d817b4c03b0c5f1-s.0uzt.a6d44yda.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/bbc41e54d2fcbd21-s.0mvwgmnhv29no.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/797e433ab948586e-s.p.09zddjkbdep5a.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Mono Fallback;src:local(Arial);ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.0%;size-adjust:134.59%}.geist_mono_8d43a2aa-module__8Li5zG__className{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.geist_mono_8d43a2aa-module__8Li5zG__variable{--font-geist-mono:"Geist Mono", "Geist Mono Fallback"}
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial}}}@layer theme{:root,:host{--spacing:.25rem;--default-font-family:var(--font-geist-sans);--default-mono-font-family:var(--font-geist-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.flex{display:flex}.grid{display:grid}.hidden{display:none}.size-5{width:calc(var(--spacing) * 5);height:calc(var(--spacing) * 5)}.h-6{height:calc(var(--spacing) * 6)}.h-8{height:calc(var(--spacing) * 8)}.h-full{height:100%}.min-h-full{min-height:100%}.w-full{width:100%}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.cursor-grab{cursor:grab}.flex-col{flex-direction:column}.rounded{border-radius:.25rem}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.active\:cursor-grabbing:active{cursor:grabbing}}:root{--background:#eef2f1;--foreground:#201d1b}body{background:var(--background);color:var(--foreground);font-family:Arial,Helvetica,sans-serif;overflow:hidden}button,input{font:inherit}button{cursor:pointer}.pattern-app{background:linear-gradient(90deg,#2f7d7314,#0000 38%),#eef2f1;flex-direction:column;height:100vh;display:flex}.app-bar{background:#ffffffe0;border-bottom:1px solid #d8dedb;flex:none;justify-content:space-between;align-items:center;gap:20px;min-height:72px;padding:12px 22px;display:flex}.brand-block{align-items:center;gap:12px;min-width:0;display:flex}.brand-mark{color:#201d1b;background:#f6b049;border:2px solid #201d1b;flex:none;place-items:center;width:42px;height:42px;font-size:14px;font-weight:900;display:grid}.eyebrow{color:#6d6862;letter-spacing:.08em;text-transform:uppercase;margin:0;font-size:11px;font-weight:800;line-height:1.2}.brand-title{color:#201d1b;letter-spacing:0;margin:0;font-size:clamp(21px,2vw,28px);font-weight:900;line-height:1.1}.export-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.export-actions button,.panel-action-button,.danger-button{color:#2a2724;background:#fff;border:1px solid #c9d0cc;border-radius:7px;min-height:36px;padding:0 13px;font-size:13px;font-weight:800}.export-actions button:hover,.panel-action-button:hover,.danger-button:hover{color:#145f56;border-color:#2f7d73}.editor-shell{flex:1;grid-template-columns:94px minmax(520px,1fr) 314px;min-height:0;display:grid;overflow:hidden}.tool-rail{background:#f8faf8;border-right:1px solid #d8dedb;flex-direction:column;gap:8px;padding:14px 10px;display:flex;overflow-y:auto}.tool-button{color:#45413d;letter-spacing:0;background:0 0;border:1px solid #0000;border-radius:7px;flex-direction:column;justify-content:center;align-items:center;gap:6px;min-height:58px;font-size:11px;font-weight:800;display:flex}.tool-button:hover{background:#fff;border-color:#cdd5d1}.tool-button.is-active{color:#145f56;background:#e4f0ed;border-color:#2f7d73}.canvas-region{flex-direction:column;gap:12px;min-width:0;min-height:0;padding:18px;display:flex;overflow:hidden}.canvas-topline{justify-content:space-between;align-items:center;gap:12px;display:flex}.mode-chip,.canvas-stats{color:#4e4945;text-transform:capitalize;align-items:center;gap:10px;font-size:13px;font-weight:800;display:flex}.canvas-stats{color:#746f69;text-transform:none;font-size:12px}.canvas-stats span{white-space:nowrap}.page-frame{flex:1;place-items:start center;min-height:0;display:grid;overflow:auto}.page-frame.is-zoomed{justify-items:center}.pattern-svg{aspect-ratio:4/3;touch-action:none;-webkit-user-select:none;user-select:none;background:#fff;border:1px solid #d9ddd9;box-shadow:0 20px 55px #201d1b21}.pattern-svg text{-webkit-user-select:none;user-select:none}.right-rail{background:#f8faf8;border-left:1px solid #d8dedb;flex-direction:column;gap:14px;min-height:0;padding:14px;display:flex}.right-rail-main{flex-direction:column;flex:1;gap:14px;min-height:0;display:flex;overflow:hidden}.right-rail-tabs{flex:none}.right-rail-content{flex:1;min-height:0;overflow-y:auto}.right-rail-tabs button{min-height:40px;font-size:13px}.editor-panel{background:#fff;border:1px solid #d8dedb;border-radius:8px;padding:14px}.right-rail-footer-panel{flex:none}.panel-heading{margin-bottom:12px}.panel-heading h2{color:#201d1b;letter-spacing:0;text-transform:capitalize;margin:3px 0 0;font-size:19px;font-weight:900;line-height:1.2}.style-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.style-choice{color:#282421;text-align:left;background:#fbfcfb;border:1px solid #d5dbd8;border-radius:7px;min-width:0;padding:6px 8px 7px}.style-choice:hover{background:#f2f8f6;border-color:#94b8b1}.style-choice.is-active{background:#e4f0ed;border-color:#2f7d73;box-shadow:inset 0 0 0 1px #2f7d73}.style-choice span{color:#403b37;letter-spacing:0;text-overflow:ellipsis;white-space:nowrap;font-size:11px;font-weight:900;line-height:1.1;display:block;overflow:hidden}.property-group{border-top:1px solid #e6ebe8;flex-direction:column;gap:10px;margin-top:14px;padding-top:14px;display:flex}.property-label{color:#5d5853;margin:0;font-size:12px;font-weight:900}.settings-list{flex-direction:column;gap:10px;display:flex}.setting-toggle{color:#403b37;background:#fbfcfb;border:1px solid #d8dedb;border-radius:7px;justify-content:space-between;align-items:center;gap:12px;min-height:44px;padding:8px 10px;font-size:13px;font-weight:900;display:flex;position:relative}.setting-toggle:hover{background:#f5faf8;border-color:#94b8b1}.setting-label{min-width:0}.setting-toggle input{opacity:0;width:1px;height:1px;position:absolute}.switch-track{background:#e7ece9;border:1px solid #cfd8d4;border-radius:999px;flex:none;align-items:center;width:42px;height:24px;transition:background .16s,border-color .16s;display:inline-flex;position:relative}.switch-thumb{background:#fff;border-radius:999px;width:18px;height:18px;transition:transform .16s;position:absolute;left:3px;box-shadow:0 1px 4px #201d1b38}.setting-toggle input:checked+.switch-track{background:#2f7d73;border-color:#2f7d73}.setting-toggle input:checked+.switch-track .switch-thumb{transform:translate(18px)}.setting-toggle input:focus-visible+.switch-track{outline-offset:2px;outline:2px solid #f6b049}.settings-block{border-top:1px solid #e6ebe8;flex-direction:column;gap:9px;margin-top:4px;padding-top:12px;display:flex}.setting-range-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.setting-range-head span{color:#6d6862;font-size:12px;font-weight:900}.setting-range{accent-color:#2f7d73;width:100%}.title-field-list{gap:8px;display:grid}.title-field-row{gap:6px;display:grid}.title-text-field{grid-template-columns:52px minmax(0,1fr)}.title-text-field input{width:100%}.segmented-control{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;display:grid}.segmented-control.is-three{grid-template-columns:repeat(3,minmax(0,1fr))}.segmented-control.is-four{grid-template-columns:repeat(2,minmax(0,1fr))}.segmented-control button{color:#403b37;background:#fbfcfb;border:1px solid #d5dbd8;border-radius:7px;min-height:34px;font-size:12px;font-weight:900}.segmented-control button.is-active{color:#145f56;background:#e4f0ed;border-color:#2f7d73}.range-row,.text-field{color:#5d5853;grid-template-columns:62px minmax(0,1fr);align-items:center;gap:10px;font-size:12px;font-weight:900;display:grid}.range-row input{accent-color:#2f7d73}.stepper-row{color:#5d5853;grid-template-columns:minmax(0,1fr) 38px 42px 38px;align-items:center;gap:8px;font-size:12px;font-weight:900;display:grid}.stepper-row button{color:#145f56;background:#fbfcfb;border:1px solid #d5dbd8;border-radius:7px;min-height:34px;font-size:18px;font-weight:900;line-height:1}.stepper-row button:disabled{cursor:default;opacity:.42}.stepper-row strong{color:#201d1b;text-align:center;font-size:14px}.text-field input{color:#201d1b;border:1px solid #d5dbd8;border-radius:7px;min-width:0;padding:8px 10px;font-size:13px;font-weight:800}.text-area-field{align-items:start}.text-area-field textarea{resize:vertical;color:#201d1b;border:1px solid #d5dbd8;border-radius:7px;min-width:0;min-height:132px;padding:8px 10px;font-size:13px;font-weight:700;line-height:1.4}.property-empty{color:#95a29c;border:1px dashed #cfd8d4;place-items:center;min-height:120px;display:grid}.danger-button{width:100%;margin-top:16px}.panel-actions{gap:8px;margin-top:16px;display:grid}.panel-action-button{width:100%}.panel-actions .danger-button{margin-top:0}.property-footnote{color:#7a746d;margin-top:10px;font-size:11px;font-weight:700}.legend-swatch{color:#262323;height:22px}.pattern-handles{pointer-events:auto}.export-svg{visibility:hidden;width:960px;height:720px;position:fixed;top:0;left:-1200px}@media (max-width:1060px){.editor-shell{grid-template-columns:82px minmax(520px,1fr)}.right-rail{display:none}}@media (max-width:760px){.app-bar{flex-direction:column;align-items:flex-start}.editor-shell{grid-template-columns:1fr}.tool-rail{border-top:1px solid #d8dedb;border-right:0;order:2;grid-template-columns:repeat(5,minmax(0,1fr));display:grid}.tool-button{min-height:56px}.canvas-region{padding:12px}.pattern-svg{min-width:680px}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}
