*{box-sizing:border-box}html,body,#root{background:#f5f6f8;width:100%;height:100%;margin:0;padding:0;font-family:Arial,sans-serif}.app-shell{flex-direction:column;width:100%;height:100vh;transition:filter .16s,transform .16s;display:flex;overflow:hidden}.app-shell-blurred{filter:blur(7px);pointer-events:none;-webkit-user-select:none;user-select:none;transform:scale(1.01)}.library-shell{color:#172026;background:#eef2f5;flex-direction:column;min-height:100vh;display:flex}.library-header{background:#fff;border-bottom:1px solid #d9e0e6;justify-content:space-between;align-items:center;gap:clamp(.75rem,2vw,1.75rem);min-height:clamp(4rem,8svh,5.5rem);padding-block:clamp(.75rem,2svh,1.25rem);padding-inline:clamp(1rem,2.4vw,2rem);display:flex}.library-header-actions{align-items:center;gap:clamp(.5rem,1.2vw,1rem);display:flex}.library-new-button{color:#fff;background:#2f6f61;border:1px solid #1f5f52;border-radius:6px;min-height:36px;padding:8px 14px;font-size:14px;font-weight:700}.library-new-button:hover{background:#275c51}.library-secondary-button{color:#374151;background:#fff;border:1px solid #cfd6dd;border-radius:6px;min-height:36px;padding:8px 14px;font-size:14px;font-weight:700}.library-secondary-button:hover{color:#2d6cdf;border-color:#2d6cdf}.library-user-menu-wrap{width:56px;height:66px;position:relative}.library-user-avatar-button{color:#172026;background:0 0;border:0;width:56px;height:66px;padding:0;position:relative}.library-user-avatar{z-index:2;color:#fff;background:linear-gradient(145deg,#2f6f61,#1f4f45);border:2px solid #fff;border-radius:50%;place-items:center;width:56px;height:56px;font-size:22px;font-weight:800;display:grid;position:absolute;top:0;left:0;overflow:hidden;box-shadow:0 8px 18px #0f172a2e}.library-user-avatar img,.library-profile-avatar img{object-fit:cover;width:100%;height:100%;display:block}.library-user-name-tab{z-index:3;color:#374151;text-align:center;text-overflow:ellipsis;white-space:nowrap;background:#fff;border:1px solid #cfd6dd;border-radius:3px;width:max-content;min-width:66px;max-width:128px;height:19px;padding:2px 9px 0;font-size:10px;font-weight:700;line-height:15px;display:block;position:absolute;bottom:8px;left:50%;overflow:hidden;transform:translate(-50%)}.library-user-avatar-button:hover .library-user-avatar,.library-user-avatar-button[aria-expanded=true] .library-user-avatar{box-shadow:0 10px 22px #0f172a3d}.library-user-menu{z-index:20;background:#fff;border:1px solid #d7dee5;border-radius:8px;flex-direction:column;gap:10px;width:220px;padding:12px;display:flex;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 16px 42px #0f172a29}.library-user-menu-account{border-bottom:1px solid #edf1f5;flex-direction:column;min-width:0;padding-bottom:10px;display:flex}.library-user-menu-account strong,.library-user-menu-account span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.library-user-menu-account strong{color:#172026;font-size:14px}.library-user-menu .language-select{justify-content:space-between}.library-user-menu .language-select select{min-width:108px}.library-user-menu-action,.library-user-menu-logout{color:#374151;text-align:left;background:#fff;border:1px solid #cfd6dd;border-radius:6px;width:100%;min-height:34px;font-size:13px;font-weight:700}.library-user-menu-action:hover,.library-user-menu-logout:hover{color:#2d6cdf;border-color:#2d6cdf}.auth-shell{color:#172026;background:#eef2f5;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-panel{background:#fff;border:1px solid #d7dee5;border-radius:8px;width:min(420px,100%);padding:24px;box-shadow:0 18px 50px #1118271f}.auth-copy{margin-bottom:20px}.auth-top-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.auth-copy p,.auth-copy h1{margin:0}.auth-copy p{color:#2f6f61;font-size:12px;font-weight:700}.auth-copy h1{margin-top:5px;font-size:24px;line-height:1.15}.auth-tabs{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:18px;display:grid}.auth-tabs button{color:#374151;background:#fff;border:1px solid #cfd6dd;border-radius:6px;min-height:36px;font-size:13px;font-weight:700}.auth-tabs button.active{color:#1f4fb3;border-color:#2d6cdf;outline:none;box-shadow:inset 0 0 0 1px #2d6cdf}.auth-form{flex-direction:column;gap:12px;display:flex}.auth-form label{color:#374151;flex-direction:column;gap:6px;font-size:13px;display:flex}.auth-form input{color:#172026;border:1px solid #cfd6dd;border-radius:6px;height:40px;padding:8px 10px;font-size:14px}.auth-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;padding:9px 10px;font-size:13px;line-height:1.35}.auth-submit{color:#fff;background:#2f6f61;border:1px solid #1f5f52;border-radius:6px;min-height:42px;margin-top:4px;font-size:14px;font-weight:700}.auth-submit:disabled{cursor:not-allowed;opacity:.65}.auth-loading{color:#5f6b76;font-size:14px}.library-header p,.library-header h1{margin:0}.library-header p{color:#2f6f61;font-size:12px;font-weight:700}.library-header h1{margin-top:4px;font-size:clamp(1.25rem,2vw,1.5rem);line-height:1.15}.library-main{width:min(1440px,100%);margin:0 auto;padding:24px}.library-projects-panel{background:#fff;border:1px solid #d7dee5;border-radius:8px;min-width:0;padding:18px}.library-modal-overlay{z-index:100;background:#1f293757;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.library-create-modal{background:#fff;border:1px solid #11182729;border-radius:8px;width:min(540px,100%);max-height:calc(100vh - 48px);padding:20px;position:relative;overflow-y:auto;box-shadow:0 18px 50px #1118273d}.library-download-modal{background:#fff;border:1px solid #11182729;border-radius:8px;width:min(460px,100%);max-height:calc(100vh - 48px);padding:20px;position:relative;overflow-y:auto;box-shadow:0 18px 50px #1118273d}.library-profile-modal{background:#fff;border:1px solid #11182729;border-radius:8px;width:min(480px,100%);max-height:calc(100vh - 48px);padding:20px;position:relative;overflow-y:auto;box-shadow:0 18px 50px #1118273d}.library-modal-top{grid-template-columns:minmax(0,1fr) 32px;gap:12px;display:grid}.library-modal-close{color:#5f6b76;background:#fff;border:1px solid #cfd6dd;border-radius:6px;width:32px;height:32px;font-size:20px;line-height:1}.library-export-options{grid-template-columns:1fr;gap:10px;display:grid}.library-export-options button{color:#172026;text-align:left;background:#fff;border:1px solid #d7dee5;border-radius:8px;flex-direction:column;gap:4px;min-width:0;padding:14px;display:flex}.library-export-options button:hover{border-color:#2d6cdf;box-shadow:0 6px 18px #0f172a14}.library-export-options strong{font-size:15px;line-height:1.2}.library-export-options span{color:#5f6b76;font-size:12px;line-height:1.35}.library-section-heading{justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:18px;display:flex}.library-section-heading>div{min-width:0}.library-section-heading h2{margin:0;font-size:18px;line-height:1.2}.library-section-heading span{color:#6b7280;font-size:12px;line-height:1.4}.library-view-tabs{flex:none;gap:8px;display:flex}.library-view-tabs button{color:#374151;background:#fff;border:1px solid #cfd6dd;border-radius:6px;min-height:32px;padding:6px 10px;font-size:13px}.library-view-tabs button.active{color:#1f4fb3;border-color:#2d6cdf;outline:none;box-shadow:inset 0 0 0 1px #2d6cdf}.library-hub-message{color:#5f6b76;background:#f8fafc;border:1px solid #d7dee5;border-radius:6px;margin:-6px 0 12px;padding:8px 10px;font-size:13px}.library-field{color:#374151;flex-direction:column;gap:8px;margin-top:16px;font-size:13px;display:flex}.library-field input{color:#172026;background:#fff;border:1px solid #cfd6dd;border-radius:6px;width:100%;height:38px;padding:8px 10px;font-size:14px}.library-field textarea{resize:vertical;color:#172026;width:100%;min-height:112px;font:inherit;background:#fff;border:1px solid #cfd6dd;border-radius:6px;padding:9px 10px;font-size:14px;line-height:1.4}.library-field textarea:focus,.library-field input:focus{border-color:#2d6cdf;outline:none;box-shadow:0 0 0 2px #2d6cdf1f}.library-profile-form{flex-direction:column;gap:16px;margin-top:16px;display:flex}.library-profile-avatar-input{color:#5f6b76;cursor:pointer;align-items:center;gap:14px;font-size:13px;font-weight:700;display:flex}.library-profile-avatar-input input{clip:rect(0 0 0 0);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}.library-profile-avatar{color:#fff;background:linear-gradient(145deg,#2f6f61,#1f4f45);border:2px solid #fff;border-radius:50%;flex:0 0 76px;place-items:center;width:76px;height:76px;font-size:28px;font-weight:800;display:grid;overflow:hidden;box-shadow:0 10px 24px #0f172a2e}.library-profile-avatar-input:hover .library-profile-avatar{box-shadow:0 12px 28px #0f172a3d}.library-profile-actions{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.library-profile-save-button{color:#fff;background:#2f6f61;border:1px solid #1f5f52;border-radius:6px;min-height:36px;padding:8px 16px;font-size:14px;font-weight:700}.library-profile-save-button:hover:not(:disabled){background:#275c51}.library-profile-save-button:disabled,.library-secondary-button:disabled{cursor:not-allowed;opacity:.55}.library-size-options{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.library-choice-button,.library-layout-option{color:#172026;background:#fff;border:1px solid #cfd6dd;border-radius:6px}.library-choice-button{min-height:40px;font-size:14px;font-weight:700}.library-choice-button.active,.library-layout-option.active{border-color:#2d6cdf;box-shadow:inset 0 0 0 1px #2d6cdf}.library-layout-inputs,.library-layout-options{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.library-layout-inputs label{color:#5f6b76;flex-direction:column;gap:6px;min-width:0;font-size:12px;display:flex}.library-layout-inputs input{width:100%}.library-layout-preview{background:#f8fafc;border:1px solid #d7dee5;border-radius:8px;justify-content:space-between;align-items:center;gap:16px;min-height:92px;padding:12px;display:flex}.library-layout-preview>div{flex-direction:column;gap:4px;min-width:0;display:flex}.library-layout-preview strong{color:#172026;font-size:16px;line-height:1.2}.library-layout-preview span{color:#5f6b76;font-size:12px;line-height:1.3}.library-layout-preview-frame{justify-content:center;align-items:center;min-width:154px;min-height:72px;display:flex}.library-layout-preview-grid{display:grid}.library-layout-preview-cell{background-color:#fff;background-image:linear-gradient(90deg,#2d6cdf2e 1px,#0000 1px),linear-gradient(#2f6f612e 1px,#0000 1px),none;background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:7px 7px;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;border:1px solid #5f6b76;width:18px;height:18px}.library-layout-option{text-align:left;align-items:center;gap:10px;min-height:80px;padding:10px;display:flex}.library-layout-icon-frame{flex:0 0 46px;justify-content:center;align-items:center;width:46px;height:46px;display:flex}.library-layout-icon{display:grid}.library-layout-icon-cell{background-color:#fff;background-image:linear-gradient(90deg,#2d6cdf2e 1px,#0000 1px),linear-gradient(#2f6f612e 1px,#0000 1px),none;background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:7px 7px;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;border:1px solid #5f6b76;width:18px;height:18px}.library-layout-option span{flex-direction:column;gap:3px;min-width:0;display:flex}.library-layout-option strong{font-size:14px;line-height:1.2}.library-layout-option small{color:#6b7280;font-size:12px;line-height:1.25}.library-create-button{color:#fff;background:#2f6f61;border:1px solid #1f5f52;border-radius:6px;width:100%;min-height:42px;margin-top:18px;font-size:14px;font-weight:700}.library-create-button:hover{background:#275c51}.library-empty{color:#6b7280;border:1px dashed #cfd6dd;border-radius:8px;justify-content:center;align-items:center;min-height:220px;font-size:14px;display:flex}.library-project-grid{grid-template-columns:repeat(auto-fill,316px);justify-content:start;gap:10px;display:grid}.library-project-card{background:#fff;border:1px solid #d7dee5;border-radius:8px;justify-self:start;width:min(316px,100%);min-width:0;display:block;position:relative}.library-project-open{color:#172026;text-align:left;background:0 0;border:0;border-radius:8px;grid-template-columns:112px minmax(0,1fr);gap:10px;width:100%;padding:8px 84px 8px 8px;display:grid}.library-project-card:hover{border-color:#2d6cdf;box-shadow:0 8px 22px #0f172a14}.library-project-delete,.library-project-download,.library-project-publish{z-index:2;color:#6b7280;background:#fffffff0;border:1px solid #d7dee5;border-radius:999px;justify-content:center;align-items:center;width:22px;height:22px;padding:0;font-size:16px;line-height:1;display:flex;position:absolute;top:6px}.library-project-delete{right:6px}.library-project-download{font-size:14px;right:32px}.library-project-publish{font-size:14px;right:58px}.library-project-delete:hover{color:#dc2626;border-color:#dc2626}.library-project-download:hover{color:#2d6cdf;border-color:#2d6cdf}.library-project-publish:hover{color:#2f6f61;border-color:#2f6f61}.creator-hub-card{color:#172026;background:#fff;border:1px solid #d7dee5;border-radius:8px;grid-template-columns:112px minmax(0,1fr);justify-self:start;gap:10px;width:min(316px,100%);min-width:0;padding:8px;display:grid}.creator-hub-card-preview{color:#5f6b76;background-color:#f8fafc;background-image:linear-gradient(90deg,#2d6cdf24 1px,#0000 1px),linear-gradient(#2f6f6124 1px,#0000 1px),none;background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:10px 10px;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;border:1px solid #e0e6ec;border-radius:6px;justify-content:center;align-items:center;width:112px;height:76px;font-size:12px;font-weight:700;display:flex}.creator-hub-card-info{flex-direction:column;justify-content:center;gap:3px;min-width:0;display:flex}.creator-hub-card-info strong{text-overflow:ellipsis;white-space:nowrap;font-size:14px;line-height:1.2;overflow:hidden}.creator-hub-card-info span{color:#5f6b76;font-size:11px;line-height:1.25}.library-project-thumbnail{background:#f8fafc;border:1px solid #e0e6ec;border-radius:6px;justify-content:center;align-items:center;width:112px;height:76px;display:flex;overflow:hidden}.library-project-thumbnail img{object-fit:cover;width:100%;height:100%;display:block}.library-project-info{flex-direction:column;justify-content:center;gap:3px;min-width:0;display:flex}.library-project-info strong{text-overflow:ellipsis;white-space:nowrap;font-size:14px;line-height:1.2;overflow:hidden}.library-project-info span{color:#5f6b76;font-size:11px;line-height:1.25}.topbar{z-index:10;background:#fff;border-bottom:1px solid #ddd;flex:0 0 clamp(3rem,6svh,4rem);justify-content:space-between;align-items:center;gap:clamp(.5rem,1.2vw,1rem);min-height:clamp(3rem,6svh,4rem);padding-inline:clamp(.625rem,1.4vw,1.125rem);display:flex;position:relative}.topbar-title{min-width:0;font-size:clamp(.875rem,1.1vw,1rem)}.topbar-controls{color:#374151;align-items:center;gap:clamp(.375rem,.8vw,.625rem);min-width:0;font-size:clamp(.75rem,.95vw,.875rem);display:flex}.topbar-project-name{color:#172026;background:#fff;border:1px solid #cfd6dd;border-radius:6px;width:clamp(7.5rem,12vw,13rem);height:clamp(1.75rem,3.5svh,2.25rem);padding:clamp(.25rem,.6svh,.375rem) clamp(.5rem,.8vw,.75rem);font-size:clamp(.75rem,.95vw,.875rem)}.language-select{color:#5f6b76;align-items:center;gap:6px;font-size:12px;line-height:1.2;display:inline-flex}.language-select select{color:#374151;background:#fff;border:1px solid #cfd6dd;border-radius:6px;height:28px;padding:2px 6px;font-size:12px}.language-select.compact{opacity:.76}.language-select.compact:hover,.language-select.compact:focus-within{opacity:1}.app-body{flex:1;min-height:0;display:flex;overflow:hidden}.sidebar{background:#fff;border-right:1px solid #ddd;flex:0 0 270px;width:270px;padding:16px;overflow:hidden auto}.workspace{flex:1;justify-content:stretch;align-items:stretch;min-width:0;min-height:0;padding:0;display:flex;overflow:hidden}.panel{margin-bottom:20px}.tool-buttons{grid-template-columns:repeat(2,40px);gap:8px;display:grid}.tool-icon-button{color:#374151;background:#fff;border:1px solid #cfd6dd;border-radius:6px;justify-content:center;align-items:center;width:40px;height:40px;padding:0;display:inline-flex}.tool-icon-button:disabled{opacity:.45;cursor:not-allowed}.tool-icon-button svg{fill:none;stroke:currentColor;stroke-width:1.7px;stroke-linecap:round;stroke-linejoin:round;width:22px;height:22px}.cell-edit-mode-control{color:#374151;flex-direction:column;gap:6px;margin-top:10px;font-size:13px;display:flex}.cell-edit-mode-buttons{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.cell-edit-mode-button{color:#374151;background:#fff;border:1px solid #cfd6dd;border-radius:6px;justify-content:center;align-items:center;gap:6px;min-width:0;height:34px;padding:0 8px;font-size:12px;font-weight:700;display:inline-flex}.cell-edit-mode-button.active{color:#1f4fb3;border-color:#2d6cdf;box-shadow:inset 0 0 0 1px #2d6cdf}.cell-edit-mode-button svg{fill:none;stroke:currentColor;stroke-width:1.8px;stroke-linecap:round;stroke-linejoin:round;flex:none;width:16px;height:16px}.sidebar-checkbox{color:#374151;grid-template-columns:16px 1fr;align-items:start;gap:3px 8px;margin-top:10px;font-size:13px;display:grid}.sidebar-checkbox input{margin:2px 0 0}.sidebar-checkbox small{color:#6b7280;grid-column:2;font-size:11px;line-height:1.3}button{cursor:pointer}button.active{outline:2px solid #2d6cdf}.palette-group-list{flex-direction:column;gap:8px;display:flex}.palette-group-block{justify-content:center;display:flex}.color-suggestion-popover-mini{z-index:50;background:#ffffffeb;border:1px solid #00000014;border-radius:999px;align-items:center;gap:8px;padding:8px 10px;display:flex;position:fixed;box-shadow:0 8px 20px #00000024}.color-suggestion-dot{cursor:pointer;border:2px solid #fff;border-radius:50%;width:26px;height:26px;padding:0;box-shadow:0 0 0 1px #0000002e}.color-suggestion-dot:hover{transform:scale(1.08)}.palette-grid{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}.palette-item{background:#fff;border:1px solid #ccc;align-items:center;gap:8px;padding:8px;display:flex}.swatch{border:1px solid #0003;width:20px;height:20px;display:inline-block}.canvas-wrap{box-sizing:border-box;background:#e8edf1;justify-content:center;align-items:flex-start;width:100%;height:100%;padding:10px;display:flex;position:relative;overflow:auto}.canvas-wrap canvas{box-sizing:border-box;background:#fff;border:1px solid #cfd6dd;flex:none;width:100%;height:100%;display:block;box-shadow:0 4px 12px #00000014}.canvas-action-toolbar{z-index:5;gap:8px;display:flex;position:absolute;top:16px;left:50%;transform:translate(-50%)}.canvas-action-button{color:#374151;background:#fffffff0;border:1px solid #cfd6dd;border-radius:6px;justify-content:center;align-items:center;width:36px;height:36px;padding:0;display:inline-flex;box-shadow:0 4px 12px #0f172a1f}.canvas-action-button:disabled{cursor:not-allowed;opacity:.45}.canvas-action-button.active{color:#1f4fb3;border-color:#2d6cdf;box-shadow:inset 0 0 0 1px #2d6cdf,0 4px 12px #0f172a1f}.canvas-action-button svg{fill:none;stroke:currentColor;stroke-width:1.7px;stroke-linecap:round;stroke-linejoin:round;width:22px;height:22px}.canvas-empty{color:#666}.palette-dock{--palette-resting-height:clamp(3.25rem, 7svh, 4.5rem);z-index:24;height:clamp(14rem,30svh,20rem);transform:translateY(calc(100% - var(--palette-resting-height)));pointer-events:auto;transition:transform .18s;position:absolute;bottom:0;left:0;right:0}.palette-dock:hover,.palette-dock:focus-within{transform:translateY(0)}.palette-dock-stage{height:100%;box-shadow:none;background:0 0;border:0;position:relative;overflow:hidden}.palette-group-grid{grid-template-columns:repeat(9,minmax(0,1fr));align-items:end;gap:1px;display:grid;position:absolute;bottom:0;left:0;right:0}.palette-group-panel{min-width:0;height:var(--palette-resting-height);box-shadow:none;contain:layout paint style;will-change:height, opacity;background:0 0;border:0;border-radius:0;flex-direction:column;transition:height .12s ease-out,opacity .12s ease-out;display:flex;position:relative;overflow:visible}.palette-group-panel.active{opacity:1;height:clamp(12rem,28svh,18rem);box-shadow:none}.palette-group-panel.dimmed{opacity:.52}.palette-group-colors{flex:1;grid-template-columns:repeat(auto-fill,minmax(1.25rem,1fr));grid-auto-rows:1.25rem;gap:0;min-height:0;padding:.25rem;display:grid;overflow:hidden}.palette-group-panel.active .palette-group-colors{overflow-y:auto}.palette-color-square{aspect-ratio:1;background-clip:content-box;border:0;border-radius:4px;justify-content:center;align-items:center;min-width:0;padding:.15625rem;transition:filter 90ms,transform 90ms;display:flex;box-shadow:inset 0 2px #ffffff80,inset 2px 0 #ffffff3d,inset 0 -5px #00000052,inset -2px 0 #0000002e,0 1px 1px #0f172a2e}.palette-color-square:focus{outline:none}.palette-color-square:hover,.palette-color-square:focus-visible{filter:saturate(1.04)brightness(1.03);transform:translateY(-1px);box-shadow:inset 0 2px #ffffff8f,inset 2px 0 #ffffff47,inset 0 -5px #0000004d,inset -2px 0 #0003,0 2px 2px #0f172a33}.palette-color-square.active{filter:brightness(.94)saturate(.96);outline:none;transform:translateY(1px)scale(.96);box-shadow:inset 0 4px #00000057,inset 2px 0 #0003,inset 0 -2px #ffffff38,inset -2px 0 #ffffff1f}.palette-color-square.transparent{background-color:#0000;background-image:linear-gradient(45deg,#cfd6dd 25%,#0000 25%),linear-gradient(-45deg,#cfd6dd 25%,#0000 25%),linear-gradient(45deg,#0000 75%,#cfd6dd 75%),linear-gradient(-45deg,#0000 75%,#cfd6dd 75%);background-position:0 0,0 .375rem,.375rem -.375rem,-.375rem 0;background-size:.75rem .75rem;background-clip:content-box}.palette-color-square span{pointer-events:none;font-size:.5rem;font-weight:900;line-height:1}.palette-color-tooltip{z-index:80;color:#172026;white-space:nowrap;pointer-events:none;background:#fffffff5;border:1px solid #1118271f;border-radius:6px;padding:.375rem .5625rem;font-size:.75rem;font-weight:800;line-height:1;position:absolute;transform:translate(-50%,calc(-100% - .375rem));box-shadow:0 8px 20px #0f172a24}.palette-current{background:#fafafa;border:1px solid #d9d9d9;align-items:center;gap:10px;margin-bottom:12px;padding:8px;display:flex}.palette-current-swatch{border:1px solid #00000040;flex:0 0 28px;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.palette-current-swatch-label{font-size:10px;font-weight:700;line-height:1}.palette-current-meta{min-width:0;font-size:13px;line-height:1.2}.palette-scroll-area{background:#fff;border:1px solid #d9d9d9;height:340px;padding:0;overflow:hidden auto}.palette-mini-grid{grid-template-columns:repeat(8,26px);justify-content:center;gap:0;display:grid}.palette-mini-cell{cursor:pointer;border:0;justify-content:center;align-items:center;width:28px;height:28px;margin:0;padding:0;display:flex;position:relative;box-shadow:inset 0 0 0 1px #0000001f}.palette-mini-cell-label{pointer-events:none;font-size:9px;font-weight:700;line-height:1}.palette-mini-cell.active{outline:none;box-shadow:inset 2px 2px 4px #0000004d,inset -1px -1px 2px #ffffff6b}.palette-current-title{margin-bottom:2px;font-size:13px;font-weight:600;line-height:1.2}.palette-current-sub{color:#666;font-size:12px;line-height:1.2}.workspace-inner{width:100%;min-width:0;height:100%;min-height:0;position:relative}.color-stats-panel{background:#fff;border:1px solid #d9d9d9;min-width:220px;padding:12px;display:block;box-shadow:0 4px 12px #00000014}.collapsible-panel{width:260px}.collapsible-panel-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.collapsible-panel-header h3{margin:0;font-size:16px}.collapsible-panel-header button{background:#fff;border:1px solid #bbb;border-radius:4px;flex:none;min-width:48px;height:28px;font-size:13px}.color-stats-empty{color:#666;margin-top:10px;font-size:13px}.color-stats-list{flex-direction:column;gap:6px;margin-top:10px;display:flex}.color-stats-row{justify-content:space-between;gap:16px;font-size:14px;display:flex}.color-stats-code{font-weight:600}.color-stats-count{color:#333}.auto-color-panel{background:#fff;border:1px solid #d9d9d9;padding:12px;display:block;box-shadow:0 4px 12px #00000014}.auto-color-form{flex-direction:column;gap:10px;margin-top:10px;display:flex}.auto-color-field{flex-direction:column;gap:4px;font-size:13px;display:flex}.auto-color-field input,.auto-color-field select{background:#fff;border:1px solid #ccc;height:32px;padding:4px 8px}.auto-color-static{background:#f8f8f8;border:1px solid #ddd;align-items:center;min-height:32px;padding:4px 8px;display:flex}.auto-color-run{cursor:pointer;background:#fff;border:1px solid #bbb;height:36px}.auto-color-run:disabled{cursor:not-allowed;opacity:.6}.auto-color-result{color:#555;font-size:13px}.reference-upload{cursor:pointer;align-items:center;gap:8px;min-width:0;display:flex}.reference-upload-input{clip:rect(0 0 0 0);white-space:nowrap;clip-path:inset(50%);width:1px;height:1px;position:absolute;overflow:hidden}.reference-upload-button{color:#172026;background:#fff;border:1px solid #bbb;border-radius:6px;flex:none;justify-content:center;align-items:center;min-height:32px;padding:6px 10px;font-size:13px;display:inline-flex}.reference-upload:focus-within .reference-upload-button,.reference-upload:hover .reference-upload-button{border-color:#2d6cdf}.reference-upload-name{color:#5f6b76;text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:12px;line-height:1.2;overflow:hidden}.reference-image-panel{background:#fff;border:1px solid #d9d9d9;padding:12px;display:block;box-shadow:0 4px 12px #00000014}.reference-image-form{flex-direction:column;gap:10px;margin-top:10px;display:flex}.reference-image-form button,.reference-image-tool{color:#172026;background:#fff;border:1px solid #bbb;border-radius:6px;min-height:32px}.reference-image-tool{justify-content:center;align-items:center;gap:6px;display:inline-flex}.reference-image-tool.active{color:#1f4fb3;border-color:#2d6cdf;box-shadow:inset 0 0 0 1px #2d6cdf}.reference-image-tool svg{fill:none;stroke:currentColor;stroke-width:1.7px;stroke-linecap:round;stroke-linejoin:round;width:18px;height:18px}.reference-image-field{flex-direction:column;gap:6px;font-size:13px;display:flex}.reference-image-inline-controls{align-items:center;gap:8px;display:flex}.reference-image-inline-controls input[type=range]{flex:1}.reference-image-inline-controls input[type=number]{width:72px}.editor-tool-overlay{z-index:22;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff0;border:1px solid #1118271f;border-radius:8px;flex-direction:column;gap:8px;padding:10px;display:flex;position:absolute;top:16px;left:16px;box-shadow:0 10px 26px #0f172a21}.editor-tool-row{align-items:center;gap:8px;display:flex}.overlay-icon-button,.overlay-mode-button{color:#374151;background:#fff;border:1px solid #cfd6dd;border-radius:6px;justify-content:center;align-items:center;gap:6px;min-width:0;height:36px;display:inline-flex}.overlay-icon-button{width:36px;padding:0}.overlay-mode-button{padding:0 10px;font-size:12px;font-weight:700}.overlay-icon-button.active,.overlay-mode-button.active{color:#1f4fb3;border-color:#2d6cdf;box-shadow:inset 0 0 0 1px #2d6cdf}.overlay-icon-button svg,.overlay-mode-button svg{fill:none;stroke:currentColor;stroke-width:1.7px;stroke-linecap:round;stroke-linejoin:round;width:20px;height:20px}.overlay-mode-button svg{width:16px;height:16px}.overlay-current-color{background:#f8fafc;border:1px solid #d7dee5;border-radius:6px;align-items:center;gap:8px;min-width:148px;height:36px;padding:5px 8px;display:flex}.overlay-current-swatch{border:1px solid #0000002e;flex:0 0 24px;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.overlay-current-swatch span{font-size:8px;font-weight:800;line-height:1}.overlay-current-meta{flex-direction:column;min-width:0;line-height:1.1;display:flex}.overlay-current-meta strong,.overlay-current-meta small{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overlay-current-meta strong{font-size:12px}.overlay-current-meta small{color:#5f6b76;font-size:11px}.overlay-code-toggle{color:#374151;white-space:nowrap;background:#f8fafc;border:1px solid #d7dee5;border-radius:6px;align-items:center;gap:6px;min-height:32px;padding:0 8px;font-size:12px;display:inline-flex}.workspace-floating-panels{z-index:20;pointer-events:auto;flex-direction:column;gap:12px;display:flex;position:absolute;top:16px;right:16px}.start-modal-overlay{z-index:100;background:#1f29373d;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.start-modal{background:#fff;border:1px solid #11182729;border-radius:8px;width:min(560px,100%);max-height:calc(100vh - 48px);padding:24px;position:relative;overflow-y:auto;box-shadow:0 18px 50px #1118273d}.start-modal-language{justify-content:flex-end;align-items:center;gap:8px;margin:-4px -2px 12px 0;display:flex}.start-modal-close{color:#5f6b76;background:#fff;border:1px solid #cfd6dd;border-radius:6px;width:28px;height:28px;font-size:18px;line-height:1}.start-modal-header{margin-bottom:22px}.start-modal-kicker{color:#2f6f61;margin:0 0 6px;font-size:13px;font-weight:700}.start-modal h2{color:#172026;margin:0;font-size:24px;line-height:1.2}.start-modal-description{color:#5f6b76;margin:10px 0 0;font-size:14px;line-height:1.5}.start-modal-section{margin-top:20px}.start-modal-section h3{color:#172026;margin:0 0 10px;font-size:15px}.start-modal-section-title-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.start-project-name-input{color:#172026;background:#fff;border:1px solid #cfd6dd;border-radius:6px;width:100%;height:40px;padding:8px 10px;font-size:14px}.saved-project-list{flex-direction:column;gap:10px;display:flex}.saved-project-card{color:#172026;text-align:left;background:#fff;border:1px solid #cfd6dd;border-radius:8px;flex-direction:column;gap:4px;width:100%;padding:12px;display:flex}.saved-project-card strong{font-size:14px;line-height:1.2}.saved-project-card span{color:#5f6b76;font-size:12px;line-height:1.3}.start-size-options{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.start-choice-button,.start-layout-option{color:#172026;background:#fff;border:1px solid #cfd6dd;border-radius:8px}.start-choice-button{min-height:44px;padding:10px 12px;font-size:15px;font-weight:700}.start-choice-button.active,.start-layout-option.active{border-color:#2d6cdf;box-shadow:inset 0 0 0 1px #2d6cdf}.start-layout-inputs,.start-layout-options{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.start-layout-inputs label{color:#5f6b76;flex-direction:column;gap:6px;min-width:0;font-size:13px;display:flex}.start-layout-inputs input{color:#172026;background:#fff;border:1px solid #cfd6dd;border-radius:6px;width:100%;height:40px;padding:8px 10px;font-size:14px}.start-layout-preview{background:#f8fafc;border:1px solid #d7dee5;border-radius:8px;justify-content:space-between;align-items:center;gap:16px;min-height:104px;margin-top:10px;padding:12px;display:flex}.start-layout-preview>div{flex-direction:column;gap:4px;min-width:0;display:flex}.start-layout-preview strong{color:#172026;font-size:16px;line-height:1.2}.start-layout-preview span{color:#5f6b76;font-size:13px;line-height:1.3}.start-layout-option{text-align:left;align-items:center;gap:12px;min-height:92px;padding:12px;display:flex}.start-layout-icon-frame{flex:0 0 52px;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.start-layout-icon{display:grid}.start-layout-icon-cell{background-color:#fff;background-image:linear-gradient(90deg,#2d6cdf2e 1px,#0000 1px),linear-gradient(#2f6f612e 1px,#0000 1px),none;background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:8px 8px;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;border:1px solid #5f6b76;width:20px;min-width:0;height:20px;min-height:0}.start-layout-copy{flex-direction:column;gap:4px;min-width:0;display:flex}.start-layout-copy strong{font-size:15px;line-height:1.2}.start-layout-copy span{color:#5f6b76;font-size:13px;line-height:1.3}.start-confirm-button{color:#fff;background:#2f6f61;border:1px solid #1f5f52;border-radius:8px;width:100%;min-height:44px;margin-top:22px;font-size:15px;font-weight:700}.start-confirm-button:hover{background:#275c51}@media (width<=1050px){.library-project-grid{grid-template-columns:repeat(auto-fill,316px)}}@media (width<=700px){.library-header{padding:clamp(.75rem,3vw,1rem)}.library-main{grid-template-columns:1fr;padding:14px}.library-layout-inputs,.library-layout-options,.library-size-options{grid-template-columns:1fr}.library-layout-preview{flex-direction:column;align-items:flex-start}.library-project-grid{grid-template-columns:1fr}.library-project-card{grid-template-columns:112px minmax(0,1fr)}.library-project-thumbnail{width:112px;height:76px}.start-modal-overlay{padding:14px}.start-modal{padding:18px}.start-layout-inputs,.start-layout-options{grid-template-columns:1fr}.start-layout-preview{flex-direction:column;align-items:flex-start}.topbar{padding-inline:clamp(.5rem,2vw,.75rem)}.topbar-controls{gap:clamp(.25rem,1.4vw,.5rem);font-size:clamp(.6875rem,2.8vw,.8125rem)}.topbar-controls>span:first-child{display:none}}
