:root{color:#1c2526;font-synthesis:none;text-rendering:optimizelegibility;background:#eef1ed;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,input,select{font:inherit}button{cursor:pointer}button:disabled,input:disabled{cursor:not-allowed;opacity:.55}.app-shell{grid-template-columns:310px minmax(360px,1fr) 340px;gap:14px;min-height:100vh;padding:14px;display:grid}.panel,.stage-wrap{background:#fbfcf9;border:1px solid #dbe0d7;border-radius:8px}.panel{flex-direction:column;gap:18px;padding:18px;display:flex;overflow:auto}.brand-block{align-items:center;gap:12px;display:flex}.mode-switch{background:#eef2eb;border:1px solid #d8ded5;border-radius:6px;grid-template-columns:1fr 1fr;gap:6px;padding:4px;display:grid}.mode-switch button{color:#52605d;background:0 0;border:0;border-radius:4px;min-height:34px;font-size:.82rem;font-weight:800}.mode-switch button.active{color:#fff;background:#315c55}.mark{color:#f8faf7;background:#315c55;border-radius:8px;place-items:center;width:42px;height:42px;display:grid}h1,h2,p{margin:0}h1{font-size:1.05rem;line-height:1.2}h2{font-size:1rem}p,.meta,small{color:#687371;font-size:.82rem}.control-section{flex-direction:column;gap:10px;display:flex}.section-title{color:#52605d;letter-spacing:0;text-transform:uppercase;font-size:.72rem;font-weight:800}.collapsible-header{color:#52605d;letter-spacing:0;text-align:left;text-transform:uppercase;background:#fff;border:1px solid #d8ded5;border-radius:6px;justify-content:space-between;align-items:center;width:100%;padding:7px 9px;font-size:.72rem;font-weight:800;display:flex}.collapsible-header:hover{background:#f6f8f3;border-color:#b8c4bb}.collapsible-header.open{background:#fff;border-bottom-color:#0000;border-radius:6px 6px 0 0}.collapsible-header svg{color:#315c55}.upload-tile,.action-row,.icon-button,.button-grid button,.scheme-button{color:#22302f;background:#fff;border:1px solid #ccd4cc;border-radius:6px;align-items:center;gap:8px;min-height:40px;padding:9px 11px;display:flex}.upload-tile,.action-row{justify-content:flex-start;position:relative}.upload-tile{border-style:dashed}.upload-tile.drop-active{color:#315c55;background:#e8f0ec;border-color:#315c55;box-shadow:inset 0 0 0 1px #315c55}.upload-tile input,.action-row input{opacity:0;position:absolute;inset:0}.action-row.compact{width:100%}.element-list,.scheme-list,.option-list{flex-direction:column;gap:8px;display:flex}.element-item{text-align:left;background:#fff;border:1px solid #d8ded5;border-radius:6px;grid-template-columns:auto 1fr auto;align-items:center;gap:9px;width:100%;padding:9px;display:grid}.element-item.public{grid-template-columns:1fr}.element-item.selected,.option-button.selected{border-color:#315c55;box-shadow:inset 0 0 0 1px #315c55}.element-type,.element-count{color:#315c55;background:#e8f0ec;border-radius:4px;padding:4px 6px;font-size:.7rem;font-weight:800}.element-summary{flex-direction:column;gap:2px;min-width:0;display:flex}.element-name,.element-summary small{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.element-summary small{color:#687371;font-size:.74rem;font-weight:700}.stage-wrap{flex-direction:column;gap:12px;padding:14px;display:flex;overflow:hidden}.stage-toolbar{justify-content:space-between;align-items:center;gap:12px;display:flex}.toolbar-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.zoom-toolbar{grid-template-columns:34px minmax(100px,160px) 34px 58px;justify-content:end;align-items:center;gap:8px;display:grid}.zoom-toolbar input{accent-color:#315c55;width:100%}.icon-only-button,.zoom-reset{color:#22302f;background:#fff;border:1px solid #ccd4cc;border-radius:6px;place-items:center;height:34px;display:grid}.icon-only-button{width:34px}.zoom-reset{min-width:58px;padding:0 8px;font-size:.78rem;font-weight:800}.icon-button.primary{color:#fff;background:#315c55;border-color:#315c55}.scheme-tray{background:#f6f8f3;border:1px solid #d8ded5;border-radius:8px}.scheme-tray-toggle{color:#315c55;text-transform:uppercase;background:0 0;border:0;justify-content:center;align-items:center;gap:7px;width:100%;min-height:34px;font-size:.78rem;font-weight:800;display:flex}.scheme-card-row{border-top:1px solid #d8ded5;gap:10px;padding:10px;display:flex;overflow:auto hidden}.scheme-card-shell{width:112px;min-width:112px;position:relative}.scheme-card{text-align:left;background:#fff;border:1px solid #d8ded5;border-radius:6px;gap:6px;width:100%;padding:7px;display:grid}.scheme-card-preview{background:#f8faf7;border:1px solid #d8ded5;border-radius:5px;grid-template-columns:repeat(2,1fr);gap:3px;width:96px;height:70px;padding:3px;display:grid;position:relative;overflow:hidden}.scheme-card-preview span{border-radius:3px}.scheme-card-preview strong{z-index:1;color:#fff;text-overflow:ellipsis;white-space:nowrap;background:#1c2526b8;border-radius:4px 4px 0 0;padding:4px 5px;font-size:.72rem;line-height:1.1;position:absolute;inset:0 0 auto;overflow:hidden}.scheme-delete-button{color:#7c2521;background:#fff7f6f0;border:1px solid #e3b8b5;border-radius:5px;place-items:center;width:26px;height:26px;padding:0;display:grid;position:absolute;bottom:5px;right:5px}.scheme-delete-button:hover{background:#fff0ee;border-color:#c96a63}.error-box{color:#7b2e1f;background:#fff2ed;border:1px solid #e2b4a6;border-radius:6px;grid-template-columns:1fr auto;align-items:start;gap:10px;padding:10px 12px;font-size:.88rem;display:grid}.error-box button{color:#7b2e1f;background:#fff;border:1px solid #e2b4a6;border-radius:4px;place-items:center;width:24px;height:24px;line-height:1;display:grid}.hidden-input{display:none}.modal-backdrop{z-index:20;background:#1c252670;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.help-modal{background:#fbfcf9;border:1px solid #d8ded5;border-radius:8px;width:min(560px,100%);box-shadow:0 24px 70px #0000003d}.help-modal-header{border-bottom:1px solid #d8ded5;grid-template-columns:1fr auto;align-items:center;gap:12px;padding:14px 16px;display:grid}.help-modal-header button{color:#22302f;background:#fff;border:1px solid #ccd4cc;border-radius:4px;place-items:center;width:28px;height:28px;display:grid}.help-content{flex-direction:column;gap:11px;padding:16px;display:flex}.help-content p{color:#35413f;font-size:.92rem;line-height:1.45}.canvas-frame{background-color:#f6f8f3;background-image:linear-gradient(45deg,#dfe4dc 25%,#0000 25%),linear-gradient(-45deg,#dfe4dc 25%,#0000 25%),linear-gradient(45deg,#0000 75%,#dfe4dc 75%),linear-gradient(-45deg,#0000 75%,#dfe4dc 75%);background-position:0 0,0 10px,10px -10px,-10px 0;background-repeat:repeat,repeat,repeat,repeat;background-size:20px 20px;background-attachment:scroll,scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box,border-box;border:1px solid #dbe0d7;border-radius:8px;place-items:center;min-height:320px;max-height:calc(100vh - 118px);display:grid;position:relative;overflow:auto}.canvas-frame.drop-active{border-color:#315c55;box-shadow:inset 0 0 0 2px #315c55}.canvas-frame.is-pannable{cursor:grab;-webkit-user-select:none;user-select:none;place-items:start}.canvas-frame.is-pannable:active{cursor:grabbing}.stage-drop-overlay{color:#315c55;text-align:center;pointer-events:none;background:#e8f0ecdb;border:2px dashed #315c55;border-radius:8px;place-items:center;font-weight:800;display:grid;position:absolute;inset:14px}.canvas-zoom-surface{place-items:center;min-width:100%;min-height:100%;display:grid}canvas{object-fit:contain;width:100%;height:100%}.empty-stage,.empty-controls{color:#687371;text-align:center;place-items:center;gap:8px;display:grid}.viewport-upload{color:#315c55;text-align:center;background:#ffffffc7;border:2px dashed #a9b7ad;border-radius:8px;place-items:center;gap:8px;min-width:min(320px,100% - 40px);min-height:130px;padding:24px;display:grid}.viewport-upload span{font-size:1rem;font-weight:800}.viewport-upload small{color:#687371}.empty-controls{align-content:center;min-height:280px}.controls-stack{flex-direction:column;gap:18px;display:flex}.text-input,select{background:#fff;border:1px solid #cbd3ca;border-radius:6px;width:100%;min-height:38px;padding:8px 10px}.button-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.button-grid.one-column{grid-template-columns:1fr}.button-grid button{justify-content:center;min-width:0}.button-grid .danger{color:#7c2521;background:#fff7f6;border-color:#e0b6b3}.selected-element-row{grid-template-columns:1fr 38px;align-items:center;gap:8px;display:grid}.selected-element-row .text-input,.selected-element-row .selected-public-element{min-height:38px}.visibility-icon-button{color:#315c55;background:#fff;border:1px solid #ccd4cc;border-radius:6px;place-items:center;width:38px;height:38px;padding:0;display:grid}.builder-element-actions{grid-template-columns:1fr 1fr 1fr;gap:7px;display:grid}.builder-element-actions button{color:#22302f;background:#fff;border:1px solid #ccd4cc;border-radius:6px;justify-content:center;align-items:center;gap:5px;min-width:0;min-height:32px;padding:6px;font-size:.78rem;display:flex}.builder-element-actions .danger{color:#7c2521;background:#fff7f6;border-color:#e0b6b3}.public-project-card,.selected-public-element{background:#fff;border:1px solid #d8ded5;border-radius:6px;flex-direction:column;gap:4px;padding:8px 10px;display:flex}.public-project-card strong,.selected-public-element{color:#22302f;font-weight:800}.public-project-card span{color:#687371;font-size:.86rem}.color-row{grid-template-columns:46px 1fr;gap:8px;display:grid}.toggle-row{color:#52605d;align-items:center;gap:8px;font-size:.86rem;font-weight:700;display:flex}.toggle-row input{accent-color:#315c55;width:16px;height:16px}.current-color-preview{cursor:pointer;background:#fff;border:1px solid #d8ded5;border-radius:6px;grid-template-columns:34px 1fr;align-items:center;gap:9px;padding:7px;display:grid;position:relative}.color-preview-row{grid-template-columns:minmax(0,1fr) auto;align-items:stretch;gap:8px;display:grid}.save-color-button{color:#22302f;white-space:nowrap;background:#fff;border:1px solid #ccd4cc;border-radius:6px;justify-content:center;align-items:center;gap:7px;min-height:40px;padding:8px 10px;display:flex}.current-color-preview span{border:1px solid #00000029;border-radius:4px;width:34px;height:24px}.color-preview-picker input[type=color]{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;inset:0}.swatch-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.library-panel,.nested-panel{background:#eef2eb;border:1px solid #d8ded5;border-top:0;border-radius:0 0 6px 6px;flex-direction:column;gap:10px;margin-top:-10px;padding:12px 10px 10px;display:flex}.nested-panel .range-control,.nested-panel .field-label{gap:4px}.nested-panel .range-control{grid-template-columns:74px minmax(90px,1fr) 48px;grid-template-areas:"label slider number";align-items:center;column-gap:8px;font-size:.8rem;display:grid}.nested-panel .range-control input[type=range]{grid-area:slider;height:14px}.nested-panel .range-control span{display:contents}.nested-panel .range-control span strong{color:#52605d;grid-area:label;font-weight:800}.nested-panel .range-control .number-input{grid-area:number}.nested-panel .hue-control{flex-direction:column;gap:5px;font-size:.8rem;display:flex}.nested-panel .hue-control .hue-row{grid-template-columns:minmax(0,1fr) 48px;align-items:center;gap:8px;width:100%;display:grid}.nested-panel .hue-control .hue-row strong{color:#52605d;grid-column:1;justify-self:start;font-weight:800}.nested-panel .hue-control .hue-row .number-input{grid-area:1/2;justify-self:stretch}.nested-panel .hue-control input[type=range]{width:100%;height:14px}.library-swatch-list{gap:7px;max-height:335px;padding-right:2px;display:grid;overflow:auto}.library-swatch{text-align:left;background:#fff;border:1px solid #d8ded5;border-radius:6px;grid-template-rows:auto auto;grid-template-columns:28px 1fr;align-items:center;column-gap:8px;min-width:0;padding:7px;display:grid}.library-swatch span{border:1px solid #00000029;border-radius:4px;grid-row:1/3;width:28px;height:28px}.library-swatch strong,.library-swatch small{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.library-swatch strong{color:#22302f;font-size:.82rem}.swatch{text-align:left;background:#fff;border:1px solid #d8ded5;border-radius:6px;grid-template-columns:24px 1fr;align-items:center;gap:8px;min-width:0;padding:7px;display:grid}.swatch span{border:1px solid #00000029;border-radius:4px;width:24px;height:24px}.swatch small{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.range-control,.field-label{color:#52605d;flex-direction:column;gap:6px;font-size:.84rem;font-weight:700;display:flex}.range-control span{justify-content:space-between;display:flex}.range-control input{width:100%}.range-control .number-input{color:#1c2526;text-align:center;appearance:textfield;background:#fff;border:1px solid #cbd3ca;border-radius:6px;width:48px;min-height:26px;padding:4px 6px}.range-control .number-input::-webkit-outer-spin-button{appearance:none;margin:0}.range-control .number-input::-webkit-inner-spin-button{appearance:none;margin:0}.hue-control input{accent-color:#315c55}.hue-guide{background:linear-gradient(90deg,red,#ff0,#00d600,#00d6d6,#2929ff,#f0f,red);border:1px solid #cbd3ca;border-radius:6px;width:100%;height:12px;display:block}.option-button{text-align:left;background:#fff;border:1px solid #d8ded5;border-radius:6px;grid-template-columns:1fr 30px 30px;align-items:center;gap:10px;padding:6px;display:grid}.option-button.no-delete{grid-template-columns:1fr 30px}.option-select{text-align:left;background:0 0;border:0;grid-template-columns:58px 1fr;align-items:center;gap:10px;min-width:0;padding:0;display:grid}.option-select img{object-fit:cover;border:1px solid #d8ded5;border-radius:4px;width:58px;height:42px}.option-select span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.option-edit,.option-delete{color:#7c2521;background:#fff7f6;border:1px solid #e0b6b3;border-radius:4px;place-items:center;width:30px;height:30px;padding:0;display:grid}.option-edit{color:#315c55;background:#fff;border-color:#ccd4cc}.empty-text{padding:10px 0}.admin-shell{background:#eef1ed;flex-direction:column;gap:14px;min-height:100vh;padding:18px;display:flex}.login-shell{justify-content:center;align-items:center}.login-panel,.admin-header,.project-table{background:#fbfcf9;border:1px solid #dbe0d7;border-radius:8px}.login-panel{flex-direction:column;gap:22px;width:min(420px,100%);padding:22px;display:flex}.login-form{flex-direction:column;gap:12px;display:flex}.login-error{color:#7c2521}.admin-header{justify-content:space-between;align-items:center;gap:12px;padding:16px;display:flex}.admin-actions,.project-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.project-table{flex-direction:column;display:flex;overflow:hidden}.project-row{border-bottom:1px solid #dbe0d7;grid-template-columns:76px minmax(180px,1fr) auto auto auto;align-items:center;gap:12px;padding:12px;display:grid}.project-row:last-child{border-bottom:0}.project-thumb{color:#687371;background:#eef2eb;border:1px solid #d8ded5;border-radius:6px;place-items:center;width:76px;height:52px;display:grid;overflow:hidden}.project-thumb img{object-fit:cover;width:100%;height:100%}.project-main{flex-direction:column;gap:4px;min-width:0;display:flex}.project-main strong,.project-main span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.project-main span{color:#52605d;font-size:.82rem}.status-pill{color:#315c55;text-transform:uppercase;background:#e8f0ec;border-radius:999px;padding:5px 9px;font-size:.72rem;font-weight:800}.status-pill.draft{color:#7b2e1f;background:#fff2ed}.empty-dashboard{text-align:center;place-items:center;gap:10px;min-height:320px;padding:28px;display:grid}.empty-dashboard p{max-width:430px}@media (width<=1120px){.app-shell{grid-template-columns:280px minmax(360px,1fr)}.right-panel{grid-column:1/-1}}@media (width<=760px){.app-shell{grid-template-columns:1fr;padding:10px}.admin-header,.project-row{grid-template-columns:1fr;align-items:stretch}.admin-header{flex-direction:column}.project-thumb{width:100%;height:140px}.stage-toolbar{flex-direction:column;align-items:stretch}.toolbar-actions{justify-content:stretch}.zoom-toolbar{grid-template-columns:34px 1fr 34px 58px;justify-content:stretch}.icon-button{flex:1;justify-content:center}}
